/* 移动端适配样式 - 产品中心板块 */

/* 移动端断点 */
@media (max-width: 768px) {
  .fk-banner {
    height: 17.5rem;
    background-position: -5rem 0rem;
    background-size: 84rem;
  }

  .banner-logo-title {
    display: none;
  }

  .fk-banner h1 {
    font-size: 2.2rem;
  }

  .banner-tags {
    margin: 0;
    gap: 1rem 1rem;
    width: 28rem;
    margin: 0;
  }

  .banner-tags li {
    font-size: 1rem;
  }

  .banner-btns {
    margin-top: 2rem;
    gap: 1.5rem;
  }
  .banner-btn-primary{
    
  }
  .banner-btn-outline{

  }
  .banner-btn{
    padding: 0.6rem 2.3rem;
    font-size: 1.1rem;
    line-height: normal;
  }

  /* 产品中心容器适配 */
  .w1300 {
    width: 100% !important;
    padding: 0 15px;
    box-sizing: border-box;
  }

  /* 产品中心标题 */
  .w1300 h3.display-5 {
    font-size: 2rem !important;
    padding: 2rem 0 !important;
    margin: 0;
  }

  /* 产品中心Tab导航 横向排列 */
  .cpzx-tab {
    flex-direction: row !important;
    flex-wrap: wrap;
    border-bottom: 1px solid #eee;
    gap: 0;
  }

  .cpzx-tab li {
    width: 25%;
    min-width: 3.2rem;
    max-width: 100%;
    box-sizing: border-box;
    padding: 0.5rem 0;
    border-bottom: 0.18rem solid #eee;
    border-right: none;
    font-size: 0.95rem;
    min-height: 2.2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
  }

  .cpzx-tab li:last-child {
    border-bottom: 0.18rem solid #eee;
  }

  .cpzx-tab li.active {
    background: #f8f9fa;
    border-bottom: 0.18rem solid #16a0ff;
    border-left: none;
  }

  .cpzx-tab li img {
    height: 0.9rem;
    margin: 0 0.2rem 0 0;
  }

  .cpzx-tab li strong {
    font-size: 0.95rem !important;
  }

  /* 产品中心内容区域 */
  .cpzx-cont {
    flex-direction: column;
    padding: 20px 0;
  }

  .cpzx-cont .cpzx-img {
    width: 100%;
    margin: 0 0 20px 0;
    order: 1;
  }

  .cpzx-cont .cpzx-img img {
    width: 100%;
    height: auto;
    border-radius: 8px;
  }

  .cpzx-cont .cpzx-info {
    width: 100%;
    margin: 0;
    order: 2;
  }

  .cpzx-cont .cpzx-info h3 {
    margin-top: 0;
    font-size: 1.5rem !important;
    flex-direction: column;
    align-items: flex-start;
    gap: 15px;
  }

  .cpzx-cont .cpzx-info h3 strong {
    margin: 0;
    flex: none;
    font-size: 1.5rem;
  }

  .cpzx-cont .cpzx-info h3 .btn {
    width: 100%;
    padding: 12px;
    font-size: 1rem;
    border-radius: 6px;
  }

  .cpzx-cont .cpzx-info p {
    font-size: 0.95rem;
    line-height: 1.6;
    margin-bottom: 1rem;
  }

  .cpzx-cont .cpzx-info h4 {
    font-size: 1.2rem;
    margin-top: 1.5rem;
    margin-bottom: 1rem;
  }

  /* 产品特点列表 */
  .cpzx-cont .cpzx-info .cpzx-ts {
    flex-wrap: wrap;
    gap: 15px;
    margin: 1.5rem 0 0 0;
  }

  .cpzx-cont .cpzx-info .cpzx-ts li {
    width: calc(50% - 7.5px);
    max-width: none;
    flex: none;
    text-align: center;
    padding: 15px 10px;
    background: #f8f9fa;
    border-radius: 8px;
    box-sizing: border-box;
  }

  .cpzx-cont .cpzx-info .cpzx-ts li img {
    width: 3rem;
    height: auto;
    margin: 0 auto 8px;
  }

  .cpzx-cont .cpzx-info .cpzx-ts li strong {
    font-size: 0.9rem;
    margin: 0;
    line-height: 1.3;
  }

  /* 产品中心Tab原始大气风格 移动端适配 */
  .carousel-indicators.cpzx-tab {
    padding-left: 0.2rem;
    /* border-bottom: 2px solid #e5e5e5; */
    overflow-x: auto;
    flex-wrap: nowrap;
    scrollbar-width: none;
    /* Firefox */
    -ms-overflow-style: none;
    /* IE/Edge */
  }

  .carousel-indicators.cpzx-tab::-webkit-scrollbar {
    display: none;
    /* Chrome/Safari/Opera */
  }

  .carousel-indicators.cpzx-tab button {
    font-size: 1.05rem;
    height: 2.8rem;
    min-width: 120px;
    max-width: 180px;
    flex-direction: row;
    padding: 0;
    margin-right: 0;
  }

  .carousel-indicators.cpzx-tab button img {
    height: 1.3rem;
    width: 1.3rem;
    margin-right: 0.4rem;
  }

  .carousel-indicators.cpzx-tab button strong {
    font-size: 1.05rem;
  }

  .carousel-indicators.cpzx-tab button.active strong,
  .carousel-indicators.cpzx-tab button[aria-current="true"] strong {
    font-size: 1.15rem;
  }

  #cpzxCarousel .carousel-inner {
    gap: 1rem;
    display: flex;
  }

  #cpzxCarousel .carousel-item {
    transition: transform 0.5s;
  }

  /* 解决方案板块移动端适配 */
  .jjfa-cont {
    height: auto;
    padding-bottom: .7rem;
  }

  /* 解决方案Carousel移动端样式优化，全部用rem */
  #jjfaCarousel {
    margin: 0 -0.75rem;
  }

  #jjfaCarousel .carousel-inner {
    padding: 0 0.75rem;
  }

  #jjfaCarousel .carousel-item {
    padding: 0;
  }

  #jjfaCarousel .carousel-item .row {
    margin: 0;
    gap: .8rem 0rem;
  }

  #jjfaCarousel .carousel-item .col-6 {
    padding: 0 0.375rem;
  }

  #jjfaCarousel .jjfa-cont {
    margin: 0;
    height: auto;
    min-height: 7.5rem;
    display: flex;
    flex-direction: column;
    background: #fff;
    border-radius: 0.5rem;
    box-shadow: 0 0.05rem 0.2rem rgba(0, 0, 0, 0.03);
  }

  #jjfaCarousel .jjfa-cont img {
    width: 100%;
    object-fit: cover;
    border-radius: 0.5rem 0.5rem 0 0;
  }

  #jjfaCarousel .jjfa-msg {
    flex: 1;
    padding: 0.7rem 0.5rem 0.5rem 0.5rem;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
  }

  #jjfaCarousel .jjfa-msg h3 {
    font-size: 1rem;
    margin: 0 0 0.3rem 0;
    line-height: 1.3;
  }

  #jjfaCarousel .jjfa-msg .desc {
    font-size: 0.8rem;
    line-height: 1.4;
    margin: 0 0 0.2rem 0;
    flex: 1;
  }

  #jjfaCarousel .jjfa-msg .more {
    font-size: 0.85rem;
    color: #16a0ff;
    margin: 0;
  }

  /* 分页器样式 */
  .jjfa-pagination {
    text-align: center;
    font-size: 0.9rem;
    color: #888;
    margin-top: 0.3rem;
    margin-bottom: 0.5rem;
    letter-spacing: 0.1em;
  }

  /* 指示器rem单位 */
  .carousel-indicators.jjfa-indicators {
    bottom: 0;
    margin: 0;
  }

  .carousel-indicators.jjfa-indicators button {
    width: 1.2rem;
    height: 0.25rem;
    border-radius: 0.15rem;
    background-color: #ddd;
    border: none;
    margin: 0 0.25rem;
  }

  .carousel-indicators.jjfa-indicators button.active {
    background-color: #16a0ff;
  }

  .jdal-box {
    height: auto;
  }

  .w1300 h3.display-5 {
    color: #000 !important;
  }

  .gsys-cont {
    padding: 1.3rem 1.5rem;
  }

  .gsys-cont dd {
    width: 5rem;
    margin-left: 1rem;
  }

  .pb-5 {
    padding-bottom: 0 !important;
  }

  .mt-5 {
    margin-top: 0 !important;
  }

  .footer-row-custom {
    display: block !important;
  }

  .footer-row-custom>.col-lg-3 {
    width: 100% !important;
    max-width: 100% !important;
    margin-bottom: 1.5rem !important;
  }

  .footer-row-custom__group {
    display: flex;
    flex-wrap: wrap;
    margin-left: -8px;
    margin-right: -8px;
  }

  .footer-row-custom__group>.col-lg-2 {
    width: 50%;
    max-width: 50%;
    margin-bottom: 1.5rem;
    padding-left: 8px;
    padding-right: 8px;
    box-sizing: border-box;
    float: none !important;
  }

  .footer-row-custom__group>.col-lg-2:last-child {
    margin-bottom: 0;
  }

  /* 产品中心产品特点横向滑动（移动端） */
  .cpzx-ts {
    flex-wrap: nowrap !important;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    display: flex;
    gap: 0.7rem;
    padding-bottom: 0.2rem;
    margin-left: -0.2rem;
    margin-right: -0.2rem;
    scrollbar-width: none;
    /* Firefox */
  }

  .cpzx-ts::-webkit-scrollbar {
    display: none;
    /* Chrome/Safari/Opera */
  }

  .cpzx-ts li {
    min-width: 5.2rem;
    max-width: 7rem;
    flex: 0 0 auto;
    margin: 0;
    text-align: center;
    background: #f8f9fa;
    border-radius: 0.5rem;
    padding: 0.7rem 0.3rem 0.5rem 0.3rem;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
  }

  .cpzx-ts li img {
    width: 2.2rem;
    height: 2.2rem;
    margin-bottom: 0.3rem;
  }

  .cpzx-ts li strong {
    font-size: 0.9rem;
    margin: 0;
    line-height: 1.3;
    white-space: nowrap;
  }

  /* 禁止所有点击/激活/高亮/浮层效果，点击后和未点击时完全一样 */
  .jjfa-cont,
  .jjfa-cont:active,
  .jjfa-cont:focus,
  .jjfa-cont:hover,
  .jjfa-cont.active {
    background: #fff !important;
    box-shadow: 0 2px 8px 0 rgba(0, 0, 0, 0.04) !important;
    filter: none !important;
    color: #222 !important;
    border: 1px solid #eee !important;
    opacity: 1 !important;
  }

  .jjfa-cont img {
    filter: none !important;
    opacity: 1 !important;
  }

  .jjfa-cont .jjfa-popup,
  .jjfa-cont .jjfa-hover-effect,
  .jjfa-cont .jjfa-btn,
  .jjfa-cont .jjfa-msg .more {
    display: none !important;
  }

  .jjfa-cont .jjfa-msg,
  .jjfa-cont .jjfa-msg h3,
  .jjfa-cont .jjfa-msg .desc {
    background: none !important;
    color: #222 !important;
    opacity: 1 !important;
    filter: none !important;
    box-shadow: none !important;
    border: none !important;
  }

  /* 禁止移动端卡片的所有 hover/active 效果，彻底还原 */
  .jjfa-cont:hover,
  .jjfa-cont:active,
  .jjfa-cont.active,
  .jjfa-cont:focus {
    background: #fff !important;
    box-shadow: 0 2px 8px 0 rgba(0, 0, 0, 0.04) !important;
    filter: none !important;
    color: #222 !important;
    border: 1px solid #eee !important;
    opacity: 1 !important;
  }

  .jjfa-cont:hover img,
  .jjfa-cont:active img,
  .jjfa-cont.active img,
  .jjfa-cont:focus img {
    filter: none !important;
    opacity: 1 !important;
  }

  .jjfa-cont:hover .jjfa-msg,
  .jjfa-cont:active .jjfa-msg,
  .jjfa-cont.active .jjfa-msg,
  .jjfa-cont:focus .jjfa-msg {
    background: none !important;
    color: #222 !important;
    opacity: 1 !important;
    filter: none !important;
    box-shadow: none !important;
    border: none !important;
    position: relative;
  }

  .jjfa-cont:hover .jjfa-msg .desc {
    color: inherit !important;
  }

  /* 如有浮层、按钮等，继续强制隐藏 */
  .jjfa-cont:hover .jjfa-popup,
  .jjfa-cont:active .jjfa-popup,
  .jjfa-cont.active .jjfa-popup,
  .jjfa-cont:focus .jjfa-popup,
  .jjfa-cont:hover .jjfa-hover-effect,
  .jjfa-cont:active .jjfa-hover-effect,
  .jjfa-cont.active .jjfa-hover-effect,
  .jjfa-cont:focus .jjfa-hover-effect,
  .jjfa-cont:hover .jjfa-btn,
  .jjfa-cont:active .jjfa-btn,
  .jjfa-cont.active .jjfa-btn,
  .jjfa-cont:focus .jjfa-btn,
  .jjfa-cont:hover .jjfa-msg .more,
  .jjfa-cont:active .jjfa-msg .more,
  .jjfa-cont.active .jjfa-msg .more,
  .jjfa-cont:focus .jjfa-msg .more {
    display: none !important;
  }

  /* 禁止移动端点击高亮和tap闪烁，彻底避免点击瞬间变动 */
  .jjfa-cont {
    -webkit-tap-highlight-color: transparent !important;
    tap-highlight-color: transparent !important;
    touch-action: manipulation !important;
    user-select: none;
  }

  .jjfa-cont:active,
  .jjfa-cont:focus,
  .jjfa-cont.active {
    outline: none !important;
    box-shadow: 0 2px 8px 0 rgba(0, 0, 0, 0.04) !important;
    background: #fff !important;
  }
}

