body {
    background: #ededed;
    overflow-x: hidden;
}
#header.is-page-header {
    background: #ededed;
}
.bg-white {
    background: #FFF;
}
.under_line {
    text-decoration: underline;
}
.mt {margin-top: 2.5rem;
}
.mb {margin-bottom: 2.5rem;
}
.mb15 {margin-bottom: 1.5rem;
}
.mt-lg {
    margin-top:50px;
}
.mb-lg {
    margin-bottom:50px;
}
.pt {padding-top: 2.5rem;
}
.pb {padding-bottom: 2.5rem;
}
.pt-lg {
    padding-top:50px;
}
.pb-lg {
    padding-bottom:50px;
}
.t-center {
    text-align: center;
}
.under-bd {
    position: relative;
}
.under-bd:before {
    content: "";
    position: absolute;
    width: 5rem;
    height: 1px;
    background: #000;
    left: 50%;
    bottom: 2.5rem;
    transform: translateX(-50%);
}
[class*="partation"] {
    background: #000;
    height: 1px;
    width: 100%;
}
.flex_wrap_row {
    display: flex;
}
[class*="flex_col-3"] {
    width: calc(100% / 3);
}

.sec_box_wrap {
    width: 88%;
    margin: auto;
    background: #FFF;
    padding: 7rem 6rem;
    position: relative;
    margin-top: -4rem;
}
.sec_box_title {
    text-align: center;
    font-weight: bold;
    font-size: 2.6rem;
    line-height: 1.5;
}
/*page style*/
.sdgs-contents-02 .flex_wrap_row{
    justify-content: space-between;
}
.sdgs-contents-02 .flex_col-3{
    width:calc(92% / 3);
}
.sdgs-contents-02 .item_caption {
    display: flex;
    justify-content: center;
    align-items: center;
}
.icon_image_wrap {
    width: 50%;
    margin: 3vw auto 1.5rem;
}
.item_content {
    text-align: center;
    display: block;
}
.item_title {
    font-size: 2.2rem;
    font-weight: bold;
    letter-spacing:0.06em;
    font-size: 2.2vw;
}
.item_content .item_caption{
    font-weight: bold;
    font-size: 1.2rem;
    font-size: 1vw;
}
.arrow {
    position: relative;
}
.arrow:after{
    content: "";
    width: 10px;
    height: 10px;
    border: 2px solid;
    border-color: transparent transparent #565656 #565656;
    transform: rotate(-45deg);
    position: absolute;
    bottom: 25px;
    left: calc(50% - 5px);
}
.num_label {
    overflow: hidden;
    position: absolute;
    display: block;
    width: 35%;
    color: #FFF;
    text-align: center;
    font-size: 2rem;
    font-weight: bold;
    padding-right: 5%;
    top: -2rem;
}
.num_label:before {
    content:"";
    width: 100%;
    height: 100%;
    background: #000;
    position: absolute;
    top: 0;
    left: -15px;
    overflow: hidden;
    transform: skewX(25deg);
}
.num_label span {
    position: relative;
}
.sdgs-icon-wrap img{
    display: block;
    height: 7.5rem;
    width: auto;
    object-fit: contain;
}
.sdgs-contents-02 .flex_col-3 {
    transition: .5s;
}
.sdgs-contents-02 .flex_col-3:hover {
    opacity: .65;
}

