@charset "UTF-8";
@import"https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@100..900&family=Ubuntu:ital,wght@0,300;0,400;0,500;0,700;1,300;1,400;1,500;1,700&display=swap";

@keyframes alpha-1 {
    0% {
        opacity: 0;
        filter: alpha(opacity=0);
        -moz-opacity: 0;
        -khtml-opacity: 0
    }

    to {
        opacity: 1;
        filter: alpha(opacity=100);
        -moz-opacity: 1;
        -khtml-opacity: 1
    }
}

@keyframes big {
    0% {
        opacity: 0;
        filter: alpha(opacity=0);
        -moz-opacity: 0;
        -khtml-opacity: 0;
        transform: scale(.2)
    }

    to {
        opacity: 1;
        filter: alpha(opacity=100);
        -moz-opacity: 1;
        -khtml-opacity: 1;
        transform: scale(1)
    }
}

@keyframes bn-city-scrol {
    0% {
        transform: translate(0)
    }

    to {
        transform: translate(-3840px)
    }
}

@keyframes bn-city-scrol-mb {
    0% {
        transform: translate(0)
    }

    to {
        transform: translate(-375px)
    }
}

@keyframes circle {
    0% {
        transform: rotate(0)
    }

    to {
        transform: rotate(36deg)
    }
}

@keyframes cloud {
    0% {
        transform: translateY(0)
    }

    50% {
        transform: translateY(-15px)
    }
}

@keyframes height-100 {
    0% {
        height: 0
    }

    to {
        height: 100%
    }
}

@keyframes width-100 {
    0% {
        width: 0
    }

    to {
        width: 100%
    }
}

@keyframes move-down {
    0% {
        opacity: 0;
        filter: alpha(opacity=0);
        -moz-opacity: 0;
        -khtml-opacity: 0;
        transform: translateY(-15px)
    }

    to {
        opacity: 1;
        filter: alpha(opacity=100);
        -moz-opacity: 1;
        -khtml-opacity: 1;
        transform: translateY(0)
    }
}

@keyframes move-down-1 {
    0% {
        opacity: 0;
        filter: alpha(opacity=0);
        -moz-opacity: 0;
        -khtml-opacity: 0;
        transform: translate(-50%, -55%)
    }

    to {
        opacity: 1;
        filter: alpha(opacity=100);
        -moz-opacity: 1;
        -khtml-opacity: 1;
        transform: translate(-50%, -50%)
    }
}

@keyframes shake {
    0% {
        transform: rotate(0)
    }

    50% {
        transform: rotate(5deg)
    }
}

@keyframes move-right {
    0% {
        transform: translate(0)
    }

    50% {
        transform: translate(-5px)
    }
}

@keyframes rotate-brand {
    0% {
        transform: translate(0)
    }

    to {
        transform: translate(-4021px)
    }
}

@keyframes rotate-brand-mb {
    0% {
        transform: translate(0)
    }

    to {
        transform: translate(-400px)
    }
}

.main {
    max-width: 1280px;
    margin-left: auto;
    margin-right: auto
}

.logo {
    flex: 0 0 auto
}

.logo a {
    display: flex
}

.logo img {
    max-width: 100%
}

@media only screen and (max-width: 991px) {
    .logo {
        width: 133px
    }
}

@media only screen and (min-width: 992px) {
    .logo {
        width: 180px
    }
}

@media only screen and (min-width: 1440px) and (min-height: 700px) {
    .logo {
        width: 280px
    }
}

.header {
    background: #fff;
    border-radius: 50px;
    display: flex;
    align-items: center;
    position: fixed;
    top: 20px;
    z-index: 10
}

@media only screen and (max-width: 991px) {
    .header {
        height: 60px;
        width: calc(100% - 60px);
        top: 10px;
        left: 30px;
        padding: 0 20px;
        justify-content: space-between
    }
}

@media only screen and (max-width: 767px) {
    .header {
        width: calc(100% - 14px);
        left: 7px
    }
}

@media only screen and (min-width: 992px) {
    .header {
        width: calc(100% - 60px);
        height: 60px;
        left: 30px;
        padding: 0 30px
    }
}

@media only screen and (min-width: 1440px) and (min-height: 700px) {
    .header {
        height: 100px
    }
}

@media only screen and (min-width: 1440px) {
    .header {
        width: calc(100% - 120px);
        left: 60px;
        padding: 0 30px
    }
}

@media only screen and (min-width: 1600px) {
    .header {
        padding: 0 60px
    }
}

.right-nav {
    flex: 1 1 auto;
    display: flex;
    justify-content: flex-end
}

.right-nav a {
    color: #333
}

.right-nav a:last-child {
    margin-right: 0
}

@media only screen and (max-width: 991px) {
    .right-nav {
        display: none
    }
}

@media only screen and (min-width: 992px) {
    .right-nav a {
        font-size: 16px;
        margin-right: 15px;
        font-weight: 700
    }

    .right-nav a:hover {
        color: #fabe00
    }
}

@media only screen and (min-width: 1280px) {
    .right-nav a {
        font-size: 18px
    }
}

@media only screen and (min-width: 1440px) {
    .right-nav a {
        font-size: 20px;
        margin-right: 30px
    }
}

@media only screen and (min-width: 1600px) {
    .right-nav a {
        margin-right: 40px
    }
}

.m-menu {
    position: relative;
    width: 26px;
    height: 18px;
    display: none
}

.m-menu.on:after {
    position: absolute;
    content: "";
    width: 40px;
    height: 40px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    background: url(../img/close_bg.png) 50% 50% no-repeat;
    background-size: cover;
    z-index: 1
}

.m-menu.on p {
    width: 20px;
    height: 2px;
    background: #fff
}

.m-menu.on p:nth-child(1) {
    display: none
}

.m-menu.on p:nth-child(2) {
    top: 50%;
    left: 3px;
    transform: rotate(45deg)
}

.m-menu.on p:nth-child(3) {
    top: 50%;
    left: 3px;
    transform: rotate(-45deg)
}

.m-menu p {
    position: absolute;
    background: #0e56c2;
    width: 26px;
    height: 2px;
    left: 0;
    z-index: 2
}

.m-menu p:nth-child(1) {
    top: 0
}

.m-menu p:nth-child(2) {
    top: 8px
}

.m-menu p:nth-child(3) {
    top: 16px
}

@media only screen and (max-width: 991px) {
    .m-menu {
        display: block
    }
}

.bnbox {
    position: relative;
    background: url(../img/bnbg.jpg) 0 0 repeat-y;
    background-size: 100% auto;
    height: 100vh;
    z-index: 1;
    overflow: hidden
}

.bnbox .main {
    position: relative;
    z-index: 2;
    display: flex;
    height: 100%
}

.bnbox .sun {
    position: absolute;
    top: 0%;
    left: 0;
    width: 50%;
    height: 50%;
    animation: move-sun 6s ease-in-out infinite alternate
}

.bnbox .sun:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding-top: 100%;
    background: url(../img/light.png) 50% 50% no-repeat;
    background-size: contain
}

@keyframes move-sun {
    0% {
        transform: translate(10%)
    }

    to {
        transform: translate(90%)
    }
}

.bnbox .bg-bt {
    position: absolute;
    left: 0;
    bottom: 0;
    background: #fff;
    z-index: 1;
    width: 100%;
    opacity: .85;
    filter: alpha(opacity=85);
    -moz-opacity: .85;
    -khtml-opacity: .85
}

@media only screen and (max-width: 991px) {
    .bnbox {
        padding-top: 70px
    }

    .bnbox .main {
        flex-direction: column
    }

    .bnbox .sun {
        top: 15%
    }

    .bnbox .bn-left-content .bn-join {
        display: none
    }

    .bnbox .bn-join {
        display: block;
        padding-bottom: 3vh
    }

    .bnbox .bg-bt {
        border-top-right-radius: 40px;
        border-top-left-radius: 40px;
        height: 30vh
    }
}

@media only screen and (min-width: 992px) {
    .bnbox {
        padding-top: 120px
    }

    .bnbox .main {
        align-items: center
    }

    .bnbox .bg-bt {
        border-top-right-radius: 80px;
        border-top-left-radius: 80px;
        height: 44vh
    }

    .bnbox .bn-join {
        display: none
    }

    .bnbox .bn-left-content .bn-join {
        display: block
    }
}

.bn-left-content {
    display: flex;
    flex-direction: column;
    align-items: center
}

@media only screen and (max-width: 991px) {
    .bn-left-content {
        padding-top: 2vh
    }
}

@media only screen and (min-width: 992px) {
    .bn-left-content {
        flex: 0 0 480px;
        margin-left: 70px
    }
}

.bn-slogan {
    font-weight: 700;
    color: #fff;
    text-shadow: 0 3px 6px rgba(0, 0, 0, .16);
    text-align: center;
    line-height: 1.2
}

@media only screen and (max-width: 767px) {
    .bn-slogan {
        font-size: min(max(8vh, 0px), 42px);
        margin-bottom: 2vh
    }

    .bn-slogan .tit {
        font-size: min(max(10.5vh, 0px), 60px)
    }
}

@media only screen and (min-width: 768px) {
    .bn-slogan {
        font-size: min(max(8vh, 0px), 80px);
        margin-bottom: 2.77vh
    }

    .bn-slogan .tit {
        font-size: min(max(10.5vh, 0px), 105px)
    }
}

.bn-data {
    color: #fff;
    font-weight: 700;
    line-height: 1.2;
    background: url(../img/bn_number_bg.png) 50% 50% no-repeat;
    background-size: cover
}

.bn-data .number {
    display: flex;
    align-items: center;
    flex-wrap: wrap
}

.bn-data .number .show {
    font-family: Ubuntu, sans-serif
}

@media only screen and (max-width: 767px) {
    .bn-data {
        font-size: min(max(4vh, 0px), 21px);
        border-radius: 20px;
        padding: 15px;
        margin-bottom: 2vh
    }

    .bn-data .number .show {
        font-size: min(max(9vh, 0px), 40px)
    }
}

@media only screen and (min-width: 768px) {
    .bn-data {
        font-size: min(max(4vh, 0px), 36px);
        margin-bottom: 2.77vh;
        border-radius: 40px;
        padding: 15px 40px
    }

    .bn-data .number .txt {
        flex: 0 0 100%
    }

    .bn-data .number .show {
        font-size: min(max(9vh, 0px), 75px)
    }
}

.bn-join {
    color: #0d4ea3;
    font-weight: 700;
    text-align: center;
    line-height: 1.2
}

@media only screen and (max-width: 767px) {
    .bn-join {
        font-size: min(max(3vh, 0px), 16px);
        text-align: center
    }

    .bn-join .tit {
        font-size: min(max(6vh, 0px), 30px)
    }
}

@media only screen and (min-width: 768px) {
    .bn-join {
        font-size: min(max(3vh, 0px), 24px)
    }

    .bn-join .tit {
        font-size: min(max(6vh, 0px), 54px)
    }
}

.bn-right-lottie {
    flex: 1 1 100%;
    height: min(max(62vh, 0px), 568px);
    position: relative
}

.bn-right-lottie .view {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: center
}

.bn-right-lottie .view img {
    max-width: 100%;
    max-height: 100%
}

@media only screen and (max-width: 991px) {
    .bn-right-lottie {
        margin-bottom: 2vh
    }
}

.bn-city-scroll {
    position: absolute;
    width: 100%;
    left: 0;
    top: 0
}

.bn-city-scroll .view,
.bn-city-scroll .view1 {
    position: absolute;
    width: max-content;
    left: 0;
    bottom: 0;
    display: flex;
    align-items: center
}

.bn-city-scroll .view img,
.bn-city-scroll .view1 img {
    max-height: 100%
}

.bn-city-scroll .round {
    width: max-content;
    height: 100%;
    display: flex;
    align-items: center
}

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

    .bn-city-scroll .view,
    .bn-city-scroll .view1 {
        height: 106px
    }

    .bn-city-scroll .view .round {
        animation: bn-city-scrol 50s linear infinite
    }

    .bn-city-scroll .view1 .round {
        animation: bn-city-scrol 55s linear infinite
    }
}

@media only screen and (min-width: 992px) {

    .bn-city-scroll .view,
    .bn-city-scroll .view1 {
        height: 215px
    }

    .bn-city-scroll .view .round {
        animation: bn-city-scrol 50s linear infinite
    }

    .bn-city-scroll .view1 .round {
        animation: bn-city-scrol 55s linear infinite
    }
}

.col-gr,
.heightlight {
    color: #d7f238
}

@media only screen and (max-width: 767px) {
    .heightlight {
        font-size: min(max(5vh, 0px), 18px)
    }
}

@media only screen and (min-width: 768px) {
    .heightlight {
        font-size: min(max(5vh, 0px), 42px)
    }
}

@media only screen and (max-width: 767px) {
    .main-tit {
        font-size: min(max(8vh, 0px), 30px);
        line-height: 1.5
    }
}

