.goalArea .goalListBox .goalList .goalItem .title::before, .goalArea .goalListBox .goalList .goalItem .title::after, .goalArea .goalListBox .goalList .goalItem .title, .bannerArea .bannerLinkBox .bannerLinkItem .textBox, .bannerArea .bannerLinkBox .bannerLinkItem .item, .bannerArea .bannerLinkBox .bannerLinkItem, .bannerArea .slick-dots li button, .bannerArea .arrowBox .arrow::before, .bannerArea .arrowBox .arrow, .bannerArea .socialBox .socialList li a svg, .bannerArea .socialBox .socialList li, .popWin .close::before, .popWin .close::after, .popWin .close {
    -webkit-transition: all 0.5s ease-in-out;
    transition: all 0.5s ease-in-out;
}

.popWin {
    position: fixed;
    left: 0;
    top: 0;
    z-index: 500;
    width: 100%;
    height: 100vh;
    font-size: 15px;
    line-height: 1.8;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    -webkit-transition: all 0.7s;
    transition: all 0.7s;
}
.popWin .mask {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.7);
    opacity: 0;
    -webkit-transition: all 0.7s;
    transition: all 0.7s;
}
.popWin .inner {
    position: absolute;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%, 50%);
            transform: translate(-50%, 50%);
    width: 800px;
    max-width: 90%;
    max-height: 85vh;
    opacity: 0;
    background-color: #fff;
    -webkit-transition: all 0.7s;
    transition: all 0.7s;
}
.popWin .popContent {
    max-height: 88vh;
    overflow-y: auto;
}
.popWin img {
    display: block;
    max-width: 100%;
    height: auto;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
}
.popWin .Txt {
    padding: 30px;
}
.popWin .Txt .popTitle {
    font-size: 25px;
    margin-bottom: 25px;
}
.popWin .close {
    width: 46px;
    height: 46px;
    background-color: #108835;
    cursor: pointer;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 1;
}
.popWin .close::before, .popWin .close::after {
    content: "";
    position: absolute;
    left: 11px;
    top: 23px;
    width: 25px;
    height: 1px;
    background-color: #fff;
}
.popWin .close::before {
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
}
.popWin .close::after {
    -webkit-transform: rotate(-45deg);
            transform: rotate(-45deg);
}
@media (min-width: 1181px) {
    .popWin .close:hover {
        background-color: #108835;
    }
    .popWin .close:hover::before {
        -webkit-transform: rotate(-30deg);
                transform: rotate(-30deg);
    }
    .popWin .close:hover::after {
        -webkit-transform: rotate(30deg);
                transform: rotate(30deg);
    }
}
.popWin.show {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}
.popWin.show .mask,
.popWin.show .inner {
    opacity: 1;
}
.popWin.show .inner {
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
}
@media (max-width: 1180px) {
    .popWin .popContent {
        max-height: calc(100vh - 150px);
    }
}

.mainArea {
    padding: 0;
}

.bannerArea .bannerBox {
    position: relative;
}
.bannerArea .bannerList {
    position: relative;
    z-index: 1;
}
.bannerArea .bannerList.slick-dotted {
    margin-bottom: 0;
}
.bannerArea .bannerList:not(.slick-slider) .bannerItem:not(:first-child) {
    display: none;
}
.bannerArea .bannerList:not(.slick-slider) .bannerItem .Img img {
    aspect-ratio: 1/0.48958;
}
@media (max-width: 640px) {
    .bannerArea .bannerList:not(.slick-slider) .bannerItem .Img img {
        aspect-ratio: 1/1;
    }
}
.bannerArea .slick-current .Txt .title {
    -webkit-animation: bannerTxtAnimation 0.8s ease-in-out forwards;
            animation: bannerTxtAnimation 0.8s ease-in-out forwards;
}
.bannerArea .slick-current .Txt .titleEn {
    -webkit-animation: bannerTxtAnimation 0.8s 0.4s ease-in-out forwards;
            animation: bannerTxtAnimation 0.8s 0.4s ease-in-out forwards;
}
.bannerArea .slick-current .Img img {
    -webkit-animation: bannerImgZoomIn linear forwards;
            animation: bannerImgZoomIn linear forwards;
}
.bannerArea .bannerItem::before {
    content: "";
    background-color: rgba(0, 0, 0, 0.15);
    display: block;
    pointer-events: none;
    z-index: 2;
    width: 100%;
    height: 100%;
    margin: auto;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}
.bannerArea .bannerItem .Txt {
    max-width: 1540px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding: 70px 25px 170px;
    z-index: 2;
    width: 100%;
    height: 100%;
    margin: auto;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}
