/* body {
    background-color: #E3F6E6;
    background: linear-gradient(to right,
            white 0%,
            white 25%,
            #E3F6E6 50%,
            white 75%,
            white 100%);banner-overlay

/* -------- */
body {
    font-family: var(--body-font);
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: var(--heading-font);
    font-weight: 700;
    margin-bottom: 20px;
}

.meeting-doc-link::before {
    content: "\f15c";
    font-family: "Font Awesome 5 Free";
    margin-right: 8px;
    color: var(--primary-color);
}

html.dark-theme * {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    stroke: none !important;
}

/* Container của các slide khách hàng */
.customer-carousel-wrapper {
    position: relative;
    overflow: hidden;
}

.emc-global-header-nav-link {
    font-size: 13px !important;
    font-family: 'Montserrat', Arial, Helvetica, sans-serif !important;
    text-transform: uppercase !important;
    padding: 8px 12px;
}

.customer-slide-item {
    display: none;

    animation-duration: 0.8s;
    animation-fill-mode: both;
}

.customer-slide-item.active {
    display: block;
    animation-name: fadeIn;
}

/* Keyframe cho hiệu ứng mờ dần (fade-in) */
@keyframes fadeIn {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

.emc-hero-blobs-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    pointer-events: none;
}

.emc-hero-blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(48px);
    opacity: 0.38;
    pointer-events: none;
    z-index: 1;
    transition: opacity 0.5s;
}

.blob1 {
    width: 340px;
    height: 340px;
    left: -80px;
    top: -60px;
    background: #a7fb6c;
}

.blob2 {
    width: 260px;
    height: 260px;
    right: -60px;
    top: 80px;
    background: #43b26c;
    opacity: 0.28;
}

.blob3 {
    width: 180px;
    height: 180px;
    left: 40%;
    bottom: -60px;
    background: #e0f5e3;
    opacity: 0.22;
}

.blob4 {
    width: 120px;
    height: 120px;
    left: 70%;
    top: 10%;
    background: #b6e7c9;
    opacity: 0.18;
}

.blob5 {
    width: 200px;
    height: 200px;
    right: 10%;
    bottom: 0;
    background: #86e29b;
    opacity: 0.19;
}

.blob6 {
    width: 100px;
    height: 100px;
    left: 10%;
    bottom: 10%;
    background: #43b26c;
    opacity: 0.15;
}

.blob-center {
    width: 420px;
    height: 420px;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    background: #a7fb6c;
    opacity: 0.18;
    filter: blur(72px);
    z-index: 0;
}

@media (max-width: 700px) {
    .blob1 {
        width: 120px;
        height: 120px;
        left: -30px;
        top: -20px;
    }

    .blob2 {
        width: 80px;
        height: 80px;
        right: -20px;
        top: 40px;
    }

    .blob3 {
        width: 60px;
        height: 60px;
        left: 50%;
        bottom: -20px;
    }

    .blob4 {
        width: 40px;
        height: 40px;
        left: 70%;
        top: 10%;
    }

    .blob5 {
        width: 60px;
        height: 60px;
        right: 10%;
        bottom: 0;
    }

    .blob6 {
        width: 30px;
        height: 30px;
        left: 10%;
        bottom: 10%;
    }

    .blob-center {
        width: 180px;
        height: 180px;
    }
}

/* CSS cho Dấu chấm phân trang (giữ nguyên như trước) */
.pagination-dots-container {
    text-align: center;
    margin-top: 30px;
    margin-bottom: 20px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
}

.pagination-dots-container .pagination-dot {
    display: block;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background-color: #d1d1d1;
    cursor: pointer;
    transition: all 0.3s ease;
    border: 1px solid #d1d1d1;
}

.pagination-dots-container .pagination-dot:hover {
    background-color: #a0a0a0;
}

.pagination-dots-container .pagination-dot.active {
    background: linear-gradient(to right, #4CAF50, #2E8B57);
    border-color: #2E8B57;
    transform: scale(1.2);
    /* box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2); */
}

/* -------- */
.number-float {
    display: inline-block;
    animation: bounce 5s ease-in-out infinite;
}

@keyframes bounce {

    0%,
    100% {
        transform: translateY(0);
    }

    30% {
        transform: translateY(-15px);
    }

    50% {
        transform: translateY(-8px);
    }

    70% {
        transform: translateY(-12px);
    }
}

/* Featured Customer Section */

.featured-customers-section {
    padding: 0 !important;
}
.featured-customers-section.py-5{
    margin-top: 0 !important;

}
.featured-row {
    margin-top: 40px;
    align-items: center;
    display: flex;

}

/* Khung ảnh */
.customer-photo-frame {
    position: relative;
    width: 100%;
    height: 400px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 30px;
}

.photo-frame-inner {
    position: relative;
    width: 85%;
    height: 85%;
    border-radius: 20px;
    /* box-shadow: 0 15px 30px rgba(8, 105, 36, 0.15); */
    overflow: hidden;
    transition: all 0.5s ease;
}

.photo-frame-inner:hover {
    transform: scale(1.02);
    /* box-shadow: 0 20px 40px rgba(8, 105, 36, 0.2); */
}

.photo-container {
    width: 100%;
    height: 100%;
    overflow: hidden;
    position: relative;
}

.featured-customer-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: all 0.8s ease;
}

.photo-frame-inner:hover .featured-customer-img {
    transform: scale(1.1);
}

/* Trang trí khung ảnh */
.frame-decoration {
    position: absolute;
    width: 40px;
    height: 40px;
    /* border: 3px solid #43b26c; */
    z-index: 2;
}