@media only screen and (min-width: 768px) {
    .main-tit {
        font-size: min(max(8vh, 0px), 50px);
        line-height: 1.5
    }
}

@media only screen and (min-width: 1280px) {
    .main-tit {
        font-size: min(max(8vh, 0px), 65px);
        line-height: 1.5
    }
}

.active-part2-div {
    position: relative;
    height: 500vh
}

.active-part2-div .active-part2 {
    top: 0;
    width: 100%;
    height: 100vh;
    color: #fff;
    font-weight: 700;
    overflow: hidden;
    position: sticky
}

.active-part2-div .active-part2 .fix-active2-bg {
    position: fixed;
    width: 100%;
    height: 100vh;
    z-index: 1;
    top: 0;
    left: 0
}

.active-part2-div .active-part2 .main {
    width: 100%
}

.active-part2-div .active-part2 .icon-tit {
    position: relative
}

.active-part2-div .active-part2 .icon-tit .icon {
    border-radius: 50%;
    background: url(../img/icon_tit.png) 50% 50% no-repeat;
    background-size: contain
}

.active-part2-div .active-part2 .icon-tit .icon:after {
    display: block;
    content: "";
    width: 100%;
    height: 100%
}

.active-part2-div .active-part2 .note {
    color: #cbe1f2;
    font-weight: 400
}

@media only screen and (max-width: 767px) {
    .active-part2-div .active-part2 {
        font-size: min(max(4vh, 0px), 15px);
        line-height: 1.5
    }

    .active-part2-div .active-part2 .fix-active2-bg {
        background-image: url(../img/part2_bg_mb.jpg);
        background-size: cover;
        background-position: 50% 50%;
        background-repeat: no-repeat
    }

    .active-part2-div .active-part2 .main {
        padding-left: 30px;
        padding-right: 30px
    }

    .active-part2-div .active-part2 .icon-tit {
        display: flex;
        align-items: center;
        line-height: 1.5
    }

    .active-part2-div .active-part2 .icon-tit .icon {
        width: 70px;
        height: 70px;
        margin-right: 15px
    }

    .active-part2-div .active-part2 .note {
        font-size: 12px;
        padding-top: 2.7vh
    }
}

@media only screen and (min-width: 768px) {
    .active-part2-div .active-part2 {
        font-size: min(max(4vh, 0px), 30px);
        line-height: 1.5
    }

    .active-part2-div .active-part2 .fix-active2-bg {
        background: url(../img/part2_bg.jpg) 50% 50% no-repeat;
        background-size: cover
    }

    .active-part2-div .active-part2 .main {
        padding-left: 30px;
        padding-right: 30px
    }

    .active-part2-div .active-part2 .icon-tit {
        padding-left: 130px;
        line-height: 100px
    }

    .active-part2-div .active-part2 .icon-tit .icon {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        left: 0;
        width: 100px;
        height: 100px;
        background: url(../img/icon_tit.png) 50% 50% no-repeat;
        background-size: contain
    }

    .active-part2-div .active-part2 .note {
        font-size: 18px;
        padding-top: 2.7vh
    }
}

@media only screen and (min-width: 1440px) and (min-height: 700px) {
    .active-part2-div .active-part2 .icon-tit {
        padding-left: 170px;
        line-height: 140px
    }

    .active-part2-div .active-part2 .icon-tit .icon {
        width: 140px;
        height: 140px
    }
}

@media only screen and (min-width: 1440px) {
    .active-part2-div .active-part2 .main {
        padding-left: 0;
        padding-right: 0
    }
}

@media only screen and (min-width: 1600px) {
    .active-part2-div .active-part2 .icon-tit {
        padding-left: 0;
        line-height: 1.5
    }

    .active-part2-div .active-part2 .icon-tit .icon {
        left: -180px
    }
}

.content-type1 {
    width: 100%;
    height: 100vh;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0;
    -khtml-opacity: 0;
    z-index: 5
}

.content-type1.on {
    animation: alpha-1 .5s forwards ease-in-out
}

.content-type1 .viewbox {
    width: 100%;
    height: 100%;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column
}

.content-type1 .cloud {
    z-index: 5;
    position: absolute;
    animation: cloud 3s linear infinite
}

.content-type1 .link {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 2
}

.content-type1 .txt {
    position: absolute;
    font-weight: 700;
    color: #333;
    text-align: left
}

.content-type1 .txt span {
    display: block;
    color: #85c134;
    font-family: Ubuntu, sans-serif;
    text-transform: uppercase
}

.content-type1 .play-btn {
    border-radius: 50%;
    position: absolute
}

.content-type1 .play-btn:before {
    content: "";
    position: absolute;
    z-index: 2;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0
}

.content-type1 .play-btn:after {
    content: "";
    position: absolute;
    border-radius: 50%;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1
}

.content-type1 .pic {
    position: absolute
}

.content-type1 .pic img {
    max-width: 100%
}

@media only screen and (max-width: 767px) {
    .content-type1 {
        padding-left: 30px;
        padding-right: 30px;
        font-size: min(max(4vh, 0px), 16px)
    }

    .content-type1 h2 {
        margin-bottom: 15px
    }

    .content-type1 .viewbox {
        padding: 0 20px
    }

    .content-type1 .cloud {
        top: 90px;
        left: 20px;
        width: 167px;
        height: 85px;
        background: url(../img/cloud_mb.png) 50% 50% no-repeat;
        background-size: contain
    }

    .content-type1 .txt {
        width: calc(100% - 90px);
        left: 55px;
        bottom: 10px;
        padding: 0 5px;
        font-size: 12px
    }

    .content-type1 .play-btn {
        width: 25px;
        height: 25px;
        right: 10px;
        bottom: 10px
    }

    .content-type1 .play-btn:before {
        background: url(../img/play_mb.png) 50% 50% no-repeat;
        background-size: 7px auto
    }

    .content-type1 .play-btn:after {
        width: calc(100% - 4px);
        height: calc(100% - 4px);
        border: 2px solid #41BDE9
    }

    .content-type1 .pic {
        bottom: 10px;
        left: 10px;
        width: 45px;
        height: 45px
    }
}

@media only screen and (min-width: 768px) {
    .content-type1 {
        padding-left: 30px;
        padding-right: 30px
    }

    .content-type1 .viewbox {
        text-align: center
    }

    .content-type1 h2 {
        margin-bottom: 15px
    }

    .content-type1 .cloud {
        top: 100px;
        left: 30px;
        width: 242px;
        height: 123px;
        background: url(../img/cloud.png) 50% 50% no-repeat;
        background-size: contain
    }

    .content-type1 .txt {
        width: calc(100% - 125px);
        left: 75px;
        bottom: 10px;
        padding: 0 10px;
        font-size: 18px
    }

    .content-type1 .play-btn {
        width: 40px;
        height: 40px;
        right: 10px;
        bottom: 10px
    }

    .content-type1 .play-btn:before {
        background: url(../img/play.png) 50% 50% no-repeat;
        background-size: 10px auto
    }

    .content-type1 .play-btn:after {
        width: calc(100% - 6px);
        height: calc(100% - 6px);
        border: 3px solid #41BDE9
    }

    .content-type1 .pic {
        bottom: 10px;
        left: 10px;
        width: 65px;
        height: 65px
    }
}

@media only screen and (min-width: 992px) {
    .content-type1 .cloud {
        top: 120px;
        left: 30px
    }

    .content-type1 .cloud:hover .play-btn:before {
        background: url(../img/play_s.png) 50% 50% no-repeat;
        background-size: 10px auto
    }

    .content-type1 .cloud:hover .play-btn:after {
        background: #fabe00;
        border-color: #fabe00
    }
}

@media only screen and (min-width: 1440px) and (min-height: 700px) {
    .content-type1 .cloud {
        top: 200px
    }
}

@media only screen and (min-width: 1440px) {
    .content-type1 .cloud {
        left: 75px
    }
}

.content-type2 {
    width: 100%;
    height: 100vh;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 5
}

.content-type2.on .icon-tit {
    animation: move-down .5s forwards ease-in-out
}

.content-type2.on .des {
    animation: move-down .5s .3s forwards ease-in-out
}

.content-type2.on .old-people-chart {
    animation: move-down .5s .6s forwards ease-in-out
}

.content-type2 .icon-tit,
.content-type2 .des,
.content-type2 .old-people-chart {
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0;
    -khtml-opacity: 0;
    transform: translateY(-15px)
}

.content-type2 .wrapper {
    width: 100%;
    height: 100%
}

@media only screen and (max-width: 767px) {
    .content-type2 {
        padding-top: 80px
    }

    .content-type2 h2 {
        margin-bottom: 15px
    }

    .content-type2 .icon-tit .icon:after {
        background: url(../img/part2_icon1.png) 50% 50% no-repeat;
        background-size: 42px auto
    }

    .content-type2 .des {
        margin-bottom: 8.3vh
    }
}

@media only screen and (min-width: 768px) {
    .content-type2 .wrapper {
        display: flex;
        align-items: center;
        justify-content: center
    }

    .content-type2 h2 {
        margin-bottom: 15px;
        line-height: 140px
    }

    .content-type2 .icon-tit .icon:after {
        background: url(../img/part2_icon1.png) 50% 50% no-repeat;
        background-size: 51.6px auto
    }

    .content-type2 .des {
        margin-bottom: 8.3vh
    }
}

@media only screen and (min-width: 1440px) and (min-height: 700px) {
    .content-type2 .icon-tit .icon:after {
        background: url(../img/part2_icon1.png) 50% 50% no-repeat;
        background-size: 86px auto
    }
}

@media only screen and (min-width: 1440px) {
    .content-type2 h2 {
        line-height: 1.5
    }
}

.old-people-chart {
    display: flex
}

.old-people-chart .item {
    background: url(../img/yang.png) 50% 50% no-repeat;
    background-size: contain
}

.old-people-chart .item:last-child {
    margin-right: 0
}

.old-people-chart .older {
    background: url(../img/older.png) 50% 50% no-repeat;
    background-size: contain
}

@media only screen and (max-width: 767px) {
    .old-people-chart {
        justify-content: space-between;
        padding: 0 20px
    }

    .old-people-chart .item {
        width: 46px;
        height: 53px
    }

    .old-people-chart .older {
        width: 53px;
        height: 53px
    }
}

@media only screen and (min-width: 768px) {
    .old-people-chart .item {
        width: 72px;
        height: 82.8px;
        margin-right: 20px
    }

    .old-people-chart .older {
        width: 82.8px;
        height: 82.8px;
        background: url(../img/older.png) 50% 50% no-repeat;
        background-size: contain
    }
}

@media only screen and (min-width: 1440px) and (min-height: 700px) {
    .old-people-chart .item {
        width: 120px;
        height: 138px;
        margin-right: 35px
    }

    .old-people-chart .older {
        width: 138px;
        height: 138px
    }
}

.content-type3 {
    width: 100%;
    height: 100vh;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 5
}

.content-type3.on .icon-tit {
    animation: move-down .5s forwards ease-in-out
}

.content-type3.on .des {
    animation: move-down .5s .3s forwards ease-in-out
}

.content-type3.on .data-show,
.content-type3.on .note {
    animation: move-down .5s .6s forwards ease-in-out
}

.content-type3 .icon-tit,
.content-type3 .des,
.content-type3 .data-show,
.content-type3 .note {
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0;
    -khtml-opacity: 0;
    transform: translateY(-15px)
}

.content-type3 .wrapper {
    width: 100%;
    height: 100%
}

.content-type3 .main {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 100%;
    height: 100%
}

.content-type3 .data-show {
    flex: 1 1 auto;
    position: relative
}

.content-type3 .data-show:after,
.content-type3 .data-show:before {
    content: "";
    position: absolute;
    top: 0;
    height: 100%
}

.content-type3 .des {
    padding-bottom: 1vh
}

@media only screen and (max-width: 767px) {
    .content-type3 {
        padding-top: 80px
    }

    .content-type3 h2 {
        margin-bottom: 15px
    }

    .content-type3 .icon-tit .icon:after {
        background: url(../img/part2_icon2.png) 50% 50% no-repeat;
        background-size: 37px auto
    }

    .content-type3 .des {
        margin-bottom: 2.7vh
    }

    .content-type3 .data-show {
        width: 100%;
        max-height: 200px
    }

    .content-type3 .data-show:after {
        width: 50%;
        left: 0;
        background: url(../img/circle_left_mb.png) 0 50% no-repeat;
        background-size: contain
    }

    .content-type3 .data-show:before {
        width: 50%;
        right: 0;
        background: url(../img/circle_right_mb.png) 0 50% no-repeat;
        background-size: contain
    }
}

