/* Import Responsive CSS */
@import url('responsive.css');

/* RESET */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
}

/* CSS Variables */
:root {
  --color-primary-dark-green: #0b3a1e;
  --color-primary-light-green: #a6bf3d;
  --color-bg-light: #f8f9ed;
  --color-bg-cream: #f1f5d6;
  --color-white: #ffffff;
  --color-black: #000000;
  --color-text-dark: #1a1a1a;
  --color-text-black: #1f1f1f;
  --color-text-gray: #999999;
  --color-text-gray-dark: #333333;
  --color-dark-green: #00350A;
  --color-green-border: #1f5a2b;
  --color-hover-green: #1a5a2e;
  --color-arrow-green: #0c612d;
  --color-dot-green: #9cc28f;
  --color-card-dark: #133b1f;
  --color-product-bg: #a7b9a9;
  --color-pill-bg: #e8f0e5;
  --color-orange: #F29F05;
  --color-link-blue: #00bfff;
  --color-link-blue-alt: #0066cc;
  --color-sky-blue: #87CEEB;
}

html {
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  scroll-behavior: smooth;
  margin: 0 !important;
  padding: 0 !important;
  position: relative;
  height: 100%;
  overflow-x: hidden !important; /* Prevent horizontal scroll from 100vw elements */
  overflow-y: auto;
  border: 0;
}

@font-face {
  font-family: 'UTM Horizon';
  src: local('UTM Horizon'),
       local('UTM-Horizon'),
       url('font/UTM-Horizon.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'SignPainter';
  src: local('SignPainter'),
       url('font/SignPainter.ttc') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Myriad Pro';
  src: local('Myriad Pro'),
       local('MyriadPro-Regular'),
       url('font/MyriadPro-Regular.otf') format('opentype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

/* Locomotive Scroll Support */
html.has-scroll-smooth {
  overflow: hidden;
}

html.has-scroll-dragging {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.has-scroll-smooth body {
  overflow: hidden;
}

.has-scroll-smooth [data-scroll-container] {
  min-height: 100vh;
  margin: 0;
  padding: 0;
}

[data-scroll-direction="horizontal"] [data-scroll-container] {
  height: 100vh;
  display: inline-block;
  white-space: nowrap;
}

[data-scroll-direction="horizontal"] [data-scroll-section] {
  display: inline-block;
  vertical-align: top;
  white-space: nowrap;
  height: 100%;
}

.c-scrollbar {
  position: absolute;
  right: 0;
  top: 0;
  width: 11px;
  height: 100%;
  transform-origin: center right;
  transition: transform 0.3s, opacity 0.3s;
  opacity: 0;
}

.c-scrollbar:hover {
  opacity: 1;
}

.has-scroll-dragging .c-scrollbar {
  opacity: 1;
}

.c-scrollbar_thumb {
  position: absolute;
  top: 0;
  right: 0;
  background-color: rgba(0, 0, 0, 0.5);
  opacity: 0.5;
  width: 7px;
  border-radius: 10px;
  margin: 2px;
  cursor: -webkit-grab;
  cursor: grab;
}

.has-scroll-dragging .c-scrollbar_thumb {
  cursor: -webkit-grabbing;
  cursor: grabbing;
}

body {
  font-family: 'Montserrat', sans-serif;
  background: var(--color-dark-green) !important; /* Dark green to hide white gaps */
  color: var(--color-text-dark);
  /* Font smoothing - Fix font rendering khác nhau giữa Windows và MacBook */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  /* Đảm bảo font-weight mặc định không bị MacBook tự động làm đậm */
  font-weight: 400;
  /* Thêm một số thuộc tính để đồng nhất font rendering */
  font-synthesis: none; /* Ngăn browser tự động tạo bold/italic */
  -webkit-text-stroke: 0; /* Tắt stroke trên WebKit */
  margin: 0 !important;
  padding: 0 !important;
  overflow-x: hidden !important; /* Prevent horizontal scroll from 100vw elements */
  position: relative;
  border: 0;
}

.page-wrapper {
  width: 100%;
  min-width: 0;
  max-width: none;
  margin: 0;
  padding: 0;
  position: relative;
  overflow-x: hidden;
  background: var(--color-dark-green) !important; /* Dark green to hide white gaps */
}

/* ========================== HEADER ======================== */

body.cooperate-page {
  margin: 0 !important;
  padding: 0 !important;
  overflow-x: hidden !important;
}

body.cooperate-page html {
  margin-top: 0 !important;
  padding-top: 0 !important;
  overflow-x: hidden !important;
}

body.cooperate-page .page-wrapper {
  margin-top: 0 !important;
  padding-top: 0 !important;
  overflow-x: hidden !important;
}

body.cooperate-page [data-scroll-container] {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

.header {
  position: fixed;
  top: 0 !important;
  left: 0;
  right: 0;
  z-index: 300;
  width: 100%;
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  line-height: 0;
  overflow-x: visible;
  overflow-y: visible;
  background: transparent !important;
}



.menu-bg {
  position: absolute;
  top: 0 ;
  left: 0;
  width: 100%;
  height: 141px;
  object-fit: cover;
  object-position: top left;
  z-index: 1;
  pointer-events: none;
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  display: block;
  background: transparent !important;
}

.header-inner {
  position: absolute;
  z-index: 10;
  width: 100%;
  max-width: 1920px;
  height: 141px;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin: 0;
  padding: 0;
  gap: 0;
  overflow: visible;
}

/* Base logo styles */
.logo {
  display: block;
  visibility: visible;
  position: relative;
}

.logo a {
  display: block;
}

.logo img {
  display: block;
  width: 100%;
  height: auto;
}

@media screen and (min-width: 1024px) and (max-width: 1439px) {
  .product-slider-wrapper {
    width: 100% !important;
    max-width: 1020px !important;
  }
  
  .product-card {
    width: 254px !important;
    min-width: 254px !important;
    max-width: 254px !important;
    height: 373px !important;
    min-height: 373px !important;
    max-height: 373px !important;
  }
  
  .product-card .product-thumb {
    width: 231px !important;
    height: 254px !important;
  }
  
  .product-card .product-thumb img {
    width: 139px !important;
    height: 197px !important;
  }
  
  .pill {
    left: 0 !important;
    position: relative !important;
  }
  
  .link {
    right: auto !important;
    bottom: auto !important;
    position: relative !important;
    align-self: center !important;
  }
}

@media screen and (min-width: 1440px) {
  /* Removed: All .cooperate-connect-section, .cooperate-connect-image-wrapper, .cooperate-connect-bg-image rules - using unified 1024px+ desktop base */
  
  .cooperate-connect-image {
    right: calc((100vw - 800px) / -2) !important;
    width: 900px !important;
  }
  
  .product-slider-wrapper {
    width: 1400px !important;
    max-width: 1400px !important;
  }
  
  .product-card {
    width: 348.35px !important;
    min-width: 348.35px !important;
    max-width: 348.35px !important;
    height: 510.97px !important;
    min-height: 510.97px !important;
    max-height: 510.97px !important;
  }
  
  .product-card .product-thumb {
    width: 317.07px !important;
    height: 348.21px !important;
  }
  
  .product-card .product-thumb img {
    width: 190.43px !important;
    height: 270.48px !important;
  }
  
  .pill {
    left: 0 !important;
  }
  
  .link {
    right: auto !important;
    bottom: auto !important;
    align-self: center !important;
  }
}

/* ==================== MÀN HÌNH 1600px TRỞ LÊN - CHỈNH SỬA VỊ TRÍ HÌNH ẢNH LOGO ==================== */
/* ==================== FLUID DESKTOP MIGRATION ====================
   The following high-width media queries are DISABLED (never match) to reduce
   breakpoint-specific overrides and transition to a single fluid desktop
   system (1024px → 1920px). */
@media screen and (min-width: 1600px) and (max-width: 0px) {
  /* Removed: All .cooperate-connect-section, .cooperate-connect-image-wrapper, .cooperate-connect-bg-image rules - using unified 1024px+ desktop base */

  body.cooperate-page .cooperate-connect-image {
    right: calc((100vw - 800px) / -2) !important;
    width: calc(900px * (100vw / 1600)) !important;
    bottom: calc(-400px * (100vw / 1600)) !important;
  }
}

@media screen and (min-width: 1728px) and (max-width: 0px) {
  /* Header rules removed - using unified fluid desktop base */
  
  body.cooperate-page {
    overflow-x: hidden !important;
    margin-top: 0 !important;
    padding-top: 0 !important;
    position: relative !important;
  }
  
  body.cooperate-page html {
    overflow-x: hidden !important;
    margin-top: 0 !important;
    padding-top: 0 !important;
  }
  
  body.cooperate-page .page-wrapper {
    overflow-x: hidden !important;
    max-width: 100% !important;
    margin-top: 0 !important;
    padding-top: 0 !important;
    position: relative !important;
  }
  
  body.cooperate-page [data-scroll-container] {
    margin-top: 0 !important;
    padding-top: 0 !important;
    position: relative !important;
  }
  
  /* CSS cho cooperate-page header/menu/logo đã được di chuyển vào media query 1920px để đồng nhất */
  
  /* Removed: .cooperate-connect-section rules - using unified 1024px+ desktop base */
  
  body.cooperate-page .cooperate-connect-image {
    right: calc((100vw - 800px) / -2) !important;
    width: 920px !important;
    bottom: -410px !important;
    transition: opacity 1.2s ease, transform 1.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;
  }
  
  /* Removed: All .cooperate-connect-section, .cooperate-connect-image-wrapper, .cooperate-connect-bg-image rules - using unified 1024px+ desktop base */
  
  .cooperate-connect-icon {
    top: 150px !important;
    left: -470px !important;
    max-width: 800px !important;
  }
  
  body.cooperate-page .footer-bottom p,
  body.cooperate-page .footer-contact p {
    font-weight: normal !important;
  }
  
  body.cooperate-page .footer-title {
    font-weight: normal !important;
  }

  /* Section extra rules removed - using unified fluid desktop base */

  /* Footer ở section "ĐỊNH HƯỚNG PHÁT TRIỂN" - section kế cuối trang about.html */
  /* Base style đã có ở dòng 1937-1949 */
  .about-development-footer {
    /* Thêm các style bạn muốn chỉnh cho footer ở đây, ví dụ: */
    bottom: -245px !important; 
    /* left: -50px !important; */
    /* width: 110% !important; */
    /* transform: translateX(10px) !important; */
    position: absolute; /* Giữ nguyên để tránh lỗi linter, bạn có thể override sau */
  }

  /* Tăng size 3 card trong section "ĐIỂM TIN" cho màn 1728px */
  .section-news-header {
    padding-left: 0 !important;
  }

  .section-news-title {
    margin-left: 0 !important;
  }

  .section-news-subtitle {
    margin-left: 0 !important;
  }

  .section-news-cards {
    max-width: 1400px !important;
  }

  .news-card {
    grid-column: span 4.5 !important;
  }

  .news-thumb {
    height: 220px !important;
  }

  .news-card-3 .news-thumb {
    height: 240px !important;
  }

  .news-body {
    padding: 20px 20px 18px !important;
    gap: 12px !important;
  }

  .news-title {
    font-size: 16px !important;
  }

  .news-meta {
    font-size: 13px !important;
    margin-top: 10px !important;
  }

  .section-news-bg-right.animate-in {
    transform: scale(0.9) translateX(0) !important;
  }

  /* Section Vision 12-grid căn giữa cho màn 1728px */
  .section-vision {
    min-height: 1100px !important;
  }

  .section-vision-grid {
    max-width: 1728px !important;
    margin: 0 auto !important;
    padding: 180px 100px 0 100px !important;
    justify-content: center !important;
  }

  .section-vision-left {
    grid-column: 2 / 6 !important;
  }

  .section-vision-right {
    grid-column: 6 / 12 !important;
  }

  /* News tabs in đậm cho màn 1728px */
  .news-tab {
    font-weight: bold !important;
  }

  /* Footer grid căn giữa cho màn 1728px */
  .footer-grid {
    max-width: 1728px !important;
    margin: 0 auto !important;
    padding: 48px 100px 20px 100px !important;
  }
  
  /* Đường kẻ ngang trải đầy từ mép trái đến mép phải viewport ở màn 1728px+ */
  .footer-top::before {
    left: calc((100vw - 1728px) / -2 - 100px) !important;
    right: calc((100vw - 1728px) / -2 - 100px) !important;
    width: 100vw !important;
  }
  
  /* Giữ nguyên vị trí đường kẻ dọc cho màn 1728px */
  .footer-top::after {
    left: calc((100% - 11 * 20px) * 7.5 / 12 + 7 * 20px) !important;
  }
}

@media screen and (min-width: 1729px) and (max-width: 0px) {
  /* Removed: All .cooperate-connect-section, .cooperate-connect-image-wrapper, .cooperate-connect-bg-image rules - using unified 1024px+ desktop base */
  
  .cooperate-connect-image {
    right: calc((100vw - 800px) / -2) !important;
    width: calc(900px * (100vw / 1440)) !important;
  }
}

@media screen and (min-width: 1920px) and (max-width: 0px) {
  /* Header rules removed - using unified fluid desktop base */
  
  /* Section extra rules removed - using unified fluid desktop base */
  
  body.cooperate-page .cooperate-connect-image {
    right: calc((100vw - 800px) / -2) !important;
    width: 950px !important;
    bottom: -420px !important;
    transition: opacity 1.2s ease, transform 1.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;
  }
  
  /* Removed: All .cooperate-connect-section, .cooperate-connect-image-wrapper, .cooperate-connect-bg-image rules - using unified 1024px+ desktop base */
  
  .cooperate-connect-icon {
    top: 150px !important;
    left: -600px !important;
    max-width: 800px !important;
  }
}

/* ==================== FLUID DESKTOP BASE (1024px → 1920px) ==================== */
@media screen and (min-width: 1024px) {
    /* 1. ÉP HEADER SÁT MÉP TRÊN - KHÔNG HỞ 1 PIXEL */
    html, body { 
        margin: 0 !important; 
        padding: 0 !important; 
        overflow-x: hidden !important; /* Prevent horizontal scrolling from 100vw */
    }
    .header {
        width: 100% !important;
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        height: 141px !important;
        aspect-ratio: auto !important;
        z-index: 9999 !important;
        margin: 0 !important;
        margin-top: 0 !important;
        padding: 0 !important;
        padding-top: 0 !important;
        background: transparent !important;
        overflow: visible !important;
    }
.menu-bg {
    position: absolute !important;
    inset: 0 !important;
    top: 0 !important;
    width: 100% !important;
    height: 141px !important;
    object-fit: cover !important;
    object-position: top center !important;
    transform: translateY(-2px) !important;
    z-index: 1 !important;
    background: transparent !important;
}
/* 2. ĐỊNH VỊ LOGO VÀO ĐÚNG HÕM (DIP) */
.header-inner {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    max-width: none !important;
    height: 141px !important;
    display: flex !important;
    justify-content: flex-end !important; /* Đẩy menu sang phải */
    align-items: flex-start !important; /* Align navbar items to top */
    padding-top: 15px !important; /* Adjusted for standard height */
    padding-right: 20% !important; /* Shift menu left, closer to logo */
    z-index: 10 !important;
}
.logo {
    position: absolute !important;
    left: 17% !important; /* Tọa độ hõm - xích qua trái nhẹ */
    top: 35% !important; /* Adjusted for standard height */
    transform: translate(-50%, -50%) !important;
    width: clamp(160px, 7.5vw, 220px) !important;
    z-index: 100 !important;
    margin: 0 !important;
    display: block !important;
    visibility: visible !important;
}
.logo a, .logo img {
    display: block !important;
    width: 100% !important;
}
/* 3. KHÔI PHỤC MENU (4 MỤC TIÊU ĐỀ) SANG PHẢI */
.navbar {
    width: auto !important;
    display: block !important;
    margin-top: 2.1% !important; /* Xích menu lên trên nhẹ */
}
.navbar ul {
    display: flex !important;
    list-style: none !important;
    gap: 50px !important; /* Fixed spacing for larger text items */
    margin: 0 !important;
    padding: 0 !important;
}
.navbar a {
    font-family: 'UTM Horizon', sans-serif !important;
    font-size: 24px !important; /* Fixed size for clear visibility at top */
    font-weight: 700 !important; /* Bold, premium look */
    color: var(--color-bg-cream) !important;
    text-decoration: none !important;
    white-space: nowrap !important;
    transition: color 0.25s !important;
    text-transform: uppercase !important;
}
.navbar a:hover { color: var(--color-white) !important; }

/* Hamburger Menu - Ẩn trên desktop */
.hamburger-menu {
  display: none;
}

.mobile-menu,
.mobile-menu-overlay {
  display: none;
}

  /* ==================== GLOBAL COOPERATE CONNECT SECTION (1024px+) ==================== */
  

  /* Section Extra - Unified Fluid Structure */
  .section-extra {
    display: flex !important;
    flex-direction: column !important;
    position: relative !important;
    padding-bottom: 0 !important;
    background: #00350A !important; /* Solid dark green background */
    width: 100% !important;
    margin-top: -5px !important; /* Force 5px overlap to bury any white line */
    outline: 1px solid var(--color-dark-green) !important; /* Anti-aliasing bleed */
    outline-offset: -1px !important;
  }

  .footer-grid {
    position: relative !important;
    z-index: 10 !important;
    width: 100% !important;
    margin-bottom: 40px !important; /* Fixed 1cm gap between text and image */
  }

  .section-extra-pattern {
    position: relative !important; /* Important: Move from absolute to relative to sit BELOW content */
    display: block !important;
    width: 120vw !important;
    height: 170px !important;
    z-index: 1 !important;
    opacity: 0.5 !important;
    object-fit: cover !important;
    margin-top: 0 !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
  }

  /* ==================== GLOBAL FLUID CSS - COOPERATE CONNECT SECTION (1024px+) ==================== */
  /* Áp dụng cho mọi màn hình Desktop từ 1024px trở lên */
  .cooperate-connect-section {
    width: 100vw !important;
    max-width: none !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    padding: 80px 0 0 0 !important;
    position: relative !important;
    overflow: hidden !important;
    overflow-x: hidden !important;
    background: var(--color-bg-cream) !important;
  }

  .cooperate-connect-image-wrapper {
    position: absolute !important;
    width: 120vw !important;
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
    bottom: -450px !important;
    top: auto !important;
    height: auto !important;
    overflow: hidden !important;
    margin: 0 !important;
    z-index: 0 !important;
  }

  .form-field-products {
    position: static !important;
  }

  .cooperate-connect-bg-image {
    position: relative !important;
    bottom: auto !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: 120vw !important;
    max-width: none !important;
    min-width: 120vw !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    height: auto !important;
    object-fit: cover !important;
    display: block !important;
    z-index: 0 !important;
  }

  .cooperate-footer-image {
    position: relative !important;
    width: 100vw !important;
    max-width: none !important;
    min-width: 100vw !important;
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: 0 !important;
    display: block !important;
    margin-bottom: -5px !important;
    object-fit: cover !important;
    object-position: center !important;
  }

  /* Move breadcrumb up behind header on desktop to hide green body background */
  body:not(.about-page):not(.products-page) .breadcrumb-section {
    margin-top: 0 !important;
    padding-top: 157px !important;
  }
}

/* Language Switcher Button - Scrolls with page */
.language-switcher {
  position: fixed;
  bottom: 30px;
  right: 30px;
  width: 44px;
  height: 44px;
  background: var(--color-white);
  border: 25px solid #000000;
  border-radius: 10px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  transition: all 0.3s ease;
  padding: 0;
  animation: floating-button 3s ease-in-out infinite;
  /* Allow Locomotive Scroll to transform button for scroll effect */
}

/* Button scrolls with page on all pages - no special override needed */

.language-switcher:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);
}

.language-switcher:active {
  transform: scale(0.95);
}

.language-switcher img {
  width: 44px;
  height: 44px;
  object-fit: contain;
  display: block;
  border-radius: 8px;
  border: 1px solid #000000;
}

/* Speech bubble for Language Switcher */
.language-switcher-bubble {
  position: absolute;
  right: 0;
  bottom: calc(100% + 12px);
  max-width: 280px;
  min-width: 200px;
  white-space: normal;
  padding: 12px 14px;
  background: #ffffff;
  color: #111111;
  border: 2px solid #000000;
  border-radius: 12px;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  line-height: 1.4;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18);
  z-index: 10001;
  pointer-events: none; /* bubble shouldn't block clicking the button */
  transform-origin: bottom right;
  opacity: 0;
  transform: translateY(6px) scale(0.98);
  transition: opacity 0.4s ease-in-out, transform 0.4s ease-in-out;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

.language-switcher-bubble.show {
  opacity: 1;
  transform: translateY(0) scale(1);
  animation: language-bubble-pop 0.3s ease-out;
}

.language-switcher-bubble.hide {
  opacity: 0;
  transform: translateY(6px) scale(0.98);
  transition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out;
}

.language-switcher-bubble::after {
  content: '';
  position: absolute;
  right: 14px;
  bottom: -10px;
  width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-top: 10px solid #000000; /* outline */
}

.language-switcher-bubble::before {
  content: '';
  position: absolute;
  right: 14px;
  bottom: -8px;
  width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-top: 10px solid #ffffff; /* inner fill */
  z-index: 1;
}

@keyframes language-bubble-pop {
  from { transform: translateY(6px) scale(0.98); opacity: 0; }
  to { transform: translateY(0) scale(1); opacity: 1; }
}

/* ===================== BREADCRUMB SECTION ======================= */

.breadcrumb-section {
  width: 100%;
  background: var(--color-bg-light);
  padding: 16px 0;
  position: relative;
  z-index: 200;
  border: none !important;
  box-shadow: none !important;
  box-shadow: inset 0 -1px 0 var(--color-bg-light) !important;
}

.breadcrumb-section::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 100%;
  height: 2px;
  background: var(--color-bg-light);
  pointer-events: none;
}

.breadcrumb-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 240px;
  box-sizing: border-box;
  display: flex;
  justify-content: center;
}

.breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  line-height: 1.5;
}