.frame-decoration-1 {
    top: -5px;
    left: -5px;
    border-right: none;
    border-bottom: none;
    border-top-left-radius: 10px;
}

.frame-decoration-2 {
    top: -5px;
    right: -5px;
    border-left: none;
    border-bottom: none;
    border-top-right-radius: 10px;
}

.frame-decoration-3 {
    bottom: -5px;
    left: -5px;
    border-right: none;
    border-top: none;
    border-bottom-left-radius: 10px;
}

.frame-decoration-4 {
    bottom: -5px;
    right: -5px;
    border-left: none;
    border-top: none;
    border-bottom-right-radius: 10px;
}

/* Thông tin khách hàng */
.customer-info-box {
    padding: 20px;
}

.customer-company-name {
    font-size: 28px;
    font-weight: 800;
    margin-bottom: 20px;
    color: #086924;
}

.customer-info-detail {
    margin-bottom: 30px;
}

.customer-info-item {
    display: flex;
    align-items: center;
    margin-bottom: 15px;
}

.customer-info-item i {
    color: #43b26c;
    font-size: 18px;
    width: 30px;
}

.customer-info-item span {
    color: #555;
    font-size: 16px;
}

/* Trích dẫn khách hàng */
.customer-quote {
    position: relative;
    background: rgba(255, 255, 255, 0.8);
    padding: 25px;
    border-radius: 15px;
    margin: 30px 0;
    /* box-shadow: 0 5px 15px rgba(8, 105, 36, 0.08); */
}

.quote-icon {
    color: #43b26c;
    font-size: 24px;
    margin-bottom: 10px;
    opacity: 0.8;
}

.customer-quote p {
    font-style: italic;
    color: #444;
    font-size: 16px;
    line-height: 1.6;
}

.quote-author {
    margin-top: 15px;
    text-align: right;
    color: #086924;
}

/* Thống kê khách hàng */
.customer-stats {
    display: flex;
    justify-content: space-between;
    margin-top: 20px;
}

.stats-container {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    margin-top: 60px;
    padding: 10px;
    border-radius: 24px;
}

/* //nen toi  */
html.dark-theme .stats-container {
    background-color: rgba(44, 44, 44, 0.9);
    /* Nền tối hơn và hơi trong suốt */
    /* box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);  */
    border: none;
}

html.dark-theme .stat-number {
    color: #76e89c;
}

html.dark-theme .stat-label {
    color: #ccc;
}

.stat-item {
    text-align: center;
}

.stat-number {
    font-size: 2.8rem;
    font-weight: 800;
    color: #086924;
    text-shadow: 2px 2px 4px rgba(167, 251, 108, 0.3);
}

.stat-label {
    margin-top: 8px;
    font-size: 1rem;
    color: #555;
}

/* slide */
.swiper-slide {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 500px;
    /* hoặc chiều cao cụ thể theo nội dung */
    padding: 20px 0;
    border: none !important;
}

.customer-photo-frame {
    max-width: 100%;
    text-align: center;
}

.featured-customer-img {
    width: 100%;
    max-width: 300px;
    height: auto;
    border-radius: 12px;
}

.featured-customers-section .row {
    min-height: 100%;
    align-items: center;
}

.swiper-container {
    overflow: hidden;
    position: relative;
    padding-bottom: 10px;
    border: none;
}

.swiper-pagination {
    color: #086924;
    position: absolute;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    text-align: center;
}

.swiper-pagination-bullet {
    width: 8px;
    /* nhỏ lại */
    height: 8px;
    margin: 0 2px;
    /* khoảng cách giữa các chấm */
    background: #1d701d;
    /* xanh lá */
    opacity: 0.5;
    border-radius: 50%;
    /* bo tròn */
}

.swiper-pagination-bullet-active {
    background: #2ecc71;
    /* xanh lá sáng hơn khi active */
    opacity: 1;
}


/* Banner */
.list-customer {
    background-color: #E3F6E6;
}

.page-banner {
    position: relative;
    /* Loại bỏ background-color cũ hoặc đặt thành trong suốt */
    background: linear-gradient(to right,
            white 0%,
            white 25%,
            #E3F6E6 50%,
            white 75%,
            white 100%);
    /* TRÙNG MÀU VỚI BODY */
    color: #000;
    /* Đặt màu chữ cho banner là màu tối để dễ đọc */
    padding: 40px 0;
    text-align: center;
    margin-bottom: 30px;
}

.hero-banner-title {
    margin-bottom: 5px;
}

.hero-banner-title .gradient-green {
    background: linear-gradient(90deg, #a7fb6c 0%, #43b26c 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-fill-color: transparent;
    font-weight: 700;
}

/* .banner-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
} */
.banner-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(227, 246, 230, 0.5);
    /* Màu #E3F6E6 với độ trong suốt 50% */
}

.container1 {
    /* background-color: #E3F6E6; */
    position: relative;
    z-index: 1;
}

.page-banner .container {
    position: relative;
    color: #000;
    z-index: 1;
}

.page-banner h1 {
    font-size: 2.8rem;
    margin-bottom: 50px;
    font-weight: 700;
}

.page-banner h1 {
    font-size: 2.8rem;
    margin: 5px 0;
    font-weight: 700;
}

.investor-hero-banner-soft {
    position: relative;
    width: 100%;
    min-height: 480px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    overflow: hidden;
    padding: 100px 0 40px 0;
}