.sdgs_detail_content .bg-white {
    padding: 8% 5%;
    position: relative;
}
.sdgs_detail_content  .flex_wrap_row {
    position: relative;
}
.sdgs_detail_content .sdgs-detail-title {
    font-size: 3.8vw;
    line-height: 1.25;
}
.sdgs_detail_content .sdgs-detail-title .caption{
    font-size: 1.8rem;
    font-family: "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
    font-weight: normal;
    font-weight: bold;
}
.sdgs_detail_content .flex_col-2 {
    width: 55%;
}
.sdgs_detail_content .image-col {
    position: absolute;
    left: 65%;
    top: 45%;
    transform: translateY(-50%) skewX(-10deg);
    width: 125%;
    height: 25vw;
    overflow: hidden;
}
.sdgs_detail_content .image-col .image_wrap picture { position: inherit; }
.sdgs_detail_content .image-col .image_wrap img {
    object-fit: contain;
    position: absolute;
    width: 65%;
    height: 128%;
    transform: translateY(-50%) skewX(10deg);
    max-width: inherit;
    top: 50%;
    left: -5%;
}
.sec_box_textarea {
    line-height: 2.2;
    text-align: justify;
}
.sec_box_textarea.en_textarea {
}
.keyword_wrap {
    border: 1px solid #000;
    padding: 2% 5%;
    line-height: 1.8;
    font-weight: bold;
}
.keyword_wrap .title {
    font-weight: bold;
    font-size: 2rem;
    position: relative;
    padding-left: 20px;
}
.keyword_wrap .title:after {
    content: '';
    display: block;
    position: absolute;
    top: calc(50% - 4px);
    left: 0;
    width: 15px;
    height: 8px;
    border-left: 4px solid #14143c;
    border-bottom: 4px solid #14143c;
    transform: rotate(-45deg);
}

.hopup-contents {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    z-index: 100;
    box-shadow: 0 0 5px 6px rgba(0,0,0,.05);
    z-index: 110;
    display: none;
    overflow-y: scroll;
    -ms-overflow-style: none;    /* IE, Edge 対応 */
    scrollbar-width: none;       /* Firefox 対応 */
    max-height: 90%;
}
.hopup-contents::-webkit-scrollbar {  
    display:none;/* Chrome, Safari 対応 */
}
.hopup-over-layer {
    position: fixed;
    width: 100%;
    height: 100%;
    background: rgba(0, 0 ,0 ,.8);
    top: 0;
    left: 0;
    z-index: 100;
    display: none;
}
.hopup-close {
    position: absolute;
    top: 5%;
    right: 5%;
    width: 40px;
    height: 40px;
    cursor: pointer;
}
.hopup-close span{
    width: 100%;
    height: 100%;
    display: block;
    position: relative;
}
.hopup-close span:before,
.hopup-close span:after {
    content: "";
    width: 40px;
    height: 1px;
    background: #000;
    transform: rotate(45deg);
    position: absolute;
    top: 50%;
    left: 0;
}
.hopup-close span:after {
    transform: rotate(-45deg);
}
.is-pc {
    display: block !important;
}
.is-sp {
    display: none !important;
}
[data-trigger="hopup"] {
    cursor: pointer;
}
.en_US_sec [class*="textarea"] {
}
@media screen and (max-width : 1749px) {
    .sdgs_detail_content .sec_box_textarea {
        min-height: 235px;
    }
}

@media screen and (min-width : 1750px) {
    .sdgs_detail_content .image-col{
        top: 42%;
    }
    .sdgs_detail_content .sec_box_textarea {
        min-height:250px;
    }
}


