/* V27 visual layer: merged from V25/V26 base, focused on detail page and color polish. */
:root {
  --zj-v27-main: #20b8aa;
  --zj-v27-main-dark: #128f86;
  --zj-v27-main-soft: #e9f8f6;
  --zj-v27-ink: #17263b;
  --zj-v27-ink-soft: #506173;
  --zj-v27-deep: #123f4a;
  --zj-v27-line: #dcecea;
  --zj-v27-card: #ffffff;
  --zj-v27-shadow: 0 18px 44px rgba(15, 67, 83, .10);
}

body {
  color: var(--zj-v27-ink);
  background: #fff;
  text-rendering: optimizeLegibility;
}

a {
  color: inherit;
}

a:hover {
  color: var(--zj-v27-main-dark);
  text-decoration: none;
}

.m {
  width: min(1240px, calc(100% - 40px));
}

.top {
  min-height: 112px;
  padding: 20px 0;
}

.top .logo {
  gap: 10px;
}

.top .logo .logo-a {
  flex: 0 0 auto;
}

.top .logo .logo-a img {
  display: block;
}

.zj-top-quals {
  gap: 8px;
}

.zj-top-qual > img {
  display: block;
  height: 42px;
  width: auto;
  max-width: 74px;
  object-fit: contain;
}

.zj-top-cert {
  border: 1px solid rgba(32, 184, 170, .28);
  border-radius: 10px;
  box-shadow: 0 18px 44px rgba(12, 45, 61, .20);
}

.top .ss {
  max-width: 700px;
}

.top .sousuo form {
  height: 48px;
  border-radius: 6px;
  overflow: hidden;
  box-shadow: 0 10px 28px rgba(18, 63, 74, .06);
}

.top .sousuo input {
  height: 48px;
  border: 1px solid var(--zj-v27-main);
  border-right: 0;
  color: var(--zj-v27-ink);
}

.top .sousuo input::placeholder {
  color: #83919d;
}

.top .sousuo button {
  height: 48px;
  background: var(--zj-v27-main);
  color: #fff;
  font-weight: 700;
  transition: background .18s ease;
}

.top .sousuo button:hover {
  background: var(--zj-v27-main-dark);
}

.top .rexian .img {
  width: 52px;
  height: 52px;
}

.top .rexian .bt {
  color: #6b778b;
  line-height: 1.25;
}

.top .rexian .phone1 {
  color: var(--zj-v27-main);
  letter-spacing: .3px;
}

header {
  background: var(--zj-v27-main);
  box-shadow: 0 8px 18px rgba(18, 63, 74, .10);
}

header .nav > li.nav-item > a {
  color: #fff;
  font-weight: 700;
  transition: background .18s ease, color .18s ease;
}

header .nav > li.nav-item:hover > a,
header .nav > li.nav-item.is-open > a,
header .nav > li.nav-item.active > a {
  background: rgba(14, 117, 110, .28);
  color: #fff;
}

header .subMenu {
  border: 0;
  box-shadow: 0 22px 60px rgba(14, 48, 63, .16);
}

header .subMenu .wrap {
  border-top: 1px solid rgba(32, 184, 170, .14);
}

.banner img,
.swiper-slide img {
  display: block;
}

.titD,
.neirong-title h3,
.moreserver {
  color: var(--zj-v27-main);
  letter-spacing: 0;
}

.neirong-title h3 {
  font-weight: 700;
}

.neirong,
#MyContent {
  color: #26384c;
  line-height: 1.88;
}

#MyContent h1,
#MyContent h2,
#MyContent h3,
#MyContent h4 {
  color: #142c46;
  line-height: 1.35;
}

#MyContent img {
  border-radius: 6px;
}

.serviceBox,
.induBox {
  background-color: #f3fbfa;
}

.serviceBox .tab ul li .txt,
.induBox .tab li {
  color: #10275a;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
}

.serviceBox .tab ul li:hover .txt,
.serviceBox .tab ul li.cur .txt,
.induBox .tab li:hover,
.induBox .tab li.cur {
  background: var(--zj-v27-main) !important;
  color: #fff !important;
  transform: translateY(-2px);
}