.hero-bg-soft {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: radial-gradient(circle at 20% 30%, #a7fb6c22 0%, #eafaf1 60%, #fff 100%),
        radial-gradient(circle at 80% 60%, #b0e0fb22 0%, #fff 80%);
    filter: blur(0.5px);
    pointer-events: none;
}

.hero-banner-content {
    position: relative;
    z-index: 2;
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 420px;
}

.hero-banner-inner {
    width: 100%;
    max-width: 650px;
    margin: 0 auto;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.hero-banner-label {
    font-size: 0.92rem;
    font-weight: bold;
    margin-bottom: 10px;
}

/* Background overlay */
.background-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    /* background: radial-gradient(circle, #E3F6E6 40%, rgb(242, 237, 239) 100%); */
    z-index: -3;
    opacity: 0.7;
}

.overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.1);
    z-index: -2;
    pointer-events: none;
}

/* Balloons */
.floating-balloons {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    z-index: -1;
}

.balloon {
    position: absolute;
    border-radius: 50%;
    opacity: 0.4;
    animation: floatUp 20s linear infinite;
}

.balloon-1 {
    width: 60px;
    height: 60px;
    left: 10%;
    background: #CDE6D0;
    animation-delay: 0s;
    opacity: 1;
}

.balloon-2 {
    width: 40px;
    height: 40px;
    left: 20%;
    background: #bad0bc;
    animation-delay: 5s;
    opacity: 1;
}

.balloon-3 {
    width: 40px;
    height: 40px;
    left: 30%;
    background: #CDE6D0;
    animation-delay: 2s;
    opacity: 1;
}

.balloon-4 {
    width: 50px;
    height: 50px;
    left: 40%;
    background: #96d49d;
    animation-delay: 7s;
    opacity: 1;
}

.balloon-5 {
    width: 45px;
    height: 45px;
    left: 50%;
    background: #a4f5ad;
    animation-delay: 4s;
    opacity: 1;
}

.balloon-6 {
    width: 55px;
    height: 55px;
    left: 60%;
    background: #CDE6D0;
    animation-delay: 1s;
    opacity: 1;
}

.balloon-7 {
    width: 65px;
    height: 65px;
    left: 70%;
    background: #CDE6D0;
    animation-delay: 6s;
    opacity: 1;
}

.balloon-8 {
    width: 35px;
    height: 35px;
    left: 80%;
    background: #CDE6D0;
    animation-delay: 3s;
    opacity: 1;
}

.balloon-9 {
    width: 50px;
    height: 50px;
    left: 90%;
    background: #CDE6D0;
    animation-delay: 8s;
    opacity: 1;
}

.balloon-10 {
    width: 40px;
    height: 40px;
    left: 95%;
    background: #93c098;
    animation-delay: 9s;
    opacity: 1;
}

@keyframes floatUp {
    0% {
        transform: translateY(100vh) scale(1);
        opacity: 0;
    }

    10% {
        opacity: 0.7;
    }

    100% {
        transform: translateY(-150vh) scale(1.2);
        opacity: 0;
    }
}

/* Carousel */
.carousel-wrapper {
    overflow: hidden;
    padding: 30px 0;
    position: relative;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
}

.carousel {
    display: flex;
    gap: 20px;
    padding: 10px;
    overflow-x: hidden;
    width: 100%;
    white-space: nowrap;
    scroll-behavior: auto;
    animation: carousel-scroll 90s linear infinite;
}

/* Customer cards */
.customer-card-container {
    display: flex;
    flex-wrap: nowrap;
    gap: 200px;
    /* Khoảng cách giữa các card */
    justify-content: center;
    padding: 20px 60px;
    /* background-color: #E3F6E6; */
    overflow-x: auto;
    scroll-behavior: smooth;
    scrollbar-width: none;
}

.customer-card-container::-webkit-scrollbar {
    display: none;
    background-color: #E3F6E6;
}

.customer-card {
    width: 150px;
    height: 150px;
    perspective: 1000px;
    border-radius: 50%;
    flex-shrink: 0;
    overflow: hidden;
    padding: 0;
    transition: transform 0.3s ease;
    border: 2px solid transparent;
    /* box-shadow: 0 3px 6px rgba(0, 0, 0, 0.06); */
}

.customer-card.highlight {
    transform: scale(1.05);
    color: #000;
}

.customer-card:hover {
    transform: translateY(-3px) scale(1.05);
    box-shadow: none;
}


/* Section chính */
.testimonials-section {
    /* background: linear-gradient(135deg, #f2faf3 0%, #e0f5e3 100%); */
    padding: 70px 0;
    background-color: #ffffff;
    position: relative;
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
}


/* Các chấm nền trang trí */
.testimonials-section>div:nth-child(1) {
    position: absolute;
    top: -100px;
    right: -100px;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(134, 226, 155, 0.12) 0%, rgba(255, 255, 255, 0) 70%);
}

.testimonials-section>div:nth-child(2) {
    position: absolute;
    bottom: -50px;
    left: -50px;
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, rgba(134, 226, 155, 0.09) 0%, rgba(255, 255, 255, 0) 70%);
}

/* Container chính bên trong */
.ecosystem-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

.hero-banner-desc {
    font-size: 1.18rem;
    color: #444;
    font-weight: 400;
    line-height: 1.6;
    margin-bottom: 0px;
    opacity: 0.92;
    text-align: center;
}

.stats-grid {
    margin-top: 0;
}

/* Tiêu đề chính */
.section-title {
    font-size: 52px;
    font-weight: 900;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif !important;
    line-height: 1.1;
    margin-bottom: 24px;
    letter-spacing: -1px;
    text-align: center;
}

.section-title span {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
}

