/* ===== Left Menu Area ===== */
.leftMenu {
    position: relative;
    padding: 0.5rem 0;
    z-index: 100;
    width: 210px;
}

.leftMenu .menu-item {
    position: static;
}

.leftMenu .menu-item .item-link {
    padding: 0.7rem 1.25rem;
    color: #333;
    font-size: 1rem;
    transition: all 0.2s;
    font-weight: 500;
}

.leftMenu .menu-item:hover .item-link {
    background-color: #eff1f6;
    color: #ff5b00;
}

.leftMenu .menu-item .count {
    color: #999;
    margin-left: 0.25rem;
    font-size: 0.9rem;
    font-weight: normal;
}

.leftMenu .menu-item:hover .count {
    color: #ff5b00;
}

.leftMenu .menu-item .arrow {
    font-size: 0.875rem;
    color: #333;
    font-family: serif;
}

.leftMenu .menu-item:hover .arrow {
    color: #ff5b00;
}

/* Sub Menu */
.leftMenu .sub-menu {
    position: absolute;
    left: 100%;
    top: 0;
    width: 500px;
    height: 100%;
    overflow-y: auto;
    background: #fff;
    display: none;
    z-index: 101;
    padding: 1rem 1.5rem;
    border-left: 1px solid #f0f0f0;
}

.leftMenu .menu-item:hover .sub-menu {
    display: block;
}

.leftMenu .sub-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}
.leftMenu .sub-list dt,.leftMenu .sub-list dd{
    font-weight: normal;
}
.leftMenu .sub-list dd {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-bottom: 0.5rem;
}
.leftMenu .sub-list dd a{
    font-size: 0.875rem;
    color: #666;
}
.leftMenu .sub-list dd a:hover {
    color: #ff5b00;
}
.leftMenu .sub-item {
    font-size: 0.875rem;
    transition: color 0.2s;
    display: block;
    width: 100%;
}

.leftMenu .sub-item:hover {
    color: #ff5b00;
}

.leftMenu .sub-item .count {
    color: #999;
    font-size: 0.9rem;
    margin-left: 0.25rem;
}

.h_party01 .rightCont .top,
.h_party01 .rightCont .bottom {
    padding: 1rem;
    gap: 1rem;
}

/* Hot Product Swiper */
.hot-pro-swiper {
    position: relative;
    padding: 0;
}

.sliderWrap .base_title {
    color: #469682;
}

.hot-pro-swiper .pro-card {
    text-decoration: none;
    transition: transform 0.2s;
}

.hot-pro-swiper .pro-card:hover {
    transform: translateY(-5px);
}

.hot-pro-swiper .pro-img {
    background: #f4f6f8;
    border-radius: 0.5rem;
}


.hot-pro-swiper .pro-name {
    font-size: 0.875rem;
    color: #333;
    font-weight: 500;
}

.hot-pro-swiper .pro-price {
    font-size: 1rem;
    color: #ff5b00;
}

/* Swiper Navigation Custom */
.hot-pro-swiper .swiper-button-next,
.hot-pro-swiper .swiper-button-prev {
    width: 40px;
    height: 40px;
    background: rgba(0, 0, 0, 0.1);
    border-radius: 50%;
    color: #469682;
    transition: all 0.3s;
}

.hot-pro-swiper .swiper-button-next:after,
.hot-pro-swiper .swiper-button-prev:after {
    font-size: 1.25rem;
    font-weight: bold;
}

.hot-pro-swiper .swiper-button-next:hover,
.hot-pro-swiper .swiper-button-prev:hover {
    background: rgba(0, 0, 0, 0.2);
}

.more-link {
    font-size: 0.9rem;
    text-decoration: none;
}

.more-link:hover {
    color: #469682 !important;
}


/* ===== Main Top Area ===== */
.h_party01 .rightCont .sliderWrap {
    width: 62%;
}

.h_party01 .rightCont #mainBanner .swiper-slide {
    border-radius: 0.5rem;
    overflow: hidden;
}

.h_party01 .rightCont #mainBanner .swiper-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.h_party01 .rightCont .sideWrap {
    flex: 1 1 0;
    gap: 1rem;
    width: 0;
}

.h_party01 .rightCont .login-box {
    border-radius: 0.5rem;
    padding: 1rem 1rem 0;
    gap: 1rem;
}

.h_party01 .rightCont .login-box .avatar {
    width: 3.5rem;
    border-radius: 50%;
}

.h_party01 .rightCont .login-box .hi {
    color: #666;
}

.h_party01 .rightCont .login-box .login-actions {
    width: 80%;
}

.h_party01 .rightCont .login-box .login-actions .btn {
    border-radius: 2rem;
    padding: 0.5rem 0;
    flex: 1;
    background: #469682;
}

.h_party01 .rightCont .login-box .btn.register-btn {
    border: 1px solid #469682;
    color: #469682;
    background: #fff;
}