.bannerArea .bannerItem .Txt .textBox {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-top: 125px;
}
.bannerArea .bannerItem .Txt .title {
    color: #fff;
    font-size: 33px;
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: 5px;
    opacity: 0;
}
.bannerArea .bannerItem .Txt .titleEn {
    color: #fff;
    display: block;
    font-size: 85px;
    font-family: "Heebo", sans-serif;
    font-weight: 600;
    line-height: 1.05;
    letter-spacing: 3px;
    margin-top: 45px;
    opacity: 0;
    word-break: break-word;
}
@media (max-width: 1440px) {
    .bannerArea .bannerItem .Txt .textBox {
        margin-top: 60px;
    }
    .bannerArea .bannerItem .Txt .title {
        font-size: 33px;
    }
    .bannerArea .bannerItem .Txt .titleEn {
        font-size: 65px;
        margin-top: 25px;
    }
}
@media (max-width: 1200px) {
    .bannerArea .bannerItem .Txt {
        padding-top: 20px;
        padding-bottom: 125px;
    }
    .bannerArea .bannerItem .Txt .title {
        font-size: 26px;
    }
    .bannerArea .bannerItem .Txt .titleEn {
        font-size: 45px;
        margin-top: 10px;
    }
}
@media (max-width: 900px) {
    .bannerArea .bannerItem .Txt .textBox {
        margin-top: 0;
    }
    .bannerArea .bannerItem .Txt .title {
        font-size: 22px;
    }
    .bannerArea .bannerItem .Txt .titleEn {
        font-size: 40px;
    }
}
@media (max-width: 768px) {
    .bannerArea .bannerItem .Txt {
        padding-bottom: 60px;
    }
}
@media (max-width: 640px) {
    .bannerArea .bannerItem .Txt .title {
        font-size: 18px;
        letter-spacing: 2px;
    }
    .bannerArea .bannerItem .Txt .titleEn {
        font-size: 36px;
        letter-spacing: 2px;
    }
}
@media (max-width: 480px) {
    .bannerArea .bannerItem .Txt {
        padding-left: 20px;
        padding-right: 20px;
    }
}
@media (max-width: 375px) {
    .bannerArea .bannerItem .Txt .title {
        letter-spacing: 1px;
    }
    .bannerArea .bannerItem .Txt .titleEn {
        font-size: 32px;
        letter-spacing: 0.5px;
    }
}
.bannerArea .bannerItem .Img {
    position: relative;
    z-index: 1;
}
@media (max-width: 768px) {
    .bannerArea .bannerItem .Img {
        padding-bottom: 65%;
    }
    .bannerArea .bannerItem .Img img {
        -o-object-fit: cover;
           object-fit: cover;
        width: 100%;
        height: 100%;
        margin: auto;
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
    }
}
@media (max-width: 640px) {
    .bannerArea .bannerItem .Img {
        padding-bottom: 100%;
    }
}
.bannerArea .socialBox {
    display: block;
    position: absolute;
    top: 50%;
    left: 50px;
    z-index: 2;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
}
.bannerArea .socialBox .socialList {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
}
.bannerArea .socialBox .socialList li {
    margin: 7.5px 0;
}
.bannerArea .socialBox .socialList li:first-child {
    margin-top: 0;
}
.bannerArea .socialBox .socialList li:last-child {
    margin-bottom: 0;
}
.bannerArea .socialBox .socialList li a {
    color: #fff;
    display: block;
    font-size: 18px;
    line-height: 35px;
    text-align: center;
}
.bannerArea .socialBox .socialList li a svg {
    width: 20px;
    height: 18px;
    display: inline-block;
    fill: #fff;
    margin-top: -2px;
    vertical-align: middle;
}
.bannerArea .socialBox .socialList li a:hover {
    color: #108835;
}
.bannerArea .socialBox .socialList li a:hover svg {
    fill: #108835;
}
.bannerArea .arrowBox {
    display: block;
    position: absolute;
    top: 50%;
    right: 50px;
    z-index: 2;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
}
.bannerArea .arrowBox .arrow {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    border: 1px solid #fff;
    overflow: hidden;
    position: relative;
    margin: 10px 0;
    cursor: pointer;
}
.bannerArea .arrowBox .arrow::before {
    content: "";
    border-style: solid;
    display: block;
    z-index: 2;
    width: 0;
    height: 100%;
    margin: auto;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}