/* 小屏幕手机适配 */
@media (max-width: 480px) {
  .carousel-inner {
    gap: 1rem;
    display: flex;
  }

  /* 小屏幕解决方案Carousel优化 */
  #jjfaCarousel .jjfa-cont {
    min-height: 6.5rem;
  }

  #jjfaCarousel .jjfa-cont img {
    height: auto;
  }

  #jjfaCarousel .jjfa-msg {
    padding: 0.5rem 0.3rem 0.3rem 0.3rem;
  }

  #jjfaCarousel .jjfa-msg h3 {
    font-size: 0.9rem;
    padding-top: 0.4rem !important;
  }

  #jjfaCarousel .jjfa-msg .desc {
    font-size: 0.75rem;
    text-align: center;
    color: #888 !important;
  }

  #jjfaCarousel .jjfa-msg .more {
    font-size: 0.8rem;
  }

  .jjfa-pagination {
    font-size: 0.8rem;
    margin-top: 0.2rem;
    margin-bottom: 0.3rem;
  }

  .w1300 {
    padding: 0 10px;
  }

  .w1300 h3.display-5 {
    font-size: 2.2rem !important;
    padding: 1.5rem 0 !important;
  }

  .cpzx-tab li {
    font-size: 0.85rem;
    padding: 0.35rem 0;
    min-width: 2.2rem;
    min-height: 1.6rem;
    height: 4rem;
  }

  .cpzx-tab li img {
    height: 0.7rem;
  }

  .cpzx-tab li strong {
    font-size: 0.85rem !important;
  }

  .cpzx-tab li.active strong {
    font-size: 1rem !important;
  }

  .cpzx-cont {
    padding: 15px 0;
  }

  .cpzx-cont .cpzx-info h3 {
    font-size: 1.3rem !important;
  }

  .cpzx-cont .cpzx-info h3 strong {
    font-size: 1.3rem;
  }

  .cpzx-cont .cpzx-info h3 .btn {
    padding: 10px;
    font-size: 0.9rem;
  }

  .cpzx-cont .cpzx-info p {
    font-size: 0.9rem;
    line-height: 1.5;
  }

  .cpzx-cont .cpzx-info h4 {
    font-size: 1.1rem;
  }

  .cpzx-cont .cpzx-info .cpzx-ts {
    gap: 10px;
    overflow-x: auto;
  }

  .cpzx-cont .cpzx-info .cpzx-ts li {
    width: calc(27% - 5px);
    padding: 12px 8px;
  }

  .cpzx-cont .cpzx-info .cpzx-ts li img {
    width: 2.5rem;
  }

  .cpzx-cont .cpzx-info .cpzx-ts li strong {
    font-size: 0.8rem;
  }
}