@media only screen and (min-width: 768px) {
    .content-type3 .wrapper {
        display: flex;
        align-items: center;
        justify-content: center;
        padding-top: 3vh;
        padding-bottom: 3vh
    }

    .content-type3 h2 {
        margin-bottom: 15px
    }

    .content-type3 .icon-tit .icon:after {
        background: url(../img/part2_icon2.png) 50% 50% no-repeat;
        background-size: 45px auto
    }

    .content-type3 .data-show {
        width: 750px;
        max-height: 380px;
        padding-left: 170px
    }

    .content-type3 .data-show:after {
        width: 50%;
        left: 0;
        background: url(../img/circle_left.png) 0 50% no-repeat;
        background-size: contain
    }

    .content-type3 .data-show:before {
        width: 50%;
        right: 0;
        background: url(../img/circle_right.png) 0 50% no-repeat;
        background-size: contain
    }
}

@media only screen and (min-width: 992px) {
    .content-type3 {
        padding-top: 110px
    }
}

@media only screen and (min-width: 1440px) and (min-height: 700px) {
    .content-type3 .icon-tit .icon:after {
        background: url(../img/part2_icon2.png) 50% 50% no-repeat;
        background-size: 75px auto
    }
}

.circle-chart {
    position: relative;
    height: 100%
}

.circle-chart.on .c-02,
.circle-chart.on .c-03,
.circle-chart.on .c-04,
.circle-chart.on .c-05,
.circle-chart.on .c-06,
.circle-chart.on .c-07,
.circle-chart.on .c-08,
.circle-chart.on .c-09 {
    animation: circle .5s forwards
}

.circle-chart.on .c-0 {
    animation: circle .5s .3s forwards
}

.circle-chart .view {
    position: absolute;
    height: 100%;
    top: 0;
    left: 0
}

.circle-chart .item {
    position: absolute;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 1
}

.circle-chart .item:nth-child(1) {
    z-index: 2
}

.circle-chart .item.c-01 {
    position: relative
}

.circle-chart .item img {
    max-width: 100%;
    max-height: 100%;
    position: relative;
    z-index: 10
}

.circle-chart .txt {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #fff;
    font-weight: 700;
    line-height: 1;
    text-align: center
}

@media only screen and (max-width: 767px) {
    .circle-chart {
        max-width: 168px;
        max-height: 168px;
        margin: 0 auto
    }

    .circle-chart .txt {
        font-size: min(max(6vh, 0px), 12px)
    }

    .circle-chart .txt p:nth-child(1) {
        font-size: min(max(8vh, 0px), 30px);
        font-family: Ubuntu, sans-serif
    }

    .circle-chart .txt p:nth-child(1) span {
        font-size: min(max(7vh, 0px), 18px)
    }
}

@media only screen and (min-width: 768px) {
    .circle-chart {
        max-width: 336px;
        max-height: 336px
    }

    .circle-chart .txt {
        font-size: min(max(6vh, 0px), 24px)
    }

    .circle-chart .txt p:nth-child(1) {
        font-size: min(max(8vh, 0px), 60px);
        font-family: Ubuntu, sans-serif
    }

    .circle-chart .txt p:nth-child(1) span {
        font-size: min(max(7vh, 0px), 36px)
    }
}

@media only screen and (min-width: 992px) {
    .circle-chart .txt {
        font-size: min(max(6vh, 0px), 13px)
    }

    .circle-chart .txt p:nth-child(1) {
        font-size: min(max(8vh, 0px), 24px)
    }

    .circle-chart .txt p:nth-child(1) span {
        font-size: min(max(7vh, 0px), 20px)
    }
}

@media only screen and (min-width: 992px) and (min-height: 700px) {
    .circle-chart .txt {
        font-size: min(max(6vh, 0px), 20px)
    }

    .circle-chart .txt p:nth-child(1) {
        font-size: min(max(8vh, 0px), 40px)
    }

    .circle-chart .txt p:nth-child(1) span {
        font-size: min(max(7vh, 0px), 34px)
    }
}

@media only screen and (min-width: 1280px) and (min-height: 700px) {
    .circle-chart .txt {
        font-size: min(max(6vh, 0px), 24px)
    }

    .circle-chart .txt p:nth-child(1) {
        font-size: min(max(8vh, 0px), 60px)
    }

    .circle-chart .txt p:nth-child(1) span {
        font-size: min(max(7vh, 0px), 36px)
    }
}

.content-type4 {
    width: 100%;
    height: 100vh;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 5
}

.content-type4.on .icon-tit {
    animation: move-down .5s forwards ease-in-out
}

.content-type4.on .des {
    animation: move-down .5s .3s forwards ease-in-out
}

.content-type4.on .lottie,
.content-type4.on .note {
    animation: move-down .5s .6s forwards ease-in-out
}

.content-type4 .icon-tit,
.content-type4 .des,
.content-type4 .lottie,
.content-type4 .note {
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0;
    -khtml-opacity: 0;
    transform: translateY(-15px)
}

.content-type4 .wrapper,
.content-type4 .main {
    width: 100%;
    height: 100%
}

.content-type4 .lottie {
    position: relative
}

.content-type4 .lottie:after {
    content: "";
    display: block;
    position: relative;
    width: 100%;
    padding-top: 127%;
    top: 0;
    left: 0
}

.content-type4 .lottie .view {
    top: 0;
    left: 0;
    position: absolute;
    width: 100%;
    height: 100%
}

.content-type4 .lottie .view img {
    max-width: 100%;
    max-height: 100%
}

@media only screen and (max-width: 767px) {
    .content-type4 {
        padding-top: 70px
    }

    .content-type4 .main {
        position: relative
    }

    .content-type4 .p1 {
        margin-bottom: 3vh
    }

    .content-type4 .des {
        padding-top: 3vh;
        margin-bottom: 3vh
    }

    .content-type4 .lottie {
        width: 160px
    }

    .content-type4 .icon-tit .icon:after {
        background: url(../img/part2_icon3.png) 50% 50% no-repeat;
        background-size: 37px auto
    }

    .content-type4 .note {
        position: absolute;
        left: 0;
        bottom: 2.7vh;
        width: 100%;
        padding: 0 20px
    }
}

@media only screen and (min-width: 768px) {
    .content-type4 .main {
        display: flex;
        justify-content: center;
        flex-direction: column
    }

    .content-type4 .boxview {
        flex: 0 0 auto
    }

    .content-type4 .p1 {
        margin-bottom: 5vh
    }

    .content-type4 .des {
        flex: 0 0 auto;
        padding-right: 60px;
        padding-top: 5vh;
        margin-bottom: 30px
    }

    .content-type4 .lottie {
        width: 50%;
        margin: 0 auto
    }

    .content-type4 .icon-tit .icon:after {
        background: url(../img/part2_icon3.png) 50% 50% no-repeat;
        background-size: 45px auto
    }
}

@media only screen and (min-width: 992px) {
    .content-type4 {
        padding-top: 110px
    }

    .content-type4 .boxview {
        display: flex
    }

    .content-type4 .lottie {
        flex: 0 0 320px;
        width: 320px;
        margin: inherit
    }
}

@media only screen and (min-width: 1440px) and (min-height: 700px) {
    .content-type4 .icon-tit .icon:after {
        background: url(../img/part2_icon3.png) 50% 50% no-repeat;
        background-size: 75px auto
    }
}

.content-type5 {
    width: 100%;
    height: 100vh;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 5
}

.content-type5.on .icon-tit {
    animation: move-down .5s forwards ease-in-out
}

.content-type5.on .des {
    animation: move-down .5s .3s forwards ease-in-out
}

.content-type5.on .line-chart-box,
.content-type5.on .note {
    animation: move-down .5s .6s forwards ease-in-out
}

.content-type5 .icon-tit,
.content-type5 .des,
.content-type5 .line-chart-box,
.content-type5 .note {
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0;
    -khtml-opacity: 0;
    transform: translateY(-15px)
}

.content-type5 .main {
    height: 100%;
    position: relative
}

.content-type5 .note {
    position: absolute;
    left: 0;
    bottom: 2.7vh
}

@media only screen and (max-width: 767px) {
    .content-type5 {
        padding-top: 80px
    }

    .content-type5 h2 {
        margin-bottom: 2.7vh
    }

    .content-type5 .des {
        margin-bottom: 8vh
    }

    .content-type5 .icon-tit .icon:after {
        background: url(../img/part2_icon4.png) 50% 50% no-repeat;
        background-size: 41px auto
    }

    .content-type5 .note {
        padding: 0 20px
    }
}

@media only screen and (min-width: 768px) {
    .content-type5 .main {
        display: flex;
        flex-direction: column;
        justify-content: center
    }

    .content-type5 h2 {
        margin-bottom: 2.7vh
    }

    .content-type5 .des {
        margin-bottom: 8vh
    }

    .content-type5 .icon-tit .icon:after {
        background: url(../img/part2_icon4.png) 50% 50% no-repeat;
        background-size: 49.8px auto
    }

    .content-type5 .note {
        padding: 0 30px
    }
}

@media only screen and (min-width: 1440px) and (min-height: 700px) {
    .content-type5 .icon-tit .icon:after {
        background: url(../img/part2_icon4.png) 50% 50% no-repeat;
        background-size: 83px auto
    }
}

@media only screen and (min-width: 1440px) {
    .content-type5 .note {
        padding: 0
    }
}

.line-chart-box.on .start:after {
    animation: height-100 .5s .5s forwards ease-in-out
}

.line-chart-box.on .start p {
    animation: move-down .5s .8s forwards ease-in-out
}

.line-chart-box.on .end:after {
    animation: height-100 .5s 1.1s forwards ease-in-out
}

.line-chart-box.on .end p {
    animation: move-down .5s 1.1s forwards ease-in-out
}

.line-chart-box.on .mid:after {
    animation: width-100 .5s .8s forwards ease-in-out
}

.line-chart-box.on .data-show {
    animation: move-down-1 .5s 1.1s forwards ease-in-out
}

.line-chart-box .line1 {
    display: flex;
    align-items: center
}

.line-chart-box .start,
.line-chart-box .end,
.line-chart-box .mid {
    position: relative
}

.line-chart-box .start:after,
.line-chart-box .end:after,
.line-chart-box .mid:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0
}

.line-chart-box .start:after,
.line-chart-box .end:after {
    width: 100%
}

.line-chart-box .mid:after {
    height: 100%
}

.line-chart-box .line2 {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between
}

.line-chart-box .line2 .start:after,
.line-chart-box .line2 .end:after,
.line-chart-box .line2 .mid:after {
    background: #fff
}

.line-chart-box .line2 p {
    position: absolute;
    height: 0;
    width: 100%;
    left: 0;
    bottom: 0;
    color: #fff;
    font-weight: 700;
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0;
    -khtml-opacity: 0;
    transform: translateY(-15px)
}

.line-chart-box .line2 p span {
    width: max-content;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%)
}

.line-chart-box .left-part,
.line-chart-box .right-part {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between
}

.line-chart-box .left-part .start:after,
.line-chart-box .left-part .end:after,
.line-chart-box .left-part .mid:after {
    background: #d7f238
}

.line-chart-box .left-part .data-show {
    background: #85c134
}

.line-chart-box .right-part .start:after,
.line-chart-box .right-part .end:after,
.line-chart-box .right-part .mid:after {
    background: #ff7934
}

.line-chart-box .right-part .data-show {
    background: #ff7934
}

.line-chart-box .data-show {
    z-index: 2;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -55%);
    color: #fff;
    font-weight: 700;
    text-align: center;
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0;
    -khtml-opacity: 0
}

.line-chart-box .data-show:before {
    position: absolute;
    left: 0;
    content: "";
    width: 100%
}

.line-chart-box .data-show {
    line-height: 1.2
}

.line-chart-box .data-show span {
    display: block
}

@media only screen and (max-width: 767px) {
    .line-chart-box {
        width: 100%
    }

    .line-chart-box .line1 .start,
    .line-chart-box .line1 .end {
        width: 5px;
        height: 30px
    }

    .line-chart-box .line1 .mid {
        width: calc(100% - 10px)
    }

    .line-chart-box .line2 .start,
    .line-chart-box .line2 .end {
        width: 10px;
        height: 30px
    }

    .line-chart-box .line2 .mid {
        width: calc(100% - 20px)
    }

    .line-chart-box .mid {
        height: 4px
    }

    .line-chart-box .left-part {
        width: 70%;
        flex: 0 0 70%
    }

    .line-chart-box .left-part .data-show:before {
        background: url(../img/line_chart_1.png) 50% 50% no-repeat;
        background-size: 20px auto
    }

    .line-chart-box .right-part {
        width: 30%;
        flex: 0 0 30%
    }

    .line-chart-box .right-part .data-show:before {
        background: url(../img/line_chart_2.png) 50% 50% no-repeat;
        background-size: 22px auto
    }

    .line-chart-box .line1 {
        margin-bottom: 20px
    }

    .line-chart-box .data-show {
        width: 60px;
        font-size: 12px;
        padding: 33px 0 10px;
        border-radius: 5px
    }

    .line-chart-box .data-show:before {
        top: 10px;
        height: 24px
    }

    .line-chart-box .data-show span {
        font-size: 18px
    }
}

