/* about */
.about-page-banner {
    background: url(../images/about-page-banner.jpg) no-repeat center top;
}

.business-page-banner {
    background: url(../images/business-page-banner.jpg) no-repeat center top;
}

.team-page-banner {
    background: url(../images/team-page-banner.jpg) no-repeat center top;
}

.case-page-banner {
    background: url(../images/case-page-banner.jpg) no-repeat center top;
}

.news-page-banner {
    background: url(../images/news-page-banner.jpg) no-repeat center top;
}

.page-banner {
    width: 100%;
    height: 560px;
    background-size: auto 100%;
    display: table;
    margin-bottom: 96px;
}

.page-banner h1 {
    font-size: 56px;
    color: #fff;
    font-weight: bold;
    display: table-cell;
    vertical-align: middle;
}

.page-banner h1 em {
    width: 15%;
    height: 1px;
    background-color: #fff;
    display: inline-block;
    vertical-align: middle;
    margin-right: 24px;
    position: relative;
}

.page-banner h1 em::after {
    display: block;
    content: "";
    width: 5px;
    height: 5px;
    background-color: #fff;
    position: absolute;
    top: -2px;
    right: 0;
}

.part-title-black {
    text-align: center;
    margin-bottom: 56px;
}

.part-title-black h1 {
    font-size: 28px;
    font-weight: bold;
    margin-bottom: 12px;
    text-align: center;
    color: #333;
}

.part-title-black span {
    display: inline-block;
    margin: auto;
    margin-bottom: 12px;
    position: relative;
}

.part-title-black span::after {
    display: block;
    content: "";
    width: 64px;
    height: 1px;
    background-color: #D8D8D8;
    position: absolute;
    right: -80px;
    top: 8px;
}

.part-title-black span::before {
    display: block;
    content: "";
    width: 64px;
    height: 1px;
    background-color: #D8D8D8;
    position: absolute;
    left: -80px;
    top: 8px;
}

.part-title-black p {
    font-size: 14px;
    color: #333;
    line-height: 24px;
}

.page-about-compony {
    padding: 96px 0;
    background: url(../images/page-compony-bg.jpg) no-repeat top center;
    margin-top: -96px;
}

.w1280 {
    width: 1280px;
    max-width: 95%;
    margin: auto;
}

.about-compony-desc {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.about-compony-desc-left {
    margin-right: 60px;
    flex: 1;
}

.about-compony-desc-left h1 {
    font-size: 32px;
    font-weight: bold;
    color: #063887;
    margin-bottom: 24px;
}

.idx-aboutus-left-desc-content {
    font-size: 14px;
    color: #333;
    line-height: 1.5;
    height: 290px;
    overflow-y: auto;
}

.about-compony-desc-right {
    flex-shrink: 0;
}

.about-compony-desc-right img {
    max-width: 100%;
}

.page-about-culture {
    margin: 96px 0;
}

.about-culture-content {
    height: 570px;
    background: url(../images/about-culture-bg.jpg) no-repeat top center;
}

.about-culture-swiper-container {
    height: 100%;
}

.about-culture-swiper-container .swiper-slide {
    position: relative;
}

.about-culture-swiper-container .swiper-slide:nth-child(2) {
    border-left: 1px solid rgba(255, 255, 255, .4);
    border-right: 1px solid rgba(255, 255, 255, .4);
}

.about-culture-item {
    width: 60%;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    transition: all .4s ease 0s;
    -webkit-transition: all .4s ease 0s;
    -moz-transition: all .4s ease 0s;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%);
    margin-top: -75px;
}

.about-culture-item h1 {
    font-size: 28px;
    color: #fff;
    margin: 24px 0;
}

.about-culture-item p {
    font-size: 16px;
    color: #fff;
    line-height: 24px;
    text-align: center;
    transition: all .4s ease 0s;
    -webkit-transition: all .4s ease 0s;
    -moz-transition: all .4s ease 0s;
    opacity: 0;
    visibility: hidden;
}

.about-culture-item p::before {
    content: "";
    display: block;
    width: 28px;
    height: 3px;
    background-color: #fff;
    margin: auto;
    margin-bottom: 32px;
}

.about-culture-swiper-container .swiper-slide:hover .about-culture-item {
    margin-top: -116px;
}

.about-culture-swiper-container .swiper-slide:hover .about-culture-item p {
    opacity: 1;
    visibility: visible;
}

.about-history-content-box {
    position: relative;
    margin-bottom: 96px;
}

