.banner {
  position: relative;
  background: no-repeat center/cover;
  height: 600rem;
}

.banner .wrap {
  height: 100%;
  display: flex;
  align-items: center;
}

.banner-text {
  color: #fff;
}

.banner-text .text {
  margin-bottom: 20rem;
  font-size: 80rem;
}

.banner-text .sub-text {
  text-transform: uppercase;
  letter-spacing: 0.38em;
  line-height: 1.8;
}

.banner img {
  width: 100%;
}

.modular1 .wrap {
  display: flex;
}

.modular1 .left,
.modular1 .right {
  height: 590rem;
  box-sizing: border-box;
  color: #fff;
}

.modular1 .left {
  /*flex: 1;*/
  padding: 110rem 40rem;
}

.modular1 .left .tit,.modular1 .right .tit {
  margin-bottom: 1em;
}

.modular1 .right .info,
.modular1 .left .info {
  line-height: 1.8;
}

.modular1 .left,
.modular1 .right {
  width: 519rem;
  padding: 50rem;
  display: flex;
  align-items: end;
  position: relative;
  transition: .5s;
  background-size: cover;
  cursor: pointer;
}

.modular1 .left .f,
.modular1 .right .f {
  position: absolute;
  width: calc(100% - 100rem);
  opacity: 0;
  transition: .5s;
}

.modular1 .left.on .f,
.modular1 .right.on .f {
  top: 50rem;
  opacity: 1;
}

.modular1 .left>.tit,
.modular1 .right>.tit {
  transition: .5s;
}

.modular1 .left.on>.tit,
.modular1 .right.on>.tit {
  opacity: 0;
}

.modular1 .left.on,
.modular1 .right.on{
  /*flex: 1;*/
  width: calc(100% - 519rem);
}

.modular {
  background: #fff;
  padding: 100rem 0;
}

.modular2 {
  padding-top: 0;
}

.modular2 .tab-content .list {
  position: relative;
}

.modular2 .tab-content .item {
  display: flex;
  position: relative;
  align-items: center;
}

.modular2 .tab-content .list .tit {
  position: absolute;
  left: 40rem;
  top: 0;
  z-index: 1;
  color: #004962;
}

.modular2 .tab-content .item .left .info {
  background: #f6f9fd;
  padding: 70rem 40rem;
}

.modular2 .tab-content .item .left {
  width: 720rem;
  z-index: 1;
}

.modular2 .tab-content .item .left .title {
  margin-bottom: 40rem;
}

.modular2 .tab-content .item .right {
  flex: 1;
  margin-left: -180rem;
}

.modular2 .tab-content .item .right img {
  max-width: 100%;
}

.modular2 .tab-content .item .left .text {
  line-height: 1.8;
  min-height: 120rem;
}

.modular2 .tab-content .item {
  display: none;
}

.modular2 .tab-content .item.on {
  display: flex;
}

.modular2 .tab-nav {
  margin-top: 64rem;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  position: relative;
}

.modular2 .tab-nav .item {
  text-align: center;
  padding: 40rem 0;
  cursor: pointer;
  opacity: 0.2;
  transition: .5s;
}

.modular2 .tab-nav .item.on {
  opacity: 1;
  color: #004962;
  font-weight: bold;
}

.modular2 .tab-nav::before,
.modular2 .tab-nav::after {
  content: '';
  display: block;
  position: absolute;
  border-top: 1px solid #004962;
  width: 100%;
  top: 3px;
  left: 0;
  transition: .5s;
}

.modular2 .tab-nav::after {
  width: var(--width);
  left: var(--left);
  top: 0px;
  border-top: 4px solid #c0a486;
}

.modular3 {
  color: #fff;
  overflow: hidden;
}

.modular3 .wrap {
  position: relative;
}

.modular3 .tit {
  padding: 0 30rem;
  line-height: 1.3;
  position: absolute;
  top: 0;
}

.modular3 .list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
}

.modular3 .list .item {
  padding: 0 70rem 0 30rem;
  line-height: 1.6;
  padding-top: 460rem;
  position: relative;
}

.modular3 .list .item::after {
  content: '';
  position: absolute;
  left: 0;
  top: -50%;
  height: 200%;
  border-left: 1px solid #4e7a95;
  transition: all .5s;
}

.modular3 .index::after {
  content: '';
  border-left: 2px solid #c0a486;
  position: absolute;
  left: -30rem;
  top: 0;
  height: 100%;
  z-index: 1;
  transition: .5s;
}

.modular3 .index {
  position: relative;
  margin-bottom: 30rem;
}

.modular4 {
  position: relative;
}

.modular4::after {
  content: '';
  position: absolute;
  left: 0;
  top: 100rem;
  width: 16rem;
  height: calc(100% - 200rem);
  background: #006d99;
}

.modular4 .wrap {
  display: flex;
}

