@charset "UTF-8";
* {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-text-size-adjust: none;
}

*:focus {
    outline: none;
}

.no-spin::-webkit-inner-spin-button,
.no-spin::-webkit-outer-spin-button {
    -webkit-appearance: none !important;
    margin: 0 !important;
    -moz-appearance: textfield !important;
}

body {
    margin: 0;
    padding: 0;
    color: #040000;
}

img {
    max-width: 100%;
    height: auto;
}

a {
    text-decoration: none;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    color: #040000;
}

a:hover {
    opacity: 0.6;
}

.h_icon .icon a:hover {
    opacity: 1;
}

li {
    list-style: none;
}

.f10 {
    font-size: 10px;
}

.f11 {
    font-size: 11px;
}

.f12 {
    font-size: 12px;
}

.f13 {
    font-size: 13px;
}

.f14 {
    font-size: 14px;
}

.f15 {
    font-size: 15px;
}

.f16 {
    font-size: 16px;
}

.f18 {
    font-size: 1.317715vw;
}

.f19 {
    font-size: 19px;
}

.f20 {
    font-size: 1.4642vw;
}

.f21 {
    font-size: 21px;
}

.f22 {
    font-size: 22px;
}

.f24 {
    font-size: 1.756955vw;
}

.f25 {
    font-size: 25px;
}

.f26 {
    font-size: 26px;
}

.f27 {
    font-size: 27px;
}

.f28 {
    font-size: 2.0498vw;
}

.f30 {
    font-size: 30px;
}

.f31 {
    font-size: 31px;
}

.f32 {
    font-size: 32px;
}

.f33 {
    font-size: 33px;
}

.f34 {
    font-size: 34px;
}

.f36 {
    font-size: 36px;
}

.f39 {
    font-size: 39px;
}

.f40 {
    font-size: 40px;
}

.f41 {
    font-size: 41px;
}

.f42 {
    font-size: 42px;
}

.f46 {
    font-size: 46px;
}

.f48 {
    font-size: 48px;
}

.f55 {
    font-size: 55px;
}

.f60 {
    font-size: 60px;
}

.f72 {
    font-size: 5.270861vw;
}

.f78 {
    font-size: 5.7101vw;
}

.f85 {
    font-size: 6.22255vw;
}

.go {
    font-family: toppan-bunkyu-gothic-pr6n, serif;
    font-weight: 400;
    font-style: normal;
}

.ex {
    font-family: toppan-bunkyu-midashi-go-std, sans-serif;
    font-weight: 900;
    font-style: normal;
}

.m {
    font-weight: 500;
}

.s {
    font-weight: 600;
}

.b {
    font-weight: bold;
}

.header .h_icon {
    width: 86.823%;
    margin: 0 auto;
    padding-top: 3.2%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding-bottom: 1%;
    /* padding-bottom: 1.701%; */
    border-bottom: 1px solid #009fe8;
    align-items: flex-end;
}

.header .h_icon .header-menu {
    width: 40%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
}

.header .h_icon .header-menu .header-link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    width: 33%;
    background-color: #009fe8;
    color: #ffffff;
    margin-left: 5px;
    padding: 5px;
}

.header .h_icon .header-menu .header-link.mail {
    position: relative;
    padding-left: 6%;
}

.header .h_icon .header-menu .header-link.mail::before {
    position: absolute;
    content: '';
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    background-image: url(img/common/mail.svg);
    width: 27px;
    height: 21px;
    top: 0;
    bottom: 0;
    margin: auto;
    left: 6%;
}

.footer {
    margin-top: 6.33%;
    background-color: #009fe8;
    padding: 2.343% 0;
    padding-left: 6%;
    padding-right: 6%;
}

.footer .flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    color: #fff;
}

.footer .flex .left {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 34%;
    flex: 0 0 34%;
}

.footer .flex .center {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    line-height: 1.333;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 27%;
    flex: 0 0 27%;
}

.footer .flex .center .sub_left,
.footer .flex .center .sub_right {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 46.5%;
    flex: 0 0 46.5%;
}

.footer .flex .center .sub_left a,
.footer .flex .center .sub_right a {
    color: #fff;
}

.footer .flex .center .sub_left {
    margin-right: 7%;
}

.footer .flex .center .sub_left a {
    display: block;
    border: 1px solid #fff;
    line-height: 1.2;
    padding: 5% 0;
    text-align: center;
}

.footer .flex .center .sub_left a:first-child {
    margin-bottom: 7.78%;
}

.footer .flex .center .sub_right a {
    display: block;
    border: 1px solid #fff;
    text-align: center;
    padding: 12% 0;
}

.footer .flex .center .sub_right a .img {
    margin-bottom: 8.5%;
}

.footer .flex .right {
    line-height: 1.4;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 37%;
    flex: 0 0 37%;
    margin-left: 2%;
}

.footer .flex .right a {
    color: #fff;
}