@media only screen and (min-width: 768px) {

    .line-chart-box .start,
    .line-chart-box .end {
        width: 20px;
        height: 53px
    }

    .line-chart-box .mid {
        width: calc(100% - 40px);
        height: 8px
    }

    .line-chart-box .left-part {
        width: 75%;
        flex: 0 0 75%
    }

    .line-chart-box .left-part .data-show:before {
        background: url(../img/line_chart_1.png) 50% 50% no-repeat;
        background-size: 24.6px auto
    }

    .line-chart-box .right-part {
        width: 25%;
        flex: 1 1 auto
    }

    .line-chart-box .right-part .data-show:before {
        background: url(../img/line_chart_2.png) 50% 50% no-repeat;
        background-size: 27px auto
    }

    .line-chart-box .line1 {
        margin-bottom: 20px
    }

    .line-chart-box .data-show {
        width: 80px;
        font-size: 16px;
        padding: 45px 0 5px;
        border-radius: 10px
    }

    .line-chart-box .data-show:before {
        top: 0;
        height: 42px
    }

    .line-chart-box .data-show span {
        font-size: 20px
    }
}

@media only screen and (min-width: 992px) {
    .line-chart-box {
        width: 600px
    }
}

@media only screen and (min-width: 1280px) {
    .line-chart-box {
        width: 760px
    }

    .line-chart-box .left-part .data-show:before {
        background: url(../img/line_chart_1.png) 50% 50% no-repeat;
        background-size: 41px auto
    }

    .line-chart-box .right-part .data-show:before {
        background: url(../img/line_chart_2.png) 50% 50% no-repeat;
        background-size: 45px auto
    }

    .line-chart-box .data-show {
        font-size: 18px;
        width: 110px;
        padding: 55px 0 10px
    }

    .line-chart-box .data-show:before {
        top: 10px;
        height: 42px
    }

    .line-chart-box .data-show span {
        font-size: 24px
    }
}

.active-part3 {
    width: 100%;
    height: 100vh;
    overflow: hidden;
    position: relative;
    background: #fff
}

.active-part3 .light-bg {
    z-index: 3
}

.active-part3.on .viewbox {
    animation: move-down .5s forwards ease-in-out
}

.active-part3 .main {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 2;
    background-color: #fff
}

.active-part3 .viewbox {
    position: relative;
    color: #0d4ea3;
    width: 100%;
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0;
    -khtml-opacity: 0;
    transform: translateY(-15px)
}

.active-part3 .viewbox:after,
.active-part3 .viewbox:before {
    content: "";
    position: absolute
}

.active-part3 .viewbox:after {
    background: url(../img/article_top.png) 50% 50% no-repeat;
    background-size: contain
}

.active-part3 .viewbox:before {
    background: url(../img/article_bt.png) 50% 50% no-repeat;
    background-size: contain
}

@media only screen and (max-width: 767px) {
    .active-part3 {
        font-size: min(max(4vh, 0px), 15px);
        line-height: 1.5
    }

    .active-part3 .main {
        padding-left: 20px;
        padding-right: 20px;
        max-width: 420px
    }

    .active-part3 .viewbox {
        padding-top: 51px;
        padding-bottom: 51px
    }

    .active-part3 .viewbox:after,
    .active-part3 .viewbox:before {
        width: 44px;
        height: 31px
    }

    .active-part3 .viewbox:after {
        left: 0;
        top: 0
    }

    .active-part3 .viewbox:before {
        right: 0;
        bottom: 0
    }

    .active-part3 h2 {
        margin-bottom: 3vh;
        text-align: center
    }
}

@media only screen and (min-width: 768px) {
    .active-part3 {
        font-size: min(max(4vh, 0px), 30px);
        line-height: 1.5
    }

    .active-part3 .main {
        padding-left: 30px;
        padding-right: 30px
    }

    .active-part3 .viewbox {
        text-align: center
    }

    .active-part3 .viewbox:after,
    .active-part3 .viewbox:before {
        width: 88px;
        height: 63px
    }

    .active-part3 .viewbox:after {
        left: 0;
        top: -60px
    }

    .active-part3 .viewbox:before {
        right: 0;
        bottom: -60px
    }

    .active-part3 h2 {
        margin-bottom: 3vh
    }
}

@media only screen and (min-width: 992px) {
    .active-part3 .light-bg .viewbg {
        padding-top: 45%
    }
}

@media only screen and (min-width: 1440px) {
    .active-part3 .main {
        padding-left: 0;
        padding-right: 0
    }

    .active-part3 .viewbox:after {
        top: 0
    }

    .active-part3 .viewbox:before {
        bottom: 0
    }
}