@media screen and (min-width : 950px) {
    #sdgs03 .keyword_wrap{
        margin-top: 2.5rem;
    }
    .sdgs_detail_content .sdgs-detail-title .caption .c_text{
        font-size: 1.6rem;
        line-height: 1.8;
    }
}
@media screen and (max-width : 950px) {
    .is-pc {
        display: none !important;
    }
    .is-sp {
        display: block !important;
    }
    .sdgs_detail_content .image-col{
        top: 42%;
    }
    .sdgs_detail_content .sec_box_textarea {
        min-height:inherit;
    }

    .sdgs-contents-01 .sec_box_wrap {
        padding: 8% 5%;
    }
    .sec_box_title {
        font-size: 2.2vw;
    }
    .under-bd:before {
        width: 25%;
    }
    .sec_box_textarea {
        line-height: 2;
    }
    .sdgs-contents-02 .flex_wrap_row {
        flex-direction: column;
    }
    .sdgs-contents-02 .flex_wrap_row [class*="flex_col-"] {
        width: 100%;
        
    }
    .sdgs-contents-02 .flex_wrap_row [class*="flex_col-"]:not(:last-child) {
        margin-bottom: 3.5rem;
    }
    .sdgs-contents-02 .flex_wrap_row .item_content {
        display: flex;
        padding: 8% 5% 5%;
        text-align: left;
    }
    .item_content .icon_image_wrap{
        width: 20%;
        margin: 0 1.5rem 0 0;
        
    }
    .item_content .item_title{
        font-size: 3rem;
        line-height: 1.25;
    }

    .arrow:after {
        bottom: inherit;
        left: inherit;
        right: 5%;
        top: 50%;
        transform: rotate(-45deg) translateY(-50%);
    }
    .md-col {
        flex-direction: column;
    }
    .md-col [class*="col"] {
        width: 100%;
    }
    
    .sdgs-contents-03 .sdgs_detail_content .image-col{
        order: 1;
        height: 30vw;
        transform: skewX(-10deg);
        top: -28vw;
        left: 12vw;
        width: 115%;
    }
    .sdgs-contents-03 .flex_col-2 {
        order: 2;
    }
    .sdgs_detail_content .image-col .image_wrap img {
        width: 100%;
    }
    [id*="sdgs0"] {
        margin-top: 27vw;
        padding: 8% 5%;
    }
    .sdgs_detail_content .sdgs-detail-title {
        font-size: 4rem;
        line-height: 1.25;
        margin-top: 5.5rem;
    }
    .sdgs-icon-wrap img {
        height: auto;
    }
    .sdgs_detail_content .sdgs-detail-title .caption .c_text{
        line-height: 1.8;
    }
}
@media screen and (max-width : 560px) {
    .sp-col {
        flex-direction: column;
    }
    .pt-lg {
        padding-top: 10vw;
    }
    #main_content {
        width: 88%;
    }
    .sec_box_title {
        font-size: 5vw;
    }
    .sdgs-contents-03 .sdgs_detail_content .image-col {
        height: 40vw;
    }
    .item_content .icon_image_wrap {
        width: 22vw;
        margin: 0 calc(1.5rem - 6px) 0 0;
    }
    .item_content .info_wrap {
        width: 50vw;
    }
    .sdgs-contents-02 .flex_wrap_row .item_content {
        align-items: center;
    }
    .sdgs-contents-01 .sec_image_wrap {
        margin: 0 -7%;
    }
    .num_label {
        width: 28%;
    }
    .item_content .item_title {
        font-size: 7.2vw;
        white-space: nowrap;
    }
    .sdgs-contents-03 .sdgs_detail_content .image-col {
        height: 55vw;
    }
    .sdgs_detail_content .sdgs-detail-title {
        margin-top: 34vw;
        display: flex;
        align-items: center;
        font-size: 7.2vw;
    }
    .sdgs_detail_content .sdgs-detail-title.start {
        align-items: flex-start;
    }
    .sdgs_detail_content .sdgs-detail-title .caption{
        font-size: 3vw;
        margin-left: 3vw;
    }
    .sdgs_detail_content .sdgs-detail-title.sp-col .caption {
        margin-left: 0;
    }
    .sdgs_detail_content .sec_box_textarea {
        margin-bottom: 2.5rem;
    }
    .sdgs-contents-02 .item_caption {
        justify-content: flex-start;
    }
    .item_content .item_caption{
        font-size: 3.2vw;
        align-items: flex-start;
    }
    .hopup-contents {
        width: 90%;
    }
    .hopup-close span:before,
    .hopup-close span:after {
        width: 30px;
    }
    #sdgs02,
    #sdgs03{
        margin-top: 38vw;
    }
}