.bannerArea .arrowBox .arrowPrev::before {
    border-width: 0 5px 9px 5px;
    border-color: transparent transparent #fff transparent;
}
.bannerArea .arrowBox .arrowPrev:hover::before {
    border-color: transparent transparent #108835 transparent;
}
.bannerArea .arrowBox .arrowNext::before {
    border-width: 9px 5px 0 5px;
    border-color: #fff transparent transparent transparent;
}
.bannerArea .arrowBox .arrowNext:hover::before {
    border-color: #108835 transparent transparent transparent;
}
.bannerArea .scrollDown {
    width: 100%;
    max-width: 1540px;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    cursor: pointer;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 0 25px;
    position: absolute;
    margin: auto;
    bottom: 60px;
    left: 50%;
    z-index: 2;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
}
.bannerArea .scrollDown span {
    display: block;
}
.bannerArea .scrollDown span.text {
    color: #fff;
    font-size: 16px;
    font-family: "Heebo", sans-serif;
    line-height: 1;
    letter-spacing: 0.5px;
    padding-left: 15px;
}
.bannerArea .scrollDown span.line {
    width: 19px;
    height: 26px;
    border: 2px solid #fff;
    border-radius: 20px;
    overflow: hidden;
    position: relative;
    z-index: 1;
}
.bannerArea .scrollDown span.line::before {
    content: "";
    width: 2px;
    height: 5px;
    -webkit-animation: bannerScrollAnimation 2s ease-in-out infinite forwards;
            animation: bannerScrollAnimation 2s ease-in-out infinite forwards;
    background-color: #fff;
    display: block;
    position: absolute;
    top: 5px;
    left: 50%;
    z-index: 2;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
}
@media (max-width: 768px) {
    .bannerArea .scrollDown {
        bottom: 135px;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
    }
}
@media (max-width: 480px) {
    .bannerArea .scrollDown span.text {
        font-size: 14px;
        padding-left: 10px;
    }
    .bannerArea .scrollDown span.line {
        width: 16px;
        height: 22px;
        border: 2px solid #fff;
        border-radius: 20px;
        overflow: hidden;
        position: relative;
        z-index: 1;
    }
    .bannerArea .scrollDown span.line::before {
        content: "";
        width: 2px;
        height: 4px;
        -webkit-animation: bannerScrollAnimation 2s ease-in-out infinite forwards;
                animation: bannerScrollAnimation 2s ease-in-out infinite forwards;
        background-color: #fff;
        display: block;
        position: absolute;
        top: 5px;
        left: 50%;
        z-index: 2;
        -webkit-transform: translateX(-50%);
                transform: translateX(-50%);
    }
}
.bannerArea .slick-dots {
    width: 30px;
    margin: 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    bottom: 50%;
    right: 48px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
}
.bannerArea .slick-dots li {
    width: 100%;
    height: 30px;
    margin: 1px 0;
}
.bannerArea .slick-dots li button {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    border: 1px solid transparent;
    padding: 0;
}
.bannerArea .slick-dots li button::before {
    content: "";
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background-color: #fff;
    margin: auto;
    opacity: 1;
    bottom: 0;
    right: 0;
}
.bannerArea .slick-dots li.slick-active button {
    border-color: rgba(255, 255, 255, 0.6);
}
.bannerArea .slick-dots li.slick-active button::before {
    opacity: 1;
    background-color: #fff;
}
@media (max-width: 1200px) {
    .bannerArea .slick-dots {
        right: 10px;
    }
}
@media (max-width: 768px) {
    .bannerArea .slick-dots {
        bottom: 0;
    }
}
.bannerArea .bannerLinkBox {
    width: 100%;
    max-width: 700px;
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: 2;
}
.bannerArea .bannerLinkBox .bannerLinkList {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}
.bannerArea .bannerLinkBox .bannerLinkItem {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    overflow: hidden;
    position: relative;
}
.bannerArea .bannerLinkBox .bannerLinkItem:nth-child(1) {
    background-color: rgba(8, 68, 26, 0.6);
}
.bannerArea .bannerLinkBox .bannerLinkItem:nth-child(2) {
    background-color: #0b5a23;
}
.bannerArea .bannerLinkBox .bannerLinkItem:nth-child(3) {
    background-color: #108835;
}
@media (min-width: 1181px) {
    .bannerArea .bannerLinkBox .bannerLinkItem:hover:nth-child(1) {
        background-color: #139f3e;
    }
    .bannerArea .bannerLinkBox .bannerLinkItem:hover:nth-child(2) {
        background-color: #139f3e;
    }
    .bannerArea .bannerLinkBox .bannerLinkItem:hover:nth-child(3) {
        background-color: #139f3e;
    }
    .bannerArea .bannerLinkBox .bannerLinkItem:hover .item {
        -webkit-transform: translateY(-5px);
                transform: translateY(-5px);
    }
    .bannerArea .bannerLinkBox .bannerLinkItem:hover p {
        -webkit-transform: translateY(-5px);
                transform: translateY(-5px);
    }
}
.bannerArea .bannerLinkBox .bannerLinkItem .item {
    padding: 35px 48px;
    position: relative;
    z-index: 2;
}
.bannerArea .bannerLinkBox .bannerLinkItem .coverLink {
    display: block;
    z-index: 2;
    width: 100%;
    height: 100%;
    margin: auto;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}
