/* ===== HOME SLIDER SWIPER ===== */
  .home-slider-swiper {
      width: 100%;
  }

  .home-slider-swiper .swiper {
      width: 100%;
  }

  .home-slider-swiper .swiper-slide {
      width: 100%;
  }

  .home-slider-swiper img {
      width: 100%;
      height: auto;
      display: block;
      object-fit: cover;
  }

  .home-slider-swiper .swiper-pagination-bullet {
      background: white;
      opacity: 1;
  }

  .home-slider-swiper .swiper-pagination-bullet-active {
      background: #333;
  }

/* ===== HOME PRODUCTS ===== */
  .hpm {
      display: grid;
      grid-template-columns: 46% 52%;
      gap: 2%;
      max-width: var(--max-site-width);
      margin: 0 auto;
      padding: 40px 20px;
    }
    
  .hpm-right h1 {
    font-size: 30px;
    color: #87B14A;
    margin-bottom: 16px;
    margin-top: 0;
  }
  
  .hpm-tabs {
    margin-bottom: 20px;
    display: grid;
    gap: 10px;
  }
  
  .hpm-tab {
    padding: 12px 16px;
    border-radius: 4px;
    cursor: pointer;
    background: #228E88;
    color: #fff;
  }
  
  .hpm-tab:nth-child(2) {
    background: #FAB019;
  }
  
  .hpm-tab.active {
    outline: 2px solid red;
  }
  
  .hpm-content {
    display: none;
  }
  
  .hpm-content.active {
    display: block;
  }
  
  .hpm-actions {
    margin-top: 20px;
  }
  
  .hpm-actions a {
    display: inline-block;
    margin-right: 10px;
    padding: 10px 14px;
    border-radius: 6px;
    color: #fff;
    text-decoration: none;
  }
  
  .hpm-actions .hotline {background:#d60000}
  .hpm-actions .cta {
    background:#5cb85c;
    cursor: pointer;
  }

  .hpm-gallery {
    display: none;
  }
  .hpm-gallery.active {
    display: block;
  }
  
  .hpm-thumb-swiper {
    margin-top: 12px;
  }
  
  .hpm-thumb-swiper .swiper-slide {
    opacity: 0.5;
    cursor: pointer;
  }
  
  .hpm-thumb-swiper .swiper-slide-thumb-active {
    opacity: 1;
    border-radius: 6px;
  }

  .dash-border {
    border-top: 1px dashed #B7BAC9;
  }

  .hpm-rating {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 8px 0 14px;
    font-size: 14px;
  }
  
  .hpm-rating .stars {
    display: flex;
  }
  
  .hpm-rating .star {
    font-size: 18px;
    color: #e0e0e0;
    position: relative;
  }
  
  .hpm-rating .star.full {
    color: #f5a623;
  }
  
  .hpm-rating .star.half {
    color: #e0e0e0;
  }
  
  .hpm-rating .star.half::before {
    content: '★';
    color: #f5a623;
    position: absolute;
    left: 0;
    width: 50%;
    overflow: hidden;
  }
  
  .hpm-rating .rating-text {
    color: #666;
    font-size: 13px;
  }  


/* ===== FACTORY ===== */
  .eecv-module {
    max-width: 1200px;
    margin: auto;
    padding: 60px 20px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    align-items: center;
  }
  
  .eecv-logo {
    max-width: 180px;
  }
  
  .eecv-left h2 {
    color: #87B14A;
    font-size: 30px;
    text-transform: uppercase;
    margin: 15px 0;
  }
  
  .eecv-stats {
    display: flex;
    gap: 40px;
  }
  
  .eecv-stat strong {
    font-size: 38px;
    color: #000;
    display: flex;
    justify-content: center;
  }
  
  .eecv-stat small {
    font-size: 16px;
    margin-left: 2px;
  }
  
  .eecv-stat p {
    margin-top: 6px;
    font-size: 14px;
  }
  
  .eecv-left {
    display: grid;
    justify-items: center;
    text-align: center;
  }

  .eecv-right {
    position: relative;
  }


/* ===== FACTORY ===== */
  .cert-module {
    max-width: var(--max-site-width);
    margin: 0 auto;
    padding: 0 20px;
    text-align: center;
  }

  .cert-title {
    color: #87B14A;
    font-size: 30px;
    font-weight: 600;
  }

  .cert-item {
    position: relative;
    padding: 30px 20px;
  }

  .cert-item img {
    height: 146px;
    object-fit: contain;
  }

  .cert-item h3 {
    margin-top: 16px;
    color: #0a5c4d;
    font-size: 20px;
  }

  .cert-swiper {
    width: 100%;
    overflow: hidden;
  }
  
  .cert-pagination {
    margin-top: 24px;
    position: relative;
  }
  
  .cert-pagination .swiper-pagination-bullet {
    width: 10px;
    height: 10px;
    background: #cfd8dc;
    opacity: 1;
  }
  
  .cert-pagination .swiper-pagination-bullet-active {
    background: #87B14A;
    width: 20px;
    height: 10px;
    border-radius: 6px;
  }
  

  /* ===== INFO ===== */
  .tabs-info-section {
    padding: 60px 0;
  }
  
  .tabs-info-title {
    font-size: 30px;
    font-weight: 700;
    margin-bottom: 30px;
    text-align: center;
    color: #87B14A;
    text-transform: uppercase;
  }
  
  .tabs-info-inner {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 40px;
  }
  
  .tabs-info-nav {
    list-style: none;
    padding: 0;
    margin: 0;
  }
  
  .tabs-info-nav li {
    padding: 14px 18px;
    margin-bottom: 10px;
    border-radius: 8px;
    cursor: pointer;
    background: #f3f3f3;
    font-weight: 500;
    transition: .2s;
  }
  
  .tabs-info-nav li.active {
    background: #7ac143;
    color: #fff;
  }
  
  .tabs-info-content {
    background: #fff;
  }
  
  .tab-content {
    display: none;
  }
  
  .tab-content.active {
    display: block;
  }
  
  .tab-content img {
    max-width: 600px;
    height: auto;
    margin: 0 auto;
  }
  

  /* === FEEDBACK === */
  
  .feedback-title {
    text-align: center;
    color: #7ac143;
    font-size: 30px;
    font-weight: 700;
    margin-bottom: 40px;
    text-transform: uppercase;
  }
  
  .feedback-list {
    max-width: 1000px;
    margin: auto;
  }
  
  .feedback-item {
    display: flex;
    gap: 16px;
    padding: 20px;
    border: 1px solid #e5e8f0;
    border-radius: 10px;
    margin-bottom: 20px;
  }
  
  .feedback-avatar img {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
  }
  
  .feedback-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 6px;
  }
  
  .feedback-name {
    font-weight: 600;
  }
  
  .feedback-verify {
    color: #1aa260;
    font-size: 13px;
    font-weight: 500;
  }
  
  .feedback-rating {
    color: #f5a623;
    margin-bottom: 6px;
  }
  
  .feedback-rating .star {
    font-size: 14px;
  }
  
  .feedback-rating .star.active {
    color: #f5a623;
  }
  
  .feedback-text {
    margin-bottom: 6px;
    line-height: 1.5;
  }
  
  .feedback-time {
    font-size: 13px;
    color: #888;
  }  


  /* === HOME NEWS === */
  .news-swiper-section {
    padding: 60px 0;
    background: radial-gradient(circle at top, #f5f7fa, #fff);
  }
  
  .news-swiper-title {
    text-align: center;
    font-size: 30px;
    font-weight: 700;
    color: #7ac143;
    margin-bottom: 40px;
    text-transform: uppercase;
  }
  
  .news-card {
    background: #fff;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(0,0,0,.08);
    height: 100%;
  }
  
  .news-thumb img {
    width: 100%;
    height: 220px;
    object-fit: cover;
  }
  
  .news-content {
    padding: 20px;
  }
  
  .news-title {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 10px;
  }
  
  .news-title a {
    color: #222;
    text-decoration: none;
  }
  
  .news-meta {
    font-size: 14px;
    color: #666;
    margin-bottom: 10px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  
  .news-more {
    color: #2b7a4b;
    font-weight: 600;
    text-decoration: none;
  }
  
  .news-view-all {
    text-align: center;
    margin-top: 30px;
  }
  
  .btn-view-all {
    padding: 10px 28px;
    border-radius: 5px;
    border: 1px solid #2b7a4b;
    color: #2b7a4b;
    text-decoration: none;
    font-weight: 600;
  }  


  /* SINGLE PRODUCT */
  .product-top {
    display: grid;
    grid-template-columns: 46% 52%;
    gap: 2%;
  }
  
  .product-summary .product-price {
    font-size: 25px;
    font-weight: 700;
    color: white;
    padding: 10px 20px;
  }
  
  .product-summary .product-price .product-price-title {
    font-size: 18px;
    margin-left: 40px;
  }

  .product-tabs {
    display: grid;
    grid-template-columns: 260px 1fr;
    margin-top: 60px;
    gap: 40px;
  }
  
  .tabs-left li {
    padding: 14px;
    margin-bottom: 10px;
    background: #f3f3f3;
    cursor: pointer;
    border-radius: 8px;
  }
  
  .tabs-left li.active {
    background: #7ac143;
    color: #fff;
  }
  
  .tab-content {
    display: none;
  }
  
  .tab-content.active {
    display: block;
  }  

  .product-gallery {
    width: 100%;
  }
  
  .product-gallery img {
    width: 100%;
    height: auto;
    object-fit: contain;
  }
  
  .swiper-button-next,
  .swiper-button-prev {
    color: #111;
  }

  .product-title {
    margin-top: 0;
    line-height: 1;
    padding: 0;
    color: #87B14A;
  }
  
  .woocommerce-breadcrumb {
    padding: 20px 0 !important;
    margin: 0 !important;
  }


  /* === HOME ORDER === */
  .home-order-wrapper{
    margin-bottom: 40px;
  }
  .home-order-inner{
      display:flex;
      gap:30px;
  }
  .home-order-form{
      flex:1;
  }
  .home-order-form input,
  .home-order-form textarea{
      width:100%;
      padding:5px;
  }
  .product-info{
      background:#f5f5f5;
      padding:10px;
      margin-bottom:10px;
  }
  .btn-home-order{
      width:100%;
      background:#e60023;
      color:#fff;
      padding:12px;
      border:none;
      font-size:16px;
      cursor:pointer;
  }
  .home-order-images{
      width:40%;
  }
  .home-order-images img{
      width:100%;
      margin-bottom:10px;
  }
  .home-order-success{
      background:#e6fffa;
      border:1px solid #38b2ac;
      padding:15px;
      margin-bottom:20px;
  }

  .order-table{
      width:100%;
      border-collapse:collapse;
      margin:20px 0;
  }
  .order-table th,
  .order-table td{
      border:1px solid #ddd;
      padding:10px;
      text-align:center;
  }
  .order-table tfoot td{
      font-weight:600;
  }
  .order-total td{
      background:#fef2f2;
      color:#e60023;
  }

  .qty-wrap{
      display:flex;
      align-items:center;
      justify-content:center;
      gap:6px;
  }
  .qty-wrap input{
      width:60px;
      text-align:center;
  }
  .qty-btn{
      width:28px;
      height:28px;
      border:1px solid #ddd;
      background:#fff;
      cursor:pointer;
      font-size:18px;
      line-height:1;
  }
  .qty-btn:hover{
      background:#f3f3f3;
  }

  .home-order-heading{
      text-align:center;
      font-size: 30px;
      margin-bottom:30px;
      color: #87B14A;
      text-transform: uppercase;
  }

  .home-order-inner{
      display:grid;
      grid-template-columns: 56% 42%;
      gap: 2%;
  }

  .home-order-right img{
      width:100%;
      display:block;
      border-radius:8px;
  }

  .home-order-thumbs{
      margin-top:10px;
  }
  .home-order-thumbs img{
      cursor:pointer;
      opacity:.7;
  }
  .home-order-thumbs .swiper-slide-thumb-active img{
      opacity:1;
  }

  .name-product-order {
    padding: 12px 10px;
    margin-bottom: 10px;
    color: white;
    display: flex;
    gap: 20px;
    border-radius: 5px;
  }

  .name-product-order span:first-child {
    font-weight: bold;
  }

  input {
      box-sizing: border-box;
  }

  input:focus-visible {
    outline: none;
  }

  .info-home-order {
    margin-bottom: 20px;
  }

  .info-home-order div {
    display: flex;
    gap: 10px;
  }

  .info-home-order input {
    background-color: #ffffff;
    border: solid 1px #E3E3E3;
    border-radius: 6px 6px 6px 6px;
    padding: 10px;
    margin-top: 15px;
  }

  .table-name-product {
    color: white;
    font-weight: bold;
  }

  .free-ship {
    color: red;
  }


  /* PAGE ABOUT */
  .about-section {
    display: grid;
    gap: 40px;
  }

  .about-video-text{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:40px;
  }

  .about-video iframe{
    width:100%;
    aspect-ratio:16/9;
    border-radius:12px;
  }

  .about-main-title{
    font-size: 30px;
    margin: 0;
    color: #87B14A;
  }

  .about-desc{
    font-size:16px;
    line-height:1.6;
  }

  .about-logo-block{
    justify-items: center;
  }

  .about-logo-block .about-desc {
    max-width: 400px;
    text-align: center;
  }

  .about-logo-block img{
    max-width:200px;
  }

  .about-grid-title{
    text-align: center;
    font-size: 30px;
    color: #87B14A;
  }

  .about-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:30px;
  }

  .about-item{
    background:#f9f9f9;
    padding:25px;
    border-radius:12px;
    text-align:center;
  }

  .about-item .icon{
    font-size: 40px;
    margin-bottom: 15px;
    color: #71b842;
  }

  .about-item h3{
    font-size:18px;
    margin-bottom:10px;
  }

  .about-item p{
    font-size:15px;
    line-height:1.5;
  }

  .post-item {
    display: flex;
    gap: 20px;
    margin-bottom: 28px;
    padding-bottom: 20px;
    border-bottom: 1px solid #eee;
  }

  .post-thumb {
    flex-shrink: 0;
    width: 500px;
  }

  .post-thumb img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 8px;
  }

  .post-content {
    flex: 1;
  }

  .post-title {
    margin: 0 0 8px;
    font-size: 30px;

  }

  .post-title a {
    color: #87B14A;
    text-decoration: none;
  }

  .post-title a:hover {
    text-decoration: underline;
  }

  .archive-title,
  .category-title {
    font-size: 35px;
    color: #0A8A82;
    margin-top: 0;
  }

  .search-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
  }

  .search-item {
    display: flex;
    gap: 16px;
  }

  .search-thumb img {
    width: 100%;
    height: auto;
    object-fit: cover;
  }

  .search-thumb {
    flex: 1;
  }

  .search-content {
    flex: 2;
  }

  .search-title-item {
    margin: 0;
  }


  /* === PAGE NEWS === */

  .single-title{
    font-size: 30px;
    color:#87B14A;
  }

  .single-meta{
    font-size:14px;
    color:#777;
    margin-bottom:20px;
    display:flex;
    gap:15px;
  }

  .single-content{
    font-size:16px;
    line-height:1.7;
  }

  .single-nav{
    display:flex;
    justify-content:space-between;
    margin:40px 0;
  }

  .single-tags{
    margin-top:30px;
    font-size:14px;
  }

  .single-page img {
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
  }