html,
body {
    color: rgba(33, 37, 41, 1);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji";
    font-size: 16px;
    margin: 0;
    padding: 0;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    background-color: #FFF;
}

.container {
    max-width: 1280px !important;
    margin: 0 auto;
    padding: 10px;
}

img {
    max-width: 100%;
    display: block;
}

#apps {
    margin-top: 0;
}

a {
    color: #000;
}

[v-cloak] {
    display: none;
}

.icon {
    width: 1em;
    height: 1em;
    vertical-align: -0.15em;
    fill: currentColor;
    overflow: hidden;
}

.d-inline-block {
    display: inline-block;
}

.d-flex-nli {
    list-style: none;
    display: flex;
}

.shadow {
    box-shadow: 0 0 3px rgba(60, 72, 88, 0.15) !important;
}

.rounded {
    border-radius: 6px !important;
}

.rounded {
    border-radius: .25rem !important;
}

.bg-white {
    background-color: #fff !important;
}

.py-2 {
    padding-top: .5rem !important;
    padding-bottom: .5rem !important;
}

.px-4 {
    padding-right: 1.5rem !important;
    padding-left: 1.5rem !important;
}

/* 分页 */
.pagination,
.pager {
    text-align: center;
}

.pagination li,
.pager li {
    display: inline-block;
    list-style: none;
    background: #fff;
    background-color: rgb(255, 255, 255);
    vertical-align: top;
    display: inline-block;
    font-size: 14px;
    min-width: 32px;
    height: 32px;
    line-height: 32px;
    cursor: pointer;
    box-sizing: border-box;
    text-align: center;
    margin: 0;
    margin: 0 2px;
    background-color: #f4f4f5;
    color: #606266;
    border-radius: 2px;
}

.pagination li a,
.pager li a {
    display: block;
    width: 100%;
    height: 100%;
    padding: 0 12px;
}

/* 导航 #topnav */
#topnav .navigation_box {
    position: fixed;
    right: 0;
    left: 0;
    top: 0;
    z-index: 9999;
    padding: 10px 0;
    background-color: #FFF;
    transition: all .5s ease;
}

#topnav .container {
    padding: 0 10px;
}

#topnav .fixedo {
    box-shadow: 0 0 6px rgba(60, 72, 88, 0.25);
    border: 0;
    background: #fff !important;
}

#topnav a,
#topnav .submenu a {
    display: inline-block;
    color: #333;
    transition: all .32s;
}

#topnav .active a {
    color: #B299FE;
}

#topnav .submenu a {
    color: #333;
}

#topnav .submenu a:hover {
    color: #000;
}

#topnav .logo,
#topnav .logo_wrapper {
    display: inline-block;
    height: 48px;
    overflow: hidden;
}

#topnav .navigation_box .container {
    display: flex;
}

#topnav .navigation_box .navigation {
    flex: 1;
}

#topnav .navigation_box .navigation_menu {
    display: flex;
    flex-wrap: wrap;
    justify-content: right;
}

#topnav .navigation_box .navigation_menu>li {
    display: inline-block;
    position: relative;
    min-width: 100px;
    line-height: 48px;
    margin: 0 10px;
    font-weight: bold;
    font-size: 14px;
    list-style: none;
    text-align: center;
}

#topnav .navigation_box .navigation_menu .submenu {
    min-width: 100px;
    background-color: rgba(255, 255, 255, 1.0);
    box-shadow: 0 0 6px rgba(0, 0, 0, .08);
    padding: 15px 25px;
    border-radius: 5px;
    position: absolute;
    top: 60px;
    left: 0;
    visibility: hidden;
    opacity: 0;
    transition: all 0.2s;
}

#topnav .navigation_box .navigation_menu .submenu>li {
    line-height: 32px;
    font-size: 12px;
    white-space: nowrap;
    font-weight: normal;
    text-align: left;
    list-style: none;
}

#topnav .navigation_box .navigation_menu .hover .submenu {
    visibility: visible;
    top: 50px;
    opacity: 1;
}

#topnav .navigation_menu .menu-arrow {
    border: solid #333;
    border-top-width: medium;
    border-right-width: medium;
    border-bottom-width: medium;
    border-left-width: medium;
    border-radius: .5px;
    border-width: 0 1px 1px 0;
    display: inline-block;
    padding: 3px;
    transform: rotate(45deg);
    position: absolute;
    transition: all .5s;
    right: -15px;
    top: 20px;
}

#topnav .navigation_menu .hover .menu-arrow {
    transform: rotate(225deg);
    top: 22px;
}