.bannerArea .bannerLinkBox .bannerLinkItem img {
    width: 40px;
    height: 40px;
    display: inline-block;
    vertical-align: middle;
}
.bannerArea .bannerLinkBox .bannerLinkItem .textBox {
    margin-top: 15px;
}
.bannerArea .bannerLinkBox .bannerLinkItem .textBox .text {
    color: #fff;
    display: block;
    letter-spacing: 0.5px;
    line-height: 1;
}
.bannerArea .bannerLinkBox .bannerLinkItem .textBox .text.tw {
    font-size: 18px;
    letter-spacing: 0.5px;
}
.bannerArea .bannerLinkBox .bannerLinkItem .textBox .text.en {
    font-size: 15px;
    font-family: "Heebo", sans-serif;
    margin-top: 10px;
}
@media (max-width: 1200px) {
    .bannerArea .bannerLinkBox {
        max-width: 500px;
    }
    .bannerArea .bannerLinkBox .bannerLinkItem .item {
        padding: 15px 25px;
    }
    .bannerArea .bannerLinkBox .bannerLinkItem img {
        width: 35px;
        height: 35px;
    }
    .bannerArea .bannerLinkBox .bannerLinkItem .textBox {
        margin-top: 10px;
    }
    .bannerArea .bannerLinkBox .bannerLinkItem .textBox .text.tw {
        font-size: 16px;
    }
    .bannerArea .bannerLinkBox .bannerLinkItem .textBox .text.en {
        font-size: 14px;
    }
}
@media (max-width: 768px) {
    .bannerArea .bannerLinkBox {
        position: static;
        max-width: 100%;
    }
}
@media (max-width: 480px) {
    .bannerArea .bannerLinkBox .bannerLinkItem .item {
        padding: 15px;
    }
    .bannerArea .bannerLinkBox .bannerLinkItem img {
        width: 30px;
        height: 30px;
    }
    .bannerArea .bannerLinkBox .bannerLinkItem .textBox .text.tw {
        font-size: 15px;
    }
}
@media (max-width: 374px) {
    .bannerArea .bannerLinkBox .bannerLinkItem img {
        width: 30px;
        height: 30px;
    }
    .bannerArea .bannerLinkBox .bannerLinkItem .item {
        padding: 15px 10px;
    }
    .bannerArea .bannerLinkBox .bannerLinkItem .textBox {
        margin-top: 5px;
    }
}

.goalArea {
    padding: 110px 0 125px;
}
@media (max-width: 1180px) {
    .goalArea {
        padding: 40px 0 60px;
    }
}
.goalArea .wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}
@media (max-width: 1180px) {
    .goalArea .wrap {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
    }
}
.goalArea .goalIntro, .goalArea .goalListBox {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
}
@media (max-width: 1180px) {
    .goalArea .goalIntro, .goalArea .goalListBox {
        width: 100%;
        -webkit-box-flex: 1;
            -ms-flex: auto;
                flex: auto;
    }
}
.goalArea .goalIntro .titleBox {
    margin-bottom: 30px;
}
.goalArea .goalIntro .textBox {
    color: #333;
    font-size: 16px;
    line-height: 1.85;
    letter-spacing: 0.5px;
    padding-top: 2px;
}
.goalArea .goalIntro + .goalListBox {
    margin-left: 40px;
    padding-left: 40px;
    position: relative;
}
.goalArea .goalIntro + .goalListBox::before {
    content: "";
    width: 1px;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.1);
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
}
@media (max-width: 1180px) {
    .goalArea .goalIntro + .goalListBox {
        margin-left: 0;
        padding-left: 0;
    }
    .goalArea .goalIntro + .goalListBox::before {
        display: none;
    }
}
@media (max-width: 640px) {
    .goalArea .goalIntro .textBox {
        font-size: 15px;
        line-height: 1.8;
    }
}
.goalArea .goalListBox {
    padding-top: 10px;
}
.goalArea .goalListBox .goalList .goalItem {
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
    padding: 20px 0;
}
.goalArea .goalListBox .goalList .goalItem:first-child {
    border-top: 1px solid rgba(0, 0, 0, 0.1);
}
.goalArea .goalListBox .goalList .goalItem .title {
    cursor: pointer;
    font-size: 20px;
    font-weight: 500;
    letter-spacing: 0.5px;
    line-height: 1.2;
    padding: 5px 0;
    position: relative;
}
.goalArea .goalListBox .goalList .goalItem .title::before, .goalArea .goalListBox .goalList .goalItem .title::after {
    content: "";
    width: 10px;
    height: 1px;
    background-color: #000;
    position: absolute;
    top: 50%;
    right: 10px;
    z-index: 1;
}
.goalArea .goalListBox .goalList .goalItem .title::after {
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
}
.goalArea .goalListBox .goalList .goalItem .title.open::after {
    -webkit-transform: rotate(180deg);
            transform: rotate(180deg);
}
@media (min-width: 1181px) {
    .goalArea .goalListBox .goalList .goalItem .title:hover {
        color: #108835;
    }
    .goalArea .goalListBox .goalList .goalItem .title:hover::before, .goalArea .goalListBox .goalList .goalItem .title:hover::after {
        background-color: #108835;
    }
}
.goalArea .goalListBox .goalList .goalItem .text {
    max-height: 135px;
    color: #626262;
    display: none;
    font-size: 16px;
    line-height: 2.1;
    letter-spacing: 0.35px;
    margin-top: 10px;
    overflow-y: auto;
}
.goalArea .goalListBox .goalList .goalItem .text::-webkit-scrollbar-track {
    -webkit-box-shadow: inset 0 0 3px rgba(0, 0, 0, 0.15);
    box-shadow: inset 0 0 3px rgba(0, 0, 0, 0.15);
    background-color: rgba(0, 0, 0, 0.1);
}
.goalArea .goalListBox .goalList .goalItem .text::-webkit-scrollbar {
    width: 3px;
    height: 3px;
    background-color: rgba(0, 0, 0, 0.1);
}
.goalArea .goalListBox .goalList .goalItem .text::-webkit-scrollbar-thumb {
    background: #108835;
}
@media (max-width: 1180px) {
    .goalArea .goalListBox {
        padding-top: 30px;
    }
}
@media (max-width: 640px) {
    .goalArea .goalListBox .goalList .goalItem {
        padding: 12px 0;
    }
    .goalArea .goalListBox .goalList .goalItem .title {
        font-size: 18px;
    }
    .goalArea .goalListBox .goalList .goalItem .text {
        font-size: 15px;
        line-height: 1.8;
    }
}