header,
main,
.footer {
    font-family: toppan-bunkyu-gothic-pr6n, serif;
    font-weight: 400;
    font-style: normal;
}

.br1024on,
.br768on,
.br480on,
.active1024 {
    display: none;
}

@media screen and (max-width: 1280px) {
    .f21 {
        font-size: 20px;
    }
    .f22 {
        font-size: 21px;
    }
    .f34 {
        font-size: 33px;
    }
    .f55 {
        font-size: 51px;
    }
    .footer .flex .left {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 41%;
        flex: 0 0 41%;
    }
    .footer .flex .center {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 17%;
        flex: 0 0 17%;
    }
    .footer .flex .right {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 41%;
        flex: 0 0 41%;
        margin-left: 1%;
    }
}

@media screen and (max-width: 1024px) {
    .br1024on {
        display: block;
    }

    .br1024off {
        display: none;
    }
    .footer .flex .center.br1024off {
        display: none;
    }
    .f20 {
        font-size: 17px;
    }
    .f21 {
        font-size: 18px;
    }
    .f22 {
        font-size: 18px;
    }
    .f28 {
        font-size: 22px;
    }
    .f34 {
        font-size: 30px;
    }
    .f36 {
        font-size: 32px;
    }
    .f42,
    .f41 {
        font-size: 37px;
    }
    .f55 {
        font-size: 40px;
    }
    .header .h_icon {
        width: 88%;
    }
    .header .h_icon .icon {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 51%;
        flex: 0 0 51%;
        margin-right: 2%;
    }
    .header .h_icon .header-menu {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 47%;
        flex: 0 0 47%;
    }
    .footer .flex {
        display: block;
    }
    .footer .active1024 {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        margin-top: 3%;
    }
    .footer .flex .center {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 35%;
        flex: 0 0 35%;
    }
    .footer .flex .right {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 62%;
        flex: 0 0 62%;
        margin-left: 3%;
    }
    .header .h_icon .header-menu .header-link.mail::before {
        width: 24px;
        height: 18px;
    }
}

@media screen and (max-width: 768px) {
    .br768on {
        display: block;
    }
    .br768off {
        display: none;
    }
    .f20 {
        font-size: 16px;
    }
    .f34 {
        font-size: 25px;
    }
    .f36 {
        font-size: 28px;
    }
    .f42,
    .f41 {
        font-size: 30px;
    }
    .f55 {
        font-size: 30px;
    }
    .header .h_icon {
        width: 93%;
        padding-bottom: 5%;
    }
    .footer {
        padding: 3%;
    }
    .footer .flex .center {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 40%;
        flex: 0 0 40%;
    }
    .footer .flex .right {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 57%;
        flex: 0 0 57%;
    }
    .header .h_icon .header-menu.br768off {
        display: none;
    }
    .menu-btn {
        position: fixed;
        right: 3.503%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        height: 40px;
        width: 40px;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        z-index: 90;
        background-color: #009fe8;
    }
    .menu-btn span,
    .menu-btn span:before,
    .menu-btn span:after {
        content: '';
        display: block;
        height: 3px;
        width: 25px;
        border-radius: 3px;
        background-color: #ffffff;
        position: absolute;
    }
    .menu-btn span:before {
        bottom: 8px;
    }
    .menu-btn span:after {
        top: 8px;
    }
    #menu-btn-check:checked ~ .menu-btn span {
        background-color: rgba(255, 255, 255, 0);
        /*メニューオープン時は真ん中の線を透明にする*/
    }
    #menu-btn-check:checked ~ .menu-btn span::before {
        bottom: 0;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
    }
    #menu-btn-check:checked ~ .menu-btn span::after {
        top: 0;
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg);
    }
    #menu-btn-check {
        display: none;
    }
    .menu-content ul {
        padding: 40px 10px 0;
    }
    .menu-content ul li {
        border-bottom: solid 1px #ffffff;
        list-style: none;
    }
    .menu-content ul li a {
        display: block;
        width: 100%;
        font-size: 15px;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        color: #ffffff;
        text-decoration: none;
        padding: 20px 15px 20px 0;
        position: relative;
    }
    .menu-content ul li a::before {
        content: '';
        width: 7px;
        height: 7px;
        border-top: solid 2px #ffffff;
        border-right: solid 2px #ffffff;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
        position: absolute;
        right: 11px;
        top: 0;
        bottom: 0;
        margin: auto;
    }
    .menu-content {
        width: 55%;
        height: 100%;
        position: fixed;
        top: 0;
        left: 100%;
        /*leftの値を変更してメニューを画面外へ*/
        z-index: 80;
        background-color: #009fe8;
        -webkit-transition: all 0.5s;
        transition: all 0.5s;
        /*アニメーション設定*/
        padding-top: 6%;
    }
    #menu-btn-check:checked ~ .menu-content {
        left: 45%;
        /*メニューを画面内へ*/
    }
    #menu-btn-check:checked ~ .header .h_icon {
        padding-bottom: 5%;
    }
    .header .h_icon .icon {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 75%;
        flex: 0 0 75%;
        margin-right: 0%;
    }
}