.breadcrumb a {
  color: var(--color-text-dark);
  text-decoration: none;
  transition: opacity 0.2s;
}

.breadcrumb a:hover {
  opacity: 0.7;
}

.breadcrumb a.breadcrumb-current {
  color: var(--color-link-blue-alt);
  text-decoration: none;
}

.breadcrumb-current {
  color: var(--color-sky-blue);
}

.breadcrumb-separator {
  color: var(--color-text-dark);
  margin: 0 4px;
}


/* ===================== COOPERATE SECTION ======================= */

.cooperate-section {
  width: 100%;
  background: var(--color-bg-light);
  padding: 80px 20px;
  position: relative;
  margin-bottom: -1px;
}

.cooperate-inner {
  max-width: 1400px;
  margin: 0 auto;
  position: relative;
}

.cooperate-title {
  font-family: 'UTM Horizon', sans-serif;
  font-size: 80px;
  font-weight: 800;
  color: var(--color-primary-dark-green);
  text-align: center;
  margin: 0 0 80px 0;
}

.cooperate-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px 40px;
  width: 70%;
  max-width: 1000px;
  margin: 0 auto;
}

.cooperate-card {
  display: flex;
  flex-direction: column;
  gap: 20px;
  position: relative; 
  top: -10px;
}

.cooperate-image-wrapper {
  width: 100%;
  overflow: hidden;
  position: relative;
  clip-path: polygon(
    0% 8%,
    5% 0%,
    15% 3%,
    25% 0%,
    35% 4%,
    45% 1%,
    55% 3%,
    65% 0%,
    75% 2%,
    85% 0%,
    95% 3%,
    100% 0%,
    100% 92%,
    95% 100%,
    85% 97%,
    75% 100%,
    65% 96%,
    55% 99%,
    45% 97%,
    35% 100%,
    25% 98%,
    15% 100%,
    5% 97%,
    0% 100%
  );
}

.cooperate-image-1 {
  height: 250px;
}

.cooperate-image-2 {
  height: 530px;
  transform: scale(0.5);
  transform-origin: center center;
  margin-top: -200px;
}

.cooperate-image-3 {
  height: 300px;
  transform: scale(0.7);
  transform-origin: center center;
}

.cooperate-image-4 {
  height: 300px;
}

/* ===================== COOPERATE CONNECT SECTION ======================= */

.cooperate-connect-section {
  width: 100%;
  background: var(--color-bg-cream);
  background-image: url('img/Vector-2.png');
  background-repeat: repeat;
  background-position: center;
  background-size: auto;
  position: relative;
  padding: 80px 20px 0;
  padding-bottom: 0;
  overflow-x: hidden;
  overflow-y: visible;
  margin-top: -1px !important; /* Overlap upper section by 1px to hide white gaps */
  margin-bottom: -2px !important; /* Overlap footer section to eliminate white line */
  z-index: 1;
  transform: translateZ(0);
  border: none !important;
  outline: none !important;
}

.cooperate-connect-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--color-bg-cream);
  z-index: 0;
  pointer-events: none;
}

.cooperate-connect-section::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 0;
  background-color: transparent !important;
  z-index: 0;
  pointer-events: none;
}