.about-history-content-box .swiper-button-prev {
    width: 32px;
    height: 32px;
    border: 1px solid #D8D8D8;
    background: none;
    background-color: #fff;
    position: absolute;
    left: -48px;
    top: 50%;
    right: inherit;
    display: inline-block;
    margin: 0;
    text-align: center;
    line-height: 30px;
    transition: all .4s ease 0s;
    -webkit-transition: all .4s ease 0s;
    -moz-transition: all .4s ease 0s;
}

.about-history-content-box .swiper-button-next {
    width: 32px;
    height: 32px;
    border: 1px solid #D8D8D8;
    background: none;
    background-color: #fff;
    position: absolute;
    top: 50%;
    left: inherit;
    right: -48px;
    display: inline-block;
    margin: 0;
    text-align: center;
    line-height: 30px;
    transition: all .4s ease 0s;
    -webkit-transition: all .4s ease 0s;
    -moz-transition: all .4s ease 0s;
}

.about-history-content-box .swiper-button-prev i,
.about-history-content-box .swiper-button-next i {
    font-size: 24px;
    color: #999;
}

.about-history-content-box .swiper-button-prev:hover,
.about-history-content-box .swiper-button-next:hover {
    background-color: #063887;
    border: #063887;
}

.about-history-content-box .swiper-button-prev:hover i,
.about-history-content-box .swiper-button-next:hover i {
    color: #fff;
}

.about-history-content-box::after {
    content: '';
    display: block;
    width: 200%;
    height: 1px;
    background: rgba(0, 0, 0, .08);
    position: absolute;
    bottom: 32px;
    left: -30%;
}

.about-history-swiper-container .swiper-wrapper {
    align-items: flex-end;
}

.about-history-swiper-container .swiper-slide .about-history-content {
    padding: 24px;
    background-color: #fff;
    margin-bottom: 48px;
    margin: 24px;
}

.about-history-content h1 {
    font-size: 18px;
    color: #333;
    font-weight: bold;
    margin-bottom: 24px;
}

.about-history-content p {
    font-size: 14px;
    line-height: 1.5;
    color: #333;
    max-height: 140px;
    overflow-y: auto;
}

.about-history-time {
    text-align: center;
}

.about-history-time em {
    width: 12px;
    height: 12px;
    line-height: 12px;
    border-radius: 50%;
    background-color: #DEDEDE;
    display: inline-block;
}

.about-history-time em i {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background-color: #C1C1C1;
    display: inline-block;
    margin-bottom: 2px;
}

.about-history-time span {
    font-size: 18px;
    font-weight: bold;
    color: #333;
    text-align: center;
    display: block;
}

.about-history-content-box .swiper-slide-active .about-history-time span,
.about-history-content-box .swiper-slide:hover .about-history-time span {
    color: #063887;
}

.about-history-content-box .swiper-slide-active .about-history-content,
.about-history-content-box .swiper-slide:hover .about-history-content {
    box-shadow: 0px 0px 24px 0px rgba(0, 0, 0, 0.09);
}

.page-about-honor {
    padding: 90px 0;
    background: url(../images/about-honor-bg.jpg) no-repeat top center;
    margin-bottom: 56px;
    height: 620px;
}

.about-honor-content-box {
    position: relative;
}

.about-honor-swiper-container .swiper-wrapper {
    align-items: flex-end;
}

.about-honor-content-box .swiper-button-prev {
    width: 32px;
    height: 32px;
    border: 1px solid #D8D8D8;
    background: none;
    background-color: #fff;
    position: absolute;
    left: -48px;
    top: 50%;
    right: inherit;
    display: inline-block;
    margin: 0;
    text-align: center;
    line-height: 30px;
    transition: all .4s ease 0s;
    -webkit-transition: all .4s ease 0s;
    -moz-transition: all .4s ease 0s;
}

.about-honor-content-box .swiper-button-next {
    width: 32px;
    height: 32px;
    border: 1px solid #D8D8D8;
    background: none;
    background-color: #fff;
    position: absolute;
    top: 50%;
    left: inherit;
    right: -48px;
    display: inline-block;
    margin: 0;
    text-align: center;
    line-height: 30px;
    transition: all .4s ease 0s;
    -webkit-transition: all .4s ease 0s;
    -moz-transition: all .4s ease 0s;
}

.about-honor-content-box .swiper-button-prev i,
.about-honor-content-box .swiper-button-next i {
    font-size: 24px;
    color: #999;
}

.about-honor-content-box .swiper-button-prev:hover,
.about-honor-content-box .swiper-button-next:hover {
    background-color: #063887;
    border: #063887;
}

.about-honor-content-box .swiper-button-prev:hover i,
.about-honor-content-box .swiper-button-next:hover i {
    color: #fff;
}