.active-part4 {
    width: 100%;
    height: 300vh;
    position: relative;
    top: 0;
    color: #0d4ea3;
    background: linear-gradient(45deg, #66b7f7, #1c7fff)
}

.active-part4 .wrapper {
    top: 0;
    width: 100%;
    height: 100vh;
    position: sticky
}

.active-part4 .main-content {
    width: 100%;
    height: 100vh;
    max-height: 900px;
    max-width: 1280px;
    margin-left: auto;
    margin-right: auto;
    position: relative
}

.active-part4 .part1,
.active-part4 .part2,
.active-part4 .part3 {
    position: absolute;
    top: 0;
    z-index: 2
}

.active-part4 .part1,
.active-part4 .part2 {
    width: 100%;
    height: 100%;
    left: 0
}

.active-part4 .part1 {
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0;
    -khtml-opacity: 0;
    z-index: 1
}

.active-part4 .part2 {
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0;
    -khtml-opacity: 0;
    z-index: 2
}

.active-part4 .part3 {
    overflow: hidden;
    width: 100%;
    height: 100vh;
    top: 0;
    left: 50%;
    transform: translate(-50%);
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0;
    -khtml-opacity: 0;
    z-index: 1
}

.active-part4 .part3 .main-tit,
.active-part4 .content-show {
    position: relative;
    z-index: 2
}

.active-part4 .circle-content {
    border-radius: 50%;
    text-align: center
}

.active-part4 .circle-pic {
    z-index: 1;
    aspect-ratio: 1/1
}

.active-part4 .circle-pic img {
    max-width: 100%;
    max-height: 100%
}

.active-part4 .tag-bt {
    position: fixed;
    width: 100vw;
    height: 100vh;
    top: 0;
    left: 0;
    overflow: hidden
}

.active-part4 .tag-bt .view {
    position: absolute
}

.active-part4 .circle-1,
.active-part4 .circle-2 {
    aspect-ratio: 1/1;
    position: absolute;
    border-radius: 50%;
    background: #fff;
    z-index: 1
}

.active-part4 .col-gr {
    font-weight: 700;
    color: #85c134
}

@media only screen and (max-width: 991px) {
    .active-part4 {
        font-size: min(max(4vh, 0px), 15px);
        line-height: 1.5
    }

    .active-part4 .light-bg {
        transform: translate(20%)
    }

    .active-part4 .main-tit {
        font-size: min(max(8vh, 0px), 30px);
        line-height: 1.5
    }

    .active-part4 .part3 .main-content {
        padding: 30vh 60px 0
    }

    .active-part4 .circle-1 {
        left: 50%;
        margin-left: -50vw;
        top: 50%;
        transform: translateY(-30vh)
    }

    .active-part4 .circle-2 {
        left: 50%;
        margin-left: -10vw;
        top: 50%;
        transform: translateY(-35vh)
    }
}

@media only screen and (max-width: 767px) {
    .active-part4 .main-content {
        padding-left: 20px;
        padding-right: 20px;
        max-width: 420px
    }

    .active-part4 .part1,
    .active-part4 .part2 {
        padding: 90px 20px 0
    }

    .active-part4 .part1 .circle-content .showbox {
        padding: 10vh 0 30px
    }

    .active-part4 .part2 .circle-content .showbox {
        padding: 15vh 0 30px
    }

    .active-part4 .part3 .main-content {
        padding: min(max(30vh, 0px), 240px) 20px 0 20px
    }

    .active-part4 .part3 .main-tit {
        text-align: center;
        padding: 0 20px
    }

    .active-part4 .part3 .des br {
        display: none
    }

    .active-part4 .part3 .circle-pic {
        margin-left: auto;
        margin-right: auto
    }

    .active-part4 .tag-bt .view {
        width: 116px;
        height: 122px;
        background: url(../img/part4_tag_mb.png) 50% 50% no-repeat;
        background-size: contain;
        right: 20px;
        bottom: 3vh
    }

    .active-part4 .circle-content {
        position: relative
    }

    .active-part4 .circle-content .mb-bg {
        position: absolute;
        width: calc(100% + 50px);
        aspect-ratio: 1/1;
        top: 0;
        left: 50%;
        transform: translate(-50%);
        background: #fff;
        border-radius: 50%;
        z-index: 1
    }

    .active-part4 .circle-content .showbox {
        position: relative;
        width: 100%;
        display: flex;
        flex-direction: column;
        align-items: center;
        z-index: 2
    }

    .active-part4 .main-tit {
        margin-bottom: 2vh
    }

    .active-part4 .circle-pic {
        position: relative;
        width: 180px
    }

    .active-part4 .circle-1,
    .active-part4 .circle-2 {
        width: 92vw
    }

    .active-part4 .circle-1 {
        left: 50%;
        margin-left: 0;
        top: 50%;
        transform: translate(-60vw, -30vh)
    }

    .active-part4 .circle-2 {
        right: 50%;
        left: auto;
        margin-left: 0;
        top: 50%;
        transform: translate(65vw, -35vh)
    }
}

@media only screen and (min-width: 768px) {
    .active-part4 .tag-bt .view {
        width: 233px;
        height: 245px;
        background: url(../img/part4_tag.png) 50% 50% no-repeat;
        background-size: contain;
        right: 40px;
        bottom: 60px
    }

    .active-part4 .circle-content {
        position: absolute;
        aspect-ratio: 1/1;
        left: 0;
        top: -10vh;
        display: flex;
        align-items: center;
        justify-content: center;
        background: #fff;
        height: 100vh;
        max-height: 600px
    }

    .active-part4 .showbox {
        padding: 0 60px
    }

    .active-part4 .main-tit {
        margin-bottom: 3vh
    }

    .active-part4 .part1 .circle-pic,
    .active-part4 .part2 .circle-pic {
        position: absolute;
        right: 10%;
        top: 40%
    }

    .active-part4 .part3 .main-content {
        display: flex;
        align-items: center;
        flex-direction: column
    }

    .active-part4 .circle-pic {
        height: 36vh;
        max-height: 240px
    }

    .active-part4 .circle-1,
    .active-part4 .circle-2 {
        height: 500px
    }

    .active-part4 .content-show {
        display: flex
    }
}

@media only screen and (min-width: 992px) {
    .active-part4 {
        font-size: min(max(4vh, 0px), 24px);
        line-height: 1.5
    }

    .active-part4 .light-bg {
        transform: translate(-20%)
    }

    .active-part4 .light-bg .viewbg {
        padding-top: 50%
    }

    .active-part4 .tag-bt .view {
        right: 30px;
        bottom: 30px
    }

    .active-part4 .circle-content {
        max-height: 700px
    }

    .active-part4 .showbox {
        padding: 0
    }

    .active-part4 .part1 .circle-pic,
    .active-part4 .part2 .circle-pic {
        right: auto;
        left: 50%;
        margin-left: 5%;
        bottom: 10vh;
        top: auto
    }

    .active-part4 .part3 .main-content {
        padding: min(max(30vh, 0px), 300px) 60px 0 95px
    }

    .active-part4 .circle-pic {
        height: 240px
    }

    .active-part4 .circle-1,
    .active-part4 .circle-2 {
        height: 650px;
        max-height: 93vh
    }

    .active-part4 .circle-1 {
        left: 50%;
        margin-left: -40vw;
        top: 10vh
    }

    .active-part4 .circle-2 {
        left: 50%;
        margin-left: -15vw;
        top: 5vh
    }
}

@media only screen and (min-width: 1280px) {
    .active-part4 {
        font-size: min(max(4vh, 0px), 30px)
    }

    .active-part4 .circle-content {
        max-height: 890px
    }

    .active-part4 .showbox {
        padding: 0
    }

    .active-part4 .part3 .main-content {
        padding: 30vh 15px 0 60px
    }

    .active-part4 .circle-1,
    .active-part4 .circle-2 {
        height: 700px
    }

    .active-part4 .circle-1 {
        top: 15vh
    }

    .active-part4 .circle-2 {
        top: 5vh
    }

    .active-part4 .part1 .circle-pic,
    .active-part4 .part2 .circle-pic {
        margin-left: 15%
    }
}

@media only screen and (min-width: 1440px) {
    .active-part4 .tag-bt .view {
        right: 40px;
        bottom: 60px
    }

    .active-part4 .part3 .main-content {
        padding: 30vh 15px 0 150px
    }

    .active-part4 .circle-1,
    .active-part4 .circle-2 {
        height: 765px
    }
}

@media only screen and (min-width: 1600px) {
    .active-part4 .circle-pic {
        height: 43vh;
        max-height: 412px
    }

    .active-part4 .circle-1 {
        left: 55px;
        margin-left: 0
    }

    .active-part4 .circle-2 {
        left: auto;
        right: 60px;
        margin-left: 0
    }

    .active-part4 .part1 .circle-pic,
    .active-part4 .part2 .circle-pic {
        left: auto;
        right: 0;
        margin-left: 0
    }
}

.active-part5 {
    background: #e8f4ff;
    overflow: hidden
}

.active-part5 .main-tit {
    color: #0e56c2;
    display: flex;
    align-items: center
}

.active-part5 .icon {
    background: url(../img/icon_tit1.png) 50% 50% no-repeat;
    background-size: contain
}

.active-part5 .icon:after {
    content: "";
    width: 100%;
    height: 100%;
    display: block
}

.active-part5 .txt {
    color: #0e56c2;
    font-weight: 700
}

.active-part5 .group {
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0;
    -khtml-opacity: 0;
    transform: translateY(-15px)
}

.active-part5 .group.on {
    animation: move-down .5s forwards ease-in-out
}

.active-part5 .group:last-child {
    margin-bottom: 0
}

@media only screen and (max-width: 991px) {
    .active-part5 {
        padding-top: 160px;
        padding-bottom: 135px
    }

    .active-part5 .main {
        max-width: inherit;
        padding-left: 30px;
        padding-right: 30px
    }

    .active-part5 .group {
        margin-bottom: 35px
    }

    .active-part5 .titshow {
        margin-bottom: 20px
    }

    .active-part5 .txt {
        font-size: 24px;
        line-height: 48px
    }

    .active-part5 .main-tit {
        font-size: 54px;
        margin-bottom: 20px
    }

    .active-part5 .icon {
        width: 140px;
        height: 140px;
        margin-right: 20px
    }

    .active-part5 .type1:after {
        background: url(../img/list_icon1.png) 50% 50% no-repeat;
        background-size: 73px auto
    }

    .active-part5 .type2:after {
        background: url(../img/list_icon2.png) 50% 50% no-repeat;
        background-size: 74px auto
    }

    .active-part5 .type3:after {
        background: url(../img/list_icon3.png) 50% 50% no-repeat;
        background-size: 72px auto
    }

    .active-part5 .type4:after {
        background: url(../img/list_icon4.png) 50% 50% no-repeat;
        background-size: 66px auto
    }

    .active-part5 .type5:after {
        background: url(../img/list_icon5.png) 50% 50% no-repeat;
        background-size: 73px auto
    }
}

@media only screen and (max-width: 767px) {
    .active-part5 {
        padding-top: 35px;
        padding-bottom: 35px
    }

    .active-part5 .main {
        padding-right: 20px;
        padding-left: 20px
    }

    .active-part5 .txt {
        font-size: 15px;
        line-height: 24px
    }

    .active-part5 .main-tit {
        font-size: 27px
    }

    .active-part5 .icon {
        width: 70px;
        height: 70px;
        margin-right: 10px
    }

    .active-part5 .type1:after {
        background: url(../img/list_icon1.png) 50% 50% no-repeat;
        background-size: 36.5px auto
    }

    .active-part5 .type2:after {
        background: url(../img/list_icon2.png) 50% 50% no-repeat;
        background-size: 37px auto
    }

    .active-part5 .type3:after {
        background: url(../img/list_icon3.png) 50% 50% no-repeat;
        background-size: 36px auto
    }

    .active-part5 .type4:after {
        background: url(../img/list_icon4.png) 50% 50% no-repeat;
        background-size: 33px auto
    }

    .active-part5 .type5:after {
        background: url(../img/list_icon5.png) 50% 50% no-repeat;
        background-size: 36.5px auto
    }
}

@media only screen and (min-width: 992px) {
    .active-part5 {
        padding-top: 160px;
        padding-bottom: 135px
    }

    .active-part5 .main {
        padding-left: 30px;
        padding-right: 30px
    }

    .active-part5 .group {
        margin-bottom: 70px
    }

    .active-part5 .titshow {
        margin-bottom: 40px
    }

    .active-part5 .txt {
        flex: 1 1 auto;
        font-size: 24px;
        line-height: 48px
    }

    .active-part5 .main-tit {
        flex: 0 0 580px;
        font-size: 54px
    }

    .active-part5 .icon {
        width: 140px;
        height: 140px;
        margin-right: 20px
    }

    .active-part5 .type1:after {
        background: url(../img/list_icon1.png) 50% 50% no-repeat;
        background-size: 73px auto
    }

    .active-part5 .type2:after {
        background: url(../img/list_icon2.png) 50% 50% no-repeat;
        background-size: 74px auto
    }

    .active-part5 .type3:after {
        background: url(../img/list_icon3.png) 50% 50% no-repeat;
        background-size: 72px auto
    }

    .active-part5 .type4:after {
        background: url(../img/list_icon4.png) 50% 50% no-repeat;
        background-size: 66px auto
    }

    .active-part5 .type5:after {
        background: url(../img/list_icon5.png) 50% 50% no-repeat;
        background-size: 73px auto
    }
}

@media only screen and (min-width: 1440px) {
    .active-part5 .main {
        padding-left: 0;
        padding-right: 0
    }

    .active-part5 .titshow {
        display: flex;
        align-items: center;
        margin-bottom: 40px
    }
}

.list-show .item {
    background: #fff;
    overflow: hidden
}

.list-show .pic-show {
    position: relative
}

.list-show .pic-show img {
    display: block;
    max-width: 100%;
    position: relative;
    z-index: 1
}

.list-show .pic-show img.mb-style {
    display: none
}

.list-show .tag {
    position: absolute;
    top: 0;
    left: 0;
    color: #fff;
    font-weight: 700;
    z-index: 2;
    background: url(../img/list_tag.png) 50% 50% no-repeat;
    background-size: cover;
    text-align: center;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center
}

.list-show .tit {
    font-weight: 700;
    color: #555
}

.list-show button {
    position: absolute;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    background: url(../img/btn_bg.jpg) 50% 50% no-repeat;
    background-size: cover;
    left: 50%;
    transform: translate(-50%)
}

.list-show .fb-tool {
    position: absolute;
    color: #fff;
    font-weight: 700;
    text-align: center
}

.list-show .fb {
    cursor: pointer;
    border-radius: 50%;
    background: #fff
}

.list-show .fb:after {
    content: "";
    width: 100%;
    height: 100%;
    display: block
}

.list-show .info {
    position: relative
}

.list-show .tit span {
    display: block
}

.list-show .now {
    background: #357af0
}

.list-show .now .tit {
    color: #fff
}

.list-show .now button {
    display: none
}

.list-show .now .fb-tool {
    display: block
}

@media only screen and (max-width: 991px) {
    .list-show .pic-show {
        flex: 0 0 auto;
        height: 288px
    }

    .list-show .pic-show img {
        max-height: 100%
    }

    .list-show .pic-show img.mb-style {
        display: block
    }

    .list-show .pic-show img.pc-style {
        display: none
    }

    .list-show .item {
        display: flex;
        border-radius: 20px;
        margin-bottom: 30px
    }

    .list-show .item:last-child {
        margin-bottom: 0
    }

    .list-show .tag {
        width: 65px;
        height: 120px;
        font-size: 24px;
        padding: 0 15px
    }

    .list-show .info {
        flex: 1 1 auto;
        height: 288px;
        padding: 25px 30px
    }

    .list-show .tit {
        font-size: 24px;
        line-height: 35px
    }

    .list-show .tit span {
        font-size: 18px
    }

    .list-show button {
        bottom: 36px;
        width: 200px;
        height: 60px;
        border-radius: 30px
    }

    .list-show button span {
        line-height: 60px;
        font-size: 20px;
        background: url(../img/agree.png) right 50% no-repeat;
        background-size: 23px auto;
        padding-right: 35px
    }

    .list-show .fb-tool {
        display: none;
        left: 50%;
        transform: translate(-50%);
        bottom: 25px;
        font-size: 20px
    }

    .list-show .fb {
        width: 60px;
        height: 60px;
        margin: 0 auto 5px
    }

    .list-show .fb:after {
        background: url(../img/fb.png) 50% 50% no-repeat;
        background-size: 20px auto
    }
}

@media only screen and (max-width: 767px) {
    .list-show .item {
        border-radius: 10px;
        position: relative;
        padding-left: 155px
    }

    .list-show .pic-show {
        height: 100%;
        overflow: hidden;
        position: absolute;
        top: 0;
        left: 0;
        width: 155px
    }

    .list-show .pic-show img {
        height: 100%;
        width: auto;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        max-width: max-content
    }

    .list-show .info {
        height: auto;
        min-height: 144px;
        padding: 15px 15px 60px 20px
    }

    .list-show .tit {
        font-size: 13px;
        line-height: 22px;
        text-align: left
    }

    .list-show .tit br {
        display: none
    }

    .list-show .tit span {
        font-size: 12px;
        line-height: 1.2
    }

    .list-show button {
        width: calc(100% - 35px);
        height: 40px;
        left: 20px;
        transform: initial;
        bottom: 15px
    }

    .list-show button span {
        font-size: 13px;
        line-height: 40px;
        background: url(../img/agree.png) right 50% no-repeat;
        background-size: 20px auto;
        padding-right: 35px
    }

    .list-show .tag {
        width: 30px;
        height: 62px;
        font-size: 13px;
        padding: 0 5px
    }

    .list-show .fb-tool {
        display: none;
        left: 50%;
        transform: translate(-50%);
        bottom: 15px;
        font-size: 12px;
        width: 100%
    }

    .list-show .fb {
        width: 30px;
        height: 30px;
        margin: 0 auto 5px
    }

    .list-show .fb:after {
        background: url(../img/fb.png) 50% 50% no-repeat;
        background-size: 10px auto
    }
}

@media only screen and (min-width: 992px) {
    .list-show {
        display: flex
    }

    .list-show .item {
        flex: 0 0 calc(33.33% - 24px);
        margin-right: 36px;
        border-radius: 20px
    }

    .list-show .item:last-child {
        margin-right: 0
    }

    .list-show .tag {
        width: 65px;
        height: 120px;
        font-size: 24px;
        padding: 0 15px
    }

    .list-show .info {
        height: 250px;
        padding: 25px 30px
    }

    .list-show .tit {
        text-align: center;
        font-size: 24px;
        line-height: 35px
    }

    .list-show .tit span {
        font-size: 18px
    }

    .list-show button {
        bottom: 36px;
        width: 200px;
        height: 60px;
        border-radius: 30px
    }

    .list-show button span {
        line-height: 60px;
        font-size: 20px;
        background: url(../img/agree.png) right 50% no-repeat;
        background-size: 23px auto;
        padding-right: 35px
    }

    .list-show button:hover {
        background: #fabe00
    }

    .list-show .fb-tool {
        display: none;
        left: 50%;
        transform: translate(-50%);
        bottom: 25px;
        font-size: 20px
    }

    .list-show .fb {
        width: 60px;
        height: 60px;
        margin: 0 auto 5px
    }

    .list-show .fb:after {
        background: url(../img/fb.png) 50% 50% no-repeat;
        background-size: 20px auto
    }
}

.active-part6 {
    position: relative;
    color: #fff;
    font-weight: 700;
    text-align: center;
    background: #e8f4ff;
    z-index: 1
}

.active-part6:before {
    content: "";
    background: #e8f4ff;
    position: absolute;
    width: 100%;
    z-index: 1;
    top: 0;
    left: 0
}

.active-part6:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    background: url(../img/bg3.png) 50% 0 no-repeat;
    background-size: cover;
    z-index: 2
}

.active-part6 .main {
    position: relative;
    z-index: 3
}

.active-part6 .slogan-show {
    position: relative
}

.active-part6 .slogan-show:after,
.active-part6 .slogan-show:before {
    content: "";
    position: absolute
}

.active-part6 .slogan-show:after {
    background: url(../img/part6_icon_bt.png) 50% 50% no-repeat;
    background-size: contain
}

.active-part6 .slogan-show:before {
    background: url(../img/part6_icon_top.png) 50% 50% no-repeat;
    background-size: contain
}

.active-part6 .slogan-show span {
    color: #d7f238;
    font-family: Ubuntu, sans-serif
}

@media only screen and (max-width: 991px) {
    .active-part6 .main {
        padding-left: 30px;
        padding-right: 30px
    }
}

@media only screen and (max-width: 767px) {
    .active-part6 {
        padding-top: 140px;
        padding-bottom: 55px
    }

    .active-part6 .main {
        padding-left: 20px;
        padding-right: 20px
    }

    .active-part6:before {
        height: calc(100% + 800px)
    }

    .active-part6:after {
        height: calc(100% + 450px)
    }

    .active-part6 .slogan-show {
        font-size: 18px;
        line-height: 40px
    }

    .active-part6 .slogan-show:after,
    .active-part6 .slogan-show:before {
        width: 44px;
        height: 31px
    }

    .active-part6 .slogan-show:after {
        right: 0;
        bottom: -30px
    }

    .active-part6 .slogan-show:before {
        left: 0;
        top: -30px
    }

    .active-part6 .slogan-show span {
        font-size: 36px
    }
}