#topnav .navigation_menu .active .menu-arrow {
    border-color: #B299FE;
}

#topnav .submenu a:after {
    content: "";
    display: block;
    height: 2px;
    width: 0;
    line-height: 2px;
    border-radius: 3px;
    background-color: #666;
    transition: all 0.32s;
}

#topnav .submenu a:hover:after {
    width: 100%;
    background-color: #666;
}

#topnav .navigation_mobile {
    position: absolute;
    right: 10px;
    top: 8px;
}

#topnav .close-open-btn {
    font-size: 28px;
    line-height: 38px;
    color: #333;
    text-align: right;
}

.mobile_menu {
    position: fixed;
    left: 0;
    background-color: rgba(255, 255, 255, 1);
    box-shadow: 0 0 6px rgba(0, 0, 0, .08);
    right: 0;
    width: 100%;
    top: 53px;
    padding: 35px;
    transition: all .48s;
    visibility: hidden;
    opacity: 0;
    z-index: 888;
}

.show {
    top: 48px;
    visibility: visible;
    opacity: 1;
}

.mobile_menu ul {
    font-size: 14px;
    font-weight: 600;
    list-style: none;
    line-height: 32px;
}

.mobile_submenu {
    display: block;
    margin-left: 1em;
    font-size: 12px !important;
    font-weight: normal !important;
    height: 0;
    overflow: hidden;
    transition: all .32s;
}

.mobile_menu .hover .mobile_submenu {
    height: auto;
}

/* body */
.focus {
    min-height: 688px;
    position: relative;
    overflow: hidden;
}

.swiper-container {
    width: 100%;
    height: 100%;
}

.focus .container {
    display: flex;
    margin: 40px auto;
    background-color: #fff;
    height: 480px;
    position: relative;
}

.focus .container div {
    flex: 1;
}

.focus .brand_img img {
    max-height: 480px;
    margin-top: 30px;
    display: block;
    float: right;
}

.section {
    padding: 100px 0;
    position: relative;
}

.bg-light {
    background-color: #f8f9fc !important;
}

.border-bottom {
    border-bottom: 1px solid #e9ecef !important;
}

.text-center {
    text-align: center;
}

.heading {
    font-size: 45px !important;
    letter-spacing: 1px;
    padding-top: 130px;
    padding-bottom: 30px;
}

.section-title .title {
    letter-spacing: .5px;
    font-size: 30px !important;
}

.me-2 {
    margin-right: .5em;
}

.mb-4 {
    margin-bottom: 1.5em;
}

.mt-4 {
    margin-top: 1.5em;
}

.mxw-600 {
    max-width: 600px;
}

.mxw-260 {
    max-width: 240px;
}

.text-muted {
    color: #8492a6 !important;
}

.text-primary {
    color: #2f55d4;
    letter-spacing: 0px;
    text-shadow: 10px 10px 5PX rgba(0, 0, 255, .08);
    font-weight: 600;
}

.mx-auto {
    margin-right: auto !important;
    margin-left: auto !important;
}

.list-unstyled {
    list-style: none;
}

.lg-mtl150 {
    margin: 70px;
    margin-top: 100px;
}

.position-relative {
    position: relative;
}

.features {
    margin: 10px;
}

.features i {
    font-size: 28px;
    color: #2f55d4;
    ;
}

.features .image {
    padding: 15px;
    margin-top: 45px;
}

.features .image::before {
    content: "";
    position: absolute;
    bottom: 5px;
    left: 50%;
    margin-left: -20px;
    width: 64px;
    height: 64px;
    top: 0px;
    border-radius: 6px;
    transform: rotate(33.75deg);
    background: linear-gradient(45deg, transparent, rgba(47, 85, 212, 0.1));
}

.features:hover .image::before {
    animation: fadenum 5s linear infinite;
}

.features h5 {
    font-size: 20px !important;
    margin-bottom: 15px;
}

@keyframes fadenum {
    0% {
        transform: rotate(33.75deg);
    }

    100% {
        transform: rotate(393.75deg);
    }
}

.work-process {
    margin: 10px;
    padding: 15px;
    position: relative;
    top: 8px;
    border-radius: 8px;
    transition: all 0.32s;
    box-shadow: 0 0 3px rgba(0, 0, 0, .15);
}

.work-process:hover {
    top: 0;
}

.d-flex {
    display: flex;
}

.step {
    flex: 1;
    font-size: 42px !important;
    font-family: "Nunito", sans-serif !important;
    font-weight: 700 !important;
    opacity: .06;
    line-height: 1.5;
    transition: all 0.32s;
}