.h_party01 .rightCont .notice-box {
    border-radius: 0.5rem;
    padding: 0 1rem;
}

.h_party01 .rightCont .notice-box .icon {
    width: 1.25rem;
}

.h_party01 .rightCont .notice-box .notice-content {
    color: #666;
    margin-top: 0.5rem;
    font-size: 0.875rem;
}

.h_party01 .rightCont .table {
    padding: 0 1rem;
    margin: 0;
}

/* ===== Price Table Area ===== */
.h_party01 .rightCont .table-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.h_party01 .rightCont .table-scroll.dragging {
    cursor: grabbing;
}

.h_party01 .rightCont .price-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 720px;
}

.h_party01 .rightCont .price-table thead,
.h_party01 .rightCont .price-table tbody {
    border: none;
}

.h_party01 .rightCont .price-table thead th {
    background: #f6f8ff;
    padding: 0.75rem 1rem;
    color: #333;
    font-size: 0.875rem;
}

.h_party01 .rightCont .price-table tbody td {
    padding: 0.75rem 1rem;
    font-size: 0.875rem;
    color: #666;
}

.h_party01 .rightCont .price-table thead th:first-child,
.h_party01 .rightCont .price-table tbody tr>td:first-child {
    text-align: left;
    color: #333;
}

.h_party01 .rightCont .price-table tbody tr:nth-child(even) {
    background: #f6f8ff;
}

.h_party01 .rightCont .price-table .final-price {
    color: #ff7a2c;
    font-weight: 600;
}

/* ===== Inquiry Service Flow (h_party02) ===== */

.h_party02 .flow-aside {
    width: 140px;
    height: 178px;
    background: #469682;
    padding: 1.25rem 1rem;
}

.h_party02 .flow-title {
    font-size: 1.25rem;
}

.h_party02 .cta-btn {
    background: #f8a52f;
    border-radius: 2rem;
    padding: 0.25rem 1.25rem;
    font-size: 0.875rem;
}

.h_party02 .flow-steps {
    flex: 1 1 0;
    width: 0;
    background: #fff;
    border-radius: 0.5rem;
    padding: 1rem;
    gap: 2rem;
    justify-content: space-between;
}

.h_party02 .step {
    position: relative;
    text-align: center;
    min-width: 120px;
}

.h_party02 .step .icon {
    width: 5rem;
    margin: 0 auto;
}

.h_party02 .step .label {
    color: #4d4d4d;
    margin-top: 0.5rem;
    white-space: nowrap;
}

.h_party02 .step:not(:last-child)::before {
    content: '>';
    position: absolute;
    right: -1.5rem;
    top: 50%;
    transform: translateY(-50%);
    color: #b3b3b3;
    font-size: 1.4rem;
    font-weight: lighter;
}



/* Supplier list card */
.join-link {
    font-size: 0.875rem;
}

.supplier-list {
    list-style: none;
    padding: 1rem 0 0;
    margin: 0;
}

.supplier-item {
    background: #f6f8ff;
    border-radius: 0.5rem;
    padding: 1.25rem 1.5rem;
    gap: 0.25rem;
    font-size: 0.875rem;
}

.supplier-item+.supplier-item {
    margin-top: 0.75rem;
}

.supplier-item .name span {
    color: #333;
}

.supplier-item .phone a {
    color: #469682;
    text-decoration: none;
}

.supplier-item .phone a:hover {
    text-decoration: underline;
}

.sup-swiper #supplierSwiper {
    height: auto;
}

.sup-swiper .swiper-pagination {
    position: static;
    margin-top: 0.75rem;
}

.sup-swiper .swiper-pagination-bullet {
    background: #94b3ab;
    opacity: 1;
}

.sup-swiper .swiper-pagination-bullet-active {
    background: #469682;
}


/* Tender grid */
.tender-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

.tender-card {
    border: 1px solid #edf0fb;
    border-radius: 0.5rem;
    padding: 1.5rem 0 0 0;
    background: #f5f5f5;
    transition: border-color .2s ease, box-shadow .2s ease;
    overflow: hidden;
}

.tender-card:hover {
    border-color: #449284;
    box-shadow: 0 0 0 2px rgba(68, 146, 132, .08);
}

.tender-title {
    color: #333;
    font-size: 0.875rem;
    line-height: 1.4;
    height: 2.5rem;
    margin: 0 1rem 1rem;
}

.tender-meta {
    color: #666;
    font-size: 0.75rem;
    margin-top: 0.5rem;
    padding: 0 1rem;
}

.tender-estimate {
    border-top: 1px dashed #edf0fb;
    background: white;
    margin-top: 1.5rem;
    padding: 0.75rem;
    font-size: 0.875rem;
}


.tender-estimate .final-price {
    color: #ff7a2c;
}

/* News area */
.news-banner .news-pic {
    width: 100%;
    border-radius: 0.5rem;
}