.aboutArea .wrap {
    max-width: 1920px;
    padding: 0;
}
.aboutArea .aboutBox {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}
@media (max-width: 1180px) {
    .aboutArea .aboutBox {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
    }
}
.aboutArea .Img {
    width: 50%;
    height: 550px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.aboutArea .Img img {
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
}
.aboutArea .Img + .Txt {
    width: 50%;
}
@media (max-width: 1180px) {
    .aboutArea .Img {
        width: 100%;
        height: 400px;
    }
    .aboutArea .Img + .Txt {
        width: 100%;
    }
}
@media (max-width: 640px) {
    .aboutArea .Img {
        height: 300px;
    }
}
@media (max-width: 374px) {
    .aboutArea .Img {
        height: 220px;
    }
}
.aboutArea .Txt {
    width: 100%;
    background-color: #108835;
    padding: 100px 360px 70px 110px;
}
.aboutArea .Txt .titleBox {
    padding-top: 5px;
}
.aboutArea .Txt .textBox {
    max-height: 550px;
    color: #fff;
    font-size: 16px;
    line-height: 1.9;
    letter-spacing: 0.45px;
    margin-top: 10px;
    overflow-y: auto;
    word-break: break-all;
}
.aboutArea .Txt .textBox::-webkit-scrollbar-track {
    -webkit-box-shadow: inset 0 0 3px rgba(0, 0, 0, 0.15);
    box-shadow: inset 0 0 3px rgba(0, 0, 0, 0.15);
    background-color: #108835;
}
.aboutArea .Txt .textBox::-webkit-scrollbar {
    width: 3px;
    height: 3px;
    background-color: #108835;
}
.aboutArea .Txt .textBox::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.1);
}
@media (max-width: 1680px) {
    .aboutArea .Txt {
        padding: 100px 80px 70px 80px;
    }
}
@media (max-width: 1280px) {
    .aboutArea .Txt {
        padding: 70px 50px;
    }
}
@media (max-width: 1180px) {
    .aboutArea .Txt {
        padding: 40px 25px 60px;
    }
    .aboutArea .Txt .titleBox {
        padding-top: 0;
    }
}
@media (max-width: 640px) {
    .aboutArea .Txt .textEditor {
        font-size: 15px;
        line-height: 1.8;
    }
}
@media (max-width: 480px) {
    .aboutArea .Txt {
        padding: 30px 20px 50px;
    }
}