/* 超小屏幕适配 */
@media (max-width: 360px) {

  .cpzx-cont .cpzx-info .cpzx-ts li {
    width: 100%;
    margin-bottom: 10px;
  }

  .cpzx-cont .cpzx-info .cpzx-ts li:last-child {
    margin-bottom: 0;
  }

  /* 超小屏幕解决方案Carousel优化 */
  #jjfaCarousel .jjfa-cont {
    min-height: 5.5rem;
  }

  #jjfaCarousel .jjfa-cont img {
    height: 2rem;
  }

  #jjfaCarousel .jjfa-msg {
    padding: 0.3rem 0.2rem 0.2rem 0.2rem;
  }

  #jjfaCarousel .jjfa-msg h3 {
    font-size: 0.8rem;
  }

  #jjfaCarousel .jjfa-msg .desc {
    font-size: 0.7rem;
  }

  #jjfaCarousel .jjfa-msg .more {
    font-size: 0.75rem;
  }

  .jjfa-pagination {
    font-size: 0.7rem;
    margin-top: 0.1rem;
    margin-bottom: 0.2rem;
  }
}

/* 横屏模式适配 */
@media (max-width: 768px) and (orientation: landscape) {

  .cpzx-tab {
    flex-direction: row;
    flex-wrap: wrap;
  }

  .cpzx-tab li {
    width: 50%;
    flex: 1;
  }

  .cpzx-cont .cpzx-info .cpzx-ts li {
    width: calc(33.333% - 10px);
  }

}