.serviceBox .list ul .right .li,
.induBox .list ul .right .li,
.pic_art_listfff dl,
.Piclist .item {
  border-color: rgba(32, 184, 170, .10) !important;
  box-shadow: 0 12px 30px rgba(16, 58, 73, .07);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.serviceBox .list ul .right .li:hover,
.induBox .list ul .right .li:hover,
.pic_art_listfff dl:hover,
.Piclist .item:hover {
  border-color: rgba(32, 184, 170, .26) !important;
  box-shadow: 0 18px 42px rgba(16, 58, 73, .12);
  transform: translateY(-3px);
}

.DemandBtn a,
.ly_left a,
.right-line .btn {
  border-radius: 8px;
  background-color: var(--zj-v27-main) !important;
  color: #fff !important;
  transition: background .18s ease, transform .18s ease, border-color .18s ease, color .18s ease;
}

.DemandBtn a:hover,
.ly_left a:hover,
.right-line .btn:hover {
  background-color: var(--zj-v27-main-dark) !important;
  color: #fff !important;
  transform: translateY(-1px);
}

.zj-detail-hero {
  position: relative;
  isolation: isolate;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 440px) !important;
  gap: clamp(34px, 5vw, 72px) !important;
  align-items: center !important;
  min-height: 430px;
  margin-bottom: 34px;
  padding: clamp(34px, 5vw, 56px) clamp(26px, 5vw, 64px) !important;
  overflow: hidden;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
}

.zj-detail-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, .96) 0%, rgba(255, 255, 255, .86) 38%, rgba(255, 255, 255, .28) 100%),
    rgba(244, 251, 250, .42);
}

.zj-detail-summary {
  max-width: 610px;
  padding: 0 !important;
}

.zj-detail-summary h1 {
  margin: 0;
  color: var(--zj-v27-ink);
  font-size: clamp(32px, 3.2vw, 46px) !important;
  font-weight: 500 !important;
  line-height: 1.25 !important;
}

.zj-detail-summary p {
  margin: 32px 0 58px;
  padding: 0 !important;
  min-height: 0 !important;
  max-width: 560px;
  color: var(--zj-v27-ink-soft) !important;
  font-size: 17px !important;
  line-height: 2 !important;
}

.zj-detail-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 18px;
}

.zj-detail-phone {
  display: inline-flex !important;
  align-items: center;
  min-height: 52px;
  margin: 0 !important;
  padding-left: 60px !important;
  background: url(../images/dh1.png) no-repeat left center !important;
  background-size: 45px auto !important;
  color: var(--zj-v27-main) !important;
  font-size: clamp(30px, 3.4vw, 44px) !important;
  line-height: 1.1 !important;
  font-style: normal;
  white-space: nowrap;
}

.zj-detail-consult {
  width: auto !important;
  min-width: 170px !important;
  height: 54px !important;
  margin: 0 !important;
  padding: 0 28px 0 58px !important;
  border-radius: 7px !important;
  background: url(../images/zx.png) no-repeat 24px center var(--zj-v27-main) !important;
  color: #fff !important;
  font-size: 18px !important;
  font-weight: 700;
  line-height: 54px !important;
}

.zj-detail-form {
  width: 100% !important;
  max-width: 440px !important;
  padding: 36px 42px 40px !important;
  background: rgba(39, 48, 51, .62) !important;
  backdrop-filter: blur(1px);
  box-shadow: 0 18px 46px rgba(6, 38, 54, .18);
}

.zj-detail-form p {
  margin: 0 0 28px !important;
  color: #fff !important;
  font-size: 26px !important;
  line-height: 1.25 !important;
}

.zj-detail-form .input,
.zj-detail-form .select1 {
  display: grid !important;
  grid-template-columns: 96px minmax(0, 1fr) !important;
  align-items: start !important;
  gap: 14px !important;
  margin: 0 0 24px !important;
}

.zj-detail-form .input span,
.zj-detail-form .select1 span {
  width: auto !important;
  padding: 0 !important;
  color: #fff !important;
  font-size: 17px !important;
  line-height: 48px !important;
  text-align: right !important;
}