.majorArea {
    padding: 120px 0;
}
@media (max-width: 1180px) {
    .majorArea {
        padding: 40px 0 60px;
    }
}
.majorArea .majorItem {
    padding: 30px 5px;
}
.majorArea .majorItem:first-child {
    padding-top: 0;
}
.majorArea .majorItem:last-child {
    padding-bottom: 0;
}
.majorArea .majorItem:nth-child(odd) .item {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
}
.majorArea .majorItem:nth-child(odd) .Txt {
    padding: 0 65px 10px 0;
}
.majorArea .majorItem:nth-child(even) .Txt {
    padding: 0 5px 10px 60px;
}
@media (max-width: 1280px) {
    .majorArea .majorItem:nth-child(odd) .Txt {
        padding: 0 30px 10px 0;
    }
    .majorArea .majorItem:nth-child(even) .Txt {
        padding: 0 0 10px 30px;
    }
}
@media (max-width: 768px) {
    .majorArea .majorItem {
        padding: 30px 0;
    }
    .majorArea .majorItem:nth-child(odd) .item {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
    }
    .majorArea .majorItem:nth-child(odd) .Txt {
        padding: 0;
    }
    .majorArea .majorItem:nth-child(even) .Txt {
        padding: 0;
    }
}
.majorArea .item {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}
@media (max-width: 768px) {
    .majorArea .item {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        padding: 20px 0;
    }
}
.majorArea .Img {
    width: 50%;
    max-width: 595px;
}
.majorArea .Img img {
    aspect-ratio: 1/0.61666;
    width: 100%;
    height: auto;
    display: block;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
}
@media (max-width: 768px) {
    .majorArea .Img {
        width: 100%;
    }
}
.majorArea .Txt {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
}
.majorArea .Txt .title {
    color: #108835;
    font-size: 24px;
    font-weight: 500;
    line-height: 1.2;
}
.majorArea .Txt .text {
    max-height: 120px;
    color: #333;
    font-size: 16px;
    line-height: 1.875;
    letter-spacing: 0.35px;
    margin-top: 30px;
}
@media (max-width: 1280px) {
    .majorArea .Txt .text {
        margin-top: 15px;
    }
}
@media (max-width: 1180px) {
    .majorArea .Txt .title {
        font-size: 20px;
    }
    .majorArea .Txt .text {
        max-height: 100px;
        font-size: 15px;
        line-height: 1.6;
    }
}
@media (max-width: 768px) {
    .majorArea .Txt {
        max-width: 595px;
        -webkit-box-flex: 1;
            -ms-flex: auto;
                flex: auto;
        margin-top: 15px;
    }
}
@media (max-width: 640px) {
    .majorArea .Txt .title {
        font-size: 18px;
    }
    .majorArea .Txt .text {
        margin-top: 10px;
    }
}

.performanceArea {
    background-color: #108835;
    padding: 105px 0 115px;
}
@media (max-width: 1180px) {
    .performanceArea {
        padding: 40px 0 20px;
    }
}
.performanceArea .titleBox {
    margin-bottom: 50px;
}
.performanceArea .performanceList {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin: 0 auto;
}
@media (max-width: 1180px) {
    .performanceArea .performanceList {
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    }
}
.performanceArea .performanceItem {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    position: relative;
    padding: 0 25px;
}
.performanceArea .performanceItem:not(:last-child)::before {
    content: "";
    width: 1px;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.5);
    position: absolute;
    bottom: 0;
    right: 0;
}
.performanceArea .performanceItem:not(:last-child)::after {
    content: "";
    width: 1px;
    height: 40px;
    background-color: #fff;
    position: absolute;
    bottom: 0;
    right: 0;
}
@media (max-width: 1180px) {
    .performanceArea .performanceItem {
        width: 50%;
        -webkit-box-flex: 1;
            -ms-flex: auto;
                flex: auto;
        margin-bottom: 30px;
        padding: 0 12px;
    }
    .performanceArea .performanceItem:nth-child(even)::before, .performanceArea .performanceItem:nth-child(even)::after {
        display: none;
    }
}
@media (max-width: 480px) {
    .performanceArea .performanceItem {
        width: 100%;
        margin-bottom: 25px;
        padding-bottom: 25px;
    }
    .performanceArea .performanceItem:not(:last-child)::before, .performanceArea .performanceItem:not(:last-child)::after {
        width: 90%;
        display: block;
        right: 50%;
        -webkit-transform: translateX(50%);
                transform: translateX(50%);
    }
    .performanceArea .performanceItem:not(:last-child)::before {
        max-width: 300px;
        height: 1px;
    }
    .performanceArea .performanceItem:not(:last-child)::after {
        max-width: 50px;
        height: 1px;
    }
}
.performanceArea .performanceItem .title {
    width: 100%;
    color: #fff;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: 0.7px;
    margin-bottom: 30px;
    padding-bottom: 20px;
    position: relative;
}
.performanceArea .performanceItem .title::before {
    content: "";
    width: 20px;
    height: 2px;
    background-color: #fff;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 1;
}
@media (max-width: 1180px) {
    .performanceArea .performanceItem .title::before {
        left: 50%;
        -webkit-transform: translateX(-50%);
                transform: translateX(-50%);
    }
}
@media (max-width: 480px) {
    .performanceArea .performanceItem .title {
        margin-bottom: 10px;
        padding-bottom: 15px;
    }
}
.performanceArea .performanceItem .textBox {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
}
@media (max-width: 1180px) {
    .performanceArea .performanceItem .textBox {
        text-align: center;
    }
}
.performanceArea .performanceItem .textBox .Img {
    width: 40px;
    height: 40px;
    display: inline-block;
    vertical-align: middle;
    margin-right: 12px;
    position: relative;
}
.performanceArea .performanceItem .textBox .Txt .text {
    color: #fff;
    display: inline-block;
}
.performanceArea .performanceItem .textBox .Txt .text.number {
    font-size: 50px;
    font-weight: 500;
    font-family: "Heebo", sans-serif;
    line-height: 0.8;
    letter-spacing: 0.5px;
}
@media (max-width: 1280px) {
    .performanceArea .performanceItem .textBox .Txt .text.number {
        font-size: 36px;
    }
}
@media (max-width: 1180px) {
    .performanceArea .performanceItem .textBox .Txt .text.number {
        font-size: 32px;
    }
}
.performanceArea .performanceItem .textBox .Txt .text.unit {
    font-size: 16px;
    line-height: 1;
    margin-left: 3px;
}
@media (max-width: 1180px) {
    .performanceArea .performanceItem .textBox .Txt .text.unit {
        font-size: 15px;
    }
}