.about-honor-content {
    text-align: center;
}

.about-honor-content img {
    max-width: 100%;
    max-height: 272px;
    margin: auto;
}

.footer {
    background: #252E37;
}

.footer .w1280 {
    padding: 64px 0;
    border-bottom: 1px solid #798692;
}

.footer-left {
    float: left;
}

.footer-left ul {
    margin-bottom: 24px;
}

.footer-left ul li {
    float: left;
    margin-right: 50px;
}

.footer-left ul li span {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: #246AD9;
    text-align: center;
    line-height: 48px;
    display: inline-block;
    margin-right: 16px;
    vertical-align: middle;
}

.footer-left ul li span i {
    font-size: 24px;
    color: #fff;
}

.footer-left ul li p {
    display: inline-block;
    font-size: 14px;
    color: #fff;
    vertical-align: middle;
}

.footer-left ol li {
    display: inline-block;
    margin: 0 8px;
}

.footer-left ol li a {
    font-size: 14px;
    color: rgba(255, 255, 255, .7);
}

.footer-left ol li a:hover {
    color: rgba(255, 255, 255, 1);
}

.footer-right {
    float: right;
    text-align: center;
}

.footer-right img {
    width: 90px;
    height: 90px;
    margin-bottom: 8px;
}

.footer-right p {
    text-align: center;
    font-size: 14px;
    color: #fff;
}

.page-copyright {
    text-align: center;
    padding: 12px 0;
    color: rgba(255, 255, 255, .4);
}

.page-copyright a {
    margin-left: 8px;
    color: rgba(255, 255, 255, .4);
}

/* business */

.business-type {
    margin-top: -96px;
    height: 64px;
    line-height: 64px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    margin-bottom: 56px;
}

.business-type .w1280 {
    overflow-x: auto;
    white-space: nowrap;
}

.business-type a {
    font-size: 16px;
    color: #333;
    margin-right: 64px;
    height: 100%;
    display: inline-block;
}

.business-type a.active,
.business-type a:hover {
    font-weight: bold;
    color: #063887;
}

.business-type a.active {
    border-bottom: 3px solid #063887;
}

.business-type-content-list {
    margin-bottom: 32px;
}

.business-type-content-list ul li {
    border-bottom: 1px dashed rgba(0, 0, 0, 0.08);
    padding: 20px 0;
}