@media screen and (max-width: 480px) {
    .br480on {
        display: block;
    }
    .br480off {
        display: none;
    }
    .f28 {
        font-size: 18px;
    }
    .f34 {
        font-size: 20px;
    }
    .f42,
    .f41 {
        font-size: 21px;
    }
    .f55 {
        font-size: 23px;
    }
    .header .h_icon {
        width: auto;
        margin: 0 10px;
        padding-top: 15px;
        padding-bottom: 10px;
    }
    .header .h_icon .icon img {
        width: 80%;
    }
    .footer {
        margin-top: 10%;
        padding: 6% 10px;
    }
    .footer .active1024 {
        display: block;
    }
    .footer .flex .center {
        padding: 4% 0;
        margin: 20px 0;
        border-left: transparent;
        border-right: transparent;
        border-top: 2px solid #ffffff;
        border-bottom: 2px solid #ffffff;
    }
    .footer .flex .right {
        text-align: center;
        line-height: 1.7;
    }
    .footer .flex .right .f16 {
        font-size: 17px;
    }
    .scroll-point {
        overflow: hidden;
    }
    .menu-btn {
        height: 35px;
        width: 35px;
        right: 10px;
        top: 5px;
    }
    .menu-btn span:after {
        top: 7px;
    }
    .menu-btn span:before {
        bottom: 7px;
    }
    .menu-btn span,
    .menu-btn span:before,
    .menu-btn span:after {
        height: 2.5px;
        width: 20px;
    }
    .header .h_icon .icon {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
    }
    .menu-content {
        width: 100%;
    }
    #menu-btn-check:checked ~ .menu-content {
        left: 0;
    }
    .footer .flex .left {
        text-align: center;
    }
    .footer .flex .center .sub_right a {
        padding: 11.5% 0;
    }
}


/* mainパーツ */
.bg_box,
.main .sec_first .left .img,
.main .sec_second,
.main .sec_second .top_txt::before,
.main .sec_second .content .left .img,
.main .sec_second .content .right .arrow,
.main .sec_second .w_arrow,
.main .sec_second .pad.bottom .content .flex_box .box .arrow,
.main .sec_second .pad.bottom .content .flex_box .box p.f24 span::before,
.main .sec_second .pad.bottom .sdg .flex .right .img,
.main .market .sec_con .content .flex .left .arrow,
.main .market .tec .content .flex .right .arrow,
.main .market .expo .content .flex .right .top_img::before,
.main .market .expo .content .flex .right .boxes .box .img {
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

.width {
    width: 86.823%;
    margin: 0 auto;
}

.pad {
    padding-left: 6.589%;
    padding-right: 6.589%;
}

.main .sec_first {
    margin-top: 1%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.main .sec_first .left {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 52.423%;
    flex: 0 0 52.423%;
    margin-right: 1%;
}

.main .sec_first .left .img {
    background-image: url(img/front/top_img1.jpg);
    padding: 33.75% 0;
}

.main .sec_first .right {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 46.577%;
    flex: 0 0 46.577%;
    text-align: center;
}

.main .sec_first .right p.f34 {
    line-height: 1.294;
    color: #009fe8;
}

.main .sec_first .right h2 {
    margin-top: 8.5%;
    margin-bottom: 9%;
    color: #009fe8;
}

.main .sec_first .right p.f21 {
    line-height: 1.648;
}

.main .sec_second {
    margin-top: 5.14%;
    padding: 5.14% 0;
    background-image: url(img/front/bg.jpg);
}

.main .sec_second .top_txt {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
    margin-bottom: 3.22%;
}

.main .sec_second .top_txt::before {
    position: absolute;
    content: '';
    background-image: url(img/front/second_bg.png);
    width: 24.5vw;
    height: 45px;
    top: 0%;
    bottom: 0;
    margin: auto;
}

.main .sec_second .top_txt p.f25 {
    position: relative;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 30%;
    flex: 0 0 30%;
}

.main .sec_second .top_txt h2.f55 {
    color: #fff;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 70%;
    flex: 0 0 70%;
    text-shadow: 5px 4px 6px #3e3e3e;
}

.tptitle {
    font-family: toppan-bunkyu-midashi-go-std, sans-serif;
    font-weight: 900;
    font-style: normal;
    line-height:120%;
    color:#228b22;
    padding:20px;
}

.main .sec_second .content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    margin-bottom: 3%;
}

.main .sec_second .content .left {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 48%;
    flex: 0 0 48%;
    margin-right: 2%;
}

.main .sec_second .content .left p.f22 {
    line-height: 1.636;
    margin-bottom: 9.5%;
}

.main .sec_second .content .left .img {
    padding: 42.688% 0 3.867%;
}

.main .sec_second .content .left .img p {
    text-align: center;
    color: #fff;
    text-shadow: 5px 0px 10px black;
    -webkit-text-stroke: 2px black;
}

.main .sec_second .content .right {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 48%;
    flex: 0 0 48%;
    margin-left: 2%;
}

.main .sec_second .content .right h4.f22 {
    line-height: 1.636;
}

.main .sec_second .content .right .boxes {
    text-align: center;
    margin-top: 17px;
}

.main .sec_second .content .right .boxes .box {
    background-color: #00a273;
    line-height: 1.32;
    color: #fff;
    padding: 3.514% 0;
    margin-bottom: 7px;
}

.main .sec_second .content .right .arrow {
    width: 50px;
    height: 57px;
    margin: 0 auto;
}

.main .sec_second .content .right .last {
    text-align: center;
    color: #f2801d;
    line-height: 1.333;
    margin-top: 10px;
    /* text-shadow: 2px 2px 5px #fff; */
    text-shadow: 1px 1px 5px #ffffff, 0 0 1em #ffffff, 0 0 1em #ffffff;
    /* -webkit-text-stroke: 1px #fff; */
}

.main .sec_second .l_text {
    line-height: 1.636;
}

.main .sec_second .w_arrow {
    background-image: url(img/front/w_arrow.svg);
    width: 100%;
    /* height: 40px; */
    height: 50px;
    margin-top: 4.686%;
    margin-bottom: 2.35%;
}

.main .sec_second .pad.bottom .top_txt {
    margin-bottom: 1.5%;
}

.main .sec_second .pad.bottom .sub {
    text-align: center;
    color: #fff;
    text-shadow: 4px 4px 6px #3e3e3e;
    margin-bottom: 3.373%;
}

.main .sec_second .pad.bottom .content {
    display: block;
}

.main .sec_second .pad.bottom .content h3 {
    position: relative;
    text-align: center;
}

.main .sec_second .pad.bottom .content h3::before,
.main .sec_second .pad.bottom .content h3::after {
    position: absolute;
    content: '';
    background-color: #000;
    width: 34vw;
    height: 1px;
    top: 0;
    bottom: 0;
    margin: auto;
}

.main .sec_second .pad.bottom .content h3::before {
    left: 0;
}

.main .sec_second .pad.bottom .content h3::after {
    right: 0;
}

.main .sec_second .pad.bottom .content .flex_box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-top: 2%;
}