.cooperate-connect-inner {
  max-width: 800px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

.cooperate-connect-title {
  font-family: 'UTM Horizon', sans-serif;
  font-size: 110px;
  font-weight: 800;
  color: var(--color-primary-dark-green);
  text-align: center;
  margin: 0 0 40px 0;
}

/* Keep "CONNECT WITH CAO PHAT" on one line in English */
html[lang="en"] .cooperate-connect-title {
  white-space: nowrap;
}

.cooperate-connect-slogan {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  line-height: 1.6;
  color: var(--color-primary-dark-green);
  text-align: center;
  margin: 0 0 60px 0;
}

/* Keep slogan on one line in Vietnamese */
html[lang="vi"] .cooperate-connect-slogan {
  white-space: nowrap;
}

.cooperate-connect-form {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.form-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.form-field label {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  font-weight: 600;
  color: var(--color-primary-dark-green);
}

.form-field input,
.form-field textarea {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid var(--color-primary-dark-green);
  border-radius: 4px;
  background: var(--color-bg-cream);
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  color: var(--color-text-dark);
  box-sizing: border-box;
  transition: background 0.3s ease;
}

/* Khi focus hoặc có giá trị thì chuyển sang màu trắng */
.form-field input:focus,
.form-field textarea:focus,
.form-field input:not(:placeholder-shown),
.form-field textarea:not(:placeholder-shown) {
  background: var(--color-white);
}

.form-field input::placeholder,
.form-field textarea::placeholder,
.form-field input::-webkit-input-placeholder,
.form-field textarea::-webkit-input-placeholder,
.form-field input::-moz-placeholder,
.form-field textarea::-moz-placeholder,
.form-field input:-ms-input-placeholder,
.form-field textarea:-ms-input-placeholder {
  color: var(--color-text-gray);
  opacity: 0.7;
}

.form-field input:focus,
.form-field textarea:focus {
  outline: 2px solid var(--color-primary-dark-green);
  outline-offset: 2px;
}

.form-field textarea {
  resize: vertical;
  min-height: 120px;
}

.form-field-products {
  position: relative;
}

.form-submit-btn {
  width: 120px;
  padding: 14px 24px;
  background: var(--color-primary-dark-green);
  color: var(--color-white);
  border: none;
  border-radius: 4px;
  font-family: 'UTM Horizon', sans-serif;
  font-size: 18px;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.3s;
  margin: 8px 0 0 0;
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: flex-start;
}

.form-submit-btn:hover {
  background: var(--color-hover-green);
}

.cooperate-connect-image-wrapper {
  position: absolute;
  bottom: -480px;
  width: 185%;
  z-index: 1;
  pointer-events: none;
}

.cooperate-connect-bg-image {
  position: relative;
  width: auto;
  height: auto;
  display: block;
  object-fit: contain;
  object-position: center;
  z-index: 1;
  opacity: 0;
  transform: translateX(-200px) translateZ(0);
  transition: opacity 0.8s ease, transform 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: transform, opacity;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.cooperate-connect-image {
  position: absolute;
  bottom: -400px;
  right: calc((100vw - 800px) / -2);
  width: 900px;
  height: auto;
  display: block;
  object-fit: contain;
  z-index: 10;
  transform: translateY(200px) translateZ(0);
  opacity: 0;
  transition: opacity 1.8s ease, transform 2.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: transform, opacity;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.cooperate-connect-image-wrapper.animate-in .cooperate-connect-bg-image {
  opacity: 0.5;
  transform: translateX(-50%) !important;
}

.cooperate-connect-section.animate-in .cooperate-connect-image {
  opacity: 1;
  transform: translateY(0) translateZ(0);
}

/* ===================== COOPERATE FOOTER ======================= */

.cooperate-footer-image {
  width: 100vw !important; /* Full viewport width to cover gaps */
  height: auto;
  display: block !important; /* Block display to eliminate inline gaps */
  object-fit: cover;
  position: relative;
  margin-top: 340px; 
  margin-bottom: -1px !important; /* Overlap footer by 1px */
  z-index: 2;
  opacity: 0;
  transform: translateY(100px) translateZ(0); 
  transition: opacity 0.8s ease, transform 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: transform, opacity;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.cooperate-connect-section.animate-in .cooperate-footer-image,
.cooperate-connect-section.footer-animated .cooperate-footer-image {
  opacity: 1;
  transform: translateY(0) translateZ(0); /* Xích ảnh xuống sau animation */
}

.cooperate-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.cooperate-card-title {
  font-family: 'UTM Horizon', sans-serif;
  font-size: 32px;
  font-weight: 800;
  color: var(--color-primary-dark-green);
  margin: 0;
}

.cooperate-card-1 .cooperate-image-wrapper,
.cooperate-card-3 .cooperate-image-wrapper {
  position: relative;
  top: 0px;
  left: -60px;
}

.cooperate-card-1 .cooperate-card-title,
.cooperate-card-3 .cooperate-card-title {
  position: relative;
  top: 0px;
  left: -60px;
}

.cooperate-card-1 .cooperate-card-text,
.cooperate-card-3 .cooperate-card-text {
  position: relative;
  top: 0px;
  left: -60px;
}

.cooperate-card-2 .cooperate-image-wrapper {
  position: relative;
  top: 0px;
  left: 0px;
}

.cooperate-card-2 .cooperate-card-title {
  position: relative;
  top: -80px;
  left: 80px;
}

.cooperate-card-2 .cooperate-card-text {
  position: relative;
  top: -80px;
  left: 80px;
}

.cooperate-card-4 .cooperate-image-wrapper {
  position: relative;
  top: 0px;
  left: 80px;
}

.cooperate-card-4 .cooperate-card-title {
  position: relative;
  top: 0px;
  left: 80px;
}

.cooperate-card-4 .cooperate-card-text {
  position: relative;
  top: 0px;
  left: 80px;
}

.cooperate-card-text {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  line-height: 1.6;
  color: var(--color-text-dark);
  margin: 0;
}

.cooperate-decorative-icon {
  position: absolute;
  bottom: 370px;
  right: 0;
  width: auto;
  height: auto;
  max-width: 200px;
  z-index: 1;
  pointer-events: none;
  animation: gentleZoom 3s ease-in-out infinite;
  transform-origin: center center;
}

.cooperate-connect-icon {
  position: absolute;
  top: 150px;
  left: -350px;
  width: auto;
  height: auto;
  max-width: 200px;
  z-index: 2;
  pointer-events: none;
  animation: gentleZoom 3s ease-in-out infinite;
  transform-origin: center center;
}

.blog-hero {
  margin-top: 0;
  width: 100%;
  height: auto;
  max-height: none;
  aspect-ratio: unset;
  overflow: hidden;
}

.blog-hero .hero-bg {
  width: 100%;
  height: auto;
  aspect-ratio: unset;
  max-height: none;
  object-fit: cover;
  object-position: center center;
  display: block;
}

/* ===================== BLOG CONTENT SECTION ======================= */

.blog-content-section {
  width: 100%;
  background: var(--color-bg-light);
  padding: 30px 20px;
  position: relative;
}

.blog-content-inner {
  max-width: 1000px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.blog-category {
  font-family: 'UTM Horizon', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: var(--color-primary-dark-green);
  text-transform: uppercase;
  margin-bottom: 8px;
}

.blog-title {
  font-family: 'Inter', sans-serif;
  font-size: 48px;
  font-weight: 400;
  color: var(--color-primary-dark-green);
  line-height: 1.2;
  margin: 0 0 32px 0;
  max-width: 90%;
  width: 100%;
}

.blog-text-content {
  display: flex;
  flex-direction: column;
  gap: 24px;
  margin-bottom: 48px;
  margin-top: -20px;
  max-width: 90%;
  width: 100%;
}

.blog-paragraph {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  line-height: 1.8;
  color: var(--color-text-dark);
  margin: 0;
}

.blog-image-wrapper {
  position: relative;
  width: 100%;
  max-width: 100%;
  margin-top: -50px;
}

.blog-vector-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  max-width: 90%;
  height: auto;
  display: block;
  object-fit: contain;
  z-index: 1;
}

.blog-content-image {
  position: relative;
  width: 100%;
  max-width: 89%;
  height: auto;
  display: block;
  object-fit: contain;
  z-index: 2;
}

.blog-image-caption {
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  color: var(--color-text-gray);
  text-align: right;
  margin-top: 16px;
  padding-right: 0;
  margin-right: 355px;
}

.blog-item-title {
  font-family: 'UTM Horizon', sans-serif;
  font-size: 48px;
  font-weight: 800;
  color: var(--color-primary-dark-green);
  line-height: 1.2;
  margin: 0 0 32px 0;
  max-width: 90%;
  width: 100%;
}

.blog-image-single {
  margin-top: -20px;
}

/* ===================== BLOG RELATED ARTICLES SECTION ======================= */

.blog-related-section {
  width: 100%;
  background: var(--color-bg-light);
  padding: 30px 20px;
  position: relative;
  margin-top: -40px;
}

.blog-related-inner {
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 60px;
}

.blog-related-title {
  font-family: 'UTM Horizon', sans-serif;
  font-size: 48px;
  font-weight: 800;
  color: var(--color-primary-dark-green);
  text-align: center;
  margin: 0;
}

.blog-related-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  width: 85%;
  max-width: 1200px;
  margin: 0 auto;
}

.blog-related-card {
  background: var(--color-bg-light);
  border-radius: 10px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.blog-related-thumb {
  width: 100%;
  height: 180px;
  overflow: hidden;
}

.blog-related-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.blog-related-body {
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
}

.blog-related-card-title {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: var(--color-primary-dark-green);
  margin: 0;
  line-height: 1.4;
  flex: 1;
}

.blog-related-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: 'Inter', sans-serif;
  font-size: 12px;
}

.blog-related-date {
  color: var(--color-text-gray);
}

.blog-related-tag {
  color: var(--color-link-blue-alt);
}

.blog-related-dots {
  display: flex;
  gap: 10px;
  justify-content: center;
}

.blog-related-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-primary-dark-green);
  opacity: 0.3;
}

.blog-related-dot.active {
  opacity: 1;
}

/* ===================== BLOG FOOTER ======================= */

.blog-footer-section {
  width: 100%;
  position: relative;
  margin-top: 60px;
}

.blog-footer-image {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

/* ===================== HERO SECTION ======================= */


.hero {
  position: relative;
  width: 100%;
  height: auto;
  max-height: 760px;
  aspect-ratio: 3/2;
  overflow: hidden;
  margin: 0 auto;

}

.hero-bg {
  width: 100%;
  height: auto;
  aspect-ratio: 3/2;
  object-fit: cover;
  object-position: center 0%;
  display: block;
}

.about-page .hero {
  width: 1730px;
  height: 595px;
  max-height: none;
  margin: 100px auto 0 auto;
  background: var(--color-bg-light);
  overflow: visible;
  position: relative;
  aspect-ratio: unset;
  padding-bottom: 0;
  margin-bottom: 0;
}

@media screen and (min-width: 1649px) {
  body.about-page .page-wrapper {
    max-width: 100% !important;
    overflow-x: visible !important;
    width: 100% !important;
  }
  
  body.about-page .hero {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    margin-top: 100px !important;
    left: 0 !important;
    right: 0 !important;
    position: relative !important;
  }
}

.about-page .hero-bg {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: left bottom;
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  transform: scale(0.88);
  transform-origin: left bottom;
}

.about-page .hero-content-about {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 10;
}

.about-page .hero-title-main {
  position: absolute;
  top: 30px;
  left: 600px;
  font-family: 'UTM Horizon', sans-serif;
  font-size: 72px;
  font-weight: 800;
  color: var(--color-primary-dark-green);
  margin: 0;
  line-height: 1.2;
  text-decoration: none;
}

.about-page .hero-title-sub {
  position: absolute;
  top: 110px;
  left: 685px;
  font-family: 'UTM Horizon', sans-serif;
  font-size: 64px;
  font-weight: 800;
  color: var(--color-primary-dark-green);
  margin: 0;
  line-height: 1.2;
  text-decoration: none;
}

.about-page .hero-description {
  position: absolute;
  top: 80px;
  left: 900px;
  max-width: 550px;
  display: flex;
  flex-direction: column;
  gap: 0px;
}

/* Fix for English language - prevent text overlap */
html[lang="en"] .about-page .hero-title-sub {
  white-space: nowrap;
}

html[lang="en"] .about-page .hero-description {
  left: 950px;
}

.about-page .hero-description p {
  font-family: 'Inter', sans-serif;
  font-size: 18px;
  font-weight: 400;
  color: var(--color-text-gray-dark);
  margin: 0;
  line-height: 1.6;
  white-space: pre-line;
  margin-right: -100px;
}

.about-page .hero-description p:first-child {
  font-weight: 600;
  color: var(--color-text-dark);
  margin-bottom: 4px;
}

/* ==================== ABOUT NEW SECTION ==================== */

.about-new-section {
  width: 100%;
  background: var(--color-bg-light);
  position: relative;
  padding: 120px 20px;
  box-sizing: border-box;
  --about-content-max-width: 1100px;
  --about-content-offset: 0px;
  --about-icon-size: 130px;
  --about-icon-top: 130px;
  --about-icon-left: 30px;
}

.about-new-section-inner {
  max-width: 1200px;
  margin: 0 auto;
  width: 100%;
  display: flex;
  justify-content: flex-end;
}

.about-new-section-icon {
  position: absolute;
  top: var(--about-icon-top);
  left: var(--about-icon-left);
  width: var(--about-icon-size);
  height: var(--about-icon-size);
  object-fit: contain;
  pointer-events: none;
  user-select: none;
  opacity: 0;
  transform: translateX(-200px) translateZ(0);
  transition: opacity 0.8s ease, transform 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: transform, opacity;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.about-new-section.animate-in .about-new-section-icon {
  opacity: 1;
  transform: translateX(0);
}

.about-new-section-content {
  display: grid;
  grid-template-columns: 0.5fr 1.5fr;
  gap: 40px;
  align-items: flex-start;
  max-width: var(--about-content-max-width);
  width: 100%;
  margin-left: auto;
  margin-right: var(--about-content-offset);
}

.about-new-section-heading {
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-family: 'UTM Horizon', sans-serif;
  font-size: 64px;
  font-weight: 800;
  line-height: 1.05;
  color: var(--color-primary-dark-green);
  text-transform: uppercase;
  margin-top: var(--about-heading-offset, 100px);
}

.about-new-section-heading span:nth-child(2) {
  font-size: 72px;
}

.about-new-section-body {
  display: flex;
  flex-direction: column;
  gap: 18px;
  font-family: 'Inter', sans-serif;
  font-size: 18px;
  line-height: 1.6;
  color: var(--color-text-dark);
  max-width: 620px;
}

.about-new-section-quote {
  font-family: 'SignPainter', 'SignPainter-HouseScript', 'Brush Script MT', 'Segoe Script', cursive;
  font-size: 28px;
  font-style: italic;
  color: var(--color-dark-green);
  margin: 0;
}

.about-new-section-body p {
  margin: 0;
}

.about-new-section-signature {
  font-family: 'SignPainter', 'SignPainter-HouseScript', 'Brush Script MT', 'Segoe Script', cursive;
  font-size: 22px;
  font-style: italic;
  color: var(--color-dark-green);
  text-align: right;
  display: block;
}

/* ==================== ABOUT VALUES SECTION ==================== */

.about-values-section {
  width: 100%;
  background: var(--color-bg-cream);
  position: relative;
  padding: 100px 20px;
  box-sizing: border-box;
  border-radius: 80px 80px 0 0;
  overflow: hidden;
}

.about-values-section-inner {
  max-width: 1200px;
  margin: 0 auto;
  width: 100%;
}

.about-values-section-title {
  font-family: 'UTM Horizon', sans-serif;
  font-size: 50px;
  font-weight: 800;
  color: var(--color-primary-dark-green);
  text-align: center;
  text-transform: uppercase;
  margin: 0 0 60px 0;
}

.about-values-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  align-items: flex-start;
}

.about-values-item {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.about-values-heading {
  font-family: 'UTM Horizon', sans-serif;
  font-size: 38px;
  font-weight: 800;
  color: var(--color-primary-dark-green);
  margin: 0;
  text-transform: uppercase;
}

.about-values-text {
  font-family: 'Inter', sans-serif;
  font-size: 18px;
  line-height: 1.6;
  color: var(--color-text-dark);
  margin: 0;
}

.about-values-section-footer {
  position: absolute;
  bottom: -100px;
  left: 0;
  right: 0;
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  object-position: bottom center;
  z-index: 5;
  pointer-events: none;
}

/* ==================== ABOUT DEVELOPMENT SECTION ==================== */

.about-development-section {
  width: 100%;
  background: var(--color-dark-green);
  position: relative;
  padding: 120px 20px 180px 20px;
  box-sizing: border-box;
  min-height: 160vh;
  overflow: hidden;
  margin-top: -1px;
}

@keyframes gentleZoom {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.25);
  }
}

@keyframes gentleZoomCenter {
  0%, 100% {
    transform: translateX(-50%) scale(1);
  }
  50% {
    transform: translateX(-50%) scale(1.25);
  }
}

.about-development-icon-top {
  position: absolute;
  top: 80px;
  left: 80px;
  width: 120px;
  height: 120px;
  object-fit: contain;
  z-index: 1;
  pointer-events: none;
  animation: gentleZoom 3s ease-in-out infinite;
  transform-origin: center center;
}

.about-development-icon-center {
  position: absolute;
  top: var(--icon-center-top, 450px);
  left: var(--icon-left, 750px);
  width: 60px;
  height: 60px;
  object-fit: contain;
  z-index: 1;
  pointer-events: none;
  opacity: 0.8;
  animation: gentleZoomCenter 3s ease-in-out infinite;
  animation-delay: 0.5s;
  transform-origin: center center;
}

.about-development-title {
  position: absolute;
  top: 80px;
  right: 80px;
  font-family: 'UTM Horizon', sans-serif;
  font-size: 140px;
  font-weight: 400;
  color: var(--color-primary-light-green);
  margin: 0;
  z-index: 2;
  text-transform: uppercase;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0;
  line-height: 1.1;
  margin-right: 350px;
}

.about-development-title span {
  display: block;
}

.about-development-content {
  max-width: 1400px;
  margin: 0 auto;
  margin-top: 280px;
  display: flex;
  flex-direction: column;
  gap: 80px;
  position: relative;
  z-index: 2;
}

.about-dev-item {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0px;
  align-items: center;
}

/* ==================== VISION SECTION - Tầm nhìn ==================== */
.about-dev-item-vision {
  --vision-image-order: 1;
  --vision-text-order: 2;
  grid-template-columns: 1fr 1fr;
}

.about-dev-image-vision {
  order: var(--vision-image-order);
  width: 100%;
  height: auto;
}

.about-dev-text-vision {
  order: var(--vision-text-order);
  --vision-text-margin-right: 270px;
}

.about-dev-item-vision.image-right {
  --vision-image-order: 2;
  --vision-text-order: 1;
}

/* ==================== MISSION SECTION - Sứ mệnh ==================== */
.about-dev-item-mission {
  --mission-image-order: 2;
  --mission-text-order: 1;
  grid-template-columns: 1fr 1fr;
}

.about-dev-image-mission {
  order: var(--mission-image-order);
  width: 100%;
  height: auto;
}

.about-dev-text-mission {
  order: var(--mission-text-order);
  --mission-text-margin-right: 200px;
}

.about-dev-item-mission.image-left {
  --mission-image-order: 1;
  --mission-text-order: 2;
}

/* ==================== CORE VALUES SECTION - Cốt lõi ==================== */
.about-dev-item-core {
  --core-image-order: 1;
  --core-text-order: 2;
  grid-template-columns: 1fr 1fr;
}

.about-dev-image-core {
  order: var(--core-image-order);
  width: 100%;
  height: auto;
}

.about-dev-text-core {
  order: var(--core-text-order);
  --core-text-margin-right: 250px;
}

.about-dev-item-core.image-right {
  --core-image-order: 2;
  --core-text-order: 1;
}

/* ==================== CHUNG CHO TẤT CẢ ẢNH ==================== */
.about-dev-image {
  width: 100%;
  height: auto;
}

/* ==================== ẢNH TẦM NHÌN (VISION) ==================== */
.about-dev-image-vision img {
  width: var(--vision-image-width, 55%);
  height: auto;
  object-fit: cover;
  border-radius: var(--vision-image-radius, 8px);
  margin-left: 200px;
  margin-right: var(--vision-image-margin-right, 0);
  margin-top: var(--vision-image-margin-top, 400px);
  margin-bottom: var(--vision-image-margin-bottom, 0);
}

/* ==================== ẢNH SỨ MỆNH (MISSION) ==================== */
.about-dev-image-mission img {
  width: var(--mission-image-width, 55%);
  height: auto;
  object-fit: cover;
  border-radius: var(--mission-image-radius, 8px);
  margin-left: var(--mission-image-margin-left, 100px);
  margin-right: 350px;
  margin-top: var(--mission-image-margin-top, -250px);
  margin-bottom: var(--mission-image-margin-bottom, 0);
}

/* ==================== ẢNH CỐT LÕI (CORE VALUES) ==================== */
.about-dev-image-core img {
  width: var(--core-image-width, 55%);
  height: auto;
  object-fit: cover;
  border-radius: var(--core-image-radius, 8px);
  margin-left: 300px;
  margin-right: var(--core-image-margin-right, 0);
  margin-top: var(--core-image-margin-top, 0);
  margin-bottom: var(--core-image-margin-bottom, 0);
}

/* ==================== CHUNG CHO TẤT CẢ TEXT ==================== */
.about-dev-text {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.about-dev-subtitle {
  font-family: 'SignPainter', 'SignPainter-HouseScript', 'Brush Script MT', 'Segoe Script', cursive;
  font-size: 30px;
  font-style: normal;
  color: var(--color-white);
  margin: 0;
  line-height: 1.2;
}

/* ==================== TÁCH RIÊNG 3 TIÊU ĐỀ ==================== */
.about-dev-subtitle-vision {
  font-family: 'SignPainter', 'SignPainter-HouseScript', 'Brush Script MT', 'Segoe Script', cursive;
  font-size: 50px;
  font-style: normal;
  color: var(--color-white);
  margin: 0;
  margin-top: var(--vision-subtitle-margin-top, -90px);
  line-height: 1.2;
}

.about-dev-subtitle-mission {
  font-family: 'SignPainter', 'SignPainter-HouseScript', 'Brush Script MT', 'Segoe Script', cursive;
  font-size: 50px;
  font-style: normal;
  color: var(--color-white);
  margin: 0;
  margin-top: var(--mission-subtitle-margin-top, -50px);
  line-height: 1.2;
  margin-left:-130px
}

.about-dev-subtitle-core {
  font-family: 'SignPainter', 'SignPainter-HouseScript', 'Brush Script MT', 'Segoe Script', cursive;
  font-size: 50px;
  font-style: normal;
  color: var(--color-white);
  margin: 0;
  margin-top: var(--core-subtitle-margin-top, -65px);
  line-height: 1.2;
  margin-left: 20px;
}

.about-dev-text p {
  font-family: 'Inter', sans-serif;
  font-size: 20px;
  line-height: 1.6;
  color: var(--color-white);
  margin: 0;
}

/* ==================== TÁCH RIÊNG NỘI DUNG (PARAGRAPH) ==================== */
.about-dev-text-vision p {
  font-family: 'Inter', sans-serif;
  font-size: var(--vision-text-font-size, 20px);
  line-height: 1.6;
  color: var(--color-white);
  margin: 0;
  margin-top: var(--vision-text-p-margin-top, 0);
  margin-left: var(--vision-text-p-margin-left, 0);
}

.about-dev-text-mission p {
  font-family: 'Inter', sans-serif;
  font-size: var(--mission-text-font-size, 20px);
  line-height: 1.6;
  color: var(--color-white);
  margin: 0;
  margin-top: var(--mission-text-p-margin-top, -5px);
  margin-left: var(--mission-text-p-margin-left, -130px);
}

.about-dev-text-core p {
  font-family: 'Inter', sans-serif;
  font-size: var(--core-text-font-size, 20px);
  line-height: 1.6;
  color: var(--color-white);
  margin: 0;
  margin-top: var(--core-text-p-margin-top, 0);
  margin-left: var(--core-text-p-margin-left, 0);
}

/* ==================== TEXT TẦM NHÌN (VISION) ==================== */
.about-dev-text-vision {
  order: var(--vision-text-order);
  margin-left: var(--vision-text-margin-left, -100px);
  margin-right: 200px;
  margin-top: var(--vision-text-margin-top, 330px);
  margin-bottom: var(--vision-text-margin-bottom, 0);
  padding-left: var(--vision-text-padding-left, 0);
  padding-right: var(--vision-text-padding-right, 10px);
  text-align: var(--vision-text-align, left);
}

/* ==================== TEXT SỨ MỆNH (MISSION) ==================== */
.about-dev-text-mission {
  order: var(--mission-text-order);
  position: relative;
  margin-left: var(--mission-text-margin-left, 0);
  margin-right: var(--mission-text-margin-right, 0);
  margin-top: var(--mission-text-margin-top, 0);
  margin-bottom: var(--mission-text-margin-bottom, 0);
  padding-left: var(--mission-text-padding-left, 0);
  padding-right: var(--mission-text-padding-right, 0);
  text-align: var(--mission-text-align, left);
  transform: translateX(var(--mission-text-translate-x, 275px));
}

/* ==================== TEXT CỐT LÕI (CORE VALUES) ==================== */
.about-dev-text-core {
  order: var(--core-text-order);
  margin-left: var(--core-text-margin-left, 0);
  margin-right: var(--core-text-margin-right, 0);
  margin-top: var(--core-text-margin-top, 0);
  margin-bottom: var(--core-text-margin-bottom, 0);
  padding-left: var(--core-text-padding-left, 0);
  padding-right: var(--core-text-padding-right, 0);
  text-align: var(--core-text-align, left);
}

.about-dev-values {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.about-dev-values p {
  font-family: 'Inter', sans-serif;
  font-size: 20px;
  line-height: 1.6;
  color: var(--color-white);
  margin: 0;
  margin-left: 20px;
}

.about-development-footer {
  position: absolute;
  bottom: -180px;
  left: 0;
  right: 0;
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  object-position: bottom center;
  z-index: 5;
  pointer-events: none;

}

.about-dev-values strong {
  color: var(--color-white);
  font-weight: 700;
}

/* ==================== PRODUCTS SECTION ==================== */

@keyframes floating {
  0%, 100% {
    transform: translateY(-15px) scale(1.1);
  }
  50% {
    transform: translateY(-28px) scale(1.1);
  }
}

@keyframes floating-button {
  0%, 100% {
    transform: translateY(-8px) scale(1.1);
  }
  50% {
    transform: translateY(-15px) scale(1.1);
  }
}

.section-products {
  position: relative;
  text-align: center;
  padding: 80px 20px 60px 20px;
  background: var(--color-bg-light);
  overflow: visible;
}

.section-products::before {
  content: '';
  position: absolute;
  top: -30px;
  left: 0;
  width: 100%;
  height: 50px;
  z-index: 2;
  background: url('img/torn.png') center top no-repeat;
  background-size: cover;
  pointer-events: none;
}

.section-products-title-card {
  position: absolute;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 100;
}

.section-products h2 {
  font-family: 'UTM Horizon', sans-serif;
  font-size: 70px;
  font-weight: 700;
  margin: 0;
  color: var(--color-green-border);
  position: relative;
  display: inline-block;
}

.title-icon-wrapper {
  position: absolute;
  top: 2px;
  right: -35px;
  width: 24px;
  height: 24px;
  overflow: visible;
}

.title-icon {
  display: block;
  width: 24px;
  height: 24px;
  background: url('img/Isolation_Mode.png') center/24px 24px no-repeat;
  opacity: 0;
  transform: translateX(-100px);
  transition: opacity 0.8s ease, transform 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.title-icon-wrapper.animate-in .title-icon {
  opacity: 1;
  transform: translateX(0);
}

.product-slider-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  margin-top: 150px;
  position: relative;
  box-sizing: border-box;
  overflow: visible;
  padding: 40px 50px;
  z-index: 1;
}

.slider-arrow {
  background: none;
  border: none;
  color: var(--color-arrow-green);
  font-size: 32px;
  cursor: pointer;
  padding: 10px 12px;
  line-height: 1;
  transition: opacity 0.2s;
  flex-shrink: 0;
  position: relative;
  z-index: 10;
  pointer-events: auto;
}

.slider-arrow:hover {
  opacity: 0.7;
}

.product-slider {
  display: flex;
  align-items: flex-start;
  gap: 50px;
  flex-shrink: 0;
  width: max-content;
  overflow: visible;
  position: relative;
  flex: 1;
}

.product-slider .product-card-link {
  display: block;
  flex-shrink: 0;
  width: auto;
  /* Không dùng transition: all để tránh conflict với JS inline styles */
  will-change: transform, opacity;
}

/* Animation cho card mới vào từ bên phải (next) */
@keyframes slideInFromRight {
  0% {
    opacity: 0;
    transform: translateX(100px) scale(0.9);
  }
  100% {
    opacity: 1;
    transform: translateX(0) scale(1);
  }
}

/* Animation cho card mới vào từ bên trái (prev) */
@keyframes slideInFromLeft {
  0% {
    opacity: 0;
    transform: translateX(-100px) scale(0.9);
  }
  100% {
    opacity: 1;
    transform: translateX(0) scale(1);
  }
}

/* Animation cho card cũ ra về bên trái (next) */
@keyframes slideOutToLeft {
  0% {
    opacity: 1;
    transform: translateX(0) scale(1);
  }
  100% {
    opacity: 0;
    transform: translateX(-100px) scale(0.9);
  }
}

/* Animation cho card cũ ra về bên phải (prev) */
@keyframes slideOutToRight {
  0% {
    opacity: 1;
    transform: translateX(0) scale(1);
  }
  100% {
    opacity: 0;
    transform: translateX(100px) scale(0.9);
  }
}

/* Class để trigger animation */
.product-card-link.slide-out-next {
  animation: slideOutToLeft 0.6s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

.product-card-link.slide-out-prev {
  animation: slideOutToRight 0.6s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

.product-card-link.slide-in-next {
  animation: slideInFromRight 0.6s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

.product-card-link.slide-in-prev {
  animation: slideInFromLeft 0.6s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

.product-card-link {
  text-decoration: none;
  color: inherit;
  display: block;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}

.product-card {
  position: relative;
  border: 2px solid var(--color-green-border);
  border-radius: 33px;
  padding: 22px 18px 20px;
  background: var(--color-bg-light);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.08);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;
  width: 348.35px;
  min-width: 348.35px;
  max-width: 348.35px;
  flex-shrink: 0;
  box-sizing: border-box;
  transition: transform 0.3s ease, box-shadow 0.3s ease, scale 0.3s ease;
  overflow: visible;
  z-index: 1;
  transform: scale(0.91);
}

.product-card::before {
  content: '';
  position: absolute;
  top: 17.78px;
  left: 0;
  right: 0;
  bottom: 148.98px;
  background: url('img/Group.png') center center/313.44px 344.21px no-repeat;
  transform: translateX(0px);
  pointer-events: none;
  z-index: 0;
  opacity: 0;
  transition: opacity 0.5s ease-in-out;
}

.product-card-link:hover .product-card::before {
  opacity: 1;
}

/* Tách riêng hover style cho từng page */
.products-page .products-grid .product-card-link:hover .product-card,
.products-page .products-grid .product-card-link:focus .product-card {
  transform: translateY(-15px) scale(1.21);
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.15);
  animation: floating 3s ease-in-out infinite;
  z-index: 10;
  position: relative;
}

/* Gom chung style hover cho card - index.html và product-detail.html giống nhau */
.product-slider .product-card-link:hover .product-card,
.product-slider .product-card-link:focus .product-card,
.related-products-section .product-card-link:hover .product-card,
.related-products-section .product-card-link:focus .product-card {
  transform: translateY(-15px) scale(1.21);
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.15);
  animation: floating 3s ease-in-out infinite;
  z-index: 10;
  position: relative;
}

.product-card.card-2 {
  background: var(--color-bg-light);
}



.product-card .product-thumb {
  width: 317.07px;
  height: 348.21px;
  min-height: 348.21px;
  max-height: 348.21px;
  background: var(--color-product-bg);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
  transition: background 0.5s ease-in-out;
  flex-shrink: 0;
  box-sizing: border-box;
  left: -4px;
}

.product-card-link:hover .product-card .product-thumb {
  background: transparent;
  align-items: center;
  justify-content: center;
}

/* Tách riêng hover style cho ảnh từng page */
.products-page .products-grid .product-card-link:hover .product-card .product-thumb img {
  transform: scale(1.3) translateX(-6px);
  transform-origin: center center;
}

/* Gom chung style hover cho ảnh - index.html và product-detail.html giống nhau */
.product-slider .product-card-link:hover .product-card .product-thumb img,
.related-products-section .product-card-link:hover .product-card .product-thumb img {
  transform: scale(1.3) translateX(2px);
  transform-origin: center center;
}

.products-page .hero {
  width: 100%;
  height: 100vh;
  max-height: none;
  margin: 0 auto;
  margin-bottom: -10px;
  transform: none;
  transform-origin: initial;
  overflow: hidden;
  position: relative;
  z-index: 2;
}

.products-page .hero-bg {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  margin-left: 0px;
}

.products-page .hero-content {
  position: absolute;
  bottom: 25%;
  left: 12%;
  z-index: 5;
  transform: translateZ(0);
}

.products-page .hero-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  border: 1.5px solid var(--color-white);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.08);
  color: var(--color-white);
  font-family: 'UTM Horizon', sans-serif;
  font-size: 20px;
  font-weight: 600;
  text-decoration: none;
}

.products-page .hero-cta:hover {
  background: rgba(255, 255, 255, 0.18);
}

.products-page .hero-footer {
  position: absolute;
  left: 0;
  right: 0;
  bottom: -25px;
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  pointer-events: none;
  z-index: 4;
  transform: scaleY(0.2);
  transform-origin: center bottom;
}

.about-page .hero-footer {
  position: absolute;
  left: 50%;
  bottom: -60px;
  width: 3490px;
  height: auto;
  display: none;
  object-fit: cover;
  pointer-events: none;
  z-index: 4;
  transform: translateX(-50%) scale(0.5);
  transform-origin: center bottom;
}

.about-page .page-wrapper {
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
  overflow: hidden;
}

@media screen and (min-width: 1649px) {
  .about-page .hero {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
  }
}

body.about-page {
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
  overflow-x: hidden;
  background: var(--color-bg-light) !important;
}

body.about-page .page-wrapper {
  background: var(--color-bg-light) !important;
}


.products-page .products-section-extra {
  width: 100%;
  height: 2100px;
  background: var(--color-bg-light);
  margin-top: -10px;
  padding-top: 0;
  position: relative;
  z-index: 3;
}

.products-page .products-section-extra-inner {
  max-width: 1677px;
  margin: 0 auto;
  padding: 80px 72px 200px;
  box-sizing: border-box;
}

.products-page .products-grid {
  display: flex;
  gap: 50px;
  margin-top: 70px;
  flex-wrap: wrap;
  padding-left: 106px;
}

.products-page .products-grid .product-card-link {
  display: block;
}

/* transform: scale(0.91) đã được định nghĩa ở base class .product-card, 
   không cần override lại ở đây để tránh trùng lặp */

.products-page .products-section-footer {
  display: block;
  width: 120%;
  height: auto;
  object-fit: cover;
  transform: scaleY(0.4);
  transform-origin: center top;
  margin-top: 130px;
  margin-left: -10%;
}

.products-page .products-list-header {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 85px;
}

.products-page .products-list-title {
  font-family: 'UTM Horizon', sans-serif;
  font-size: 96px;
  font-weight: 800;
  color: var(--color-primary-dark-green);
  margin: 0;
  line-height: 1.05;
  margin-left: 124px;
}

.products-page .products-filter {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 10px;
  margin-left: 182px;
}

.products-page .filter-label {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: var(--color-dark-green);
  margin-right: 12px;
  margin-top: -75px;
}

.products-page .filter-selects {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
}

.products-page .filter-selects select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding: 12px 16px;
  border: 1px solid var(--color-primary-dark-green);
  border-radius: 4px;
  background: var(--color-bg-light);
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  color: var(--color-primary-dark-green);
  min-width: 220px;
  background-image: linear-gradient(45deg, transparent 50%, var(--color-primary-dark-green) 50%), linear-gradient(135deg, var(--color-primary-dark-green) 50%, transparent 50%);
  background-position: calc(100% - 18px) calc(50% - 3px), calc(100% - 12px) calc(50% - 3px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-right: 28px;
}

.products-page .filter-selects select:focus {
  outline: 2px solid rgba(11, 58, 30, 0.25);
  outline-offset: 1px;
}


.product-card.card-3 .product-thumb {
  background: var(--color-product-bg);
}

/* Tách riêng base style cho ảnh từng page */
.products-page .products-grid .product-card .product-thumb img {
  width: 190.43px;
  height: 270.48px;
  max-width: 190.43px;
  max-height: 270.48px;
  object-fit: contain;
  flex-shrink: 0;
  transition: transform 0.3s ease;
  transform-origin: center center;
  margin: 0 auto;
  display: block;
  margin-left: 45px;
}

/* Gom chung base style cho ảnh - index.html và product-detail.html giống nhau */
.product-slider .product-card .product-thumb img,
.related-products-section .product-card .product-thumb img {
  width: 190.43px;
  height: 270.48px;
  max-width: 190.43px;
  max-height: 270.48px;
  object-fit: contain;
  flex-shrink: 0;
  transition: transform 0.3s ease;
  transform-origin: center center;
  margin: 0 auto;
  display: block;
  margin-left: 65px;
}

.product-info {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  position: relative;
  flex-shrink: 0;
  width: 100%;
  min-width: 0;
}

.product-title {
  font-size: 20px;
  font-weight: 700;
  color: var(--color-text-black);
  position: relative;
  left: 0;
  margin: 0;
  text-align: left;
  flex: 1 1 auto;
  min-width: 0;
  word-wrap: break-word;
  overflow-wrap: break-word;
  line-height: 1.2;
  transition: color 0.3s ease;
}

.product-card-link:hover .product-card .product-title,
.product-card-link:focus .product-card .product-title {
  color: var(--color-primary-light-green);
}

.product-price {
  font-size: 20px;
  font-weight: 600;
  color: var(--color-orange);
  position: relative;
  right: 0;
  margin: 0;
  text-align: right;
  flex: 0 0 auto;
  margin-left: auto;
  white-space: nowrap;
}

.price-value {
  color: var(--color-orange) !important;
}

.product-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  position: relative;
  margin-top: auto;
  flex-shrink: 0;
  width: 100%;
}

.pill {
  display: inline-block;
  padding: 4px 10px;
  border: 1px solid var(--color-green-border);
  border-radius: 6px;
  font-size: 12px;
  color: var(--color-green-border);
  background: var(--color-pill-bg);
  position: relative;
  left: 0;
  margin: 0;
  white-space: nowrap;
}

.link {
  color: var(--color-link-blue);
  font-weight: 600;
  text-decoration: none;
  position: relative;
  right: auto;
  margin: 0;
  bottom: auto;
  white-space: nowrap;
  align-self: center;
  margin-top: 4px;
}

.link:hover {
  text-decoration: underline;
}

/* ==================== SECTIONS CONTAINER ================= */

.sections-container {
  will-change: transform;
  transform: translateZ(0);
  position: relative;
  width: 100%;
  margin: 0 auto;
  overflow: visible;
}

/* ==================== BACKGROUND S3 SECTION =============== */

.section-about {
  position: relative;
  width: 100%;
  max-width: 1920px;
  margin: 0 auto;
  padding: 0;
  border-radius: 20px 20px 0 0;
  overflow: hidden;
  z-index: 1;
  box-sizing: border-box;
  will-change: transform;
  transform: translateZ(0);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  contain: layout style paint;
}

/* Lớp phủ đen nhẹ để chữ dễ đọc hơn - ảnh sáng hơn nhưng vẫn tối ở vùng chữ */
.section-about::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, 
    rgba(0, 0, 0, 0) 0%, 
    rgba(0, 0, 0, 0.1) 50%, 
    rgba(0, 0, 0, 0.4) 80%, 
    rgba(0, 0, 0, 0.5) 100%);
  z-index: 5;
  pointer-events: none;
}