.carousel-inner,
.carousel-indicators.cpzx-tab {
  user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  -moz-user-select: none;
}

body.dragging {
  user-select: none !important;
}

/* 合并所有分页器样式，包含gsys-dot-pagination */
.jjfa-dot-pagination,
.jdal-dot-pagination,
.hzfs-dot-pagination,
.gsys-dot-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.7rem;
  margin-top: 0.5rem;
  margin-bottom: 0.7rem;
  min-height: 1.2rem;
}

.jjfa-dot-pagination .dot,
.jdal-dot-pagination .dot,
.hzfs-dot-pagination .dot,
.gsys-dot-pagination .dot {
  width: 0.6rem;
  height: 0.6rem;
  border-radius: 50%;
  background: #aaa;
  display: inline-block;
  transition: background 0.2s;
}

.jjfa-dot-pagination .dot.active,
.jdal-dot-pagination .dot.active,
.hzfs-dot-pagination .dot.active,
.gsys-dot-pagination .dot.active {
  background: #1890ff;
}

@media (max-width: 480px) {
  #jdalCarousel {
    margin-bottom: .8rem
  }

  .jjfa-dot-pagination,
  .jdal-dot-pagination,
  .hzfs-dot-pagination,
  .gsys-dot-pagination {
    gap: 0.5rem;
    margin-top: .8rem;
    margin-bottom: 1.4rem;
    min-height: 1rem;
  }

  .jjfa-dot-pagination .dot,
  .jdal-dot-pagination .dot,
  .hzfs-dot-pagination .dot,
  .gsys-dot-pagination .dot {
    width: 0.6rem;
    height: 0.6rem;
  }

  .carousel-item .mb-3 {
    margin-bottom: 0 !important;
  }
}