.step-icon i {
    font-size: 42px !important;
    font-weight: 700 !important;
    opacity: .06;
    line-height: 1.5;
    transition: all 0.32s;
}

.work-process:hover .step,
.work-process:hover .step-icon i {
    opacity: .36;
}

h4.title {
    font-size: 24px !important;
    margin-bottom: 12px;
}

.obs {
    font-size: 3rem;
    font-family: Times New Roman, Helvetica, Verdana, Georgia, Lucida Grande;
}

/* pages */
.page_head {
    position: relative;
    text-align: center;
}

.pg_title {
    font-size: 32px !important;
    letter-spacing: 1px;
    font-weight: 600;
    font-family: 楷体;
    text-shadow: 5px 5px 3px rgba(0, 0, 0, .15);
}

.page_label {
    position: absolute;
    transform: translateY(-30%);
    color: #ccc;
    right: 12px;
    left: 12px;
}

.pg_section {
    padding: 60px 0;
}

.pg_postion {
    position: absolute;
    right: 12px;
    left: 12px;
    bottom: -60px;
    transform: translateY(-50%);
    text-align: center;
    z-index: 1;
}

.pg_postion_item {
    font-size: 14px;
    font-weight: 600;
    display: block;
    line-height: 20px;
    position: relative;
    padding-right: 25px;
}

.pg_postion_item:last-child {
    padding-right: 0;
}

.pg_postion_item::after {
    content: "·" !important;
    font-size: 14px;
    color: #3c4858;
    font-family: 'Material Design Icons';
    position: absolute;
    right: 10px;
}

.pg_postion_item:last-child:after {
    display: none;
}

.page_title {
    font-size: 32px !important;
    letter-spacing: 1px;
    text-align: center;
}

.pg_light {
    background-image: linear-gradient(0deg, #f8f9fc, #fff);
}

.pg_light:after {
    content: "";
    display: block;
    position: absolute;
    bottom: -25px;
    height: 50px;
    width: 100%;
    background-color: #f8f9fc;
    border-bottom-left-radius: 100%;
    border-bottom-right-radius: 100%;
}

.page_ibox img {
    max-height: 500px;
}

.page_tbox {
    padding: 30px 60px;
}

/* footer */
.footer {
    background-color: #202942;
    padding-top: 60px;
    color: #adb5bd;
    line-height: 24px;
    font-size: 14px;
}

.bnav_logo {
    max-height: 38px;
}

.logo-footer img {
    max-width: 120px;
}

.kf img {
    max-width: 120px;
}

.footer .footer-head {
    letter-spacing: 1px;
    font-weight: 500;
    color: #f8f9fc;
    font-size: 20px !important;
}

.footer a {
    color: #adb5bd;
}

.footer-list {
    line-height: 30px;
}

.footer-bar {
    border-top: 1px solid #283353;
    padding: 10px 0;
}

.icp {
    float: right;
}

@media only screen and (max-width:767px) {
    #apps {
        margin-top: 0;
    }
    #topnav {
        box-sizing: border-box;
        padding: 10px 0;
    }
    .el-message {
        min-width: 320px;
    }
    #topnav .navigation_box {
        box-shadow: 0 0 6px rgba(60, 72, 88, 0.25);
    }

    #topnav .logo,
    #topnav .logo_wrapper {
        height: 38px;
    }

    .focus .container {
        display: block;
        padding: 0 15px;
    }

    .focus .brand_img img {
        margin: 50px 15px;
    }

    .section {
        padding: 50px 0;
    }

    .heading {
        padding-top: 0;
        font-size: 28px !important;
        line-height: 1.5;
        font-weight: 600;
    }

    .para-desc {
        font-size: 14px !important;
    }

    .lg-mtl150 {
        margin: 20px;
        margin-top: 50px;
    }

    .logo-footer {
        display: block;
        text-align: center;
        line-height: 40px;
        padding-bottom: 10px;
    }

    .logo-footer img {
        display: block;
        margin: 0 auto;
    }

    .features .image::before {
        margin-left: -32px;
        animation: fadenum 5s linear infinite;
    }

    .icp {
        display: block;
        width: 100%;
    }

    .page_head {
        padding: 20px 0 !important;
    }

    .page_tbox {
        padding: 30px 10px;
    }
}

/*特殊字体*/
@font-face {
    font-family: 'wiosn_ls';
    src: url('/themes/webfonts/f002.ttf');
    src: local('☺'), url('/themes/webfonts/f002.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'wiosn_jh';
    src: url('/themes/webfonts/f001.ttf');
    src: local('☺'), url('/themes/webfonts/f001.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}