.modular4 .left {
  width: 880rem;
  z-index: 2;
  background: #fff;
  margin: 46rem 0;
  padding: 60rem 260rem 60rem 40rem;
  box-sizing: border-box;
}

.modular4 .left .tit {
  color: #004962;
  letter-spacing: 0.3em;
}

.modular4 .left .info {
  margin: 60rem 0;
}

.modular4 .left .list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 50rem 130rem;
  margin-bottom: 60rem;
}

.modular4 .right {
  flex: 1;
  margin-left: -350rem;
}

.modular4 .right img {
  width: 100%;
}

.modular4 .left .list .item {
  padding-left: 40rem;
  position: relative;
}

.modular4 .left .list .item::after {
  content: '';
  position: absolute;
  left: 0;
  top: 0.2em;
  height: 1em;
  width: 8px;
  background: #004962;
  border-radius: 5px;
}

.modular4 .left .list h2 {
  margin-bottom: 20rem;
}

.modular4 .left .list .text {
  line-height: 1.8;
}

.modular5 .wrap {
  flex-direction: row-reverse;
}

.modular5 .left {
  padding-left: 70rem;
  padding-right: 100rem;
}

.modular5 .right {
  margin-right: -350rem;
  margin-left: 0;
}

.modular5::after {
  left: auto;
  right: 0;
}

.modular4 .left .text {
  line-height: 1.6;
}

.modular4 .left .text p {
  margin-bottom: 40rem;
}

.modular6 {
  padding-top: 0;
}

.modular6 .item {
  padding: 60rem 100rem 60rem 70rem;
  background-size: cover;
}

.modular6 .item .tit {
  margin-bottom: 40rem;
}

.modular6 .item .text {
  line-height: 1.6;
}

.modular6 .wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60rem;
  color: #fff;
}

.modular6 .right {
  display: grid;
  flex-direction: column;
  grid-template-columns: 1fr;
  gap: 60rem;
}

.modular7 {
  padding-top: 0;
}

.modular7 .wrap {
  display: flex;
  flex-direction: row-reverse;
}

.modular7 .wrap .top{
    width: 55%;
    margin-left: -15%;
}

.modular7 img {
  width: 100%;
  object-fit: cover;
  height: 100%;
}

.modular7 .bottom {
  margin: 40rem 40rem 40rem 0;
  padding-left: 70rem;
  background: #fff;
  color: #000;
  display: flex;
  z-index: 1;
  position: relative;
  flex: 1;
  overflow: hidden;
  flex-direction: column;
}

.modular7 .bottom .info {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 50rem;
    padding-top: 0;
}

.modular7 .bottom .tit,
.modular7 .bottom .info .item {
  padding: 50rem;
  box-sizing: border-box;
  word-break: break-all;
  margin-bottom: 20rem;
  position: relative;
}

.modular7 .bottom .info .item:after{
    content: '\e6022';
    position: absolute;
    right: 0;
    font-family: 'iconfont';
    top: 50%;
    transform: translate(0px, -50%) scale(1.3);
    color: #006d99;
}

.modular7 .bottom .info .item:nth-child(2):after{
    content: '\e614';
}
.modular7 .bottom .info .item:nth-child(3):after{
    content: '\e607';
    transform: translate(0px, -50%) scale(1.05);
}

.modular7 .bottom .info .item {
  padding: 0rem 0;
  line-height: 1.8;
  border-bottom: 1px solid #000;
  padding-bottom: 20rem;
}

.modular7 .bottom .info .item a {
  color: #fff;
}

.modular7 .bottom .info .item:nth-child(3) {
  flex: 1;
}

.modular7 .bottom::after,
.modular7 .bottom::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 18rem;
    height: 100%;
    background: #006d99;
}

.modular7 .bottom::before {
  width: 0rem;
  z-index: 2;
  background: #c0a486;
}

.modular8 {
  padding-top: 0;
}

.modular8 .th {
  display: flex;
  background: #004962;
  color: #fff;
}

.modular8 .th .col {
  padding: 40rem 50rem;
  width: 450rem;
  box-sizing: border-box;
}

.modular8 .th .col i {
  transform: rotate(90deg);
  display: inline-block;
  transition: .5s;
}

.modular8 .row.on .th .col i {
  transform: rotate(0deg);
}
.modular8 .row .col span{
  display: block;
}
.modular8 .row .col .close{
  display: none;
}
.modular8 .row.on .col span{
  display: none;
}
.modular8 .row.on .col .close {
  display: block;
}

.modular8 .th .col:last-child {
  flex: 1;
  display: flex;
  gap: 20rem;
  align-items: center;
  cursor: pointer;
}

.modular8 .content {
  max-height: 0px;
  transition: .5s;
  overflow: hidden;
}

.modular8 .content .box {
  padding: 40rem 60rem;
}

.modular8 .content .info {
  display: flex;
  gap: 230rem;
}

.modular8 .content .list {
  margin-top: 20rem;
  margin-bottom: 50rem;
  display: flex;
  flex-direction: column;
  gap: 20rem;
}

