@font-face {
  font-family: AkzidenzGrotesk-BoldCond;
  src: url(../font/AkzidenzGrotesk-BoldCond.otf); }

@font-face {
  font-family: FuturaBT-Bold;
  src: url(../font/FuturaBT-Bold.otf); }

@font-face {
  font-family: SourceSans3-Bold;
  src: url(../font/SourceSans3-Bold.ttf); }

@font-face {
  font-family: SourceSans3-Light;
  src: url(../font/SourceSans3-Light.ttf); }

@font-face {
  font-family: SourceSans3-Regular;
  src: url(../font/SourceSans3-Regular.ttf); }

* {
  font-size: 16px;
  font-family: SourceSans3-Regular;
  color: #333333;
  line-height: 1.5; }

body {
  overflow-x: hidden; }

.header {
  position: absolute;
  top: 94px;
  left: 0;
  right: 0;
  z-index: 5;
}
.header .header-body {
    width: 100%;
    max-width: 1700px;
	/* padding: 0 120px; */
    margin: 0 auto;
    display: flex;
    justify-content: space-between; }
  .header .header-logo {
    width: 160px;
    font-size: 0; }
  .header .header-logo a img { width: 100%;}
  .header .nav-list {
    display: flex;
    gap: 15px 30px; }
  .header .nav-item {
    background-color: #fff;
    border: solid 2px #fa4c41;
    border-radius: 14px;
    color: #fa4c41; }
    .header .nav-item * {
      color: inherit; }
    .header .nav-item a {
      display: block;
      /* padding: 5px 15px; */
	  width: 160px;
	  height: 60px;
	  line-height: 60px;
	  text-align: center;
	  text-transform: uppercase;
	  font-size: 24px;
	  font-weight: 700;
      font-family: SourceSans3-Bold; }
  .header .nav-itemact, .header .nav-item:hover {
    border-color: transparent;
    background-color: #fa4c41;
    color: #fff; }

.footer {
  position: relative;
  background-repeat: no-repeat;
  background-position: right top;
  /* background-size: 100% 100%; */
  background-size: cover;
  background-image: url(../img/footerbg_103.png);
  padding: 10em 0 5em; }
  .footer .indexbgbody-side {top: -70px; z-index: -1;}
  .footer * {
    color: #fff; }
  .footer .footer-body {
    width: 95%;
    max-width: 1500px;
    margin: 0 auto; }
  .footer .footer-tit {
    font-size: 42px;
    font-family: AkzidenzGrotesk-BoldCond; }
  .footer .footer-wayls {
    margin-top: 120px;
    display: flex;
    justify-content: space-between;
    gap: 265px; }
  .footer .footer-wayitem {
    flex-basis: 50%; }
  .footer .footer-wayitem + .footer-wayitem { flex-basis: 40%;} 
  .footer .footer-waywd {
    font-size: 36px; }
    .footer .footer-waywd * {
      font-size: inherit; }
  .footer .footer-mda {
    margin-top: 80px;
    display: flex;
    align-items: center; }
    .footer .footer-mda .footer-mda-t {
      margin-right: 3em; }
    .footer .footer-mda .footer-mda-lks .fa-stack {
      margin-left: 1.5em;
      overflow: hidden; }
      .footer .footer-mda .footer-mda-lks .fa-stack:first-child {
        margin-left: 0; }
      .footer .footer-mda .footer-mda-lks .fa-stack:hover .fa-stack-1x {
        transform: scale(1.3);
        -webkit-transform: scale(1.3); }
    .footer .footer-mda .footer-mda-lks .fa-stack-1x {
      font-size: 20px;
      color: #fa4c41;
      transition: transform 0.3s;
      -webkit-transition: -webkit-transform 0.3s; }

.banner {
  position: relative; }
  .banner .banner-img {
    font-size: 0;
    position: relative;
    padding-top: 50%; }
    .banner .banner-img img, .banner .banner-img video {
      width: 100%;
      height: 100%;
      object-fit: cover;
      position: absolute;
      top: 0;
      left: 0; }
    .banner .banner-img video { background-color: #000;}
  .banner .banner-body {
    width: 95%;
    max-width: 1500px;
    margin: 0 auto;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    margin: 0 auto;
    height: 100%;
    padding: 5em 0 10em;
    display: flex;
    align-items: flex-end; }
  .banner .banner-body-ny { width: 100%; max-width: 1700px; padding-left: 35px;}	
  .banner .banner-wd {
    font-size: 88px;
    font-family: FuturaBT-Bold;
    color: #fff;
    max-width: 740px;
    line-height: 1.15; 
	text-shadow: 0 0 20px rgb(0 0 0 / 30%);}

.pagination {
  margin-top: 50px;
  display: flex;
  justify-content: flex-end; }
  .pagination .pagination-main {
    box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.2);
    border-radius: 50px; }
  .pagination .pagination-box {
    padding: 20px 30px;
    display: flex;
    justify-content: space-between;
    gap: 30px; }
  .pagination .pagination-arr {
    font-size: 20px;
    color: #a6a6a6;
    cursor: pointer; }
    .pagination .pagination-arr:hover {
      color: #fa4c41; }
  .pagination .pagination-mdline {
    width: 2px;
    background-color: #fa4c41;
    margin: 0 10px; }

.indexban {
  position: relative; }
  .indexban .indexban-item-img {
    position: relative;
    padding-top: 58%; }
    .indexban .indexban-item-img img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      position: absolute;
      top: 0;
      left: 0; }
  .indexban .indexban-item-main {
    width: 100%;
    /* max-width: 1500px; */
	padding: 0 120px;
    margin: 0 auto;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 100%;
    display: flex;
    flex-direction: row-reverse;
    align-items: center; }
    .indexban .indexban-item-main * {
      color: #fff; }
  .indexban .indexban-item-box {
    flex-basis: 40%; }
  .indexban .indexban-item-t {
    font-size: 88px;
	line-height: 100px;
    font-family: FuturaBT-Bold; }
  .indexban .indexban-item-d {
	width: 90%;
    font-size: 36px;
    margin-top: 60px; }
  .indexban .indexban-next {
    position: absolute;
    bottom: 15%;
    left: 0;
    right: 0;
    z-index: 5;
    margin: 0 auto;
    display: inline;
    width: 1em;
    color: #fff;
    font-size: 40px;
    text-align: center;
    cursor: pointer;
    animation: arrbtn 1.5s linear infinite alternate; }
  .indexban .indexban-page {
    bottom: 14%;
    /* right: 120px; */
	right: calc((100% - 1700px)/2);
    left: auto;
    width: auto; }
    .indexban .indexban-page .swiper-pagination-bullet {
      background-color: #fff;
      opacity: 0.7;
      width: 21px;
      height: 21px; }
    .indexban .indexban-page .swiper-pagination-bullet-active {
      opacity: 1; }

@keyframes arrbtn {
  0% {
    opacity: 0.5; }
  100% {
    opacity: 1; } }

.indexab {
  position: relative;
  z-index: 1;
  /* padding: 10% 0; */
  padding-top: 110px;
  margin-bottom: 13%; }
  .indexab * {
    color: #fff; }
  .indexab .indexab-bkimg {
    position: absolute;
    top: -270px;
    left: 0;
    width: 100%; }
  .indexab .indexab-body {
    width: 95%;
    max-width: 1500px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    gap: 140px;
    position: relative; }
  .indexab .indexabl, .indexab .indexabr {
	  padding-bottom: 60px;
    flex-basis: 46%; }
  .indexab .indexabm {
    width: 3px;
    padding: 30px 0;
    background-color: #fda6a0;
    /* opacity: 0.5; */
    box-sizing: content-box; }
  .indexab .indexbal-t {
    font-size: 52px;
    font-family: FuturaBT-Bold;
    max-width: 440px; }
  .indexab .indexabl-d {
    margin-top: 80px; }
    .indexab .indexabl-d * {
      font-size: 30px;
      line-height: 1.5; }
  .indexab .indexabr-ls {
    display: flex;
    justify-content: space-around;
    gap: 120px; }
  .indexab .indexabr-i {
    flex-basis: 50%;
    text-align: center; }
    .indexab .indexabr-i .indexabr-in {
      font-size: 130px;
      font-family: FuturaBT-Bold; }
    .indexab .indexabr-i .indexabr-it {
      font-size: 42px;
      font-family: SourceSans3-Bold;
      margin-top: 10px; }
    .indexab .indexabr-i .indexabr-id {
	  font-size: 30px;
      margin-top: 30px; }

.indexbody {
  width: 95%;
  max-width: 1500px;
  margin: 0 auto;
  position: relative; }

.indexbgbody {
  background-repeat: no-repeat;
  background-size: 100% 100%;
  background-position: center;
  background-image: url(../img/bg2_05.png);
  padding: 230px 0;
  position: relative;
  margin-top: 40px; }

.indexbgbody-side {
  position: absolute;
  top: -40px;
  right: 0;
  width: 210px;
  font-size: 0; }
  .indexbgbody-side img {
    width: 100%; }

.indextit .indextit-l * {
  font-size: 42px;
  font-family: AkzidenzGrotesk-BoldCond;
  color: #a6a6a6;
  vertical-align: middle; }

.indextit .indextit-l img {
  width: 1em;
  margin-left: 10px; }

.indextit .indextit-t {
  margin-top: 5px;
  font-size: 52px;
  line-height: 52px;
  font-family: FuturaBT-Bold;
  max-width: 1130px; }

.indexvid {
  margin-top: 60px; }
  .indexvid .indexvid-main {
    font-size: 0; }
    .indexvid .indexvid-main video {
      width: 100%;
      height: 100%; }

.indexhow {
  margin-top: 60px; }
  .indexhow .indexhow-item {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    position: relative;
    margin-top: 120px; }
    .indexhow .indexhow-item:first-child {
      margin-top: 0; }
    .indexhow .indexhow-item:nth-child(2n-1) .indexhow-item-info {
      left: 0; }
    .indexhow .indexhow-item:nth-child(2n) {
      flex-direction: row-reverse; }
      .indexhow .indexhow-item:nth-child(2n) .indexhow-item-info {
        right: 0; }
  .indexhow .indexhow-item-info {
    position: absolute;
    z-index: 1;
    width: 60%;
	max-width: 760px;
    height: 70%;
    display: flex;
    align-items: center; }
    .indexhow .indexhow-item-info .indexhow-item-infobg {
      background-color: #fff;
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%; }
    .indexhow .indexhow-item-info .indexhow-item-infobox {
      position: relative;
      padding: 30px 70px; }
    .indexhow .indexhow-item-info .indexhow-item-info-t {
      padding-left: 15px;
      border-left: solid 3px #fa4c41;
      font-size: 44px;
      font-family: SourceSans3-Bold;
      line-height: 1; }
    .indexhow .indexhow-item-info .indexhow-item-info-d {
      font-size: 36px;
      font-family: SourceSans3-Light;
      margin-top: 20px; }
  .indexhow .indexhow-item-img {
    width: 60%;
	max-width: 860px;
    position: relative;
    font-size: 0; }

.indexcho {
  position: relative; }
  .indexcho .indexcho-main {
    margin-top: 60px; }
  .indexcho .indexcho-list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 3em; }
  .indexcho .indexcho-i {
    flex-basis: 30%; }
    .indexcho .indexcho-i .indexcho-iimg {
      font-size: 0;
      text-align: center; 
	  padding:20px 60px;
	  }

.indexinco {
  padding-top: 13em; }
  .indexinco .indexinco-main {
    display: flex;
    justify-content: space-between;
    align-items: center;
	padding-top: 100px;
    grid-gap: 80px; }
  .indexinco .indexincol {
    flex-basis: 50%; }
  .indexinco .indexincor {
    flex-basis: 50%; }
  .indexinco .indexinco-img {
    /* font-size: 0;
    position: relative;
    padding-top: 130%; */ }
    .indexinco .indexinco-img img {
      width: 100%;
      /* height: 100%; */
      object-fit: cover;
     /* position: absolute;
      top: 0;
      left: 0; */ }
  .indexinco .indexinco-infoi {
    margin-top: 120px; }
  .indexinco .indexinco-infot {
    padding-left: 15px;
    border-left: solid 3px #fa4c41;
    font-size: 44px;
	line-height: 46px;
    font-family: SourceSans3-Bold; }
  .indexinco .indexinco-infod {
    margin-top: 30px;
    font-size: 36px;
    font-family: SourceSans3-Light; }

.indexbus {
  margin-top: 50px; }
  .indexbus .indexbus-list {
    margin-top: 120px;
    display: flex;
    flex-wrap: wrap;
    gap: 50px 30px; }
  .indexbus .indexbus-item {
    flex-basis: calc(50% - 15px); }
    .indexbus .indexbus-item .indexbus-item-img {
      position: relative;
      padding-top: 65%;
      overflow: hidden;
      box-shadow: 0 0 10px 2px rgba(0, 0, 0, 0.1); }
      .indexbus .indexbus-item .indexbus-item-img img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        position: absolute;
        top: 0;
        left: 0;
        transition: transform 0.5s;
        -webkit-transition: -webkit-transform 0.5s; }
    .indexbus .indexbus-item .indexbus-item-t {
      margin-top: 20px; }
      .indexbus .indexbus-item .indexbus-item-t span {
        display: inline-block;
        font-size: 44px;
        font-family: SourceSans3-Bold;
        background-repeat: no-repeat;
        background-position: left bottom;
        background-image: linear-gradient(to right, #fa4c41 0%, #fa4c41 100%);
        background-size: 0 3px;
        transition: background-size 0.5s;
        -webkit-transition: background-size 0.5s; }
    .indexbus .indexbus-item:hover .indexbus-item-img img {
      transform: scale(1.1);
      -webkit-transform: scale(1.1); }
    .indexbus .indexbus-item:hover .indexbus-item-t span {
      background-size: 100% 3px; }

.indexphi {
  background-image: url(../img/index11_02.png);
  /* background-size: 100% auto; */
  padding: 200px 0 400px; }
  .indexphi .indexphi-main {
    max-width: 740px; }
  .indexphi .indexphi-wd {
    font-size: 36px;
    font-family: SourceSans3-Light;
    margin-top: 80px; }

.indexpart {
  margin-top: 50px;
  margin-bottom: 140px; }
  .indexpart .indexpart-list {
    margin-top: 180px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 80px 20px; }
  .indexpart .indexpart-item {
    flex-basis:calc(25% - 15px); }
  .indexpart .indexpart-img {
	  text-align: center;
	  padding: 0 40px;
    font-size: 0; }

.product {
  width:100%;
  max-width:1700px;
  padding-left:30px;
  margin-top: 80px;
  display: flex;
  justify-content: space-between;
  gap: 40px; }
  .product .productl {
    flex-basis: 370px; }
  .product .productr {
    flex-basis: calc(100% - 520px); }
  .product .product-cat .product-cati {
    margin-top: 40px; }
    .product .product-cat .product-cati:first-child {
      margin-top: 0; }
  .product .product-cat .product-cata {
    display: flex;
    justify-content: space-between;
    align-items: center!important;
    opacity: 0.5; }
  .product .product-cat .product-cati-name {
    font-size: 44px;
    font-family: SourceSans3-Bold;
    line-height: 1.2;
    display: inline-block;
    width: calc(100% - 35px); }
  .product .product-cat .product-cati-rd {
    width: 25px;
    height: 25px;
    border: solid 1px currentcolor;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: 3px; }
    .product .product-cat .product-cati-rd .product-cati-rdin {
      width: 15px;
      height: 15px;
      background-color: #fa4c41;
      border-radius: 50%;
      display: none; }
  .product .product-cat .product-catiact .product-cata, .product .product-cat .product-cati:hover .product-cata {
    opacity: 1; }
	
	.currentprotype{ opacity: 1;}	
	.product .product-cat .currentprotype .product-cata{ opacity: 1;}
	.product .product-cat .currentprotype .product-cati-rd .product-cati-rdin{ display:block;}
	
  .product .product-cat .product-catiact .product-cati-rd .product-cati-rdin, .product .product-cat .product-cati:hover .product-cati-rd .product-cati-rdin {
    display: block; }
  .product .product-plist {
    display: flex;
    flex-wrap: wrap;
    gap: 36px; }
    .product .product-plist .product-pitem {
      flex-basis: calc(33.33% - 24px); }
      .product .product-plist .product-pitem:hover .product-pitem-img img {
        transform: scale(1.2);
        -webkit-transform: scale(1.2); }
    .product .product-plist .product-pitem-img {
      position: relative;
      padding-top: 100%;
      overflow: hidden; }
      .product .product-plist .product-pitem-img img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        position: absolute;
        top: 0;
        left: 0;
        transition: transform 0.5s;
        -webkit-transform: -webkit-transform 0.5s; }
    .product .product-plist .product-pitem-t {
      margin-top: 20px;
      font-size: 36px;
      font-family: SourceSans3-Light; }

.abouttit {
  font-size: 52px;
  padding-left: 35px;
  font-family: FuturaBT-Bold; }

.aboutab {
  background-position: center bottom;
  background-size: 120% auto; margin-top: 0; padding-top: 140px; /* background: #f2f2f2; */}
  .aboutab .indexbgbody-side { top: 0;}
  .aboutab .aboutab-side2 {
    left: 0;
    bottom: 15%;
    right: auto;
    top: auto;
    transform: rotate(180deg);
    -webkit-transform: rotate(180deg); }
  .aboutab .aboutab-list {
    position: relative;
	padding: 0 35px;
    margin-top: 140px; }
  .aboutab .aboutab-item {
    display: flex;
    align-items: center;
    gap: 36px;
    margin-top: 140px; }
    .aboutab .aboutab-item:first-child {
      margin-top: 0; }
    .aboutab .aboutab-item:nth-child(2n) {
      flex-direction: row-reverse; }
    .aboutab .aboutab-item .aboutab-iteml {
      flex-basis: 50%; }
    .aboutab .aboutab-item .aboutab-itemr {
      flex-basis: 50%; }
    .aboutab .aboutab-item .aboutab-item-img {
      position: relative;
      padding-top: 65%; }
      .aboutab .aboutab-item .aboutab-item-img img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        position: absolute;
        top: 0;
        left: 0; }
    .aboutab .aboutab-item .aboutab-item-info * {
      color: #333; }
    .aboutab .aboutab-item .aboutab-item-infot {
      display: flex;
      align-items: flex-end; }
      .aboutab .aboutab-item .aboutab-item-infot * {
        line-height: 1; }
    .aboutab .aboutab-item .aboutab-item-num {
      font-size: 120px;
      font-family: SourceSans3-Light;
      line-height: 0.7; color: #888;}
    .aboutab .aboutab-item .aboutab-item-sla {
      font-size: 40px;
      width: 1em;
      text-align: center;
      transform: rotate(20deg);
      -webkit-transform: rotate(20deg);  color: #888;}
    .aboutab .aboutab-item .aboutab-item-tit {
      font-size: 44px;
      font-family: SourceSans3-Bold;  color: #888;}
    .aboutab .aboutab-item .aboutab-item-infod {
      margin-top: 50px;
      padding-left: 80px;
      font-size: 36px; }
      .aboutab .aboutab-item .aboutab-item-infod * {
        font-size: inherit; }

.aboutfre {
  margin-top: 60px; }
  .aboutfre .aboutfre-main {
    margin-top: 100px;
    padding-left: 35px;}
    .aboutfre .aboutfre-main .aboutfre-swi {
      overflow: visible; }
      .aboutfre .aboutfre-main .aboutfre-swi .swiper-slide {
        height: auto; }
    .aboutfre .aboutfre-main .aboutfre-swii {
      background-color: #fff;
      box-shadow: 0 2px 10px 0 rgba(0, 0, 0, 0.2);
      border-radius: 30px;
      height: 100%; }
      .aboutfre .aboutfre-main .aboutfre-swii .aboutfre-swii-box {
        padding: 50px; }
      .aboutfre .aboutfre-main .aboutfre-swii .aboutfre-swii-t {
        font-size: 44px;
		line-height: 50px;
		min-height: 150px;
        font-family: SourceSans3-Bold; }
      .aboutfre .aboutfre-main .aboutfre-swii .aboutfre-swii-l {
        margin: 30px 0;
        width: 70%;
        max-width: 280px;
        height: 1px;
        background-color: #fa4c41; }
      .aboutfre .aboutfre-main .aboutfre-swii .aboutfre-swii-d {
        font-size: 36px;
		line-height: 48px;
        font-family: SourceSans3-Light; }
        .aboutfre .aboutfre-main .aboutfre-swii .aboutfre-swii-d * {
          font: inherit; }

.aboutsta {
  background-position: center top;
  background-size: 100% auto;
  padding: 13em 0;
  margin-bottom: -12em; }
  .aboutsta .aboutsta-side1 {
    left: 0;
    right: auto;
    transform: rotate(180deg);
    -webkit-transform: rotate(180deg); }
  .aboutsta .aboutsta-main {
    margin-top: 8em;
    gap: 25px; }
    .aboutsta .aboutsta-main .aboutsta-list {
      display: flex;
      align-items: flex-start;
      gap: 20px; }
    .aboutsta .aboutsta-main .aboutsta-item {
      position: relative;
      flex-basis: 19%; }
      .aboutsta .aboutsta-main .aboutsta-item:nth-child(2n) {
        margin-top: 5em; }
      .aboutsta .aboutsta-main .aboutsta-item:nth-child(5n) {
        margin-top: 10em; }
      .aboutsta .aboutsta-main .aboutsta-item .aboutsta-item-line {
        position: absolute;
        top: 0;
        left: 0;
        width: 2px;
        height: 100%;
        background-color: #a6a6a6; }
      .aboutsta .aboutsta-main .aboutsta-item .aboutsta-item-box {
        padding: 10px 0 10px 20px; }
      .aboutsta .aboutsta-main .aboutsta-item .aboutsta-item-num {
        font-size: 120px;
        font-family: SourceSans3-Light;
        color: #a6a6a6;
        line-height: 0.9; }
      .aboutsta .aboutsta-main .aboutsta-item .aboutsta-item-img {
        font-size: 0;
        position: relative;
        padding-top: 150%;
        margin: 20px 0; }
        .aboutsta .aboutsta-main .aboutsta-item .aboutsta-item-img img {
          width: 100%;
          height: 100%;
          object-fit: cover;
          position: absolute;
          top: 0;
          left: 0; }
      .aboutsta .aboutsta-main .aboutsta-item .aboutsta-item-t {
        font-size: 44px;
        font-family: SourceSans3-Bold;
        line-height: 1; }

.zoom75 { zoom:1}