.section-title span:first-child {
    /* color: #1a3c1a; */
}

.section-title span:last-child {
    /* background: linear-gradient(90deg, #a7fb6c 0%, #43b26c 100%); */
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-fill-color: transparent;
}

/* Mô tả bên dưới tiêu đề */
.ecosystem-container>p {
    text-align: center;
    max-width: 800px;
    margin: 0 auto 40px;
    color: #555;
    font-size: 16px;
    line-height: 1.6;
}

/* Lưới testimonial */
.testimonials-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 40px;
    margin-top: 50px;
}

/* Card testimonial */
.testimonial-card {
    /* background: #f8fff8; */
    border-radius: 24px;
    /* box-shadow: 0 10px 30px rgba(8, 105, 36, 0.08); */
    padding: 40px;
    position: relative;
    overflow: hidden;
    transition: all 0.4s ease;
    display: flex;
    flex-direction: column;
    cursor: pointer;
}

.testimonial-card:hover {
    transform: translateY(-10px);
    /* box-shadow: 0 20px 40px rgba(8, 105, 36, 0.12); */
}

/* Phần đầu avatar và tên */
.testimonial-header {
    display: flex;
    align-items: center;
    gap: 24px;
    margin-bottom: 24px;
}

.testimonial-avatar {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    overflow: hidden;
    /* box-shadow: 0 4px 12px rgba(8, 105, 36, 0.15); */
}

.testimonial-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Tên và chức vụ */
.testimonial-name {
    font-size: 20px;
    font-weight: 700;
    color: #086924;
    margin-bottom: 4px;
}

.testimonial-position {
    font-size: 14px;
    color: #666;
}

/* Nội dung đánh giá */
.testimonial-content {
    font-size: 16px;
    color: #555;
    line-height: 1.6;
    position: relative;
    padding-left: 24px;
    border-left: 3px solid #43b26c;
    margin-bottom: 20px;
}

/* Phần sao đánh giá */
.testimonial-stars {
    color: #43b26c;
}

/* Ví dụ icon sao, bạn cần thêm fontawesome hoặc thay icon */
.testimonial-stars i {
    margin-right: 4px;
}

/* Flip card inner structure */
.card-inner {
    position: relative;
    width: 100%;
    height: 100%;
    transition: transform 0.8s;
    transform-style: preserve-3d;
    border-radius: 50%;
}

.customer-card:hover .card-inner {
    transform: rotateY(180deg);
}

.card-front,
.card-back {
    position: absolute;
    width: 100%;
    height: 100%;
    backface-visibility: hidden;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}

.card-front {
    background-color: transparent;
}

.card-back {
    background-color: #E3F6E6;
    transform: rotateY(180deg);
}

/* Avatar fill full */
.customer-avatar {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    overflow: hidden;
    border: none;
    margin: 0;
}

.customer-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
    user-select: none;
    pointer-events: none;
}

/* Contact button */
.contact-btn {
    background-color: #00a862;
    color: white;
    padding: 10px 20px;
    border-radius: 25px;
    border: none;
    cursor: pointer;
    margin-top: 10px;
    font-size: 0.9em;
    font-weight: bold;
    transition: background 0.3s ease;
}

.customer-card.highlight .contact-btn {
    background-color: white;
}

.contact-btn:hover {
    background-color: #005e3a;
}

/* Slider navigation */
.slider-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}

.slider-btn {
    z-index: 2;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    color: white;
    border: none;
    font-size: 1.5em;
    padding: 10px 15px;
    cursor: pointer;
    border-radius: 50%;
    opacity: 0.8;
    transition: opacity 0.2s;
}

.slider-btn.left {
    left: 0;
}

.slider-btn.right {
    right: 0;
}

.slider-btn:hover {
    opacity: 1;
}

/* Pagination */
.pagination {
    text-align: center;
    margin-top: 20px;
}

.pagination a,
.pagination strong {
    margin: 0 5px;
    text-decoration: none;
    color: #00704a;
    font-weight: bold;
}

.pagination strong {
    color: #333;
}


/* -------- */



/* Responsive */
/* --- Các kiểu Responsive hoàn chỉnh --- */