.main .sec_second .pad.bottom .content .flex_box .box {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 32.2%;
    flex: 0 0 32.2%;
    margin-right: 1.687%;
}

.main .sec_second .pad.bottom .content .flex_box .box h4.f24 {
    text-align: center;
    background-color: #00a273;
    height: 93.6px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    color: #fff;
    line-height: 1.32;
}

.main .sec_second .pad.bottom .content .flex_box .box .arrow {
    background-image: url(img/front/g_arrow.svg);
    width: 50px;
    height: 30px;
    margin: 4% auto 5%;
}

.main .sec_second .pad.bottom .content .flex_box .box p.f24 {
    text-align: center;
    padding-left: 10%;
}

.main .sec_second .pad.bottom .content .flex_box .box p.f24 span {
    position: relative;
}

.main .sec_second .pad.bottom .content .flex_box .box p.f24 span::before {
    position: absolute;
    content: '';
    background-image: url(img/front/check.svg);
    width: 27px;
    height: 27px;
    top: 0;
    bottom: 0;
    margin: auto;
    left: -40px;
}

.main .sec_second .pad.bottom .content .flex_box .box:last-child {
    margin-right: 0;
}

.main .sec_second .pad.bottom .sdg {
    margin-top: 5%;
}

.main .sec_second .pad.bottom .sdg h2 {
    text-align: center;
    color: #f2801d;
    line-height: 1.333;
    /* text-shadow: 0px -1px 5px #fff; */
    text-shadow: 1px 1px 5px #ffffff, 0 0 1em #ffffff, 0 0 1em #ffffff;
}

.main .sec_second .pad.bottom .sdg .flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-top: 2.53%;
}

.main .sec_second .pad.bottom .sdg .flex .left {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 38%;
    flex: 0 0 38%;
    margin-right: 2%;
    line-height: 1.636;
}

.main .sec_second .pad.bottom .sdg .flex .right {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 60%;
    flex: 0 0 60%;
}

.main .sec_second .pad.bottom .sdg .flex .right .img {
    background-image: url(img/front/second_img2.png);
    padding: 16% 0;
}

.main .market {
    margin-top: 3.661%;
}

.main .market h2.top {
    color: #49aa48;
    text-align: center;
}

.main .market .flex_box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-top: 3.12%;
}

.main .market .flex_box a {
    background-color: #49aa48;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 31.85%;
    flex: 0 0 31.85%;
    line-height: 1.333;
    margin-right: 2.24%;
    padding: 1.35%;
    border: 1px solid #bdbdbd;
    -webkit-box-shadow: 4px 4px 4px #bdbdbd;
    box-shadow: 4px 4px 4px #bdbdbd;
}