.section-about > img:first-of-type {
  width: 100%;
  height: auto;
  max-width: 100%;
  min-height: 1100px;
  object-fit: cover;
  display: block;
  will-change: transform;
  transform: translateZ(0);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

@media screen and (min-width: 1649px) and (max-width: 1919px) {
  .section-about {
    max-width: 100% !important;
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  
  .section-about > img:first-of-type {
    width: 100vw !important;
    max-width: none !important;
    position: relative;
    left: 50% !important;
    margin: 0;
    transform: translateX(-50%) scale(1);
    transform-origin: center;
  }
}

@media screen and (min-width: 1920px) {
  .section-about > img:first-of-type {
    width: 1920px;
    max-width: none;
    position: relative;
    left: 50%;
    margin: 0;
    transform: translateX(-50%) scale(1);
    transform-origin: center;
  }
}

@media (min-width: 1920px) {
  .section-about > img:first-of-type {
    left: 50%;
  }
}

.section-about-footer {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  max-width: 100%;
  height: 200px;
  display: block;
  object-fit: cover;
  object-position: top center;
  z-index: 10;
  box-sizing: border-box;
  will-change: transform;
  transform: translateZ(0);
}

.section-about-content {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  z-index: 10;
  padding: 10px 50px 901px 0;
  box-sizing: border-box;
  will-change: transform;
  transform: translateZ(0);
}

.section-about-text {
  width: 590px; /* Giảm từ 690px xuống 650px */
  height: 440px;
  background: transparent;
  padding: 30px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  margin-top: 80px;
  margin-right: -60px;
}

.section-about-intro {
  font-family: 'Inter', sans-serif;
  font-size: 20px;
  font-weight: 600;
  line-height: auto;
  letter-spacing: 0%;
  color: var(--color-white);
  margin: 0 0 20px 0;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5), 0 0 4px rgba(0, 0, 0, 0.3);
}

.section-about-description {
  font-family: 'Inter', sans-serif;
  font-size: 18px;
  font-weight: 400;
  line-height: auto;
  letter-spacing: 0%;
  color: var(--color-white);
  margin: 0;
  flex: 1;
  overflow-y: auto;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5), 0 0 4px rgba(0, 0, 0, 0.3);
}