.newsArea {
    padding-top: 115px;
    position: relative;
}
@media (max-width: 1180px) {
    .newsArea {
        padding-top: 40px;
        padding-bottom: 60px;
    }
}
.newsArea .newsBg {
    width: 100%;
    height: 500px;
    background-image: url(../images/home_news_bg.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: top center;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
}
@media (max-width: 640px) {
    .newsArea .newsBg {
        height: 100%;
    }
}
.newsArea .titleBox {
    margin-bottom: 55px;
    position: relative;
    z-index: 2;
}
@media (max-width: 640px) {
    .newsArea .titleBox {
        margin-bottom: 20px;
    }
}
.newsArea .newsBox {
    width: calc(100% - 40px);
    max-width: 1785px;
    background-color: #fff;
    -webkit-box-shadow: 0 -5px 8px rgba(0, 0, 0, 0.1);
            box-shadow: 0 -5px 8px rgba(0, 0, 0, 0.1);
    margin: 0 auto;
    position: relative;
    z-index: 2;
}
.newsArea .newsBox .slick-dots {
    position: static;
    margin-top: 20px;
}
.newsArea .newsBox .slick-dots li {
    width: 12px;
    height: 12px;
}
.newsArea .newsBox .slick-dots li button {
    width: 12px;
    height: 12px;
}
.newsArea .newsBox .slick-dots li button::before {
    color: #108835;
}
.newsArea .newsList {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin: 0 -30px;
    padding: 35px 5px 45px;
    position: relative;
}
.newsArea .newsList::before {
    content: "";
    width: 82%;
    height: 1px;
    background-color: rgba(0, 0, 0, 0.1);
    position: absolute;
    bottom: 50%;
    left: 50%;
    z-index: 1;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
}
.newsArea .newsList.slick-dotted {
    margin-bottom: 0;
}
@media (max-width: 1280px) {
    .newsArea .newsList {
        margin: 0 -15px;
    }
}
@media (max-width: 1180px) {
    .newsArea .newsList {
        padding: 20px 0 30px;
    }
    .newsArea .newsList::before {
        display: none;
    }
}
@media (max-width: 640px) {
    .newsArea .newsList {
        margin: 0;
        padding: 10px 0 20px;
    }
}
.newsArea .newsItem {
    width: 33.3333333333%;
    padding: 60px 30px 50px;
}
@media (max-width: 1280px) {
    .newsArea .newsItem {
        padding: 40px 15px 30px;
    }
}
@media (max-width: 1180px) {
    .newsArea .newsItem {
        width: 50%;
        position: relative;
    }
    .newsArea .newsItem::before {
        content: "";
        width: 90%;
        height: 1px;
        background-color: rgba(0, 0, 0, 0.1);
        position: absolute;
        bottom: 0;
        left: 50%;
        z-index: 1;
        -webkit-transform: translateX(-50%);
                transform: translateX(-50%);
    }
    .newsArea .newsItem:nth-last-child(2)::before, .newsArea .newsItem:last-child::before {
        display: none;
    }
}
@media (max-width: 640px) {
    .newsArea .newsItem {
        width: 100%;
        padding: 20px 0;
    }
    .newsArea .newsItem::before {
        width: 100%;
    }
    .newsArea .newsItem:nth-last-child(2)::before {
        display: block;
    }
    .newsArea .newsItem .slick-active + .slick-active::before {
        display: none;
    }
}
.newsArea .newsItem .Txt {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}
@media (max-width: 640px) {
    .newsArea .newsItem .Txt {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
    }
}
.newsArea .newsItem .Txt .dateBox {
    width: 50px;
    color: #108835;
    display: block;
    font-weight: 400;
    font-family: "Heebo", sans-serif;
    line-height: 1;
}
@media (min-width: 641px) {
    .newsArea .newsItem .Txt .dateBox .mobileDate {
        display: none;
    }
}
.newsArea .newsItem .Txt .dateBox .date {
    font-size: 40px;
}
.newsArea .newsItem .Txt .dateBox .monthYear {
    font-size: 14px;
    margin-top: 12px;
    position: relative;
}
.newsArea .newsItem .Txt .dateBox .monthYear::before {
    content: "";
    width: 100%;
    height: 1px;
    background-color: #108835;
    position: absolute;
    top: -7px;
    left: 0;
    z-index: 1;
}
@media (max-width: 640px) {
    .newsArea .newsItem .Txt .dateBox {
        width: 100%;
    }
    .newsArea .newsItem .Txt .dateBox .mobileDate {
        display: block;
        font-size: 14px;
    }
    .newsArea .newsItem .Txt .dateBox .date {
        display: none;
        font-size: 14px;
        margin-right: 5px;
    }
    .newsArea .newsItem .Txt .dateBox .monthYear {
        display: none;
        margin-top: 0;
    }
    .newsArea .newsItem .Txt .dateBox .monthYear::before {
        display: none;
    }
}
.newsArea .newsItem .Txt .textBox {
    padding-left: 20px;
}
.newsArea .newsItem .Txt .textBox .title {
    height: 65px;
    color: #000;
    font-size: 20px;
    font-weight: 500;
    letter-spacing: 0.5px;
    line-height: 1.5;
}
.newsArea .newsItem .Txt .textBox .text {
    height: 55px;
    color: #626262;
    font-size: 14px;
    line-height: 1.7;
    letter-spacing: 0.3px;
    margin-top: 18px;
}
@media (max-width: 640px) {
    .newsArea .newsItem .Txt .textBox {
        padding-left: 0;
    }
    .newsArea .newsItem .Txt .textBox .title {
        height: 30px;
        font-size: 18px;
    }
    .newsArea .newsItem .Txt .textBox .text {
        height: 50px;
        margin-top: 5px;
    }
}

.mailSubscribeArea {
    background-image: url(../images/home_subscribe_bg.jpg);
    padding: 115px 0 120px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-attachment: fixed;
}
@media (max-width: 1180px) {
    .mailSubscribeArea {
        padding: 40px 0 60px;
    }
}
.mailSubscribeArea .wrap {
    width: calc(100% - 40px);
    max-width: 1180px;
    background-color: #fff;
    -webkit-box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
            box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}
.mailSubscribeArea .mailSubscribeBox {
    max-width: 540px;
    padding: 80px 0 105px;
    margin: 0 auto;
}
@media (max-width: 768px) {
    .mailSubscribeArea .mailSubscribeBox {
        padding: 40px 0 50px;
    }
}
@media (max-width: 480px) {
    .mailSubscribeArea .mailSubscribeBox {
        padding: 30px 0 40px;
    }
}
.mailSubscribeArea .titleBox {
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 50px;
}
.mailSubscribeArea .titleBox .title {
    font-size: 30px;
}
.mailSubscribeArea form .formRow {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
}
.mailSubscribeArea form .formRow input {
    width: calc(100% - 170px);
    border-bottom: 1px solid #b5b5b5;
    color: #626262;
    caret-color: #626262;
    display: block;
    font-size: 16px;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.5px;
    padding: 18px 0;
}
.mailSubscribeArea form .formRow input::-webkit-input-placeholder {
    color: #626262;
}
.mailSubscribeArea form .formRow input::-moz-placeholder {
    color: #626262;
}
.mailSubscribeArea form .formRow input:-ms-input-placeholder {
    color: #626262;
}
.mailSubscribeArea form .formRow input::-ms-input-placeholder {
    color: #626262;
}
.mailSubscribeArea form .formRow input::placeholder {
    color: #626262;
}
.mailSubscribeArea form .formRow input.error {
    border-color: red;
}
@media (max-width: 640px) {
    .mailSubscribeArea form .formRow {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        -webkit-box-align: start;
            -ms-flex-align: start;
                align-items: flex-start;
    }
    .mailSubscribeArea form .formRow input {
        width: 100%;
    }
    .mailSubscribeArea form .formRow .btn {
        width: 100%;
        margin-top: 20px;
    }
    .mailSubscribeArea form .formRow .btn a {
        width: 100%;
    }
}