.news-hero {
    padding: 0.5rem 0;
    display: block;
    border-bottom: 1px solid #edf0fb;
}

.news-hero .title {
    color: #449284;
    text-decoration: none;
}

.news-hero .title:hover {
    text-decoration: underline;
}

.news-desc {
    color: #666;
    margin: 0.5rem 0;
    font-size: 0.875rem;
}

.news-meta {
    font-size: 0.75rem;
    color: #adadad !important;
}

.news-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.news-list li {
    line-height: 2.5;
    font-size: 0.875rem;
}

.news-list li a {
    color: #3d4140;
    text-decoration: none;
}

.news-list li a:hover {
    color: #469682;
}

.news-list li::before {
    content: '';
    display: inline-block;
    width: 0.25rem;
    height: 0.25rem;
    border-radius: 50%;
    background: #469682;
    margin-right: 0.5rem;
    position: relative;
    top: -0.1rem;
}



.product-list {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
    width: 100%;
}

.product-item {
    background: #f9f9f9;
    padding: 1.5rem 0;
}

.product-item .icon {
    width: 4rem;
}

/* ===== Partners & Links (h_party03) ===== */
.h_party03 {
    border-radius: 0.5rem;
}

/* ===== Partners & Links (h_party06) ===== */
.h_party06 {
    border-radius: 0.5rem;
}

.h_party06 .tabs {
    padding-bottom: 0.25rem;
}

.h_party06 .tab-btn {
    color: #333;
    text-decoration: none;
    position: relative;
}

.h_party06 .tab-btn.active {
    color: #449284;
}

.h_party06 .tab-btn.active::after {
    position: absolute;
    content: '';
    display: block;
    left: 0;
    bottom: -0.5rem;
    width: 100%;
    height: 2px;
    background: #449284;
}

#brandSwiper .swiper-slide {
      text-align: center;
      background: #fff;
      height: calc((100% - 10px) / 2) !important;

      /* Center slide text vertically */
      display: flex;
      justify-content: center;
      align-items: center;
    }
#brandSwiper .swiper-slide img{
    max-width: 100%;
    height: 100%;
    object-fit: contain;
}
.brand-swiper .swiper-pagination {
    position: static;
    margin-top: 0.75rem;
}

.brand-swiper .swiper-pagination-bullet {
    background: #94b3ab;
    opacity: 1;
}

.brand-swiper .swiper-pagination-bullet-active {
    background: #469682;
}

.friend-links {
    gap: 0.75rem 2rem;
}

.friend-links li a {
    color: #3d4140;
    font-size: 0.875rem;
}

.friend-links li a:hover {
    color: #469682;
}
/*商城首页 begin*/
.shopHome .panel-header{
    width: 20%;
}
.shopHome .columnHeader{
    font-size: 1rem;
    font-weight: bold;
}
.shopHome .columnActions a{
    width: 48%;
    font-size: 0.875rem;
    color: #333;
}
.shopHome .columnActions a:hover{
    color: #ff5b00;
}

.shopHome .product-grid{
    grid-template-columns: repeat(5, 1fr);
    width: 80%;
}
/* 商城首页 end */


/* Responsive (<=1200px) */
@media (max-width: 1200px) {
    .h_party01 .rightCont .sliderWrap,
    .h_party01 .rightCont .sideWrap {
        width: 100%;
    }
    .h_party01 .rightCont .notice-box {
        display: none;
    }

    .h_party02 .flow-steps {
        gap: 0;
        justify-content: space-around;
    }

    .h_party02 .step .icon {
        width: 2.5rem;
    }



}

/* Responsive (<=768px) */
@media (max-width: 768px) {
    

    .h_party01 .rightCont .top {
        flex-direction: column;
    }
    .h_party01 .rightCont .bottom{
        gap: 2rem;
    }
    

    #mainBanner {
        height: 150px;
    }

    .h_party02 {
        flex-direction: column;
        gap: 1rem;
    }

    .h_party02 .flow-aside {
        width: 100%;
        text-align: center;
        height: auto;
    }

    .h_party02 .cta-btn {
        width: 70%;
    }

    .h_party02 .flow-steps {
        width: 100%;
        gap: 1.25rem;
    }

    .h_party02 .step {
        min-width: calc(33.33% - 1rem);
    }

    .h_party02 .step:not(:last-child)::before {
        right: -1rem;
    }

    .h_party02 .step:not(:last-child)::after {
        right: -0.9rem;
    }

    .tender-grid {
        grid-template-columns: 1fr;
    }

    .product-list {
        grid-template-columns: repeat(2, 1fr);
        gap: 1;
    }

    .brand-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .shopHome .panel-header{
        width: 100%;
    }
    .shopHome .columnActions a{
        width: auto;
    }
    .shopHome .product-grid{
        width: 100%;
        grid-template-columns: repeat(2, 1fr);
    }
}