.zj-detail-form input:not(.input_out),
.zj-detail-form textarea {
  width: 100% !important;
  max-width: 100% !important;
  border: 0 !important;
  border-radius: 7px !important;
  background: #fff !important;
  color: #1f2d3a !important;
  font-size: 16px !important;
  box-shadow: none !important;
}

.zj-detail-form input:not(.input_out) {
  height: 48px !important;
  line-height: 48px !important;
  padding: 0 18px !important;
}

.zj-detail-form textarea {
  min-height: 130px !important;
  padding: 14px 18px !important;
  resize: vertical;
}

.zj-detail-form input::placeholder,
.zj-detail-form textarea::placeholder {
  color: #76818c !important;
}

.zj-detail-form .ly_tj {
  margin: 18px 0 0 !important;
}

.zj-detail-submit {
  display: block !important;
  width: 100% !important;
  height: 54px !important;
  margin: 0 !important;
  border: 1px solid var(--zj-v27-main) !important;
  border-radius: 8px !important;
  background: #fff !important;
  color: var(--zj-v27-main) !important;
  font-size: 20px !important;
  font-weight: 800 !important;
  letter-spacing: 0 !important;
}

.zj-detail-submit:hover {
  background: var(--zj-v27-main) !important;
  color: #fff !important;
}

.zj-detail-form .zj-lead-success {
  max-width: none;
  margin-top: 14px;
  border-color: rgba(155, 232, 194, .86);
  background: rgba(239, 255, 246, .96);
}

.right-line {
  border-top-color: var(--zj-v27-main) !important;
}

.right-line .btn,
.input_out {
  color: var(--zj-v27-main) !important;
  background: #fff !important;
}

.right-line .btn:hover,
.input_out:hover {
  color: #fff !important;
  background: var(--zj-v27-main) !important;
}

.foot {
  background: linear-gradient(135deg, var(--zj-v27-deep), #1f8b83);
}

.foot .phone,
.foot .beian a {
  color: #e8fffb;
}

.foot .foot-1 {
  border-color: rgba(255, 255, 255, .26);
}

.floatBox .btn,
.floatBox a {
  color: var(--zj-v27-main);
}

.floatBox .zj-float-qr {
  border-color: rgba(32, 184, 170, .22);
  box-shadow: 0 18px 46px rgba(15, 67, 83, .18);
}

@media screen and (max-width: 1280px) {
  .zj-detail-hero {
    grid-template-columns: minmax(0, 1fr) minmax(340px, 400px) !important;
    padding-left: 36px !important;
    padding-right: 36px !important;
  }

  .zj-detail-form {
    padding: 32px 34px 36px !important;
  }
}

@media screen and (max-width: 1024px) {
  .m {
    width: min(100% - 32px, 960px);
  }

  .top {
    min-height: 0;
  }

  .zj-detail-hero {
    grid-template-columns: 1fr !important;
    min-height: 0;
    gap: 28px !important;
  }

  .zj-detail-summary p {
    margin: 22px 0 28px;
  }

  .zj-detail-form {
    max-width: 560px !important;
  }
}

@media screen and (max-width: 767px) {
  .m {
    width: calc(100% - 28px);
  }

  .zj-top-qual > img {
    height: 26px;
    max-width: 58px;
  }

  .zj-detail-hero {
    padding: 24px 18px !important;
  }

  .zj-detail-summary h1 {
    font-size: 28px !important;
  }

  .zj-detail-summary p {
    font-size: 15px !important;
    line-height: 1.85 !important;
  }

  .zj-detail-phone {
    min-height: 42px;
    padding-left: 48px !important;
    background-size: 36px auto !important;
    font-size: 28px !important;
  }

  .zj-detail-consult {
    min-width: 150px !important;
    height: 48px !important;
    line-height: 48px !important;
    padding-left: 52px !important;
    background-position: 20px center !important;
  }

  .zj-detail-form {
    padding: 26px 20px 28px !important;
  }

  .zj-detail-form .input,
  .zj-detail-form .select1 {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    margin-bottom: 16px !important;
  }

  .zj-detail-form .input span,
  .zj-detail-form .select1 span {
    line-height: 1.4 !important;
    text-align: left !important;
  }
}