/* Điều chỉnh cho thiết bị di động nhỏ (Extra small devices - phones, <576px) */
@media (max-width: 575.98px) {

    /* Banner và Thống kê */
    .page-banner h1 {
        font-size: 2rem;
        margin-bottom: 20px;
    }

    .hero-banner-label {
        font-size: 0.8rem;
    }

    .hero-banner-desc {
        font-size: 1rem;
        margin-bottom: 20px;
    }

    .page-banner .container .row>div {
        flex-basis: 100%;
        /* Mỗi thống kê chiếm 1 hàng */
        text-align: center;
        margin-bottom: 15px;
    }

    .page-banner .container .row>div:last-child {
        margin-bottom: 0;
    }

    /* Khối thống kê hero-stats-grid mới thêm */
    .hero-stats-grid {
        grid-template-columns: 1fr;
        /* 1 cột trên mobile */
        gap: 20px;
        margin-top: 0px;
        padding: 5px;
    }

    .stat-item-inner .number-float {
        font-size: 36px;
        margin-bottom: 5px;
    }

    .stat-item-inner .stat-label-large {
        font-size: 15px;
    }

    /* Phần Khách hàng nổi bật */
    .featured-customers-section {
        padding: 40px 0;
        /* Giảm đệm phần */
    }

    .featured-row {
        flex-direction: column;
        /* Xếp chồng ảnh và thông tin */
        text-align: center;
        /* Căn giữa nội dung */
    }

    .customer-photo-frame {
        width: 80%;
        /* Giảm chiều rộng khung ảnh */
        height: 300px;
        /* Giảm chiều cao khung ảnh */
        margin: 0 auto 20px;
        /* Căn giữa và khoảng cách dưới */
    }

    .photo-frame-inner {
        width: 100%;
        /* Đảm bảo khung ảnh con đầy đủ */
        height: 100%;
    }

    .customer-company-name {
        font-size: 24px;
        /* Giảm kích thước tên công ty */
        margin-top: 20px;
    }

    .customer-info-box {
        padding: 15px;
        /* Giảm đệm hộp thông tin */
    }

    .customer-quote {
        padding: 15px;
        /* Giảm đệm trích dẫn */
        margin: 20px 0;
    }

    .customer-stats {
        /* Đây là phần thống kê nhỏ bên trong phần Featured Customer */
        flex-direction: column;
        /* Xếp chồng thống kê */
        gap: 10px;
    }

    .stat-value {
        font-size: 20px;
    }

    .stat-label {
        font-size: 12px;
    }

    /* Danh sách Khách hàng (Carousel ngang) */
    .carousel-wrapper {
        padding: 20px 0;
        /* Giảm đệm tổng thể */
    }

    .customer-card-container {
        gap: 50px;
        /* Giảm khoảng cách giữa các thẻ */
        padding: 10px 20px;
        /* Giảm đệm ngang */
    }

    .customer-card {
        width: 120px;
        /* Giảm kích thước thẻ */
        height: 120px;
    }

    .contact-btn {
        font-size: 0.7em;
        /* Giảm kích thước chữ nút */
        padding: 5px 10px;
        /* Giảm đệm nút */
    }


    /* Phần Lời chứng thực */
    .testimonials-grid {
        grid-template-columns: 1fr;
        /* 1 cột trên di động */
        gap: 30px;
    }

    .testimonial-card {
        padding: 25px;
        /* Giảm đệm thẻ */
    }

    .testimonial-header {
        flex-direction: column;
        /* Xếp chồng avatar và tên */
        text-align: center;
        gap: 15px;
    }

    .testimonial-avatar {
        width: 60px;
        /* Giảm kích thước avatar */
        height: 60px;
    }

    .testimonial-name {
        font-size: 18px;
        /* Giảm kích thước tên */
    }

    .testimonial-position {
        font-size: 13px;
        /* Giảm kích thước chức vụ */
    }

    .testimonial-content {
        padding-left: 0;
        /* Bỏ padding trái cho đường viền */
        border-left: none;
        /* Bỏ đường viền xanh lá cây */
        text-align: center;
        /* Căn giữa nội dung */
    }

    .testimonial-stars {
        justify-content: center;
        /* Căn giữa các sao */
        display: flex;
        margin-top: 10px;
    }

    .section-title {
        font-size: 36px;
        /* Giảm kích thước tiêu đề phần */
    }

    .ecosystem-container>p {
        font-size: 14px;
        /* Giảm kích thước mô tả dưới tiêu đề */
        margin: 0 auto 30px;
    }

    /* Các bong bóng nền */
    .balloon {
        width: 30px !important;
        /* Giảm kích thước */
        height: 30px !important;
        opacity: 0.3 !important;
        /* Giảm độ mờ */
    }
}

/* Điều chỉnh cho thiết bị di động (Small devices - phones, >=576px và <768px) */
@media (min-width: 576px) and (max-width: 767.98px) {
    .page-banner h1 {
        font-size: 2.5rem;
    }

    /* Khối thống kê hero-stats-grid mới thêm */
    .hero-stats-grid {
        grid-template-columns: repeat(2, 1fr);
        /* 2 cột trên tablet dọc */
        gap: 25px;
        margin-top: 40px;
        padding: 30px;
    }

    .stat-item-inner .number-float {
        font-size: 40px;
    }

    .stat-item-inner .stat-label-large {
        font-size: 16px;
    }

    .customer-photo-frame {
        height: 350px;
    }

    .customer-company-name {
        font-size: 26px;
    }

    .customer-card-container {
        gap: 100px;
        padding: 15px 30px;
    }

    .customer-card {
        width: 140px;
        height: 140px;
    }

    .contact-btn {
        font-size: 0.8em;
        padding: 6px 14px;
    }

    .testimonials-grid {
        grid-template-columns: 1fr;
        /* Vẫn 1 cột trên tablet dọc */
    }

    .section-title {
        font-size: 42px;
    }
}

/* Điều chỉnh cho máy tính bảng (Medium devices - tablets, >=768px và <992px) */
@media (min-width: 768px) and (max-width: 991.98px) {

    /* Khối thống kê hero-stats-grid mới thêm */
    .hero-stats-grid {
        grid-template-columns: repeat(3, 1fr);
        /* 3 cột trên tablet ngang */
        gap: 25px;
        margin-top: 50px;
        padding: 35px;
    }

    .stat-item-inner .number-float {
        font-size: 44px;
    }

    .stat-item-inner .stat-label-large {
        font-size: 17px;
    }

    /* Đảm bảo hàng khách hàng nổi bật vẫn ngang */
    .featured-row {
        flex-direction: row;
        text-align: left;
    }

    /* Các testimonial có thể là 2 cột */
    .testimonials-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .testimonial-header {
        flex-direction: row;
        text-align: left;
    }

    .testimonial-content {
        padding-left: 24px;
        border-left: 3px solid #43b26c;
        text-align: left;
    }

    .testimonial-stars {
        justify-content: flex-start;
    }

    .section-title {
        font-size: 48px;
    }
}