.main .market .flex_box .box .sub {
    text-align: center;
    color: #fff;
    border: 1px solid #fff;
    padding: 9% 0px;
}

.main .market .flex_box  a:last-child {
    margin-right: 0;
}

/* .main .market .flex_box .box:last-child .sub span {
  display: block;
  margin-bottom: -10%;
  line-height: 1.3;
} */

.main .market .sec_con {
    padding: 3.879% 10px;
    border: 3px solid #49aa48;
    margin-bottom: 2.53%;
    -webkit-box-shadow: 4px 4px 4px #8a8a8a;
    box-shadow: 4px 4px 4px #8a8a8a;
}

.main .market .sec_con h2.mds {
    text-align: center;
    color: #fff;
    position: relative;
    background: -webkit-gradient(
            linear,
            left top,
            right top,
            from(#fff),
            color-stop(5%, #4bab4a),
            color-stop(95%, #4bab4a),
            to(#fff)
    );
    background: linear-gradient(to right, #fff 0%, #4bab4a 5%, #4bab4a 95%, #fff 100%);
    padding-top: 16px;
    padding-bottom: 10.5px;
    margin-bottom: 3.449%;
}

.main .market .sec_con h2.mds span {
    display: block;
    border-bottom: 1px solid #fff;
    padding-bottom: 13.3px;
}

.main .market .sec_con .content {
    padding: 0 2.5867%;
}

.main .market .sec_con .content h3 {
    color: #49aa48;
    border-bottom: 1px solid #49aa48;
    line-height: 1.2;
    text-align: center;
    margin-bottom: 2.932%;
    padding-bottom: 9.4px;
}

.main .market .sec_con .content .flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.main .market .sec_con .content .flex .left,
.main .market .sec_con .content .flex .right {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 48%;
    flex: 0 0 48%;
}

.main .market .sec_con .content .flex .left {
    margin-right: 2%;
}

.main .market .sec_con .content .flex .left p.f20 {
    line-height: 1.65;
    margin-bottom: 22.73%;
}

.main .market .sec_con .content .flex .left .boxes {
    margin-top: 4.735%;
}

.main .market .sec_con .content .flex .left .boxes .box {
    color: #49aa48;
    line-height: 1.364;
    text-align: center;
    border-top: 3px solid #49aa48;
}

.main .market .sec_con .content .flex .left .boxes .box p {
    padding: 3.98% 0;
}

.main .market .sec_con .content .flex .left .boxes .box:last-child {
    border-bottom: 3px solid #49aa48;
}

.main .market .sec_con .content .flex .left .arrow {
    width: 50px;
    height: 57px;
    margin: 4.23% auto 3.8%;
}

.main .market .sec_con .content .flex .left p.orange {
    text-align: center;
    color: #f08300;
    line-height: 1.5;
}

.main .market .sec_con .content .flex .right {
    margin-left: 2%;
}

.main .market .sec_con .content .flex .right .img:last-child {
    margin-top: 5.5%;
}

.main .market .sec_con .content .flex .right .img:last-child small {
    text-align: right;
    display: block;
    margin-top: -5%;
}

.main .market .sec_con .content.second {
    margin-top: 6.1%;
}

.main .market .task {
    margin-top: 3.036%;
}

.main .market .tec .content .flex .left p.f20 {
    margin-top: 11.8%;
    margin-bottom: 0;
}

.main .market .tec .content .flex .right .boxes {
    margin-top: 4.735%;
}

.main .market .tec .content .flex .right .boxes .box {
    color: #49aa48;
    line-height: 1.364;
    text-align: center;
    border-top: 3px solid #49aa48;
}

.main .market .tec .content .flex .right .boxes .box p {
    padding: 3.98% 0;
}

.main .market .tec .content .flex .right .boxes .box:last-child {
    border-bottom: 3px solid #49aa48;
}

.main .market .tec .content .flex .right .arrow {
    width: 50px;
    height: 57px;
    margin: 4.23% auto 8px;
}

.main .market .tec .content .flex .right .img:last-child {
    margin-top: 0;
}

.main .market .tec .content.second .flex .left p.f20 {
    margin-top: 0;
    letter-spacing: 0.04em;
}

.main .market .tec .content.second .flex .left .img {
    margin-top: -3%;
}

.main .market .spread .content .two {
    line-height: 1.65;
    margin-bottom: 2.932%;
}

.main .market .spread .content.second .flex .left p.f20 {
    margin-bottom: 15%;
}

.main .market .spread .content.second .flex .right .img.point {
    margin-top: 0;
}

.main .market .spread .content.second .flex .right .img_box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.main .market .spread .content.second .flex .right .img_box .img {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 51%;
    flex: 0 0 51%;
}

.main .market .spread .content.second .flex .right .img_box .img:last-child {
    margin-top: 0;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 49%;
    flex: 0 0 49%;
}

.main .market .expo {
    margin-bottom: 0;
}

.main .market .expo .content .flex .left p.f20 {
    margin-bottom: 5.684%;
}

.main .market .expo .content .flex .right .top_img {
    position: relative;
}

.main .market .expo .content .flex .right .top_img::before {
    background-image: url(img/front/multi_arrow.svg);
    position: absolute;
    content: '';
    width: 100%;
    height: 220px;
    top: 100%;
    z-index: -1;
}

.main .market .expo .content .flex .right .center_txt {
    margin-top: 3.79%;
    background-color: #49aa48;
    color: #fff;
    text-align: center;
    padding: 4% 0;
}

.main .market .expo .content .flex .right .boxes {
    margin-top: 130px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.main .market .expo .content .flex .right .boxes .box {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 23.65%;
    flex: 0 0 23.65%;
    border: 1px solid #49aa48;
    padding: 3% 0 3.7%;
    margin-right: 9.5px;
}

.main .market .expo .content .flex .right .boxes .box .point {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.main .market .expo .content .flex .right .boxes .box .text {
    line-height: 1.5;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    height: 7.321vw;
}

.main .market .expo .content .flex .right .boxes .box .img {
    padding: 40% 0;
    margin-top: 18%;
}

.main .market .expo .content .flex .right .boxes .box:last-child {
    margin-right: 0;
}

.main .market .expo .content .flex .right .boxes .box:last-child .img {
    padding: 27% 0;
    margin-top: 33%;
}

.main .market .spread .last_text {
    margin-top: 8%;
    margin-bottom: 2%;
    line-height: 1.571;
    color: #49aa48;
    text-align: center;
}

@media screen and (max-width: 1680px) {
    .main .market .expo .content .flex .right .top_img::before {
        height: 280px;
    }
    .main .market .expo .content .flex .right .boxes {
        margin-top: 170px;
    }
}

@media screen and (max-width: 1440px) {
    .main .market .expo .content .flex .right .top_img::before {
        height: 220px;
    }
    .main .market .expo .content .flex .right .boxes {
        margin-top: 130px;
    }
}

@media screen and (max-width: 1280px) {
    .main .sec_second .top_txt::before {
        width: 27vw;
    }
    .main .sec_second .top_txt h2.f55 {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 68%;
        flex: 0 0 68%;
    }
    .main .sec_second .top_txt p.f25 {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 32%;
        flex: 0 0 32%;
    }
    .main .market .sec_con .content .flex .left p.orange {
        font-size: 19px;
    }
}

@media screen and (max-width: 1024px) {
    .width {
        width: 88%;
    }
    .pad {
        padding-left: 6%;
        padding-right: 6%;
    }
    .main .sec_first .left {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 43%;
        flex: 0 0 43%;
        margin-right: 2%;
    }
    .main .sec_first .right {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 55%;
        flex: 0 0 55%;
    }
    .main .sec_second .top_txt p.f25 {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 32%;
        flex: 0 0 32%;
        font-size: 22px;
    }
    .main .sec_second .top_txt h2.f55 {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 68%;
        flex: 0 0 68%;
    }
    .main .sec_second .top_txt::before {
        width: 27vw;
        height: 36px;
    }
    .main .sec_second .content .right .last .f34 {
        font-size: 26px;
    }
    .main .sec_second .content .right .boxes .box {
        font-size: 18px;
    }
    .main .market .flex_box a .sub {
        font-size: 28px;
    }

    .main .market .flex_box a .sub .f26 {
        font-size: 22px;
    }

    .main .market .sec_con .content .flex .left,
    .main .market .sec_con .content .flex .right {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 49%;
        flex: 0 0 49%;
    }
    .main .market .sec_con .content .flex .left {
        margin-right: 1%;
    }
    .main .market .sec_con .content .flex .right {
        margin-left: 1%;
    }
    .main .market .sec_con .content {
        padding: 0;
    }
    .main .market .tec .content.second .flex .left .img {
        margin-top: 3%;
    }
    .main .market .expo .content .flex .right .boxes .box {
        margin-right: 8px;
    }
    .main .market .sec_con .content .flex .right .img:last-child small {
        font-size: 11px;
    }
    .main .market .expo .content .flex .right .top_img::before {
        height: 200px;
    }
    .main .market .sec_con .content .flex .left p.orange {
        font-size: 17px;
    }
    .main .sec_second .pad.bottom .sdg .flex .left {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 39%;
        flex: 0 0 39%;
        margin-right: 1%;
    }
}

@media screen and (max-width: 768px) {
    .width {
        width: 95%;
    }
    .pad {
        padding-left: 2.5%;
        padding-right: 2.5%;
    }
    .main .sec_first .right p.f21 {
        font-size: 16px;
    }
    .main .sec_first .left {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 40%;
        flex: 0 0 40%;
    }
    .main .sec_first .right {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 60%;
        flex: 0 0 60%;
    }
    .main .sec_first .right h2 {
        margin-top: 6%;
        margin-bottom: 7%;
    }
    .main .sec_second .top_txt {
        display: block;
    }
    .main .sec_second .top_txt h2.f55 {
        font-size: 40px;
        text-align: center;
        margin-top: 2%;
    }
    .main .sec_second .top_txt::before {
        width: 40vw;
        top: -75%;
    }
    .main .sec_second .pad.bottom .top_txt {
        margin-bottom: 2.5%;
    }
    .main .sec_second .w_arrow {
        margin-top: 5%;
        margin-bottom: 3%;
    }
    .main .sec_second .content .right .boxes .box {
        margin-bottom: 10px;
    }
    .main .sec_second .pad.bottom .content .flex_box .box h4.f24 {
        font-size: 18px;
    }
    .main .sec_second .pad.bottom .sdg .flex .left {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 45%;
        flex: 0 0 45%;
        line-height: 1.4;
    }
    .main .sec_second .pad.bottom .sdg .flex .left .f22 {
        font-size: 16px;
    }
    .main .sec_second .pad.bottom .sdg .flex .right {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 53%;
        flex: 0 0 53%;
    }
    .main .sec_second .pad.bottom .content .flex_box .box .arrow {
        width: 30px;
        height: 18px;
    }
    .main .market .sec_con h2.mds {
        font-size: 24px;
    }
    .main .sec_second .pad.bottom .content .flex_box .box p.f24 {
        font-size: 16px;
    }
    .main .market .flex_box a .sub {
        font-size: 22px;
    }

    .main .market .flex_box a .sub .f26 {
        font-size: 16px;
    }

    .main .market .task {
        margin-top: 5%;
    }
    .main .market .sec_con {
        padding: 4.5% 10px;
    }
    .main .market .sec_con .content .flex .left p.f20 {
        margin-bottom: 12%;
    }
    .main .market .sec_con .content .flex .left .arrow,
    .main .market .tec .content .flex .right .arrow {
        width: 40px;
        height: 46px;
    }
    .main .market .sec_con .content .flex .left p.orange {
        font-size: 20px;
    }
    .main .market .sec_con .content .flex .right .img:last-child small {
        font-size: 10px;
        margin-top: 0;
    }
    .main .market .spread .content .two {
        font-size: 16px;
    }
    .main .market .spread .content.second .flex .left p.f20 {
        letter-spacing: 0.04em;
    }
    .main .market .spread .content.second .flex .left .boxes .box span.f18 {
        display: block;
        margin-top: 2%;
        font-size: 11px;
    }
    .main .market .expo .content .flex .left p.f20 {
        letter-spacing: 0.03em;
    }
    .main .market .expo .content .flex .right .top_img::before {
        height: 160px;
    }
    .main .market .expo .content .flex .right .boxes {
        margin-top: 95px;
    }
}

@media screen and (max-width: 480px) {
    .width {
        width: auto;
        margin-left: 10px;
        margin-right: 10px;
    }
    .pad {
        padding-left: 10px;
        padding-right: 10px;
    }
    .main .sec_first {
        display: block;
    }
    .main .sec_first .right h2 {
        /* font-size: 32px; */
        font-size: 48px;
        margin-top: 4%;
        margin-bottom: 5%;
    }
    .main .sec_first .right {
        margin-top: 6%;
    }
    .main .sec_second .top_txt::before {
        width: 65vw;
        height: 30px;
    }
    .main .sec_second .top_txt h2.f55 {
        font-size: 23px;
        text-align: center;
        margin-top: 4%;
    }
    .main .sec_second .top_txt {
        margin-bottom: 6%;
    }
    .main .sec_second .content {
        display: block;
        margin-bottom: 6%;
    }
    .main .sec_second .content .left p.f22 {
        line-height: 1.6;
        margin-bottom: 6%;
        font-size: 15px;
    }
    .main .sec_second .l_text .f22 {
        font-size: 16px;
    }
    .main .sec_second {
        margin-top: 8%;
        padding: 8% 0;
    }
    .main .sec_second .content .left {
        margin-right: 0;
    }
    .main .sec_second .content .right {
        margin-left: 0;
        margin-top: 5%;
    }
    .main .sec_second .content .right h4.f22 {
        font-size: 20px;
    }
    .main .sec_second .content .right .boxes .box {
        margin-bottom: 12px;
    }
    .main .sec_second .content .right .arrow {
        width: 35px;
        height: 40px;
    }
    .main .sec_second .content .right .last,
    .main .sec_second .pad.bottom .sdg h2 {
        text-shadow: 3px 3px 4px #fff;
        /* -webkit-text-stroke: 0px #fff; */
    }
    .main .sec_second .w_arrow {
        margin-top: 8%;
        margin-bottom: 8%;
        height: 20px;
    }
    .main .sec_second .pad.bottom .top_txt {
        margin-bottom: 4%;
    }
    .main .sec_second .pad.bottom .sub {
        font-size: 11px;
        margin-bottom: 7%;
    }
    .main .sec_second .pad.bottom .content h3 {
        font-size: 20px;
    }
    .main .sec_second .pad.bottom .content h3::before,
    .main .sec_second .pad.bottom .content h3::after {
        width: 18vw;
    }
    .main .sec_second .pad.bottom .content .flex_box {
        display: block;
        margin-top: 8%;
    }
    .main .sec_second .pad.bottom .content .flex_box .box {
        margin-right: 0;
        margin-bottom: 6%;
    }
    .main .sec_second .pad.bottom .content .flex_box .box:last-child {
        margin-bottom: 0;
    }
    .main .sec_second .pad.bottom .content .flex_box .box h4.f24 {
        font-size: 24px;
    }
    .main .sec_second .pad.bottom .content .flex_box .box .arrow {
        margin: 4% auto;
    }
    .main .sec_second .pad.bottom .content .flex_box .box p.f24 {
        font-size: 20px;
    }
    .main .sec_second .pad.bottom .sdg .flex {
        -webkit-box-orient: vertical;
        -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
        flex-direction: column-reverse;
        margin-top: 6%;
    }
    .main .sec_second .pad.bottom .sdg .flex .left {
        margin-right: 0;
        margin-top: 5%;
    }
    .main .sec_second .pad.bottom .sdg .flex .right {
        width: 100%;
    }
    .main .market {
        margin-top: 10%;
    }
    .main .market h2.top {
        line-height: 1.45;
    }
    .main .market .flex_box {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        justify-content: center;
    }
    .main .market .flex_box a {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 48.85%;
        flex: 0 0 48.85%;
        padding: 8px;
    }
    .main .market .flex_box a:nth-child(2n) {
        margin-right: 0;
    }
    .main .market .flex_box a:nth-child(n + 3) {
        margin-top: 4%;
    }
    .main .market .flex_box a .sub .f24 {
        font-size: 13px;
    }
    .main .market .task {
        margin-top: 8%;
    }
    .main .market .sec_con {
        padding: 6% 10px;
    }
    .main .market .sec_con h2.mds {
        font-size: 18px;
        padding-top: 10px;
        padding-bottom: 8px;
        margin-bottom: 5%;
    }
    .main .market .sec_con h2.mds span {
        padding-bottom: 10px;
    }
    .main .market .sec_con .content h3 {
        font-size: 20px;
        margin-bottom: 10px;
        padding-bottom: 10px;
    }
    .main .market .sec_con .content .flex {
        display: block;
    }
    .main .market .sec_con .content .flex .left {
        margin-right: 0;
        margin-bottom: 10%;
    }
    .main .market .sec_con .content .flex .right {
        margin-left: 0;
    }
    .main .market .sec_con .content .flex .left p.f20 {
        font-size: 15px;
        margin-bottom: 8%;
        line-height: 1.55;
    }
    .main .market .sec_con .content .flex .left .arrow,
    .main .market .tec .content .flex .right .arrow {
        width: 32px;
        height: 37px;
    }
    .main .market .sec_con .content .flex .right .img:last-child {
        margin-top: 6%;
    }
    .main .market .sec_con .content.second {
        margin-top: 8%;
    }
    .main .market .sec_con {
        margin-bottom: 10%;
    }
    .main .market .tec .content .flex .left p.f20 {
        margin-top: 6%;
    }
    .main .market .tec .content .flex .right .img:last-child {
        margin-top: 0;
    }
    .main .market .spread .content .two {
        font-size: 15px;
        margin-bottom: 6%;
    }
    .main .market .sec_con .content .flex .left .boxes {
        margin-top: 6%;
    }
    .main .market .spread .content.second .flex .left p.f20 {
        letter-spacing: 0em;
        margin-bottom: 8%;
    }
    .main .market .spread .content.second .flex .right .img_box {
        display: block;
    }
    .main .market .spread .content.second .flex .right .img_box .img:last-child {
        margin-top: 6%;
    }
    .main .market .expo .content .flex .left p.f20 {
        letter-spacing: 0em;
    }
    .main .market .expo .content .flex .right .boxes {
        font-size: 14px;
        margin-top: 85px;
    }
    .main .market .expo .content .flex .right .boxes .box .text {
        height: 60px;
    }
    .main .market .expo .content .flex .right .top_img::before {
        height: 150px;
    }
    .main .market .expo .content .flex .right .boxes .box {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 23.2%;
        flex: 0 0 23.2%;
    }
    .main .sec_second .content .left .img p {
        font-size: 55px;
    }

    .main .sec_second .top_txt p.f25 {
        font-size: 18px;
    }

    .main .sec_second .top_txt::before {
        top: -70%;
    }
}
.outer-link {
    color: #0089ff;
}