.business-type-title {
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.business-type-title-left {
    flex: 1;
    padding-right: 32px;
    display: flex;
    align-items: center;
}

.business-type-title .num {
    width: 64px;
    height: 64px;
    background: url(../images/business-type-iconde.png) no-repeat top left;
    background-size: cover;
    font-size: 24px;
    color: #999;
    padding-left: 12px;
    line-height: 64px;
    margin-right: 32px;
    flex-shrink: 0;
}

.business-type-title h1 {
    font-size: 18px;
    font-weight: bold;
    color: #333;
    flex: 1;
}

.business-type-content-list ul li span {
    font-size: 24px;
    color: #999;
}

.business-type-content-list ul li span {
    width: 20px;
    height: 20px;
    position: relative;
}

.business-type-content-list ul li span::before {
    content: "";
    display: block;
    width: 20px;
    height: 2px;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    background-color: #C1C1C1;
}

.business-type-content-list ul li span::after {
    content: "";
    display: block;
    width: 2px;
    height: 20px;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    background-color: #C1C1C1;
}

.business-type-content-list ul li.active span::after {
    display: none;
}

.business-type-content-list ul li.active .num {
    color: #fff;
    background: url(../images/business-type-iconac.png) no-repeat top left;
    background-size: 100% 100%;
}

.business-type-content-list ul li.active h1 {
    color: #063887;
}

.business-type-txt {
    padding-left: 96px;
    padding-top: 16px;
    font-size: 16px;
    line-height: 1.5;
    color: #333;
    display: none;
}

.web-pagination {
    margin-bottom: 56px;
}

.web-pagination ul {
    text-align: center;
    font-size: 0;
}

.web-pagination ul li {
    width: 32px;
    height: 32px;
    border: 1px solid #D8D8D8;
    text-align: center;
    line-height: 32px;
    display: inline-block;
    vertical-align: middle;
    cursor: pointer;
    margin: 0 4px;
}

.web-pagination ul li i {
    font-size: 24px;
    color: #999;
}

.web-pagination ul li a {
    font-size: 14px;
}

.web-pagination ul li.active,
.web-pagination ul li:hover {
    background-color: #063887;
    border: 1px solid #063887;
}

.web-pagination ul li.active i,
.web-pagination ul li.active a,
.web-pagination ul li:hover i,
.web-pagination ul li:hover a {
    color: #fff;
}


/* page-team */
.page-team-content-list {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    margin-bottom: 12px;
}

.page-team-content-list .idx-team-item {
    width: calc((100% - 60px) / 4);
    margin-bottom: 20px;
    margin-right: 20px;
    cursor: pointer;
}

.page-team-content-list .idx-team-item:nth-child(4n) {
    margin-right: 0;
}

.idx-team-img {
    width: 100%;
}

.idx-team-img img {
    max-width: 100%;
}

.idx-team-item p {
    width: 100%;
    height: 48px;
    background-color: #fff;
    text-align: center;
    line-height: 48px;
    transition: all .4s ease 0s;
    -webkit-transition: all .4s ease 0s;
    -moz-transition: all .4s ease 0s;
}

.idx-team-item p span {
    font-size: 16px;
    font-weight: bold;
    color: #333;
    margin-right: 4px;
    transition: all .4s ease 0s;
    -webkit-transition: all .4s ease 0s;
    -moz-transition: all .4s ease 0s;
}

.idx-team-item p em {
    font-size: 14px;
    color: #666;
    margin-left: 4px;
    transition: all .4s ease 0s;
    -webkit-transition: all .4s ease 0s;
    -moz-transition: all .4s ease 0s;
}

.idx-team-item:hover p {
    background-color: #063887;
    color: #fff;
}

.idx-team-item:hover p span,
.idx-team-item:hover p em {
    color: #fff;
}



.team-tc-box {
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: rgba(0, 0, 0, .5);
    z-index: -1;
    transition: all .3s ease-out;
    -moz-transition: all .3s ease-out;
    -webkit-transition: all .3s ease-out;
    transform: scale(.5, .5);
    -moz-transform: scale(.5, .5);
    -webkit-transform: scale(0.5, .5);
    opacity: 0;
    visibility: hidden;
    transform-origin: center top;
}

.team-tc-box.active {
    z-index: 9999;
    opacity: 1;
    visibility: visible;
    transform: scale(1);
    -moz-transform: scale(1);
    -webkit-transform: scale(1);
}

.team-tc-content {
    width: 1200px;
    max-width: 95%;
    height: 560px;
    background-color: #fff;
    display: flex;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    padding: 72px 32px 32px;
}

.team-tc-left {
    flex-shrink: 0;
    width: 320px;
    border-right: 1px solid #D8D8D8;
    padding-right: 32px;
}

.team-tx {
    width: 108px;
    height: 108px;
    border-radius: 50%;
    overflow: hidden;
    border: solid 1px #fff;
    background-color: #fff;
    box-shadow: 0px 8px 4px 0px rgba(0, 0, 0, 0.12);
    margin: auto;
    margin-bottom: 32px;
}

.team-tx img {
    width: 100%;
    object-fit: cover;
}

.team-tc-left h1 {
    font-size: 28px;
    color: #333;
    margin-bottom: 12px;
    text-align: center;
}

.team-tc-left p {
    font-size: 16px;
    color: #666;
    text-align: center;
    margin-bottom: 32px;
}

.team-tc-left ul li {
    font-size: 16px;
    color: #333;
    margin-bottom: 12px;
}

.team-tc-left ul li i {
    font-size: 16px;
    color: #063887;
    margin-right: 4px;
}

.team-tc-right {
    padding-left: 32px;
    font-size: 16px;
    color: #333;
    line-height: 24px;
    overflow-y: auto;
}

.team-tc-close {
    width: 48px;
    height: 48px;
    text-align: center;
    line-height: 48px;
    position: absolute;
    top: 0;
    right: 0;
    cursor: pointer;
}

.team-tc-close i {
    font-size: 24px;
    color: #999;
}

.team-tc-close:hover i {
    color: #063887;
    transition: all .4s ease-out;
    -moz-transition: all .4s ease-out;
    -webkit-transition: all .4s ease-out;
}

/* case */
.page-case-content-list {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    margin-bottom: 12px;
}

.page-case-content-list .idx-case-item {
    width: calc((100% - 60px) / 3);
    margin-bottom: 20px;
    margin-right: 20px;
    cursor: pointer;
}

.page-case-content-list .idx-case-item:nth-child(3n) {
    margin-right: 0;
}

.idx-case-item {
    background-color: rgba(255, 255, 255, .9);
    border: 1px solid rgba(0, 0, 0, 0.08);
    padding: 32px;
    transition: all .4s ease 0s;
    -webkit-transition: all .4s ease 0s;
    -moz-transition: all .4s ease 0s;
    position: relative;
    top: 0;
}

.idx-case-item a {
    display: block;
}

.idx-case-item a h1 {
    font-size: 16px;
    color: #333;
    margin-bottom: 8px;
    transition: all .4s ease 0s;
    -webkit-transition: all .4s ease 0s;
    -moz-transition: all .4s ease 0s;
}

.idx-case-item a h1::before {
    display: block;
    content: "";
    width: 32px;
    height: 4px;
    background-color: #063887;
    margin-bottom: 24px;
}

.idx-case-item a p {
    font-size: 14px;
    color: #666;
    margin-bottom: 8px;
}

.idx-case-item a span {
    font-size: 12px;
    color: #666;
}

.idx-case-item:hover {
    position: relative;
    top: -8px;
    background-color: #fff;
    box-shadow: 0px 8px 12px 0px rgba(0, 0, 0, 0.08);
}

.idx-case-item:hover h1 {
    color: #063887;
    font-weight: bold;
}

/* detail */
.article-detail-page {
    margin-bottom: 56px;
}

.article-detail-title {
    margin-bottom: 32px;
    text-align: center;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    padding-bottom: 24px;
}

.article-detail-title h1 {
    font-size: 28px;
    font-weight: bold;
    color: #333;
    text-align: center;
    margin-bottom: 24px;
}

.article-detail-title span {
    font-size: 14px;
    color: #999;
    margin: 0 16px;
}

.article-detail-title span i {
    font-size: 14px;
    color: #d6d6d6;
    margin-right: 4px;
}

.article-detail-content {
    font-size: 14px;
    line-height: 1.5;
    padding-bottom: 48px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    margin-bottom: 32px;
}

.btn-link-default {
    font-size: 14px;
    color: #063887;
    display: inline-block;
    padding: 8px 48px;
    border: 2px solid #063887;
}

.btn-link-default i {
    font-size: 16px;
    /* vertical-align: -1px; */
    transition: all .4s ease 0s;
    -webkit-transition: all .4s ease 0s;
    -moz-transition: all .4s ease 0s;
    margin-right: 4px;
}

.btn-link-default:hover {
    background-color: #063887;
}

.btn-link-default:hover,
.btn-link-default:hover i {
    color: #fff;
}

/* news */
.page-news-content-list {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    margin-bottom: 12px;
}

.idx-news-item {
    width: calc((100% - 60px) / 3);
    margin-bottom: 20px;
    margin-right: 20px;
    padding: 16px;
    background-color: #fff;
    transition: all .4s ease 0s;
    -webkit-transition: all .4s ease 0s;
    -moz-transition: all .4s ease 0s;
    position: relative;
    top: 0;
}

.idx-news-item .idx-news-img {
    width: 100%;
    height: 210px;
    overflow: hidden;
    margin-bottom: 24px;
}

.idx-news-item .idx-news-img img {
    width: 100%;
    height: 100%;
}

.idx-news-item h1 {
    font-size: 18px;
    color: #333;
    margin-bottom: 12px;
    transition: all .4s ease 0s;
    -webkit-transition: all .4s ease 0s;
    -moz-transition: all .4s ease 0s;
}

.idx-news-item p {
    font-size: 14px;
    color: #666;
    margin-bottom: 12px;
}

.idx-news-item:hover {
    box-shadow: 0px 8px 12px 0px rgba(0, 0, 0, 0.08);
    top: -8px;
}

.idx-news-item:hover h1 {
    color: #063887;
    font-weight: bold;
}

/* customer */
.page-customer-content-list {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    margin-bottom: 12px;
}

.page-customer-content-list .page-customer-item {
    width: calc((100% - 60px) / 4);
    background-color: #fff;
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(0, 0, 0, 0.08);
    margin: 0 20px 20px 0;
}

.page-customer-content-list .page-customer-item:nth-child(4n) {
    margin: 0 0 20px 0;
}

.page-customer-content-list .page-customer-item img {
    max-width: 100%;
}

.page-customer-content-list .page-customer-item p {
    font-size: 20px;
    color: #fff;
    width: 100%;
    height: 0%;
    text-align: center;
    padding: 12px;
    background-color: #063887;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    bottom: 50%;
    z-index: 1;
    transition: all .4s ease 0s;
    -webkit-transition: all .4s ease 0s;
    -moz-transition: all .4s ease 0s;
    opacity: 0;
}

.page-customer-content-list .page-customer-item:hover p {
    height: 100%;
    bottom: 0;
    opacity: 1;
    transform: translateY(0%);
}