@media only screen and (min-width: 768px) {
    .active-part6 {
        padding-top: 320px;
        padding-bottom: 110px
    }

    .active-part6:before {
        height: calc(100% + 800px)
    }

    .active-part6:after {
        height: calc(100% + 620px)
    }

    .active-part6 .slogan-show {
        font-size: 36px;
        line-height: 80px
    }

    .active-part6 .slogan-show:after,
    .active-part6 .slogan-show:before {
        width: 88px;
        height: 63px
    }

    .active-part6 .slogan-show:after {
        right: 0;
        bottom: -60px
    }

    .active-part6 .slogan-show:before {
        left: 0;
        top: -60px
    }

    .active-part6 .slogan-show span {
        font-size: 75px
    }
}

.active-part7 {
    position: relative;
    z-index: 2;
    overflow: hidden
}

.active-part7:after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    z-index: 2
}

.active-part7 .content-view {
    background: #e6f3fe
}

.active-part7 .wrapper,
.active-part7 .main {
    position: relative;
    z-index: 3
}

.active-part7 .bg-city {
    position: relative;
    z-index: 2
}

.active-part7 .bg-city:after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%
}

.active-part7 .main-tit,
.active-part7 .des {
    color: #0d4ea3;
    text-align: center
}

.active-part7 .bg-bt {
    position: absolute;
    width: 100%;
    left: 0;
    bottom: 0;
    z-index: 2
}

@media only screen and (max-width: 991px) {
    .active-part7 {
        padding-top: 75px;
        padding-bottom: 39%
    }

    .active-part7 .content-view {
        padding-top: 90px
    }

    .active-part7 .des {
        text-align: left
    }

    .active-part7 .main {
        padding-left: 30px;
        padding-right: 30px
    }
}

@media only screen and (max-width: 767px) {
    .active-part7 {
        font-size: 15px
    }

    .active-part7:after {
        padding-top: 125.866%;
        background: url(../img/bg2_mb.png) 50% 0 no-repeat;
        background-size: 100% auto
    }

    .active-part7 .main {
        padding-left: 20px;
        padding-right: 20px
    }

    .active-part7 .main-tit {
        margin-bottom: 10px
    }

    .active-part7 .des {
        line-height: 25px;
        padding: 0 20px
    }

    .active-part7 .bg-bt {
        padding-top: 40.4%;
        background: url(../img/bg4_mb.png) 50% 50% no-repeat;
        background-size: contain
    }

    .active-part7 .bg-city {
        padding-top: 56.8%;
        position: relative
    }

    .active-part7 .bg-city:after {
        padding-top: 70.2666%;
        background: url(../img/city_mb.png) 50% bottom no-repeat;
        background-size: 100% auto
    }
}

@media only screen and (min-width: 768px) {
    .active-part7 {
        font-size: 30px;
        padding-top: 210px;
        padding-bottom: 22%
    }

    .active-part7 .content-view {
        padding-top: 90px
    }

    .active-part7:after {
        padding-top: 45.5%;
        background: url(../img/bg2.png) 50% 0 no-repeat;
        background-size: 100% auto
    }

    .active-part7 .bg-bt {
        padding-top: 23.385%;
        background: url(../img/bg4.png) 50% 50% no-repeat;
        background-size: contain
    }

    .active-part7 .wrapper {
        padding-bottom: 90px
    }

    .active-part7 .main-tit {
        margin-bottom: 10px
    }

    .active-part7 .bg-city {
        padding-top: 19.27%
    }

    .active-part7 .bg-city:after {
        padding-top: 27.7%;
        background: url(../img/city.png) 50% bottom no-repeat;
        background-size: 100% auto
    }
}

@media only screen and (min-width: 1280px) {
    .active-part7 {
        padding-top: 280px
    }

    .active-part7 .content-view {
        padding-top: 120px
    }
}

@media only screen and (min-width: 1440px) {
    .active-part7 {
        padding-top: 380px
    }
}

.active-account {
    position: relative;
    z-index: 3
}

.active-account .item {
    position: relative
}

.active-account ul {
    list-style: none
}

.active-account ul li {
    border: 1px solid #E6F3FE;
    background: #fff;
    border-radius: 30px;
    color: #0d4ea3;
    font-weight: 700
}

.active-account ul li:last-child {
    margin-bottom: 0
}

.active-account ul .txt {
    color: #0d4ea3;
    position: relative;
    display: block
}

.active-account ul .txt:before {
    content: "";
    position: absolute;
    left: 20px;
    top: 50%;
    transform: translateY(-50%);
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: #0d4ea3
}

.active-account .type-show {
    position: relative
}

.active-account .type-show .link {
    position: absolute;
    z-index: 2
}

.active-account .people1,
.active-account .people2,
.active-account .people3 {
    position: absolute;
    z-index: 1
}

.active-account .people1:before,
.active-account .people2:before,
.active-account .people3:before {
    content: "";
    display: block;
    width: 100%
}

.active-account .type1 .type-show {
    padding-top: 85%;
    background: url(../img/account_1.png) 50% bottom no-repeat;
    background-size: contain
}

.active-account .type1 .link {
    width: 92%;
    padding-top: 62%;
    bottom: 2%;
    left: 3%;
    opacity: .8;
    border-radius: 47%
}

.active-account .type1 .people1 {
    width: 16.85%;
    top: 19%;
    left: 0;
    animation: cloud 5s forwards infinite
}

.active-account .type1 .people1:before {
    padding-top: 168.48%;
    background: url(../img/account_1_people.png) 50% 50% no-repeat;
    background-size: contain
}

.active-account .type1 .people2 {
    width: 21.8%;
    left: 2%;
    bottom: 8%;
    animation: cloud 5s forwards infinite
}

.active-account .type1 .people2:before {
    padding-top: 121%;
    background: url(../img/account_1_people2.png) 50% 50% no-repeat;
    background-size: contain
}

.active-account .type1 .people3 {
    width: 18.7%;
    right: 21%;
    bottom: 0;
    transform-origin: 0 bottom;
    animation: shake 5s forwards infinite
}

.active-account .type1 .people3:before {
    padding-top: 192.34%;
    background: url(../img/account_1_people3.png) 50% 50% no-repeat;
    background-size: contain
}

.active-account .type2 .type-show {
    padding-top: 87%;
    background: url(../img/account_2.png) 50% bottom no-repeat;
    background-size: contain
}

.active-account .type2 .link {
    width: 93%;
    padding-top: 62%;
    bottom: 5%;
    left: 7%;
    opacity: .8;
    border-radius: 47%
}

.active-account .type2 .people1 {
    width: 13.88%;
    bottom: 18%;
    left: 0;
    animation: cloud 5s forwards infinite
}

.active-account .type2 .people1:before {
    padding-top: 322.7%;
    background: url(../img/account_2_people1.png) 50% 50% no-repeat;
    background-size: contain
}

.active-account .type2 .people2 {
    width: 27.1%;
    right: 8.3%;
    bottom: 0;
    transform-origin: 0 bottom;
    animation: shake 5s forwards infinite
}

.active-account .type2 .people2:before {
    padding-top: 145.38%;
    background: url(../img/account_2_people2.png) 50% 50% no-repeat;
    background-size: contain
}

.active-account .type3 .type-show {
    padding-top: 93.6%;
    background: url(../img/account_3.png) 50% bottom no-repeat;
    background-size: contain
}

.active-account .type3 .link {
    width: 101%;
    padding-top: 67%;
    bottom: 0%;
    left: 0%;
    opacity: .8;
    border-radius: 47%
}

.active-account .type3 .people1 {
    width: 27.6%;
    top: 10%;
    right: 6.97%;
    animation: cloud 5s forwards infinite
}

.active-account .type3 .people1:before {
    padding-top: 158.13%;
    background: url(../img/account_3_people1.png) 50% 50% no-repeat;
    background-size: contain
}

.active-account .type3 .people2 {
    width: 43%;
    right: -3%;
    bottom: 0;
    transform-origin: 0 bottom;
    animation: move-right 5s forwards infinite
}

.active-account .type3 .people2:before {
    padding-top: 89.58%;
    background: url(../img/account_3_people2.png) 50% 50% no-repeat;
    background-size: contain
}

.active-account .type4 .type-show {
    padding-top: 88.2%;
    background: url(../img/account_4.png) 50% bottom no-repeat;
    background-size: contain
}

.active-account .type4 .link {
    width: 100%;
    padding-top: 67%;
    bottom: 0%;
    left: 0%;
    opacity: .8;
    border-radius: 47%
}

.active-account .type4 .people1 {
    width: 18%;
    top: 16%;
    left: 9.36%;
    transform-origin: 0 bottom;
    animation: shake 5s forwards infinite
}

.active-account .type4 .people1:before {
    padding-top: 216.77%;
    background: url(../img/account_4_people1.png) 50% 50% no-repeat;
    background-size: contain
}

.active-account .type4 .people2 {
    width: 20.65%;
    left: -5%;
    bottom: 10%;
    animation: cloud 5s forwards infinite
}

.active-account .type4 .people2:before {
    padding-top: 210.326%;
    background: url(../img/account_4_people2.png) 50% 50% no-repeat;
    background-size: contain
}

.active-account .type5 .type-show {
    padding-top: 79.15%;
    background: url(../img/account_5.png) 50% bottom no-repeat;
    background-size: contain
}

.active-account .type5 .link {
    width: 91%;
    padding-top: 60%;
    bottom: 0%;
    left: 0%;
    opacity: .8;
    border-radius: 47%
}

.active-account .type5 .people1 {
    width: 26%;
    top: 10%;
    left: 3%;
    transform-origin: 0 bottom;
    animation: shake 5s forwards infinite
}

.active-account .type5 .people1:before {
    padding-top: 145.9459%;
    background: url(../img/account_5_people1.png) 50% 50% no-repeat;
    background-size: contain
}

.active-account .type5 .people2 {
    width: 23.766%;
    right: 0;
    bottom: 6%;
    animation: cloud 5s forwards infinite
}

.active-account .type5 .people2:before {
    padding-top: 159.745%;
    background: url(../img/account_5_people2.png) 50% 50% no-repeat;
    background-size: contain
}

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

    .active-account,
    .active-account ul {
        padding-left: 20px;
        padding-right: 20px
    }

    .active-account ul li {
        height: 45px;
        line-height: 45px;
        font-size: 15px;
        margin-bottom: 18px
    }

    .active-account ul li .txt {
        padding: 0 20px 0 35px
    }

    .active-account .type1,
    .active-account .type2,
    .active-account .type3,
    .active-account .type4,
    .active-account .type1 .type-show,
    .active-account .type2 .type-show,
    .active-account .type3 .type-show,
    .active-account .type4 .type-show,
    .active-account .type5 .type-show {
        margin-bottom: 30px
    }
}

@media only screen and (min-width: 768px) {
    .active-account {
        padding-left: 30px;
        padding-right: 30px;
        display: flex;
        flex-wrap: wrap;
        justify-content: center
    }

    .active-account ul {
        max-width: 360px;
        margin: 0 auto;
        padding-top: 30px
    }

    .active-account ul li {
        height: 60px;
        line-height: 24px;
        font-size: 18px;
        margin-bottom: 8px;
        display: flex;
        align-items: center
    }

    .active-account ul .txt {
        padding: 15px 20px 15px 35px
    }

    .active-account .type1 {
        flex: 0 0 31.499%;
        width: 31.499%;
        margin-bottom: 30px
    }

    .active-account .type2 {
        flex: 0 0 30.82%;
        width: 30.82%;
        margin: 0 2% 30px 0
    }

    .active-account .type3 {
        flex: 0 0 28.7%;
        width: 28.7%;
        margin-bottom: 30px
    }

    .active-account .type4 {
        flex: 0 0 28.7%;
        width: 28.7%;
        margin: 0 1%
    }

    .active-account .type5 {
        flex: 0 0 32%;
        width: 32%;
        margin: 0 1%
    }
}

@media only screen and (min-width: 992px) {
    .active-account {
        max-width: 1554px;
        margin: 0 auto
    }

    .active-account .item ul li {
        cursor: pointer
    }

    .active-account .item ul li:hover {
        background: #fabe00
    }

    .active-account .item ul li:hover .txt {
        color: #fff
    }

    .active-account .item ul li:hover .txt:before {
        background: #fff
    }

    .active-account .type1 {
        flex: 0 0 31.499%;
        width: 31.499%
    }

    .active-account .type2 {
        flex: 0 0 30.82%;
        width: 30.82%;
        margin: 0 2%
    }

    .active-account .type3 {
        flex: 0 0 28.7%;
        width: 28.7%
    }

    .active-account .type4 {
        flex: 0 0 28.7%;
        width: 28.7%;
        margin: 0 1%
    }

    .active-account .type5 {
        flex: 0 0 32%;
        width: 32%;
        margin: 0 1%
    }
}