/* Điều chỉnh cho màn hình desktop nhỏ (Large devices - desktops, >=992px và <1200px) */
@media (min-width: 992px) and (max-width: 1199.98px) {
    .customer-card-container {
        padding: 20px 40px;
        gap: 150px;
    }

    .customer-card {
        width: 150px;
        height: 150px;
    }

    .contact-btn {
        font-size: 0.9em;
        padding: 10px 20px;
    }
}

/* Điều chỉnh cho màn hình desktop lớn (Extra large devices - large desktops, >=1200px) */
@media (min-width: 1200px) {

    /* Các kiểu mặc định của bạn đã được thiết kế cho màn hình lớn. */
    /* Bạn có thể thêm các tối ưu hóa đặc biệt cho màn hình siêu rộng nếu cần. */
    .section-title {
        font-size: 52px;
    }
}

@media screen and (min-width: 768px) {
    .stats-grid {
        flex-direction: column !important;
        align-items: center;
        gap: 10px !important;
        padding: 24px 16px !important;
    }
}

@media screen and (max-width: 980px) {
    .stats-container {
        display: flex;
        justify-content: space-between;
        gap: 18px;
        margin-top: 60px;
        padding: 10px;
        border-radius: 24px;
    }

}

@media (max-width: 388px) {
    .stat-item {
        flex: 1 1 100%;
        text-align: center;
        padding: 8px 0;
    }

    .stat-item {
        flex: 1 1 100%;
        text-align: center;
    }

    .stat-number {
        font-size: 36px;
        font-weight: 800;
        color: #086924;
        margin-bottom: 10px;
        text-shadow: 2px 2px 4px rgba(167, 251, 108, 0.3);
    }

    .stat-label {
        font-size: 16px;
        color: #555;
        font-weight: 500;
    }

    .stat-number {
        font-size: 20px;
    }

    .stat-label {
        font-size: 12px;
    }

    .stats-container {
        flex-direction: row;
        gap: 12px;
    }
}

@media (min-width: 1024px) {
    .stat-item {
        flex: 1 1 0;
    }

    .stat-number {
        font-size: 48px;
    }

    .stat-label {
        font-size: 18px;
    }

    .stats-container {
        gap: 32px;
    }
}

/* --- Global Styles hoặc Styles mặc định cho Desktop (> 768px rộng và mọi hướng) --- */
.testimonials-section {
    background: linear-gradient(135deg, #f2faf3 0%, #e0f5e3 100%);
    /* Giữ nguyên gradient */
    padding: 80px 0;
    /* Padding mặc định */
    position: relative;
    overflow: hidden;
    border: none;
    /* Bỏ !important */
    box-shadow: none;
    /* Bỏ !important */
    outline: none;
    /* Bỏ !important */
}

/* Các chấm nền trang trí */
.testimonials-section>div:nth-child(1) {
    position: absolute;
    top: -100px;
    right: -100px;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(134, 226, 155, 0.12) 0%, rgba(255, 255, 255, 0) 70%);
}

.testimonials-section>div:nth-child(2) {
    position: absolute;
    bottom: -50px;
    left: -50px;
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, rgba(134, 226, 155, 0.09) 0%, rgba(255, 255, 255, 0) 70%);
}

/* Container chính bên trong */
.ecosystem-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* Tiêu đề chính */
.section-title {
    font-size: 52px;
    font-weight: 900;
    line-height: 1.1;
    margin-bottom: 24px;
    letter-spacing: -1px;
    text-align: center;
}

.section-title span:first-child {
    color: #1a3c1a;
    /* Đặt lại màu chữ nếu bạn bỏ comment */
}