@media (max-width: 360px) {

  .jjfa-dot-pagination,
  .jdal-dot-pagination,
  .hzfs-dot-pagination,
  .gsys-dot-pagination {
    gap: 0.3rem;
    margin-top: 0;
    margin-bottom: 0.2rem;
    min-height: 0.8rem;
  }

  .jjfa-dot-pagination .dot,
  .jdal-dot-pagination .dot,
  .hzfs-dot-pagination .dot,
  .gsys-dot-pagination .dot {
    width: 0.35rem;
    height: 0.35rem;
  }
}

@media (min-width: 992px) {
  .footer-row-custom {
    display: flex !important;
    justify-content: center;
    align-items: flex-start;
    gap: 0;
  }

  .footer-row-custom>.col-lg-3,
  .footer-row-custom__group>.col-lg-2 {
    flex: 1 1 0;
    min-width: 0;
    max-width: none;
    text-align: center;
    margin-bottom: 0 !important;
    padding-left: 0;
    padding-right: 0;
  }

  .footer-row-custom>.col-lg-3 {
    display: flex;
    flex-direction: column;
    align-items: start;
    white-space: nowrap;
  }

  .footer-row-custom__group {
    display: flex;
    flex: 4 1 0;
    flex-wrap: nowrap;
    width: auto;
    margin: 0 0 0 12rem;
  }

  .footer-row-custom__group>.col-lg-2 {
    display: flex;
    flex-direction: column;
    align-items: start;
    justify-content: flex-start;
    padding: 0 8px;
  }

  .footer-row-custom__group h5,
  .footer-row-custom__group ul {
    text-align: center;
  }

  footer h5 {
    font-size: 1.2rem;
  }
}