@media only screen and (min-width: 1280px) {
    .active-account .type2 {
        margin: 0 4%
    }

    .active-account .type4,
    .active-account .type5 {
        margin: 0 2%
    }

    .active-account ul li {
        font-size: 24px
    }
}

.year-active {
    position: relative
}

.year-active.on .main {
    animation: move-down .5s forwards ease-in-out
}

.year-active .main-tit {
    text-align: center;
    color: #0570b8
}

.year-active .light-bg .viewbg {
    padding-top: 30%
}

.year-active .main {
    position: relative;
    z-index: 2;
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0;
    -khtml-opacity: 0;
    transform: translateY(-15px)
}

.year-active .des {
    font-weight: 700;
    color: #0570b8;
    text-align: center
}

.year-active h3 {
    color: #0570b8;
    font-weight: 700
}

@media only screen and (max-width: 767px) {
    .year-active {
        padding-bottom: 70px;
        padding-top: 60px
    }

    .year-active .main {
        padding-left: 20px;
        padding-right: 20px
    }

    .year-active .main-tit {
        margin-bottom: 10px
    }

    .year-active .des {
        font-size: 18px;
        margin-bottom: 15px
    }

    .year-active .pic-show {
        padding-top: 172%;
        background: url(../img/year_pic_mb.png) 50% 50% no-repeat;
        background-size: contain;
        margin-bottom: 15px
    }

    .year-active h3 {
        font-size: 24px;
        line-height: 30px;
        margin-bottom: 10px
    }

    .year-active .info {
        font-size: 15px;
        line-height: 25px
    }

    .year-active .left-part {
        margin-bottom: 20px
    }

    .year-active .more-btn {
        margin-left: auto;
        margin-right: auto
    }
}

@media only screen and (min-width: 768px) {
    .year-active {
        padding-top: 90px;
        padding-bottom: 120px
    }

    .year-active .main {
        padding-left: 30px;
        padding-right: 30px
    }

    .year-active .main-tit {
        margin-bottom: 10px
    }

    .year-active .des {
        font-size: 36px;
        margin-bottom: 30px
    }

    .year-active .pic-show {
        padding-top: 37.8%;
        background: url(../img/year_pic.png) 50% 50% no-repeat;
        background-size: contain;
        margin-bottom: 30px
    }

    .year-active .txt-show {
        display: flex;
        align-items: center
    }

    .year-active .left-part {
        flex: 1 1 auto
    }

    .year-active h3 {
        font-size: 36px
    }

    .year-active .info {
        font-size: 20px;
        line-height: 35px;
        padding-right: 60px
    }
}

@media only screen and (min-width: 992px) {
    .year-active .info {
        padding-right: 145px
    }
}

.more-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    color: #fff;
    border-radius: 30px;
    background: url(../img/btn_bg.jpg) 50% 50% no-repeat;
    background-size: cover
}

@media only screen and (max-width: 767px) {
    .more-btn {
        width: 180px;
        height: 45px;
        font-size: 15px
    }
}

@media only screen and (min-width: 768px) {
    .more-btn {
        flex: 0 0 200px;
        font-size: 20px;
        width: 200px;
        height: 60px
    }

    .more-btn:hover {
        background: #fabe00
    }
}

.partner .main-tit {
    text-align: center;
    color: #0570b8
}

.partner .more-btn {
    margin: 0 auto
}

@media only screen and (max-width: 767px) {
    .partner {
        padding-bottom: 80px
    }

    .partner .main-tit {
        margin-bottom: 10px
    }
}

@media only screen and (min-width: 768px) {
    .partner {
        padding-bottom: 160px
    }

    .partner .main-tit {
        margin-bottom: 10px
    }
}

.rotate-brand {
    position: relative;
    overflow: hidden
}

.rotate-brand .showbox {
    position: relative;
    height: 100%
}

.rotate-brand .showbox.mb-style {
    display: none
}

.rotate-brand .showbox img {
    max-height: 100%
}

.rotate-brand .wrapper {
    position: absolute;
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    height: 100%
}

.rotate-brand .list {
    height: 100%
}

@media only screen and (max-width: 767px) {
    .rotate-brand {
        height: 113px;
        margin-bottom: 30px
    }

    .rotate-brand .showbox {
        display: none
    }

    .rotate-brand .showbox.mb-style {
        display: block
    }

    .rotate-brand .list {
        display: flex;
        align-items: center;
        height: 100%;
        animation: rotate-brand-mb 21s linear infinite
    }
}

@media only screen and (min-width: 768px) {
    .rotate-brand {
        height: 130px;
        margin-bottom: 50px
    }

    .rotate-brand .list {
        display: flex;
        align-items: center;
        height: 100%;
        animation: rotate-brand 30s linear infinite
    }
}

.footer {
    background: url(../img/ft_bg.jpg) 50% 0 no-repeat;
    background-size: cover
}

.footer .ft-logo img {
    max-width: 100%
}

.footer .link a {
    font-weight: 700;
    color: #eef8ff
}
.footer a{
    color: #eef8ff
}
.footer .tool {
    border-bottom: 1px solid #89BDE3
}

.footer .tool .main {
    display: flex;
    justify-content: space-between;
    align-items: center
}

.footer .info-show .item {
    display: flex;
    align-items: center;
    color: #bbe2ff
}

.footer .info-show h5 {
    color: #eef8ff
}

.footer .info-show .right-part {
    flex: 1 1 auto
}

.footer .icon {
    background: #0e56c2;
    border-radius: 50%
}

.footer .icon:after {
    content: "";
    display: block;
    width: 100%;
    height: 100%
}

.footer .copyright {
    color: #fff
}

@media only screen and (max-width: 991px) {
    .footer {
        padding-bottom: 30px
    }

    .footer .main {
        padding-left: 30px;
        padding-right: 30px
    }

    .footer .tool {
        padding-top: 30px;
        padding-bottom: 30px;
        margin-bottom: 30px
    }

    .footer .ft-logo {
        max-width: 166px;
        flex: 0 0 50%
    }

    .footer .link {
        text-align: right
    }

    .footer .link a {
        display: block;
        font-size: 15px;
        margin-bottom: 10px
    }

    .footer .link a:last-child {
        margin-bottom: 0
    }

    .footer .icon {
        width: 50px;
        height: 50px;
        flex: 0 0 50px
    }

    .footer .locat:after {
        background: url(../img/ft_locat.png) 50% 50% no-repeat;
        background-size: 27px
    }

    .footer .phone:after {
        background: url(../img/ft_phone.png) 50% 50% no-repeat;
        background-size: 28px
    }

    .footer .info-show {
        padding-bottom: 25px
    }

    .footer .info-show .item {
        font-size: 12px;
        line-height: 25px;
        margin-bottom: 20px
    }

    .footer .info-show .item:last-child {
        margin-bottom: 0
    }

    .footer .info-show .right-part {
        padding-left: 15px
    }

    .footer .info-show h5 {
        font-size: 18px
    }

    .footer .copyright {
        font-size: 12px;
        text-align: center;
        line-height: 20px
    }
}

@media only screen and (max-width: 767px) {
    .footer .main {
        padding-left: 20px;
        padding-right: 20px
    }
}

@media only screen and (min-width: 992px) {
    .footer {
        padding-bottom: 60px
    }

    .footer .ft-logo {
        width: 374px;
        flex: 0 0 374px
    }

    .footer .tool {
        padding-top: 50px;
        padding-bottom: 50px;
        margin-bottom: 65px
    }

    .footer .link {
        display: flex;
        justify-content: flex-end
    }

    .footer .link a {
        font-size: 20px;
        margin-left: 55px
    }

    .footer .link a:hover {
        color: #fabe00
    }

    .footer .link a:first-child {
        margin-left: 0
    }

    .footer .info-show {
        display: flex;
        justify-content: space-between;
        padding-bottom: 60px
    }

    .footer .info-show .item {
        flex: 0 0 calc(50% - 30px);
        font-size: 18px;
        line-height: 40px
    }

    .footer .info-show .right-part {
        padding-left: 25px
    }

    .footer .info-show h5 {
        font-size: 24px;
        margin-bottom: 10px
    }

    .footer .icon {
        flex: 0 0 100px;
        width: 100px;
        height: 100px
    }

    .footer .locat:after {
        background: url(../img/ft_locat.png) 50% 50% no-repeat;
        background-size: 54px
    }

    .footer .phone:after {
        background: url(../img/ft_phone.png) 50% 50% no-repeat;
        background-size: 56px
    }

    .footer .copyright {
        font-size: 18px
    }
}

.pop-add-join {
    position: fixed;
    width: 100%;
    height: 100%;
    z-index: 100;
    top: 0;
    left: 0;
    display: none
}

.pop-add-join.on {
    display: block
}

.pop-add-join.on .wrapper {
    animation: alpha-1 .5s .1s forwards ease-in-out
}

.pop-add-join .wrapper {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    -webkit-backdrop-filter: blur(15px);
    backdrop-filter: blur(15px);
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0;
    -khtml-opacity: 0
}

.pop-add-join .viewbox {
    position: relative
}

.pop-add-join .pic1 {
    position: relative;
    z-index: 1;
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0;
    -khtml-opacity: 0;
    transform: scale(.2);
    animation: big .5s .2s forwards ease-in-out
}

.pop-add-join .pic2 {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0;
    -khtml-opacity: 0;
    animation: alpha-1 .5s .6s forwards ease-in-out
}

.pop-add-join .txt {
    position: absolute;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    color: #fff;
    z-index: 2;
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0;
    -khtml-opacity: 0;
    animation: alpha-1 .5s .5s forwards ease-in-out
}

@media only screen and (max-width: 991px) {
    .pop-add-join .pic1 {
        width: 300px
    }

    .pop-add-join .pic2 {
        width: 161.32%
    }

    .pop-add-join .txt {
        font-size: 30px
    }
}

@media only screen and (max-width: 767px) {
    .pop-add-join .pic1 {
        width: 180px
    }

    .pop-add-join .pic2 {
        width: 161.32%
    }

    .pop-add-join .txt {
        font-size: 18px
    }
}

@media only screen and (min-width: 992px) {
    .pop-add-join .pic1 {
        width: 460px
    }

    .pop-add-join .pic2 {
        width: 161.32%
    }

    .pop-add-join .txt {
        font-size: 45px
    }
}

.pop-box {
    display: none;
    position: fixed;
    width: 100%;
    height: 100%;
    z-index: 100;
    top: 0;
    left: 0;
    -webkit-backdrop-filter: blur(15px);
    backdrop-filter: blur(15px)
}

@media only screen and (max-width: 767px) {
    .pop-box {
        padding-top: 30px
    }
}

@media only screen and (min-width: 768px) {
    .pop-box {
        padding-top: 60px
    }
}

@media only screen and (min-width: 1280px) {
    .pop-box {
        padding-top: 120px
    }
}

.pop-content {
    position: relative;
    background: #fff;
    margin: 0 auto;
    box-shadow: 0 3px 30px #00000029
}

.pop-content .note {
    color: #888;
    font-size: 13px;
    line-height: 1.5
}

.pop-content .close {
    background: #b6d9f4;
    border-radius: 50%;
    position: absolute
}

.pop-content .close:after {
    content: "";
    display: block;
    width: 100%;
    height: 100%
}

.pop-content .box-tit {
    display: flex;
    align-items: center
}

.pop-content .box-tit h2 {
    color: #0d4ea3;
    flex: 1 1 auto
}

.pop-content .box-tit .icon {
    border-radius: 50%;
    background: url(../img/icon_tit1.png) 50% 50% no-repeat;
    background-size: cover
}

.pop-content .box-tit .icon:after {
    content: "";
    width: 100%;
    height: 100%;
    display: block
}

.pop-content .type-tit {
    color: #0e56c2;
    font-weight: 700;
    position: relative
}

.pop-content .type-tit:before {
    position: absolute;
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #0e56c2;
    top: 50%;
    transform: translateY(-50%)
}

.pop-content .more-btn {
    margin: 0 auto
}