.section-title span:last-child {
    background: linear-gradient(90deg, #a7fb6c 0%, #43b26c 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-fill-color: transparent;
}

/* Mô tả bên dưới tiêu đề */
.ecosystem-container>p {
    text-align: center;
    max-width: 800px;
    margin: 0 auto 40px;
    color: #555;
    font-size: 16px;
    line-height: 1.6;
}

/* Lưới testimonial (MẶC ĐỊNH: 2 cột) */
.testimonials-grid-container {
    /* Đã đổi tên class theo HTML mới */
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    /* Mặc định 2 cột */
    gap: 40px;
    margin-top: 50px;
}

/* Card testimonial */
.testimonial-card {
    background: #f8fff8;
    /* Màu nền card */
    border-radius: 24px;
    /* box-shadow: 0 10px 30px rgba(8, 105, 36, 0.08); */
    padding: 40px;
    position: relative;
    overflow: hidden;
    transition: all 0.4s ease;
    display: flex;
    flex-direction: column;
    cursor: pointer;
}

.testimonial-card:hover {
    transform: translateY(-10px);
    /* box-shadow: 0 20px 40px rgba(8, 105, 36, 0.12); */
}

/* Phần đầu avatar và tên */
.testimonial-header {
    display: flex;
    align-items: center;
    gap: 24px;
    margin-bottom: 24px;
}

.testimonial-avatar {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    overflow: hidden;
    /* box-shadow: 0 4px 12px rgba(8, 105, 36, 0.15); */
}

.testimonial-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Tên và chức vụ */
.testimonial-name {
    font-size: 20px;
    font-weight: 700;
    color: #086924;
    margin-bottom: 4px;
}

.testimonial-position {
    font-size: 14px;
    color: #666;
}

/* Nội dung đánh giá */
.testimonial-content {
    font-size: 16px;
    color: #555;
    line-height: 1.6;
    position: relative;
    padding-left: 24px;
    border-left: 3px solid #43b26c;
    margin-bottom: 20px;
    text-align: justify;
    /* Thêm text-align: justify để căn đều */
}

/* Phần sao đánh giá */
.testimonial-stars {
    color: #43b26c;
    margin-top: 0;
    /* Đảm bảo không có margin top thừa */
}

.testimonial-stars i {
    margin-right: 4px;
}

/* --- MEDIA QUERIES cho Responsive --- */

/* Khi màn hình DỌC (ví dụ: điện thoại hoặc máy tính bảng dọc) */
@media screen and (max-width: 767.98px) and (orientation: portrait),
screen and (max-width: 575.98px) {

    /* Cho mobile nhỏ hơn 576px, luôn 1 cột */
    .testimonials-section {
        padding: 50px 0;
        /* Giảm padding tổng thể */
    }

    .section-title {
        font-size: 36px;
        /* Giảm kích thước tiêu đề */
        margin-bottom: 20px;
        line-height: 1.2;
    }

    .ecosystem-container>p {
        font-size: 14px;
        margin: 0 auto 30px;
        padding: 0 15px;
        /* Thêm padding cho nội dung không sát cạnh */
    }

    /* Lưới testimonial: CHUYỂN VỀ 1 CỘT */
    .testimonials-grid-container {
        grid-template-columns: 1fr;
        /* 1 cột trên màn hình dọc hoặc mobile nhỏ */
        gap: 30px;
        /* Giảm khoảng cách giữa các thẻ */
        margin-top: 30px;
    }

    .testimonial-card {
        padding: 30px;
        /* Giảm padding thẻ */
        /* box-shadow: 0 8px 25px rgba(8, 105, 36, 0.06); */
        /* Điều chỉnh bóng đổ */
    }

    .testimonial-header {
        flex-direction: column;
        /* Xếp chồng avatar và tên */
        text-align: center;
        /* Căn giữa */
        gap: 15px;
    }

    .testimonial-avatar {
        width: 70px;
        height: 70px;
    }

    .testimonial-name {
        font-size: 18px;
    }

    .testimonial-position {
        font-size: 13px;
    }

    .testimonial-content {
        font-size: 15px;
        padding-left: 0;
        /* Bỏ padding trái */
        border-left: none;
        /* Bỏ đường viền */
        text-align: center;
        /* Căn giữa nội dung */
    }

    .testimonial-stars {
        justify-content: center;
        /* Căn giữa các sao */
        display: flex;
        /* Đảm bảo flexbox để justify-content hoạt động */
        font-size: 1em;
        /* Giảm kích thước sao */
    }

    /* Điều chỉnh các chấm nền trang trí */
    .testimonials-section>div:nth-child(1) {
        width: 200px;
        height: 200px;
        top: -60px;
        right: -60px;
        opacity: 0.2;
    }

    .testimonials-section>div:nth-child(2) {
        width: 120px;
        height: 120px;
        bottom: -30px;
        left: -30px;
        opacity: 0.15;
    }
}

/* Khi màn hình NGANG (ví dụ: máy tính bảng ngang hoặc desktop) */
@media screen and (min-width: 768px) and (orientation: landscape),
screen and (min-width: 992px) {

    /* Desktop luôn là 2 cột */
    .testimonials-section {
        padding: 80px 0;
        /* Trở về padding mặc định */
    }

    .section-title {
        font-size: 52px;
        /* Trở về kích thước mặc định */
        margin-bottom: 24px;
    }

    .ecosystem-container>p {
        font-size: 16px;
        margin: 0 auto 40px;
        padding: 0;
    }

    /* Lưới testimonial: 2 CỘT */
    .testimonials-grid-container {
        grid-template-columns: repeat(2, 1fr);
        /* 2 cột trên màn hình ngang hoặc desktop */
        gap: 40px;
        margin-top: 50px;
    }

    .testimonial-card {
        padding: 40px;
        /* Trở về padding mặc định */
    }

    .testimonial-header {
        flex-direction: row;
        /* Trở về hàng ngang */
        text-align: left;
        /* Căn trái */
        gap: 24px;
    }

    .testimonial-avatar {
        width: 80px;
        height: 80px;
    }

    .testimonial-name {
        font-size: 20px;
    }

    .testimonial-position {
        font-size: 14px;
    }

    .testimonial-content {
        font-size: 16px;
        padding-left: 24px;
        /* Trở về padding trái */
        border-left: 3px solid #43b26c;
        /* Trở về đường viền */
        text-align: justify;
        /* Trở về căn đều */
    }

    .testimonial-stars {
        justify-content: flex-start;
        /* Căn trái sao */
        font-size: 1.1em;
    }

    /* Các chấm nền trang trí về lại kích thước lớn hơn */
    .testimonials-section>div:nth-child(1) {
        width: 400px;
        height: 400px;
        top: -100px;
        right: -100px;
        opacity: 0.3;
    }

    .testimonials-section>div:nth-child(2) {
        width: 300px;
        height: 300px;
        bottom: -50px;
        left: -50px;
        opacity: 0.25;
    }
}

/* Điều chỉnh thêm cho tablet ngang nếu muốn bố cục khác biệt so với desktop */
@media screen and (min-width: 768px) and (max-width: 991.98px) and (orientation: landscape) {
    .testimonials-section {
        padding: 70px 0;
    }

    .section-title {
        font-size: 48px;
    }

    .testimonials-grid-container {
        gap: 30px;
    }

    .testimonial-card {
        padding: 35px;
    }

    /* Có thể tinh chỉnh thêm kích thước chấm nền nếu muốn */
    .testimonials-section>div:nth-child(1) {
        width: 300px;
        height: 300px;
        top: -90px;
        right: -90px;
        opacity: 0.28;
    }

    .testimonials-section>div:nth-child(2) {
        width: 200px;
        height: 200px;
        bottom: -45px;
        left: -45px;
        opacity: 0.23;
    }
}

/* theme dark */

#ropeGlow,
#bulbGlowLarge {
    display: none;
}