.section-about-cta {
  font-family: 'Inter', sans-serif;
  font-size: 20px;
  font-weight: 600;
  color: var(--color-green-border);
  background: var(--color-white);
  text-decoration: none;
  align-self: flex-end;
  margin-top: 20px;
  padding: 12px 24px;
  border-radius: 6px;
  display: inline-block;
}

.section-about-cta:hover {
  text-decoration: underline;
}

/* ==================== OVERLAP IMAGE ====================== */

.overlap-image {
  position: relative;
  bottom: 250px;
  left: 50%;
  transform: translateX(-50%) translateZ(0);
  display: flex;
  justify-content: center;
  padding: 19px 1220px 0 319px;
  box-sizing: border-box;
  z-index: 100;
  width: 100%;
  overflow: hidden;
  will-change: transform;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.overlap-image img {
  width: 219px;
  height: 178px;
  object-fit: contain;
  display: block;
  opacity: 0;
  transform: translateX(-200px) translateZ(0);
  transition: opacity 0.8s ease, transform 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: transform, opacity;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.overlap-image.animate-in img {
  opacity: 1;
  transform: translateX(0);
}

/* ==================== NEW SECTION ========================= */

.section-vision {
  width: 100%;
  min-height: 1286px;
  margin: 0 auto;
  margin-top: -280px;
  background: var(--color-dark-green);
  position: relative;
  z-index: 1;
  overflow: visible;
  border: none;
  padding: 0;
}

.section-vision-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 20px;
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
  padding: 180px 72px 0 72px;
  position: relative;
  z-index: 60;
  box-sizing: border-box;
}

.section-vision-left {
  grid-column: 1 / 6;
  display: flex;
  flex-direction: column;
  gap: 30px;
  position: relative;
  padding-top: 100px;
}

.section-vision-right {
  grid-column: 6 / 13;
  display: flex;
  flex-direction: column;
  gap: 30px;
  position: relative;
}

.section-vision-img {
  width: 100%;
  max-width: 437px;
  height: auto;
  object-fit: cover;
  z-index: 60;
}

.section-vision-quote {
  width: 100%;
  max-width: 568px;
  font-family: 'SignPainter', 'SignPainter-HouseScript', 'Brush Script MT', 'Segoe Script', cursive;
  font-size: 36px;
  font-style: normal;
  color: var(--color-white);
  line-height: 1.5;
  letter-spacing: 0%;
  z-index: 61;
  margin: 0;
}

.section-vision-title {
  font-family: 'UTM Horizon', sans-serif;
  font-size: 180px;
  font-weight: 400;
  color: var(--color-primary-light-green);
  line-height: 110%;
  letter-spacing: 0%;
  width: 100%;
  max-width: 713px;
  margin: 0;
  margin-top: -100px;
}

.section-vision-text {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.section-vision-subtitle {
  font-family: 'UTM Horizon', sans-serif;
  font-size: 40px;
  font-weight: 700;
  color: var(--color-white);
  margin: 0;
}

.section-vision-desc {
  font-family: 'Inter', sans-serif;
  font-size: 18px;
  font-weight: 400;
  color: var(--color-white);
  line-height: 1.6;
  margin: 0;
}

.section-vision-desc strong {
  color: var(--color-white);
}

.section-vision-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: fit-content;
  font-family: 'UTM Horizon', sans-serif;
  font-size: 20px;
  font-weight: 500;
  color: var(--color-white);
  background: transparent;
  border: 1.5px solid var(--color-white);
  padding: 12px 24px;
  border-radius: 8px;
  text-decoration: none;
  margin-top: 15px;
}

.section-vision-cta:hover {
  opacity: 0.9;
}

.section-vision-footer {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  z-index: 60;
  transform: scaleY(0.77);
  transform-origin: bottom center;
  margin-bottom: -3px;
}


/* ==================== SECTION 5 ========================= */

.section-news {
  width: 100%;
  height: auto;
  min-height: 850px;
  margin: 0 auto;
  background: var(--color-bg-cream);
  position: relative;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 30px 40px;
  overflow: visible;
  border: none !important;
  outline: 1px solid var(--color-dark-green) !important; /* Anti-aliasing bleed */
  outline-offset: -1px !important;
}

.section-news-bg-right {
  position: absolute;
  right: 0;
  top: -100px;
  bottom: auto;
  height: auto;
  width: auto;
  max-height: none;
  object-fit: contain;
  object-position: right top;
  z-index: 5;
  pointer-events: none;
  transform: scale(1) translateX(80px);
  transform-origin: right top;
  opacity: 0;
  transition: opacity 0.6s ease-out, transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.section-news-bg-right.animate-in {
  opacity: 1;
  transform: scale(0.83) translateX(0);
}

.section-news-footer {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: auto;
  object-fit: cover;
  object-position: bottom center;
  z-index: 10;
  pointer-events: none;
  transform: scaleY(0.8);
  transform-origin: bottom center;
  margin-bottom: -1px;
}

.section-extra {
  width: 100%;
  background: var(--color-dark-green);
  color: var(--color-bg-cream);
  margin-top: 0 !important; /* Lock together with cooperate-connect-section */
  border: none !important;
  outline: 1px solid var(--color-dark-green) !important; /* Anti-aliasing bleed */
  outline-offset: -1px !important;
}

.footer-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 20px;
  max-width: 100%;
  padding: 48px 72px 20px 72px;
  position: relative;
  z-index: 10 !important;
  border: none !important;
}

.footer-top,
.footer-bottom {
  position: relative;
  z-index: 10;
  border: none !important;
}

.footer-top {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 20px;
  padding-bottom: 20px;
  position: relative;
}

.footer-top::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: -72px;
  right: -72px;
  width: calc(100% + 144px);
  height: 3px;
  background: #FFFFFF;
  z-index: 2;
}

