@charset "utf-8";
/**
 * Created by sunJia on 2025/03/07.
 * @Description: Global Styles
 */

.flex{ display: flex; display: -ms-flexbox; justify-content: space-between; -ms-justify-content: space-between; -ms-flex-pack: justify;}
body{ -webkit-tap-highlight-color: transparent;}/* 移动端点击，取消选中背景 */
@font-face {
  font-family: 'DIN';
  src: url('../images/DIN-Bold.eot');
  src: url('../images/DIN-Bold.eot?#iefix') format('embedded-opentype'),
      url('../images/DIN-Bold.woff2') format('woff2'),
      url('../images/DIN-Bold.woff') format('woff'),
      url('../images/DIN-Bold.ttf') format('truetype');
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}

/* header */
header{
  position: relative;
  width: 100%;
  left: 0;
  top: 0;

  z-index: 2;
}
/* header::before{
  content: '';
  display: block;
  width: 100%;
  height: 0;
  padding-bottom: 14.58%;
  background-image: -moz-linear-gradient( 90deg, rgba(0,0,0,0) 0%, rgb(0,0,0) 100%);
  background-image: -webkit-linear-gradient( 90deg, rgba(0,0,0,0) 0%, rgb(0,0,0) 100%);
  background-image: -ms-linear-gradient( 90deg, rgba(0,0,0,0) 0%, rgb(0,0,0) 100%);
  opacity: 0.7;
  position: absolute;
  left: 0px;
  top: 0px;
  z-index: -1;
  pointer-events: none;
} */
header .headTop{
  background-size: auto 100%;
}
header .headTop > .flex{
  padding: 30px 0;
  align-items: center;
  background: url(../images/head_bg.png) no-repeat;
  background-position: calc(100% - 0px) top;
}
.logo{
  align-items: center;
}
.logo a{
  display: block;
  font-size: 0;
}
.logo01{
  position: relative;
  margin-right: 40px;
}
.logo01::before{
  content: '';
  display: block;
  width: 3px;
  height: 60px;
  background: #1e4b57;
  position: absolute;
  right: -20px;
  top: 50%;
  transform: translateY(-50%);
  opacity: 0.3;
}
.logo img{
  max-height: 100px;
}

.headBottom{
  background: url(../images/nav_bg.png) no-repeat center/cover;
}
.headBottom > .flex{
  align-items: center;
}