html.dark-theme #ropeGlow,
html.dark-theme #bulbGlowLarge {
    display: block;
}

.light-bulb-container {
    /* Ví dụ: */
    /* position: absolute; */
    /* top: 20px; */
    /* right: 20px; */
    /* z-index: 1000; */
}

#bulb {
    cursor: pointer;
    pointer-events: auto;
}


body {
    background-color: #f8f9fa;
    color: #333;
    transition: background-color 0.5s ease, color 0.5s ease;
}

html.dark-theme body {
    background-color: #1a1a1a;
    color: #f8f9fa;
}

html.dark-theme h1,
html.dark-theme h2,
html.dark-theme h3,
html.dark-theme h4,
html.dark-theme h5,
html.dark-theme h6 {
    color: #e0e0e0;
}

html.dark-theme a {
    color: #90caf9;
}

html.dark-theme a:hover {
    color: #bbdefb;
}

.card,
.section-background-white {
    background-color: #fff;
    border: 1px solid #ddd;
    /* box-shadow: 0 4px 8px rgba(0,0,0,0.1); */
    transition: background-color 0.5s ease, color 0.5s ease, border-color 0.5s ease, box-shadow 0.5s ease;
}

html.dark-theme .card,
html.dark-theme .section-background-white {
    background-color: #2c2c2c;
    color: #f8f9fa;
    /* box-shadow: 0 4px 12px rgba(0,0,0,0.5);  */
}

.btn-primary {
    background-color: #007bff;
    color: #fff;
    transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease;
}

html.dark-theme .btn-primary {
    background-color: #6a9cff;
    color: #1a1a1a;
}

input[type="text"],
input[type="email"],
input[type="password"],
textarea {
    background-color: #fff;
    color: #333;
    transition: background-color 0.5s ease, color 0.5s ease, border-color 0.5s ease;
}

html.dark-theme input[type="text"],
html.dark-theme input[type="email"],
html.dark-theme input[type="password"],
html.dark-theme textarea {
    background-color: #3a3a3a;
    color: #f8f9fa;
}


/* HEADER/NAVBAR */
#emc-global-header {
    background-color: #fff;
    transition: background-color 0.5s ease, border-color 0.5s ease;
}

html.dark-theme #emc-global-header {
    background-color: #222;
    /* Nền tối cho header */
}

html.dark-theme .navbar-nav .nav-link {
    color: #e0e0e0 !important;
}

html.dark-theme .navbar-nav .nav-link:hover {
    color: #90caf9 !important;
}

/* FOOTER */
footer {
    background-color: #343a40;
    color: #f8f9fa;
    transition: background-color 0.5s ease, color 0.5s ease;
}

html.dark-theme footer {
    background-color: #111;
    color: #e0e0e0;
}

/* /// */
html.dark-theme {
    box-sizing: border-box;
}

html.dark-theme *,
html.dark-theme *::before,
html.dark-theme *::after {
    box-sizing: inherit;
    border: none !important;
    box-shadow: none !important;
    background-color: transparent !important;
}


html.dark-theme .customer-photo-frame,
html.dark-theme .photo-frame-inner,
html.dark-theme .photo-container {
    border: none !important;
}

html.dark-theme .customer-info-box {
    border: none !important;
}

html.dark-theme .customer-info-item {
    border: none !important;
}

html.dark-theme .customer-info-item i {
    border: none !important;
}

html.dark-theme .customer-quote {
    border: none !important;
    border-left: none !important;
}

html.dark-theme body .ecosystem-section#eco-solutions>.ecosystem-container>div>div>div.icon-bg-fix,
html.dark-theme body .optimize-icon {
    border: none !important;
}

html.dark-theme .stats-container {
    border: none !important;
}

html.dark-theme .card,
html.dark-theme input,
html.dark-theme textarea,
html.dark-theme select,
html.dark-theme button {
    border: none !important;
}

html.dark-theme img {
    border: none !important;
}


html.dark-theme * {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    border-image: none !important;
}

html.dark-theme .customer-info-box.aos-init.aos-animate {
    border: none !important;
    box-shadow: none !important;
}

html.dark-theme div .customer-info-item {
    padding: 10px;
    border-radius: 10px;
}

html.dark-theme .swiper-slide.swiper-slide-active {
    border-radius: 30px !important;

}

html.dark-theme .swiper-slide,
html.dark-theme .row.align-items-center,
html.dark-theme .col-md-6,
html.dark-theme .customer-photo-frame,
html.dark-theme .photo-frame-inner,
html.dark-theme .photo-container,
html.dark-theme .featured-customer-img,
html.dark-theme .avatar-placeholder,
html.dark-theme .customer-info-box,
html.dark-theme .customer-info-detail,
html.dark-theme .customer-info-item,
html.dark-theme .customer-quote,
html.dark-theme .quote-icon,
html.dark-theme .frame-decoration-1,
html.dark-theme .frame-decoration-2 {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    border-image: none !important;
    background-image: none !important;
    stroke: none !important;
    stroke-width: 0 !important;
}

html.dark-theme .stats-container .stat-item {
    border-radius: 4px !important;
    border: none !important;
    box-shadow: none !important;
}