.footer-columns {
  display: contents;
}

.footer-col {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.footer-logo-col {
  grid-column: 2 / 3;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
}

.footer-company-col {
  grid-column: 4 / 9;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
}

.footer-social {
  grid-column: 9 / 13;
  position: relative;
  padding-top: 0;
}

.footer-company-col .footer-contact {
  flex: 1;
  margin-top: 20px;
}

.footer-top::after {
  content: '';
  position: absolute;
  top: -70px;
  bottom: 0;
  left: calc((100% - 11 * 20px) * 8.2 / 12 + 8 * 20px - 30px);
  width: 3px;
  background: #FFFFFF;
}

.footer-logo {
  width: 220px;
  height: auto;
  object-fit: contain;
  margin-top: -60px;
  display: block;
  transition: opacity 0.2s;
}

.footer-logo-col a {
  display: inline-block;
  text-decoration: none;
  cursor: pointer;
}

.footer-logo-col a:hover .footer-logo {
  opacity: 0.8;
}

.footer-title {
  font-family: 'UTM Horizon', sans-serif;
  font-size: 18px;
  font-weight: 700;
  margin: 0 0 8px 0;
  color: var(--color-bg-cream);
}

.footer-company-name-card {
  margin-bottom: 10px;
  width: 100%;
}

.footer-company-name {
  font-family: 'Myriad Pro', 'MyriadPro-Bold', 'MyriadPro-Regular', sans-serif;
  font-size: 20px;
  font-weight: bold;
  margin: 0;
  color: var(--color-bg-cream);
}

.footer-contact .footer-title {
  font-family: 'Myriad Pro', 'MyriadPro-Bold', 'MyriadPro-Regular', sans-serif;
  font-weight: bold;
}

.footer-social .footer-title {
  font-family: 'Myriad Pro', 'MyriadPro-Bold', 'MyriadPro-Regular', sans-serif;
  font-weight: bold;
}

.footer-contact p {
  margin: 0 0 6px 0;
  font-size: 13px;
  line-height: 1.5;
  color: var(--color-bg-cream);
}

.section-extra .footer-contact p,
.section-extra .footer-sub,
.section-extra .footer-bottom p {
  text-transform: none;
}

.section-extra .footer-label {
  font-weight: 700;
}

.footer-social .footer-sub {
  margin: -7px 0 12px 0;
  font-size: 14px;
  line-height: 1.4;
  color: var(--color-bg-cream);
}

.footer-icons {
  display: flex;
  gap: 14px;
}

.footer-icons a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px;
  border: none;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.05);
  transition: background 0.2s, border-color 0.2s;
}

.footer-icons a:hover {
  opacity: 0.6;
}

.footer-icon-img {
  width: 32px;
  height: 32px;
  object-fit: contain;
  display: block;
}

.footer-bottom {
  grid-column: 2 / -1;
  padding-top: 20px;
  font-size: 12px;
  line-height: 1.5;
  color: var(--color-bg-cream);
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.section-extra-pattern {
  display: block;
  width: 120vw;
  height: 6px;
  object-fit: cover;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}

.section-chan {
  width: 100%;
  background: var(--color-white);
  display: flex;
  justify-content: flex-end;
}

.section-chan-img {
  display: block;
  width: auto;
  max-width: 100%;
  height: 100%;
  transform: scale(0.7);
  transform-origin: right center;
  margin-top: -22px;
}

.section-news-inner {
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 0px;
  position: relative;
  z-index: 10;
  top: -70px;
}

.section-news-header {
  padding-left: 100px;
}

.section-news-title {
  font-family: 'UTM Horizon', sans-serif;
  font-size: 160px;
  font-weight: 800;
  color: var(--color-primary-dark-green);
  margin: 0;
  margin-left: -30px;
  margin-top: -20px;
}

.section-news-subtitle {
  font-family: 'Inter', sans-serif;
  font-size: 18px;
  font-weight: 500;
  color: var(--color-primary-dark-green);
  margin: 0;
  margin-left: -30px;
}

.section-news-cards-wrapper {
  width: 100%;
  overflow: hidden;
  margin-top: 90px;
  position: relative;
  transform: translateZ(0);
  -webkit-transform: translateZ(0);
  perspective: 1000px;
  -webkit-perspective: 1000px;
  display: flex;
  justify-content: center;
}

.section-news-cards {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 30px;
  max-width: 1250px;
  width: 100%;
}

.news-card-link {
  display: block;
  text-decoration: none;
  color: inherit;
  grid-column: span 4;
  width: 100%;
}

.news-card {
  grid-column: span 4;
  min-width: 0;
  background: var(--color-white);
  border-radius: 10px;
  overflow: hidden;
  border: none;
  display: flex;
  flex-direction: column;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  max-width: 100%;
  transition: border-color 0.45s ease, box-shadow 0.45s ease, transform 0.45s ease;
}

.news-card-link {
  display: block;
  width: 100%;
  text-decoration: none;
  color: inherit;
}

.news-card-link:hover,
.news-card-link:focus {
  text-decoration: none;
  color: inherit;
}


.news-card-2 {
  border: 2px solid var(--color-primary-light-green);
  border-radius: 10px;
  overflow: hidden;
}

.news-thumb {
  width: 100%;
  height: 200px;
  overflow: hidden;
  background: var(--color-bg-cream);
  position: relative;
}

.news-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.news-card-3 .news-thumb {
  width: 100%;
  /* Cho cùng chiều cao với các card khác để 3 card cân nhau */
  height: 200px;
  background: var(--color-primary-light-green);
  display: flex;
  align-items: center;
  justify-content: center;
}

.news-card-3 .news-thumb img {
  max-width: 135px;
  max-height: 120px;
  width: auto;
  height: auto;
  object-fit: contain;
}

.news-body {
  padding: 18px 18px 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
  background: var(--color-white);
}

.news-card-2 .news-body {
  background: var(--color-card-dark);
  color: var(--color-white);
  transition: background-color 0.45s ease, color 0.45s ease;
}

.news-title {
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: var(--color-primary-dark-green);
  margin: 0;
  line-height: 1.4;
}

.news-card-2 .news-title {
  color: var(--color-white);
  transition: color 0.45s ease;
}

.news-meta {
  display: flex;
  align-items: center;
  gap: 24px;
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  color: var(--color-primary-dark-green);
  margin-top: 8px;
}

.news-card-2 .news-meta {
  color: var(--color-white);
  transition: color 0.45s ease;
}

.news-tag {
  padding-left: 0;
}

.section-products .section-news-dots {
  margin-top: 50px;
}

.section-news-dots .dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-dot-green);
  opacity: 0.6;
}