.nav{ position: relative;}
.nav ul{ position: relative; justify-content: space-between; gap: 100px;}
.nav li{ position: relative;}
.nav li:first-child{ margin-left: 40px;}
.nav li > a{ display: block; width: 90px;line-height: 50px; padding: 0px; font-weight: bold; color: #fff;position: relative;}
.nav li > a::before{ content: ''; display: block; width: 0%; height: 3px;background: #f8b551;
  position: absolute;left: 50%;bottom: 0px;transform: translateX(-50%);transition: all 0.35s ease;}
.nav li:hover > a::before,
.nav li > a.on::before,
.nav li > a.active::before{ width: 100%;}
.nav .subnav{ display: none; position: absolute; top: 100%; left: 50%;transform: translateX(-50%); width: 100%; min-width: 160px;
    box-sizing: border-box; padding: 10px 0 15px; border-top: 1px solid #f8b551;z-index: 1;overflow: hidden;
    background: url(../images/subnav_bg.png) no-repeat center bottom; background-size: 100% 30px;}
.nav .subnav::before{ content: '';display: block;width: 100%;height: 100%;background: #1e4b57;opacity: 0.55;
  position: absolute;bottom: 0px;left: 0;z-index: -1;}
.nav dd a{ display: block; padding: 8px 0; text-align: center; line-height: 20px; color: #fff;}
.nav dd a:hover{ color: #1e4b57;background: #fff;}

/*手机端导航默认*/
.mobile_bg{width: 100%;height: 100%;z-index: 90;position: fixed;top: 0;left: 0;background: rgba(0,0,0,0.6);display: none;}
.gp-menu{ display: none; width: 100%;z-index: 98;height: 100%;position: relative;}
.gp-menu-header{position: absolute;top: 0;right: 0;z-index: 996;width: 100%;height: 40px;background: rgba(0,0,0,0);}
.gp-menu-link{float: left;line-height: 40px;height: 40px;padding-left: 15px;}
.gp-menu-link a{color:#fff;}
.gp-menu-header-icon{color: #fff; height: 40px;font-size:25px;text-align: center; float:right;width: 40px;position: relative;  -webkit-transition: background 0.5s; -moz-transition: background 0.5s; -o-transition: background 0.5s; transition: background 0.5s;margin-right: 10px;cursor: pointer;}
.gp-menu-header-icon span{  position: absolute; left: calc((100% - 25px) / 2);  top: calc((100% - 2px) / 3);  width: 27px;  height: 3px;  background-color: #003670;}
.gp-menu-header-icon-out span{width: 27px;height: 4px;background-color:#1e4b57;display: block;border-radius: 4px;}
.gp-menu-header-icon-out span:nth-child(1){animation-duration: 0.5s;animation-fill-mode: both;animation-name: outfirst;}       
.gp-menu-header-icon-out span:nth-child(2){animation-duration: 0.5s;animation-fill-mode: both;animation-name: outsecond;}
.gp-menu-header-icon-out span:nth-child(3){animation-duration: 0.5s;animation-fill-mode: both;animation-name: outthird;}
.gp-menu-header-icon span:nth-child(1){transform: translateY(4px) rotate(0deg);}
.gp-menu-header-icon span:nth-child(2){transform: translateY(-4px) rotate(0deg);}
.gp-menu-header-icon span:nth-child(3){transform: translateY(-4px) rotate(0deg);}
@keyframes outfirst {
  0% {transform: translateY(0) rotate(-45deg);}
  100% {transform: translateY(-4px) rotate(0deg);}
}   
@keyframes outsecond {
  0% { transform: translateY(0) rotate(45deg);}
  100% {transform: translateY(4px) rotate(0deg);}
}
@keyframes outthird {
  0% {transform: translateY(0) rotate(90deg);}
  100% {transform: translateY(12px) rotate(0deg); }
}
.gp-menu-header-icon-click span{background-color:#fff ;top: calc((100% - 2px) / 2.1);}
.gp-menu-header-icon-click span:nth-child(1){animation-duration: 0.5s; animation-fill-mode: both;animation-name: clickfirst;}     
.gp-menu-header-icon-click span:nth-child(2){animation-duration: 0.5s; animation-fill-mode: both;animation-name: clicksecond;}
.gp-menu-header-icon-click span:nth-child(3){animation-duration: 0.5s; animation-fill-mode: both;animation-name: clickthird;}
@keyframes clickfirst {
  0% {transform: translateY(4px) rotate(0deg);}
  100% {transform: translateY(0) rotate(45deg);}
}   
@keyframes clicksecond {
  0% {transform: translateY(-4px) rotate(0deg);}
  100% {transform: translateY(0) rotate(-45deg);}
} 
@keyframes clickthird {
    0% {  opacity: 0}
  100% {opacity: 0}
}   
.gp-menu-nav{ width: 100%; max-height: 100vh; overflow-y: scroll;
  position: fixed;top: 0;right: 0px;padding: 40px;display: none;background:#152583;}

.gp-m-logo{ padding-left: 10px; height: 50px; border-bottom: none !important;margin-bottom: 10px;}
.gp-m-logo img{ height: 100%; max-width: unset; width: auto;}
/*导航*/
.gp-menu-nav a{}
.gp-menu-nav > ul { padding-bottom: 20px;}
.gp-menu-nav > ul li{-webkit-animation-duration: 0.5s;animation-duration: 0.5s;-webkit-animation-fill-mode: both;animation-fill-mode: both;-webkit-animation-name: returnToNormal;animation-name: returnToNormal;}
.gp-menu-nav > ul > li{position: relative;border-bottom: 1px solid rgba(255,255,255,0.3);}
.gp-menu-nav > ul > li > a{display: inline-block;padding:14px 0 14px 25px;font-size: 16px;}
.gp-menu-nav > ul > li > ul {background: rgba(0,0,0,0.1);padding:0 25px}
.gp-menu-nav > ul > li > ul a{display: inline-block;padding:10px 0; font-size: 14px;}
.gp-menu-arrow {cursor: pointer;width: 30px;height: 50px;line-height: 50px;color:#fff;text-align: center;position: absolute;right: 0;top: 0;font-size: 20px;margin-right: 10px;transition: all 0.3s ease-in-out;}
.gp-menu-nav > ul > li.on .gp-menu-arrow{transform: rotate(90deg);}
.gp-menu-nav li ul {display: none;}
/*导航内标签效果*/
.gp-menu-nav a{color:#fff;}
.open .gp-menu-link{display: none;}
.open .gp-menu-header{background: none;}
@-webkit-keyframes returnToNormal {
  from {
    opacity: 0;-webkit-transform: translate3d(0, 100%, 0);transform: translate3d(0, 100%, 0);
  }
  to {
    opacity: 1;-webkit-transform: none;transform: none;
  }
}
@keyframes returnToNormal {
  from {
    opacity: 0;-webkit-transform: translate3d(0, 100%, 0);transform: translate3d(0, 100%, 0);
  }
  to {
    opacity: 1;-webkit-transform: none;transform: none;
  }
}
/* search */
.search{ border-radius: 20px; background: rgba(255,255,255,0.3);}
.gp-search{position: relative;width:200px;height: 40px;line-height:40px;border: 0px solid rgba(255,255,255,0.16);
  overflow: hidden;display: inline-block;vertical-align: middle;border-radius: 20px;overflow: hidden;
  transition: all 0.35s ease-in-out;*display: inline;*zoom:1;}
.gp-ser{width:100%; height:40px; z-index:9999994; margin:0 auto;position: relative;}
.gp-search input,.gp-search button{position:absolute;border:none;height: 100%;background:transparent;top:0px;overflow: hidden; }
.gp-search input.notxt{color:#fff; width:100%;left: 0;padding-left: 15px;padding-right: 70px;outline: none;box-sizing: border-box;font-size: 14px;}
.gp-search input.notxt::placeholder{ color: #fff;}
.gp-search input.notxt:focus{ }
.gp-search .notxt1{position: absolute;width: 64px;right:0px;cursor:pointer;color:#d0121b;font-size: 18px;border-radius: 20px;}
.gp-search .notxt1::before{ content: '';display: block;width: 100%;height: 100%; background: #E30113 url(../images/search.png) no-repeat center;
  position: absolute;left: 50%;top: 50%;transform: translate3d(-50%,-50%,0);}

.gp-pc-links a{
  position: relative;
  color: #fff;
}
.gp-pc-links a::after{
  content: '';
  display: block;
  width: 1px;
  height: 20px;
  background: rgba(255,255,255,0.3);
  position: absolute;
  left: -23px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
  pointer-events: none;
}


/* 侧栏悬浮 */
.fixdBox{
  width: 117px;
  position: fixed;
  right: 50px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  color: #fff;
  text-align: center;
}
.fixdCon{
  display: block;
}
.robot{
  opacity: 0;
  transform: translateY(80px);
}
.robot.show{
  transition: all 1s ease;
  opacity: 1;
  transform: translateY(-50%);
}
.robotBox{
  font-size: 0;
}
.robotBox > img{
  animation: robot 2s ease infinite;
}
.robotBase{
  animation: robotBase 2s ease infinite;
}
@keyframes robot {
  0%{ transform: translateY(0px);}
  50%{ transform: translateY(-10px);}
  100%{ transform: translateY(0px);}
}
@keyframes robotBase {
  0%{ opacity: 1;}
  50%{ opacity: 0.3;}
  100%{ opacity: 1;}
}
.robot .name{
  color: #333;
  font-weight: bold;
  line-height: 25px;
}
.robot .name.active{
  color: #fff;
}





/* footer */
footer{
  position: relative;
  z-index: 1;
  background: url(../images/footer_bg.png) no-repeat center left/cover;
  padding: 50px 0;
}
footer *{ color: rgba(255,255,255,1);}

footer .left{
  width: 330px;
  flex-shrink: 0;
}
footer .middle{
  width: 800px;
  text-align: center;
}
.ft-logo{
  font-size: 0;
  margin-top: -100px;
}
.ft-logo a{
  display: block;
}
.ft-logo2{
  margin: 10px 0 20px;
}
footer .middle .flex{
  justify-content: center;
  gap: 0 30px;
  flex-wrap: wrap;
}
footer .middle span{
  line-height: 20px;
}
.copy{
  margin-top: 10px;
}

footer .right{
  position: relative;
  width: 230px;
}
footer .ft-links a{
  display: block;
  width: 100px;
}
footer .ft-links .img{
  position: relative;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  margin: 0 auto;
}
footer .ft-links a:nth-of-type(1) .img{
  background: #EC922A;
}
footer .ft-links a:nth-of-type(2) .img{
  background: #0084FF;
}
footer .ft-links .img img{
  position: absolute;
  top: 50%;
  left: 50%;
  margin-top: -10px;
  margin-left: -10px;
}
footer .ft-links .name{
  font-weight: bold;
  text-align: center;
  margin-top: 4px;
}
.codeBox{
  margin-top: 20px;
  gap: 10px;
}
.code{
  display: inline-block;
  text-align: center;
  width: auto;
}
.code .gp-img-responsive{
  padding-bottom: 100%;
}
.code .gp-img-responsive img{
  transform: none;
  opacity: 1;
}
.code .img{
  max-width: 100px;
  margin: 0 auto;
}
.code .name{
  line-height: 20px;
  margin-top: 10px;
  text-wrap: nowrap;
}


footer dt{
  line-height: 1;
  border-bottom: 1px solid rgba(255,255,255,0.2);
  margin-bottom: 10px;
}
footer dt span{
  display: inline-block;
  position: relative;
  padding-bottom: 20px;
  line-height: 25px;
  color: #fff;
}
footer dt span::before{
  content: '';
  display: none;
  height: 2px;
  width: 100%;
  max-width: 50px;
  background: #f8b551;
  position: absolute;
  left: 0;
  bottom: 0px;
}
footer dl{
  display: flex;
  display: -ms-flexbox;
  flex-wrap: wrap;
}
footer dt{
  width: 100%;
}
footer dd{
  display: flex;
  display: -ms-flexbox;
  flex-wrap: wrap;
  width: 50%;
}
footer dd a{
  display: block;
  line-height: 20px;
  margin-top: 20px;
}
footer .left a{
  display: block;
  color: #fff;
  line-height: 20px;
}
footer a:hover{
  color: #fff;
}



/* 响应式样式 */
@media screen and (max-width:1680px){
  
}

@media screen and (max-width:1540px) {
  .nav ul{
    gap: 60px;
  }
}

@media screen and (max-width:1480px) {
  .logo a img{
    max-height: 100px;
  }
  .nav li > a{
    line-height: 50px;
  }

  .soso{
  float:right;margin-right:120px;margin-top:-60px;
}
}

@media screen and (max-width:1280px) {
  footer{
    padding: 30px 0;
  }
  footer .left{
    width: 320px;
  }
  footer .middle .flex{
    gap: 10px;
  }
  .ft-logo{
    margin-top: -90px;
    margin-bottom: 15px;
  }
  .ft-logo1 img{
    max-height: 135px;
  }
  .ft-logo2{
    margin: 10px 0;
  }
  .ft-logo2 img{
    max-height: 55px;
  }
  .soso{
  float:right;margin-right:120px;margin-top:-30px;
}
}

@media screen and (max-width:1240px) {
  
}

@media screen and (max-width:1200px) {
  footer .middle .flex{
    flex-wrap: wrap;
  }
}

@media screen and (max-width:1100px) {
  .nav li > a{
    font-size: 18px;
    font-weight: normal;
  }
  .nav ul{ gap: 40px;}
  .gp-pc-links a::after{ left: -20px;}
}

@media screen and (min-width:999px) and (max-width:1080px) {
  footer .middle .flex{
    gap: 5px 10px;
  }
  .copy{
    margin-top: 5px;
  }
}

@media screen and (max-width:998px) {
  .nav, header .intro, .gp-search{ display: none;}
  .gp-menu{ display: block; top: -50px;}
  .gp-search .notxt1::before{ background: rgba(255,255,255,0.3) url(../images/search.png) no-repeat center;}
  .fixdBox{ right: 10px;}

  .open header{
    z-index: 50;
  }
  header .headTop > .flex{
    background-size: auto 160%;
    background-position: calc(100% - 10vw) top;
  }
  .logo{
    justify-content: flex-start;
    width: 90%;
    max-width: 400px;
    flex-shrink: 0;
  }
  .logo a img{
    height: auto !important;
  }
  .gp-menu-header-icon{ margin-right: 0;}
  .gp-menu-header{ width: auto;}
  .gp-menu-nav{
    padding-top: 60px;
  }
  footer .flex:has(.left){
    flex-direction: column;
  }
  footer .left{
    width: 100%;
  }
  footer dd{
    display: flex;
    display: -ms-flexbox;
    flex-wrap: wrap;
    width: 100%;
  }
  footer dd a{
    width: 25%;
  }
  footer .middle{ 
    width: 100%;
    margin-top: 20px;
  }
  .ft-logo{
    margin: 0 0 10px;
  }
  .ft-logo1 img{
    max-height: 120px;
  }
  .ft-logo2{
    margin: 0;
  }
  footer .right{
    width: 100%;
    margin-top: 20px;
  }
  footer .right > .flex{
    justify-content: center;
    gap: 30px;
  }
}

@media screen and (max-width:880px) {
  
}

@media screen and (max-width:767px) {
  footer dd a{
    width: 33.33%;
  }
}

@media screen and (max-width:680px) {
  
}

@media screen and (max-width:540px) {
    .soso{
 display: none;
}
}
  
@media screen and (max-width:479px) {
  footer dd{
    gap: 0px 20px;
  }
  footer .left a{
    margin-top: 10px;
    width: auto;
  }
  .ft-logo1 img{
    max-height: 100px;
  }
  .ft-logo2 img{
    max-height: 45px;
  }
}

@media screen and (max-width:414px) {
  header .headTop > .flex{
    background-size: auto 100%;
  }
  .logo{
    width: 85%;
  }
  .logo01{
    margin-right: 20px;
  }
  .logo01::before{
    right: -10px;
  }
}
@media screen and (max-width:390px) {
  footer dt span{
    padding-bottom: 10px;
  }
  footer dd{
    max-width: 140px;
  }
  footer dd a:first-child{
    margin-top: 0;
  }
  footer .left{
    width: auto;
  }
  footer .left a{
    width: 100%;
  }
}
@media screen and (max-width:370px) {
  .gp-menu{
    top: -45px;
  }
}

/* 优化图片显示，不拉伸变形铺满展示 */
/* .gp-img-responsive{
  position: relative;
}
.gp-img-responsive img{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
} */