.modular8 .content .list .tab {
  margin: 30rem 0;
  background: #004962;
  display: inline-block;
  padding: 0.25em 1em;
  color: #fff;
}

.modular8 .content .list .text {
  line-height: 1.6;
}

.modular8 .table .row .th {
  cursor: pointer;
}

.modular8 .table .row:nth-child(2n) .th {
  background: #f6f9fd;
  color: #000;
}

.modular8 .table .row:nth-child(2n+1) .th {
  background: #fff;
  color: #000;
}

.modular8 .table .row:nth-child(1) .th {
  background: #004962;
  color: #fff;
}

.modular8 .table .row.on:nth-child(2n+1) .content {
  border-top: 1px solid #e1e3fd;
}

.modular8 .table .row.on .content {
  max-height: 1000px;
  border-bottom: 1px solid #e1e3fd;
  margin-bottom: 30rem;
}

@media screen and (min-width: 1024px) {
  .modular3 .list .item:hover::after {
    margin-left: -10rem;
  }

  .modular3 .list .item:hover .index::after {
    left: -40rem;
    border-width: calc(10rem + 2px);
  }
}

@media screen and (max-width: 1024px) {
.modular1 .left.on, .modular1 .right.on{
width: auto;
height: auto;
}
.modular1 .left>.tit, .modular1 .right>.tit{
display: none;
}
.modular1 .left .f, .modular1 .right .f{
    position: initial;
    width: auto;
    opacity: 1 !important;
}
.modular7 .wrap{
    position: relative;
}

.modular7 .wrap .top{
    width: 100%;
    margin-left: 0;
    position: absolute;
    left: 0;
    height: 100%;
}
  .modular4 .wrap {
    flex-direction: column;
  }

  .modular4 .left {
    width: auto;
  }

  .modular4 .left {
    padding: 40rem;
    z-index: 1;
    position: relative;
    margin: auto;
    width: 95%;
  }

  .modular4 .right {
    margin-left: 0;
    margin-top: -50rem;
  }

  .modular4 .left .list {
    gap: 50rem;
  }

  .modular5 .wrap {
    flex-direction: column-reverse;
  }

  .modular5 .left {
    width: 95%;
    margin: 0;
  }

  .modular5 .right {
    margin-right: 0;
    margin-bottom: -350rem;
  }

  .modular6 .wrap {
    grid-template-columns: 1fr;
  }

  .modular7 .bottom {
    flex-direction: column;
    gap: 0;
  }

  .modular7 .bottom .tit {
    width: auto;
    margin-bottom: 0;
    padding: 60rem;
  }

  .modular7 .bottom .info {
    flex-direction: column;
    gap: 0;
    padding: 60rem;
    padding-top: 0rem;
  }

  .modular7 .bottom {
    margin: auto;
    background: none;
    margin-top: 0;
    padding: 0;
  }

  .modular7 .bottom::after, .modular7 .bottom::before{
    display: none;
  }

  .modular7 .bottom .info .item {
    width: 100% !important;
    padding: 0;
  }

  .modular8 .content .info {
    flex-direction: column;
    gap: 20rem;
  }

  .modular8 .th .col {
    width: 70%;
    padding: 20rem 20rem;
  }

  .modular8 .content .box {
    padding: 40rem 20rem;
  }

  .modular1 .wrap {
    flex-direction: column;
  }

  .modular1 .left,
  .modular1 .right {
    width: auto;
    background-size: cover;
  }

  .modular2 .tab-content .list .tit {
    position: relative;
    margin-bottom: 30rem;
  }

  .modular2 .tab-content .item {
    flex-direction: column;
  }

  .modular2 .wrap {
    display: flex;
    flex-direction: column-reverse;
  }

  .modular2 .tab-content .item .left {
    width: auto;
  }

  .modular2 .tab-content .item .right {
    margin-left: 0;
  }

  .modular2 .tab-nav {
    margin-top: 0rem;
    margin-bottom: 64rem;
  }

  .modular3 {
    background-size: cover;
  }

  .modular3 .list {
    grid-template-columns: 1fr;
    gap: 50rem;
  }

  .modular3 .list .item {
    padding-top: 0;
    padding-bottom: 50rem;
  }

  .modular3 .tit {
    position: relative;
    margin-bottom: 64rem;
  }

  .modular3 .list .item::after {
    top: auto;
    left: -50%;
    bottom: 0;
    border: 0;
    border-bottom: 1px solid #4e7a95;
    width: 200%;
    height: auto;
  }

  .modular8 .th .col:nth-child(3),
  .modular8 .th .col:nth-child(2) {
    display: none;
  }

  .modular8 .th .col:nth-child(3) {
    width: auto;
    flex: 1;
  }

  .modular4 .left .list {
    grid-template-columns: 1fr;
  }
  
  .modular1 .left, .modular1 .right {
    height: auto;
  }
}