.section-news-dots .dot.active {
  opacity: 0.6;
  background: var(--color-dot-green);
}

.section-news-dots .dot:nth-child(2) {
  opacity: 1 !important;
  background: var(--color-primary-dark-green) !important;
}

/* ===================== NEWS PAGE STYLES ======================= */

.news-page-main {
  width: 100%;
  background: var(--color-bg-light);
  padding: 40px 0 0;
  margin-bottom: 0;
  border-top: none !important;
  box-shadow: none !important;
  box-shadow: inset 0 1px 0 var(--color-bg-light) !important;
}

.news-page-main::before {
  content: '';
  position: absolute;
  left: 0;
  top: -1px;
  width: 100%;
  height: 2px;
  background: var(--color-bg-light);
  pointer-events: none;
}

.news-page-title-wrapper {
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 240px;
  text-align: center;
  margin-bottom: 24px;
}

.news-page-main-title {
  font-family: 'UTM Horizon', sans-serif;
  font-size: 120px;
  font-weight: 800;
  color: var(--color-primary-dark-green);
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: 0;
  position: relative;
}

.news-title-text {
  display: inline-block;
}

.news-title-icon {
  font-size: 0px;
  font-weight: normal;
  color: var(--color-primary-dark-green);
  display: inline-block;
  line-height: 1;
  margin-left: 6px;
  vertical-align: baseline;
  position: relative;
  top: -8px;
}

.news-tabs-wrapper {
  width: 100%;
  max-width: 1300px;
  margin: 0 auto;
  padding: 0;
  display: flex;
  justify-content: center;
  margin-bottom: 30px;
  margin-top: -150px;
}

.news-tabs {
  display: flex;
  align-items: center;
  gap: 0;
  border-bottom: 1px solid var(--color-primary-dark-green);
  padding-bottom: 12px;
  width: 100%;
  max-width: 1300px;
  margin: 0 auto;
  justify-content: space-between;
}

.news-tab {
  font-family: 'Inter', sans-serif;
  font-size: 22px;
  font-weight: bold;
  color: var(--color-primary-dark-green);
  text-decoration: none;
  padding: 8px 0;
  background: transparent !important;
  background-color: transparent !important;
  border: none;
  cursor: pointer;
  transition: background-color 0.2s, color 0.2s;
  white-space: nowrap;
  flex: 1;
  text-align: center;
}

.news-tab:hover {
  color: var(--color-primary-dark-green);
  opacity: 0.8;
  background: transparent !important;
  background-color: transparent !important;
}

.news-tab.active {
  background: var(--color-primary-light-green) !important;
  background-color: var(--color-primary-light-green) !important;
  color: var(--color-primary-dark-green);
  border-radius: 4px;
}

.news-tab:not(.active) {
  background: transparent !important;
  background-color: transparent !important;
}

.news-tab-separator {
  color: var(--color-primary-dark-green);
  margin: 0 8px;
  font-size: 18px;
}

.news-page-content {
  width: 100%;
  background: var(--color-bg-light);
  padding: 24px 0 0;
  scroll-margin-top: 100px;
  position: relative;
  overflow: visible;
  margin-bottom: 0;
}

.news-page-subsection {
  width: 100%;
  margin-bottom: -60px;
  scroll-margin-top: 150px;
}

.news-page-subsection + .news-page-subsection {
  margin-top: -60px;
}

.news-page-subsection:last-of-type {
  margin-bottom: 20px;
}

.news-page-footer {
  position: relative;
  bottom: 0;
  left: 0;
  width: 100%;
  max-width: 100%;
  height: 200px;
  display: block;
  object-fit: cover;
  object-position: top center;
  z-index: 10;
  box-sizing: border-box;
  pointer-events: none;
  margin: 0;
  padding: 0;
}

.news-page-content-inner {
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 240px;
  margin-bottom: 100px;
}

.news-page-section-title {
  font-family: 'UTM Horizon', sans-serif;
  font-size: 48px;
  font-weight: 800;
  color: var(--color-primary-dark-green);
  margin: 0 0 40px 0;
  text-align: center; 
  margin-bottom: 50px;
}

.news-page-cards {
  display: grid;
  grid-template-columns: repeat(3, 500px);
  gap: 24px;
  margin-bottom: 0;
  transform: scale(0.84);
  transform-origin: center;
  justify-content: center;
  position: relative;
}

.news-page-card-link {
  display: block;
  text-decoration: none;
  color: inherit;
}

.news-page-card {
  background: transparent;
  border-radius: 12px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: none;
  border: none;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1), 
              box-shadow 0.3s ease, 
              background 0.3s ease,
              opacity 0.3s ease,
              border 0.3s ease,
              border-radius 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  order: 0;
  will-change: transform;
  box-sizing: border-box;
  transform: translate3d(0, 0, 0);
  -webkit-transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.news-page-card-link {
  display: block;
  width: 100%;
  text-decoration: none;
  color: inherit;
}

.news-page-card-link:hover,
.news-page-card-link:focus {
  text-decoration: none;
  color: inherit;
}

/* Card ở vị trí giữa (thứ 2) đồng bộ bo góc với 2 bên */
.news-page-cards > .news-page-card:nth-child(2),
.news-page-card-active {
  border-radius: 12px;
  overflow: hidden;
}

.news-page-cards > .news-page-card:nth-child(2) .news-page-thumb,
.news-page-card-active .news-page-thumb {
  border-radius: 0;
  overflow: hidden;
  transition: border-radius 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.news-page-cards > .news-page-card:nth-child(2) .news-page-body,
.news-page-card-active .news-page-body {
  border-radius: 0;
  transition: border-radius 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.news-page-card:hover {
  transform: translateY(-4px);
  box-shadow: none;
}

/* Giữ đồng bộ khi hover cho card ở giữa */
.news-page-cards > .news-page-card:nth-child(2):hover,
.news-page-card-active:hover {
  border-radius: 12px;
}

.news-page-thumb {
  width: 100%;
  height: 310px;
  overflow: hidden;
  background: var(--color-bg-cream);
  position: relative;
}

.news-page-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.6s ease;
  transform-origin: center center;
}

.news-page-card:hover .news-page-thumb img {
  transform: scale(1.15);
}

.news-page-card-monan .news-page-thumb {
  background: var(--color-primary-light-green);
  display: flex;
  align-items: center;
  justify-content: center;
}

.news-page-card-monan .news-page-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
  transform-origin: center center;
}

.news-page-card-tieu .news-page-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
  transform-origin: center center;
}

.news-page-card-bun {
  border-radius: 12px;
  overflow: hidden;
}

.news-page-card-bun:hover {
  border-radius: 12px;
}

.news-page-card-bun.news-page-card-active {
  border-radius: 12px;
}

.news-page-card-bun .news-page-thumb {
  border-radius: 0;
  overflow: hidden;
}

.news-page-card-bun .news-page-body {
  border-radius: 0;
}

.news-page-card-bun .news-page-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
  transform-origin: center center;
}

.news-page-card:hover .news-page-card-monan .news-page-thumb img,
.news-page-card:hover .news-page-card-tieu .news-page-thumb img,
.news-page-card:hover .news-page-card-bun .news-page-thumb img {
  transform: scale(1.15);
}

.news-page-body {
  padding: 20px 16px 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
  background: transparent;
}

.news-page-card-active .news-page-body {
  background: var(--color-card-dark);
}

.news-page-card-active .news-page-card-title {
  color: var(--color-white);
}

.news-page-card-active .news-page-meta {
  color: var(--color-white);
}

.news-page-card-active .news-page-tag {
  color: var(--color-primary-light-green);
}

.news-page-card-title {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: var(--color-primary-dark-green);
  margin: 0;
  line-height: 1.4;
}

.news-page-meta {
  display: flex;
  align-items: center;
  gap: 30px;
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  color: var(--color-primary-dark-green);
  margin-top: 8px;
}

.news-page-date {
  color: inherit;
}

.news-page-tag {
  color: var(--color-link-blue-alt);
  font-weight: 600;
}

.news-page-dots {
  display: flex;
  gap: 10px;
  justify-content: center;
  margin-top: 30px;
}

.news-page-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--color-dot-green);
  opacity: 0.6;
  cursor: pointer;
  transition: opacity 0.3s, background 0.3s;
}

.news-page-dot.active {
  opacity: 1;
  background: var(--color-primary-dark-green);
}

/* Placeholder for empty sections */
.news-page-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 310px;
  background: var(--color-bg-cream);
  border-radius: 12px;
  color: var(--color-text-light);
  font-size: 18px;
  font-weight: 500;
}

/* ===================== PRODUCT DETAIL INFO CARDS ======================= */

.product-info-card {
  background: var(--color-bg-light);
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  position: relative;
}

.product-info-card-1 {
  top: -30px;
  left: 0px;
  margin-bottom: 30px;
}

.product-info-card-2 {
  top: -30px;
  left: 0px;
  margin-bottom: 30px;
}

.product-info-card-3 {
  top: 0px;
  left: 0px;
  margin-bottom: 20px;
}

.product-info-card-4 {
  top: 0px;
  left: 0px;
  margin-bottom: 0;
}

/* ==================== PRODUCT DETAIL INFO SECTION ==================== */

.product-detail-info-container {
  width: 1200px;
  height: auto;
  min-height: 400px;
  margin: -20px auto 0;
  padding-top: 30px;
  padding-right: 50px;
  padding-bottom: 30px;
  padding-left: 50px;
  background: var(--color-bg-light);
  border: 2px solid var(--color-green-border);
  position: relative;
  box-sizing: border-box;
}


.product-detail-info-wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  align-items: start;
  position: relative;
}

.product-info-card-1 {
  top: -30px;
  left: 0px;
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 10px;
  margin-left: 0;
  padding-top: 0;
  padding-right: 30px;
  padding-bottom: 20px;
  padding-left: 30px;
}

.product-info-card-2 {
  top: -30px;
  left: 0px;
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 15px;
  margin-left: 0;
  padding-top: 0;
  padding-right: 30px;
  padding-bottom: 20px;
  padding-left: 30px;
}

.product-info-card-3 {
  top: 0px;
  left: 0px;
  margin-top: -10px;
  margin-right: 0;
  margin-bottom: 15px;
  margin-left: 0;
  padding-top: 0;
  padding-right: 30px;
  padding-bottom: 20px;
  padding-left: 30px;
}

.product-info-card-4 {
  top: 0px;
  left: 0px;
  margin-top: -10px;
  margin-right: 0;
  margin-bottom: 0;
  margin-left: 0;
  padding-top: 0;
  padding-right: 30px;
  padding-bottom: 20px;
  padding-left: 30px;
}

.product-detail-info-title {
  font-family: 'Myriad Pro', 'MyriadPro-Regular', sans-serif !important;
  font-size: 30px !important;
  color: var(--color-primary-dark-green) !important;
  font-weight: bold !important;
  margin-top: 15px !important;
  margin-right: 0 !important;
  margin-bottom: 10px !important;
  margin-left: 0 !important;
  padding-top: 0 !important;
  padding-right: 0 !important;
  padding-bottom: 25px !important;
  padding-left: 0 !important;
  border-bottom: 2px solid var(--color-primary-dark-green) !important;
}

.product-detail-info-description {
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin: 0;
  padding: 0;
}

.product-detail-info-desc-item {
  display: flex;
  gap: 10px;
  font-size: 16px;
  line-height: 1.3;
  color: #000;
  text-transform: none;
}

.product-detail-info-desc-item span:not(.bullet) {
  text-transform: none;
}

.product-detail-info-desc-item .bullet {
  color: #000;
  font-weight: bold;
  font-size: 18px;
  flex-shrink: 0;
}

