main { overflow: hidden; zoom: 1 }

/*slide*/
.slide { position: relative; height: 37.5rem }
.slide .swiper-slide { height: 37.5rem; overflow: hidden }
.slide .swiper-slide .slide-img { width: 100%; height: 37.5rem; text-indent: -9999em; background-repeat: no-repeat; background-size: cover; background-position: center }
.slide .swiper-button-prev, .slide .swiper-button-next { display: block; position: absolute; top: 50%; z-index: 1; width: 66px; height: 66px; line-height: 66px; margin-top: -33px; font-size: 66px; font-weight: 600; color: #fff }
.slide .swiper-button-prev { left: 10px }
.slide .swiper-button-next { right: 10px }
.slide .swiper-button-prev:hover, .slide .swiper-button-next:hover { cursor: pointer; color: #003f96 }
.slide .swiper-page { display: block; position: absolute; bottom: 1.875rem; left: 0; z-index: 2; width: 100%; text-align: center }
.slide .swiper-page .swiper-pagination-bullet { display: inline-block; opacity: 1; height: 16px; width: 16px; margin: 0 10px; background: #fff; border-radius: 8px; cursor: pointer }
.slide .swiper-page .swiper-pagination-bullet-active { width: 53px }

/*tilte*/
.tittop { padding: 80px 0; justify-content: space-between }
.tittop a.more { line-height: 60px; font-weight: 500; font-size: 24px; color: #003f96 }
.tittop a.more:hover { opacity: .6 }
.title h2 { line-height: 60px; font-weight: 500; font-size: 42px; color: #333 }
.title h2:after { content: ''; display: inline-block; width: 80px; height: 4px; margin-left: 18px; background: #003f96 }
.title p { line-height: 40px; font-weight: 500; font-size: 28px; color: #333; text-transform: uppercase }

/*pro*/
.pro li a { display: block; position: relative; background: #fafafa; -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); transition: .42s ease }
.pro li a .propic-big { display: flex; align-items: center; justify-content: center; width: 100%; height: 243px; margin: 0 }
.pro li a .propic-small { position: absolute; top: 55%; right: 22px; z-index: 2; width: 86px; height: 86px; margin: 0; background: #b6ccea; border-radius: 100%; overflow: hidden }
.pro li a .propic-big img, .pro li a .propic-small img { display: inline-block; width: 100%; height: 100% }
.pro li a h3 { height: 106px; padding: 20px 15px; line-height: 33px; font-weight: 500; font-size: 24px; color: #333; background: #e0e0e0 }
.pro li a h3 span { width: 65%; display: -webkit-box; -webkit-box-orient: vertical; overflow: hidden; overflow-wrap: break-word; -webkit-line-clamp: 2; text-overflow: ellipsis }
.pro li a:hover { z-index: 2; background: #fafafa; box-shadow: 0px 3px 25px 0px #b6ccea; transform: scale3d(1.26, 1.26, 1) }
.pro li a:hover h3 { color: #fff; background: #003f96 }

/*skill*/
.skill li a { display: block; position: relative; padding: 20px 15px 50px; text-align: center; background: #fafafa; -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); transition: .42s ease }
.skill li a figure { width: 100%; height: 218px; margin: 0 }
.skill li a figure img { display: inline-block; width: 100%; height: 100% }
.skill li a h3 { margin-top: 50px; line-height: 40px; font-weight: 400; font-size: 28px; color: #333 }
.skill li a p { margin-top: 25px; line-height: 27px; font-weight: 400; font-size: 14px; color: #666 }
.skill li a:hover { z-index: 2; background: #003f96; border-radius: 36px; transform: scale3d(1.1, 1.2, 1) }
.skill li a:hover h3, .skill li a:hover p { color: #fff }

/*about*/
.aboutbar { margin-top: 100px; padding-bottom: 100px; background: #235da7 url(../images/about_bg.png) no-repeat top center; background-size: cover }
.aboutbar .tittop { padding: 80px 0 }
.aboutbar .title h2, .aboutbar .title p { color: #fff }
.aboutbar .title h2:after { background: #fff }
.aboutbar .col-5 { flex: 0 0 46%; max-width: 46% }
.aboutbar .col-7 { flex: 0 0 54%; max-width: 54% }

.about-info { color: #fff }
.about-info p { position: relative; line-height: 36px; font-weight: 400; font-size: 18px }
.about-info p>a{color: #003f96; text-decoration: underline;}
.about-info p a.about-more { position: absolute; right: 0; bottom: 0; color: #fff; text-decoration: none; opacity: .6 }
.about-info p a.about-more:hover { opacity: 1 }
.about-pic { width: 100%; margin-top: 34px; justify-content: space-between }
.about-pic img { display: inline-block; width: 30%; height: 118px }
.about-video { width: 100%; height: 100% }
.about-count { width: 100%; margin-top: 100px; align-content: center; justify-content: space-around; align-items: center; border-radius: 33px; border: 1px solid #fff }
.about-count li { flex: 1; padding: 58px 0; border-right: 1px solid #fff; text-align: center; color: #fff }
.about-count li:last-child { border-right: none }
.about-count li b { font-family: Arial-Black, Arial; font-weight: 900; font-size: 51px }
.about-count li b sup { margin-left: 5px; font-style: normal; font-weight: 500; font-size: 42px }
.about-count li p { margin-top: 5px; line-height: 25px; letter-spacing: 1px; font-size: 18px; opacity: .6 }

/*partner*/
.partnerbar { width: 100%; background: url(../images/partner_bg.png) no-repeat top right }
.partner { position: relative; width: 100%; height: 152px; margin-top: 10px; padding: 0 24px }
.partner-scrolling { width: 100%; height: 152px; padding: 26px }
.partner-scrolling ul { height: 100px }
.partner-scrolling ul li { width: 20%; height: 100px; line-height: 100px; text-align: center; cursor: grab; background: #ffff; border: 1px solid #eaeaea; box-sizing: border-box; -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); transition: .42s ease }
.partner-scrolling ul li img { width: auto; max-height: 98px; height: auto }
.partner-scrolling ul li:hover { border-color: #003f96; transform: scale3d(1.12, 1.12, 1); box-shadow: 0px 6px 16px 0px rgba(227, 227, 227, 0.5) }
.partner .partner-prev, .partner .partner-next { display: block; position: absolute; top: 50%; z-index: 1; width: 32px; height: 32px; line-height: 32px; text-align: center; margin-top: -15px; font-size: 30px; font-weight: 600; color: #000 }
.partner .partner-prev { left: 0 }
.partner .partner-next { right: 0 }
.partner .partner-prev:hover, .partner .partner-next:hover { cursor: pointer; color: #003f96 }

/*news*/
.newsbar { padding-bottom: 50px }
.newsbar .tittop { align-items: center }
.newsbar .hd ul li { display: inline-block; width: 150px; height: 40px; line-height: 40px; font-size: 21px; font-weight: 400; color: #003f96; cursor: pointer; text-align: center; background: rgba(0, 63, 150, .1) }
.newsbar .hd ul li.on { color: #fff; background: #003f96 }

.news-hot { padding: 40px; background: #fafafa }
.news-hot time { line-height: 29px; font-weight: 400; font-size: 21px; color: #333 }
.news-hot h3 { margin-top: 6px; line-height: 29px; font-weight: 400; font-size: 21px; color: #333 }
.news-hot p { margin-top: 10px; padding-left: 15px; line-height: 22px; font-weight: 400; font-size: 16px; color: #666; border-left: 1px solid #c0c0c0 }
.news-hot figure { width: 100%; height: 140px; margin: 19px 0; cursor: grab; overflow: hidden }
.news-hot figure img { display: inline-block; width: 100%; height: 100%; -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); transition: .42s ease }
.news-hot figure:hover img { transform: scale3d(1.1, 1.1, 1) }
.news-hot a.more { display: block; width: 150px; height: 40px; line-height: 40px; font-size: 21px; text-align: center; color: #fff; background: #003f96 }
.news-hot a.more:hover { background: #122e53 }

.news-list { border-top: 1px solid #eee }
.news-list li { padding-top: 6px; padding-bottom: 20px; border-bottom: 1px solid #eee }
.news-list li h3 { display: flex; justify-content: space-between; align-items: center; padding-left: 55px; line-height: 60px; font-weight: 400; font-size: 21px; color: #333; background: url(../images/browser.png) no-repeat 20px center }
.news-list li h3:hover { background-image: url(../images/browser_hover.png) }
.news-list li p { position: relative; padding-right: 30%; padding-left: 55px; line-height: 22px; font-weight: 400; font-size: 16px; color: #666 }
.news-list li p a { position: absolute; right: 0; bottom: 3px; display: inline-block; height: 18px; padding-left: 20px; line-height: 18px; font-size: 18px; color: #666; border-left: 1px solid #dadce5 }
.news-list li p a:hover { color: #003f96; border-left-color: #003f96 }

.link{}
.link span{ color: #333 }
.link a{ margin-right: 15px }

/*grid*/
@media only screen and (max-width:1400px){

}

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

}

@media only screen and (max-width:992px){
    /*tilte*/
    .tittop { padding: 60px 0 }

    /*pro*/
    .pro li { flex: 0 0 33.33333%; max-width: 33.33333% }

    /*skill*/
    .skill li { flex: 0 0 50%; max-width: 50%; margin-bottom: 20px }
    .skill li a { padding: 20px 15px 36px }
    .skill li a h3 { margin-top: 36px }
    .skill li a p { min-height: 54px; margin-top: 15px }

    /*about*/
    .aboutbar { margin-top: 50px; padding-bottom: 36px }
    .aboutbar .tittop { padding: 60px 0 }
    .aboutbar .col-5 { flex: 0 0 100%; max-width: 100% }
    .aboutbar .col-7 { flex: 0 0 100%; max-width: 100%; margin-top: 20px }
}

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

}

@media only screen and (max-width:576px){
    /*slide*/
    .slide { height: 18.75rem }
    .slide .swiper-slide { height: 18.75rem }
    .slide .swiper-slide .slide-img { height: 18.75rem }
    .slide .swiper-button-prev, .slide .swiper-button-next { display: none }
    .slide .swiper-page { bottom: 1rem }
    .slide .swiper-page .swiper-pagination-bullet { height: 10px; width: 10px }
    .slide .swiper-page .swiper-pagination-bullet-active { width: 42px }

    /*tilte*/
    .tittop { padding: 36px 0 }
    .tittop a.more { font-size: 16px }
    .title h2 { font-size: 26px }
    .title h2:after { width: 60px; height: 2px }
    .title p { font-size: 20px }

    /*pro*/
    .pro li { flex: 0 0 100%; max-width: 100%; margin-bottom: 20px }
    .pro li:last-child { margin-bottom: 0 }

    /*skill*/
    .skill li { flex: 0 0 100%; max-width: 100% }
    .skill li:last-child { margin-bottom: 0 }
    .skill li a p { min-height: inherit }

    /*about*/
    .aboutbar { margin-top: 50px; padding-bottom: 36px }
    .aboutbar .tittop { padding: 36px 0 }
    .about-info p { font-size: 16px }
    .about-pic img { height: 88px }
    .about-count { margin-top: 36px }
    .about-count li { flex: 0 0 50%; max-width: 50%; padding: 36px 0 }
    .about-count li:first-child { border-bottom: 1px solid #fff }
    .about-count li:nth-child(2) { border-right: none; border-bottom: 1px solid #fff }
    .about-count li b { font-size: 36px }
    .about-count li b sup { font-size: 24px }
    .about-count li p { letter-spacing: 0; font-size: 16px }

    /*news*/
    .newsbar { padding-bottom: 0 }
    .newsbar .tittop { align-items: center }
    .newsbar .hd { margin-top: 20px }
    
    .link{ display: none }
}