@media only screen and (max-width: 767px) {
    .pop-content {
        border-radius: 15px;
        max-width: 90%;
        padding: 20px
    }

    .pop-content .close {
        width: 40px;
        height: 40px;
        top: 15px;
        right: 15px
    }

    .pop-content .close:after {
        background: url(../img/close.png) 50% 50% no-repeat;
        background-size: 16px auto
    }

    .pop-content .box-tit {
        margin-bottom: 15px;
        padding-right: 50px
    }

    .pop-content .box-tit h2 {
        font-size: 20px;
        padding-left: 15px
    }

    .pop-content .type-tit {
        font-size: 24px;
        padding-left: 20px
    }

    .pop-content .type-tit:before {
        left: 5px
    }

    .pop-content .info {
        padding-left: 20px;
        font-size: 18px;
        line-height: 30px;
        margin-bottom: 20px
    }

    .pop-content .icon {
        width: 45px;
        height: 45px;
        flex: 0 0 45px
    }

    .pop-content .type1:after {
        background: url(../img/list_icon1.png) 50% 50% no-repeat;
        background-size: 29.2px auto
    }

    .pop-content .type2:after {
        background: url(../img/list_icon2.png) 50% 50% no-repeat;
        background-size: 29.6px auto
    }

    .pop-content .type3:after {
        background: url(../img/list_icon3.png) 50% 50% no-repeat;
        background-size: 28.8px auto
    }

    .pop-content .type4:after {
        background: url(../img/list_icon4.png) 50% 50% no-repeat;
        background-size: 26.4px auto
    }

    .pop-content .type5:after {
        background: url(../img/list_icon5.png) 50% 50% no-repeat;
        background-size: 29.2px auto
    }

    .pop-content .brand-type:after {
        background: url(../img/brand_icon.png) 50% 50% no-repeat;
        background-size: 29px auto
    }
}

@media only screen and (min-width: 768px) {
    .pop-content {
        border-radius: 30px;
        max-width: 80%;
        padding: 40px 60px 60px
    }

    .pop-content .close {
        width: 80px;
        height: 80px;
        top: 40px;
        right: 30px
    }

    .pop-content .close:after {
        background: url(../img/close.png) 50% 50% no-repeat;
        background-size: 33px auto
    }

    .pop-content .box-tit {
        margin-bottom: 25px
    }

    .pop-content .box-tit h2 {
        font-size: 30px;
        padding-left: 30px
    }

    .pop-content .type-tit {
        font-size: 36px;
        padding-left: 45px
    }

    .pop-content .type-tit:before {
        left: 10px
    }

    .pop-content .info {
        padding-left: 45px;
        font-size: 20px;
        line-height: 40px;
        margin-bottom: 20px
    }

    .pop-content .icon {
        width: 90px;
        height: 90px;
        flex: 0 0 90px
    }

    .pop-content .type1:after {
        background: url(../img/list_icon1.png) 50% 50% no-repeat;
        background-size: 47.45px auto
    }

    .pop-content .type2:after {
        background: url(../img/list_icon2.png) 50% 50% no-repeat;
        background-size: 48.1px auto
    }

    .pop-content .type3:after {
        background: url(../img/list_icon3.png) 50% 50% no-repeat;
        background-size: 46.8px auto
    }

    .pop-content .type4:after {
        background: url(../img/list_icon4.png) 50% 50% no-repeat;
        background-size: 42.9px auto
    }

    .pop-content .type5:after {
        background: url(../img/list_icon5.png) 50% 50% no-repeat;
        background-size: 47.45px auto
    }

    .pop-content .brand-type:after {
        background: url(../img/brand_icon.png) 50% 50% no-repeat;
        background-size: 58px auto
    }
}

@media only screen and (min-width: 992px) {
    .pop-content {
        max-width: 775px
    }

    .pop-content.pop-brand {
        max-width: 1280px
    }

    .pop-content .close {
        cursor: pointer
    }
}

.pop-brand img {
    max-width: 100%
}

@media only screen and (min-width: 992px) {
    .pop-brand {
        height: 80vh;
        max-height: 800px;
        display: flex;
        flex-direction: column
    }

    .pop-brand .box-scroll {
        flex: 1 1 auto;
        overflow-y: auto
    }
}

.show {
    display: block !important
}

.mb-nav-box {
    display: none;
    position: fixed;
    width: 100%;
    height: 100vh;
    top: 0;
    left: 0;
    z-index: 9;
    background: #0e56c2;
    padding-top: 90px
}

.mb-nav-box .viewbox {
    border-top: 1px solid #0098FF
}

.mb-nav-box .link a {
    display: block;
    color: #fff;
    font-weight: 700;
    font-size: 18px;
    padding: 15px 40px;
    border-bottom: 1px solid #0098FF
}

.mb-nav-box .top-show {
    padding: 20px 40px 0
}

.mb-nav-box .top-show a {
    display: flex;
    color: #fff;
    font-weight: 700;
    font-size: 18px;
    align-items: center;
    margin-bottom: 20px
}

.mb-nav-box .top-show a:last-child {
    margin-bottom: 0
}

.mb-nav-box .top-show .txt {
    flex: 1 1 auto
}

.mb-nav-box .top-show .icon {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: url(../img/icon_tit.png) 50% 50% no-repeat;
    background-size: cover;
    margin-right: 15px
}

.mb-nav-box .top-show .icon:after {
    content: "";
    display: block;
    width: 100%;
    height: 100%
}

.mb-nav-box .top-show .pic1:after {
    background: url(../img/fix_pic1.png) 50% 50% no-repeat;
    background-size: cover
}

.mb-nav-box .top-show .pic2:after {
    background: url(../img/fix_pic2.png) 50% 50% no-repeat;
    background-size: cover
}

.mb-nav-box .top-show .mic:after {
    background: url(../img/mic.png) 50% 50% no-repeat;
    background-size: 16px auto
}

.cta-box {
    position: fixed;
    right: 30px;
    bottom: 30px;
    z-index: 9
}

@media only screen and (max-width: 767px) {
    .cta-box {
        right: 20px;
        bottom: 20px
    }
}

@media only screen and (min-width: 1440px) and (min-height: 700px) {
    .cta-box {
        right: 60px;
        bottom: 60px
    }
}

.fix-cta {
    position: relative;
    margin-bottom: 25px;
    display: block
}

.fix-cta:last-child {
    margin-bottom: 0
}

.fix-cta .txt {
    display: none;
    position: absolute;
    right: 80px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 18px;
    font-weight: 700;
    color: #0e56c2;
    background: #ddf0ff;
    border-radius: 35px;
    line-height: 65px;
    padding: 0 30px;
    width: max-content
}

.fix-cta .icon {
    flex: 0 0 auto;
    width: 40px;
    height: 40px;
    display: block;
    border-radius: 50%;
    background: url(../img/icon_tit.png) 50% 50% no-repeat;
    background-size: cover
}

.fix-cta .icon:after {
    content: "";
    display: block;
    width: 100%;
    height: 100%
}

.fix-cta.type1 {
    margin-bottom: 29px
}

.fix-cta.type1 .icon:after {
    background: url(../img/fix_pic1.png) 50% 50% no-repeat;
    background-size: cover
}

.fix-cta.type2 {
    margin-bottom: 17px
}

.fix-cta.type2 .icon:after {
    background: url(../img/fix_pic2.png) 50% 50% no-repeat;
    background-size: cover
}

.fix-cta.type3 .icon:after {
    background: url(../img/mic.png) 50% 50% no-repeat;
    background-size: 16px auto
}

.fix-cta .typeshow {
    display: block;
    position: absolute;
    background: #fff;
    border-radius: 10px;
    padding: 3px 15px;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 240px
}

.fix-cta .typeshow .link {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 2
}

.fix-cta .typeshow .viewbox {
    display: flex;
    align-items: center
}

.fix-cta .typeshow .right-part {
    flex: 1 1 auto;
    padding: 0 5px;
    font-size: 16px;
    font-weight: 700;
    color: #333
}

.fix-cta .typeshow .right-part span {
    text-transform: uppercase;
    color: #85c134
}

.fix-cta .typeshow .play {
    flex: 0 0 auto;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 3px solid #41BDE9;
    cursor: pointer
}

.fix-cta .typeshow .play:after {
    content: "";
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
    background: url(../img/play.png) 50% 50% no-repeat;
    background-size: auto 10px
}

.fix-cta .typeshow .close {
    position: absolute;
    width: 30px;
    height: 30px;
    background: #b6d9f4;
    border-radius: 50%;
    top: -15px;
    right: -15px;
    cursor: pointer
}

.fix-cta .typeshow .close:after {
    content: "";
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
    background: url(../img/fix_close.png) 50% 50% no-repeat;
    background-size: 11px auto
}

@media only screen and (max-width: 767px) {
    .fix-cta {
        margin-bottom: 25px
    }

    .fix-cta .txt {
        display: none
    }

    .fix-cta.type1 {
        margin-bottom: 26px
    }

    .fix-cta.type2 {
        margin-bottom: 22px
    }

    .fix-cta.type3 .icon:after {
        background: url(../img/mic.png) 50% 50% no-repeat;
        background-size: 11px auto
    }

    .fix-cta .typeshow {
        padding: 10px;
        width: 200px
    }

    .fix-cta .typeshow .right-part {
        padding-left: 10px;
        padding-right: 10px;
        line-height: 1.2
    }

    .fix-cta .typeshow .right-part span {
        font-size: 12px
    }

    .fix-cta .typeshow .right-part p {
        font-size: 13px
    }
}

@media only screen and (min-width: 992px) {
    .fix-cta.down:hover .txt {
        display: block
    }

    .fix-cta.down:hover>.icon {
        background: url(../img/close_bg.png) 50% 50% no-repeat;
        background-size: cover
    }

    .fix-cta .typeshow:hover .play {
        background: #fabe00;
        border: 3px solid #FABE00
    }

    .fix-cta .typeshow:hover .play:after {
        background: url(../img/play_s.png) 50% 50% no-repeat;
        background-size: auto 10px
    }

    .fix-cta .typeshow .close:hover {
        background: #fabe00
    }
}

@media only screen and (min-width: 1440px) and (min-height: 700px) {
    .fix-cta.type3 .icon:after {
        background: url(../img/mic.png) 50% 50% no-repeat;
        background-size: 22px auto
    }

    .fix-cta .icon {
        width: 65px;
        height: 65px
    }

    .fix-cta .typeshow {
        width: 303px
    }

    .fix-cta .typeshow .right-part {
        font-size: 18px;
        padding: 0 15px 0 20px
    }
}

.light-bg {
    position: absolute;
    z-index: 1
}

.light-bg .viewbg {
    position: relative;
    width: 100%
}

.light-bg .viewbg:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding-top: 100%;
    background: url(../img/light.png) 50% 50% no-repeat;
    background-size: contain
}

@media only screen and (max-width: 991px) {
    .light-bg {
        width: 100%
    }

    .light-bg .viewbg {
        padding-top: 50%
    }
}

@media only screen and (min-width: 992px) {
    .light-bg {
        width: 52.34%;
        top: 0;
        left: 50%;
        transform: translate(-50%)
    }

    .light-bg .viewbg {
        padding-top: 13%
    }
}

.fix-dot {
    position: absolute;
    right: 30px;
    top: 30vh;
    z-index: 6
}

.fix-dot .dot {
    width: 18px;
    height: 18px;
    margin-bottom: 5px;
    border-radius: 50%;
    border: 3px solid #B6D9F4;
    background-color: #b6d9f44d;
    position: relative
}

.fix-dot .dot.now {
    border: 3px solid #fff
}

.fix-dot .dot.now:after {
    display: block
}

.fix-dot .dot:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #fff;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: none
}

@media only screen and (max-width: 767px) {
    .fix-dot {
        right: 5px
    }
}

@media only screen and (min-width: 992px) {
    .fix-dot .dot {
        cursor: pointer
    }

    .fix-dot .dot:hover {
        border-color: #fff
    }
}

@media only screen and (min-width: 1440px) and (min-height: 700px) {
    .fix-dot {
        right: 60px
    }

    .fix-dot .dot {
        width: 28px;
        height: 28px;
        border: 4px solid #B6D9F4
    }

    .fix-dot .dot.now {
        border: 6px solid #fff
    }

    .fix-dot .dot:after {
        width: 10px;
        height: 10px
    }
}

* {
    box-sizing: border-box
}

body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
form,
fieldset,
input,
textarea,
p,
blockquote,
img {
    margin: 0;
    padding: 0
}

fieldset,
img,
abbr,
acronym {
    border: 0
}

q:before,
q:after {
    content: ""
}

input,
button,
select,
textarea {
    border: none;
    outline: none
}

button {
    background: none;
    cursor: pointer;
    padding: 0
}

a {
    cursor: pointer;
    text-decoration: none
}

body,
html {
    width: 100%;
    height: 100%
}

body {
    font-size: 18px;
    line-height: 1.5;
    color: #333;
    font-family: Ubuntu, Noto Sans TC, sans-serif
}

@media only screen and (max-width: 767px) {
    body {
        line-height: 1.5
    }
}

.clearfix:after {
    content: ".";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden
}

.clearfix {
    zoom: 1
}

#menWalk {
    width: 100%;
    height: 100%;
}

#threeclock {
    width: 100%;
    height: 100%;
}

#tagBt {
    display: none
}

#healthyPart1 {
    transition: opacity 1s, transform 1s;
}

#healthyPart2 {
    transition: opacity 1s, transform 1s;
}

#healthyPart3 {
    transition: opacity 1s, transform 1s;
}

#circle1 {
    transition: opacity 1s, transform 1s;
}

#circle2 {
    transition: opacity 1s, transform 1s;
}