.quality-commitment-title {
  font-family: 'Myriad Pro', 'MyriadPro-Regular', sans-serif;
  font-size: 30px;
  color: var(--color-primary-dark-green);
  font-weight: bold;
  margin-top: -25px;
  margin-right: 0;
  margin-bottom: 10px;
  margin-left: 0;
  padding-top: 0;
  padding-right: 0;
  padding-bottom: 0;
  padding-left: 0;
  position: relative;
}

.quality-commitment-title::before {
  content: '';
  position: absolute;
  top: -25px;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--color-primary-dark-green);
}

.quality-commitment-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 0;
}

.quality-commitment-item {
  display: flex;
  gap: 10px;
  font-size: 16px;
  line-height: 1.3;
  color: #000;
  text-transform: none;
}

.quality-commitment-item span:not(.bullet) {
  text-transform: none;
}

.quality-commitment-item .bullet {
  color: #000;
  font-weight: bold;
  font-size: 18px;
  flex-shrink: 0;
}

.product-info-section-title {
  font-family: 'Myriad Pro', 'MyriadPro-Regular', sans-serif;
  font-size: 30px;
  color: var(--color-primary-dark-green);
  font-weight: bold;
  margin-top: 15px;
  margin-right: 0;
  margin-bottom: 0;
  margin-left: 0;
  padding-top: 0;
  padding-right: 0;
  padding-bottom: 25px;
  padding-left: 0;
  border-bottom: 2px solid var(--color-primary-dark-green);
}

.manufacturing-title {
  font-family: 'Myriad Pro', 'MyriadPro-Regular', sans-serif;
  font-size: 30px;
  color: var(--color-primary-dark-green);
  font-weight: bold;
  margin-top: -25px;
  margin-right: 0;
  margin-bottom: 10px;
  margin-left: 0;
  padding-top: 0;
  padding-right: 0;
  padding-bottom: 0;
  padding-left: 0;
  position: relative;
}

.manufacturing-title::before {
  content: '';
  position: absolute;
  top: -25px;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--color-primary-dark-green);
}

.product-info-list {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 0;
  margin-top: 15px;
}

.product-info-item {
  display: flex;
  gap: 10px;
  font-size: 16px;
  line-height: 1.3;
}

.product-info-item .info-label {
  font-weight: 600;
  color: #000;
  min-width: 120px;
  flex-shrink: 0;
}

.product-info-item .info-value {
  color: #333;
  flex: 1;
  text-transform: none;
}

.manufacturing-info {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 0;
}

.manufacturing-info p {
  font-size: 16px;
  line-height: 1.3;
  color: #000;
  margin: 0;
  text-transform: none;
}

.company-name {
  font-weight: normal;
  color: var(--color-primary-dark-green);
}

@media (max-width: 768px) {
  .product-detail-info-wrapper {
    grid-template-columns: 1fr;
    gap: 30px;
  }
  .product-detail-info-container {
    padding-top: 30px;
    padding-right: 15px;
    padding-bottom: 30px;
    padding-left: 15px;
  }
}

@media (min-width: 1024px) {
/* ===================== PRODUCT DETAIL PAGE (MOVED FROM product-detail.html) ===================== */
.product-detail-section {
  padding: 60px 20px 0;
  background: #f8f9ed;
  min-height: 60vh;
  position: relative;
}

.product-detail-container {
  max-width: 1400px;
  margin: 0 auto;
}

.loading-message,
.error-message {
  text-align: center;
  padding: 40px;
  font-size: 18px;
}

.product-detail-wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: start;
}

/* Left Panel - Product Image */
.product-detail-left {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.product-image-panel {
  background: transparent;
  border-radius: 0;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: auto;
  position: relative;
}

.product-main-image {
  width: 100%;
  max-width: 400px;
  height: auto;
  object-fit: contain;
}

/* Thumbnails */
.product-thumbnails {
  display: flex;
  gap: 15px;
  justify-content: center;
}

.product-thumb-item {
  width: 120px;
  height: 120px;
  border-radius: 15px;
  overflow: hidden;
  cursor: pointer;
  border: 3px solid transparent;
  transition: all 0.3s;
  background: white;
  padding: 5px;
}

.product-thumb-item:hover {
  border-color: #4CAF50;
  transform: scale(1.05);
}

.product-thumb-item.active {
  border-color: #0b3a1e;
  border-width: 3px;
}

.product-thumb-item img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* Right Panel - Product Info */
.product-detail-right {
  display: flex;
  flex-direction: column;
  gap: 8px;
  background: #f8f9ed;
  padding: 20px 30px;
  border-radius: 10px;
}

.product-detail-title {
  font-family: 'UTM Horizon', sans-serif;
  font-size: 54px;
  font-weight: normal;
  color: #0b3a1e;
  margin: -35px 0 -5px -50px;
  line-height: 1.2;
}

/* Rating */
.product-rating {
  display: flex;
  gap: 5px;
  margin: 0 0 5px -50px;
}

.star {
  font-size: 24px;
  color: #ddd;
}

.star.filled {
  color: #FFD700;
}

.star.half {
  background: linear-gradient(90deg, #FFD700 50%, #ddd 50%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* Description List */
.product-description-list {
  margin: 0 0 8px -50px;
}

.product-desc-item {
  display: flex;
  gap: 10px;
  margin-bottom: 12px;
  font-size: 12px;
  line-height: 1.6;
  color: #000;
}

.product-desc-item .bullet {
  color: #000;
  font-weight: bold;
  font-size: 16px;
  flex-shrink: 0;
}

/* Price Section */
.product-price-section {
  margin: -20px 0 30px -50px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.price-label {
  font-size: 12px;
  color: #333;
  display: inline;
  margin-bottom: 0;
  font-weight: 500;
}

.price-value {
  font-size: 24px;
  font-weight: bold;
  color: #F29F05 !important;
}

/* Info Table */
.product-info-table {
  width: 100%;
  border-collapse: collapse;
  margin: 0 0 8px -50px;
  border-top: 2px solid #0b3a1e;
  border-bottom: 2px solid #0b3a1e;
  border-left: none;
  border-right: none;
}

.product-info-table thead {
  background: transparent;
}

.product-info-table th {
  padding: 12px 15px;
  text-align: left;
  font-size: 11px;
  color: #000;
  font-weight: 600;
  border: none;
  background: transparent;
}

.product-info-table th:first-child,
.product-info-table td:first-child {
  border-right: 2px solid #0b3a1e;
}

.product-info-table th:nth-child(2),
.product-info-table td:nth-child(2) {
  border-right: 2px solid #0b3a1e;
}

.product-info-table td {
  padding: 12px 15px;
  border: none;
  vertical-align: top;
}

.product-info-table tbody tr {
  background: transparent;
}

.info-cell-center {
  vertical-align: middle;
}

.info-box {
  border: 1px solid #0b3a1e;
  border-radius: 5px;
  padding: 10px 12px;
  background: #f8f9ed;
  text-align: center;
  font-size: 11px;
  color: #000;
  font-weight: 500;
  margin: 0;
}

.size-weight-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.size-weight-option {
  cursor: pointer;
  user-select: none;
}

.size-weight-option.active {
  border-width: 1px;
  font-weight: 500;
}

.size-weight-list.has-4-sizes .size-weight-option {
  padding: 7px 12px;
  font-size: 10px;
  line-height: 1.15;
}

/* Social Icons Card */
.product-social-card {
  margin: 20px 0 30px -50px;
}

/* Social Icons */
.product-social-icons {
  display: flex;
  gap: 15px;
  margin: 0;
  align-items: center;
  flex-wrap: wrap;
}

.social-icon {
  display: inline-block;
  transition: transform 0.3s;
  flex-shrink: 0;
}

.social-icon:hover {
  transform: scale(1.1);
}

.social-icon img {
  width: auto;
  height: auto;
  max-width: 50px;
  max-height: 50px;
  display: block;
  object-fit: contain;
}

/* Contact Section Card */
.product-contact-card {
  margin-top: 0;
  margin-left: -50px;
}

/* Contact Section */
.product-contact-section {
  margin: 0;
}

.contact-header {
  border: 1px solid #0b3a1e;
  border-radius: 5px;
  padding: 12px 20px;
  background: white;
  color: #0b3a1e;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  font-weight: bold;
  font-size: 16px;
  transition: background 0.3s;
}

.contact-header:hover {
  background: #f0f0f0;
}

.contact-arrow {
  transition: transform 0.3s;
  font-size: 14px;
  color: #0b3a1e;
}

.contact-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease-out;
  padding: 0;
  margin-top: 0;
}

.contact-content.expanded {
  max-height: 250px;
  padding: 15px 0;
  margin-top: 10px;
}

.contact-content p {
  margin: 10px 0;
  color: #333;
}

.btn-contact-now {
  display: inline-block;
  margin-top: 15px;
  padding: 12px 24px;
  background: #4CAF50;
  color: white;
  text-decoration: none;
  border-radius: 5px;
  font-weight: bold;
  transition: background 0.3s;
}

.btn-contact-now:hover {
  background: #45a049;
}

/* Related Products */
.related-products-section {
  padding: 60px 20px 250px;
  background: #f8f9ed;
  margin-bottom: 0;
  overflow: visible;
  position: relative;
}

.related-products-inner {
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-bottom: 0;
  overflow: visible;
}

.related-products-title {
  text-align: center;
  margin-bottom: 30px;
  font-family: 'UTM Horizon', sans-serif;
  font-size: 48px;
  color: #0b3a1e;
  font-weight: bold;
  letter-spacing: 0.5px;
}

.related-products-slider-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  position: relative;
  padding: 0;
  overflow: visible;
}

.related-slider-arrow {
  background: none;
  border: none;
  color: #0b3a1e;
  font-size: 36px;
  cursor: pointer;
  padding: 10px 12px;
  line-height: 1;
  transition: opacity 0.2s;
  font-weight: bold;
  z-index: 10;
}

.related-slider-arrow:hover {
  opacity: 0.7;
}

.related-products-slider {
  display: flex;
  align-items: stretch;
  gap: 50px; /* Lấy từ .products-page .products-grid */
  width: 100%;
  max-width: calc(100% - 120px);
  justify-content: center;
  overflow: visible;
  padding: 30px 0 0;
}

.related-products-dots {
  display: flex;
  gap: 10px;
  justify-content: center;
  margin-top: 40px;
  margin-bottom: 0;
}

.related-products-dots .dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #9cc28f;
  opacity: 0.6;
  cursor: pointer;
  transition: all 0.3s;
}

.related-products-dots .dot.active {
  opacity: 0.6; /* Override active class */
  background: #9cc28f;
}

/* Chỉ dot ở giữa (thứ 2) sáng lên */
.related-products-dots .dot:nth-child(2) {
  opacity: 1 !important;
  background: #0b3a1e !important;
}

/* Footer Product Detail Image */
.footer-product-detail {
  width: 100%;
  height: auto;
  display: block;
  margin-top: 40px;
}

/* Related Products Footer */
.related-products-footer {
  width: 100vw;
  height: auto;
  display: block;
  padding: 0;
  position: absolute;
  bottom: 0px;
  left: 50%;
  transform: translateX(-50%);
  margin: 0;
}

/* Product Detail Info Section */
.product-detail-info-section {
  background: #f8f9ed;
  padding: 60px 0 0;
  position: relative;
  margin-top: -60px;
}

/* Section Wrapper - có thể tùy chỉnh kích thước toàn bộ section */
.product-detail-info-section-wrapper {
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* Header box-pd - có thể tùy chỉnh kích thước riêng */
.product-detail-info-header {
  position: relative;
  text-align: center;
  width: auto;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px 0 0;
  background: #f8f9ed;
  margin-bottom: 0px;
}

.product-detail-info-header-bg {
  width: auto;
  max-width: 600px;
  height: auto;
  display: block;
  margin: 0 auto;
  opacity: 0;
}

.product-detail-info-header-text {
  position: absolute;
  font-family: 'Inter', sans-serif;
  font-size: 36px;
  color: #0b3a1e;
  font-weight: 600;
  margin: 0;
  z-index: 10;
  left: 50%;
  top: 100%;
  transform: translate(-50%, -100%);
  white-space: nowrap;
  background: #0b3a1e;
  color: #ffffff;
  padding: 12px 28px 16px;
  border-radius: 20px 20px 0 0;
}

.product-detail-info-container {
  position: relative;
  margin-top: 0px;
}
}

/* Responsive */
@media (max-width: 1024px) {
  .product-detail-wrapper {
    gap: 40px;
  }
  .product-image-panel {
    min-height: 400px;
    padding: 30px;
  }
}

@media (max-width: 768px) {
  .product-detail-section {
    padding: 40px 15px;
  }
  .product-detail-wrapper {
    grid-template-columns: 1fr;
    gap: 30px;
  }
  .product-image-panel {
    min-height: 300px;
    padding: 20px;
  }
  .product-thumbnails {
    flex-wrap: wrap;
  }
  .product-thumb-item {
    width: 80px;
    height: 80px;
  }
  .product-detail-title {
    font-size: 28px;
  }
  .info-header-row,
  .info-content-row {
    grid-template-columns: 1fr;
    gap: 15px;
  }
  .info-box-group {
    grid-column: 1;
  }
  .product-social-icons {
    justify-content: center;
  }
}




