:root {
  /* PDF-extracted palette */
  --green: #83A042;
  --green-light: #9CB85C;
  --green-dark: #6C8535;
  --green-bg: #EEF3E4;
  --blue: #2B5DA9;
  --blue-dark: #1E4A8A;
  --accent: #AA4224;
  --accent-hover: #90351B;
  --bg: #FFFFFF;
  --white: #FFFFFF;
  --off-white: #FAFBFA;
  --text: #3A332E;
  --text-light: #6B6560;
  --heading: #2D3436;
  --border: #E0E2DE;

  --font: 'Inter', system-ui, -apple-system, sans-serif;
  --ease: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
  --shadow-md: 0 2px 8px rgba(0,0,0,0.06);
  --shadow-lg: 0 4px 16px rgba(0,0,0,0.08);
  --radius: 4px;
  --radius-lg: 8px;
}

/* ========== DEFAULT BACKGROUND OVERRIDE ========== */
/* The base background is handled by .ambient-bg to permit deep-Z rendering */

/* ========== AMBIENT PARALLAX ========== */
.ambient-bg { position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; pointer-events: none; z-index: -1; overflow: hidden; background: var(--off-white); }
.ambient-shape { position: absolute; pointer-events: none; opacity: 0.08; transition: transform 0.5s ease-out; }
.shape-1 { width: 60vw; height: 60vw; background: linear-gradient(135deg, var(--green), var(--green-dark)); top: -10vw; left: -10vw; animation: morph1 28s ease-in-out infinite alternate; }
.shape-2 { width: 70vw; height: 70vw; background: linear-gradient(135deg, var(--blue), var(--blue-dark)); bottom: -15vw; right: -15vw; animation: morph2 32s ease-in-out infinite alternate-reverse; }
.shape-3 { display: none; }

@keyframes morph1 {
  0% { border-radius: 30% 70% 70% 30% / 30% 30% 70% 70%; transform: translate(0, 0) rotate(0deg) scale(1); }
  25% { border-radius: 50% 50% 30% 70% / 60% 30% 70% 40%; transform: translate(4vw, 6vw) rotate(45deg) scale(1.05); }
  50% { border-radius: 60% 40% 60% 40% / 40% 60% 40% 60%; transform: translate(8vw, -3vw) rotate(90deg) scale(0.95); }
  75% { border-radius: 30% 70% 50% 50% / 50% 40% 60% 50%; transform: translate(-4vw, 8vw) rotate(135deg) scale(1.02); }
  100% { border-radius: 40% 60% 70% 30% / 40% 50% 60% 50%; transform: translate(-8vw, -8vw) rotate(180deg) scale(1); }
}

@keyframes morph2 {
  0% { border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%; transform: translate(0, 0) rotate(0deg) scale(1); }
  33% { border-radius: 30% 70% 70% 30% / 30% 30% 70% 70%; transform: translate(-6vw, -4vw) rotate(-45deg) scale(1.05); }
  66% { border-radius: 50% 50% 30% 70% / 50% 40% 60% 50%; transform: translate(4vw, -8vw) rotate(-90deg) scale(0.95); }
  100% { border-radius: 40% 60% 50% 50% / 40% 60% 40% 60%; transform: translate(8vw, 4vw) rotate(-135deg) scale(1.02); }
}

/* ========== RESET ========== */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; font-size: 16px; }
body { font-family: var(--font); color: var(--text); background: transparent; line-height: 1.7; -webkit-font-smoothing: antialiased; overflow-x: hidden; }

/* ========== TYPOGRAPHY ========== */
h1, h2, h3, h4 { color: var(--blue); font-weight: 700; line-height: 1.2; }
h1 { font-size: clamp(2rem, 3.5vw, 2.75rem); letter-spacing: -0.5px; text-transform: uppercase; }
h2 { font-size: clamp(1.5rem, 2.5vw, 2.25rem); letter-spacing: -0.3px; }
h3 { font-size: 1.15rem; }
p { margin-bottom: 1rem; }
a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; }

/* ========== UTILITIES ========== */
.container { max-width: 1200px; margin: 0 auto; padding: 0 clamp(1.25rem, 3vw, 2rem); }
.section { padding: clamp(3rem, 5vw, 4.5rem) 0; }
.text-center { text-align: center; }
.grid { display: grid; gap: 1.5rem; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 768px) { .grid-2, .grid-3 { grid-template-columns: 1fr; } }
.eyebrow { display: inline-block; font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; color: var(--green); margin-bottom: 0.75rem; }

/* ========== BUTTONS ========== */
.btn { display: inline-flex; align-items: center; justify-content: center; padding: 0.8rem 1.6rem; border-radius: var(--radius); font-weight: 600; cursor: pointer; transition: all 0.3s var(--ease); font-size: 0.95rem; }
.btn-primary { background: var(--blue); color: var(--white); border: 2px solid var(--blue); box-shadow: var(--shadow-md); }
.btn-primary:hover { background: var(--blue-dark); border-color: var(--blue-dark); transform: translateY(-2px); box-shadow: var(--shadow-lg); }
.btn-accent { background: var(--accent); color: var(--white); border: 2px solid var(--accent); box-shadow: var(--shadow-md); }
.btn-accent:hover { background: var(--accent-hover); border-color: var(--accent-hover); transform: translateY(-2px); box-shadow: var(--shadow-lg); }
.btn-ghost { background: transparent; color: var(--white); border: 1px solid rgba(255,255,255,0.6); }
.btn-ghost:hover { background: var(--white); color: var(--green); border-color: var(--white); }
.btn-outline { background: transparent; color: var(--green); border: 2px solid var(--green); }
.btn-outline:hover { background: var(--green); color: var(--white); }
.btn-sm { padding: 0.625rem 1.5rem; font-size: 0.85rem; }

/* ========== NAVBAR (single source of truth — 72px fixed, identical on every page) ========== */
.navbar { position: fixed; top: 0; left: 0; right: 0; height: 72px; z-index: 1000; background: rgba(255,255,255,0.98); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border-bottom: 1px solid var(--border); }
.navbar.scrolled { box-shadow: var(--shadow-md); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; height: 72px; max-width: 1200px; margin: 0 auto; padding: 0 clamp(1.25rem, 3vw, 2rem); }
.logo { display: flex; flex-direction: column; align-items: flex-start; justify-content: center; gap: 2px; flex-shrink: 0; line-height: 1; }
.logo-img { height: 52px; width: auto; display: block; }
.logo-tagline { font-size: 0.6rem; letter-spacing: 2px; text-transform: uppercase; color: var(--green); font-weight: 700; margin-left: 26px; line-height: 1; white-space: nowrap; }
.nav-links { display: flex; align-items: center; gap: 1.4rem; flex-shrink: 1; min-width: 0; }
.nav-links a { color: var(--text); font-weight: 500; font-size: 0.9rem; line-height: 1; transition: color 0.2s; position: relative; white-space: nowrap; }
.nav-links a:hover, .nav-links a.active { color: var(--green); }
.nav-links a::after { content: ''; position: absolute; bottom: -4px; left: 0; width: 100%; height: 2px; background: var(--green); transform: scaleX(0); transform-origin: right; transition: transform 0.3s var(--ease); }
.nav-links a:hover::after, .nav-links a.active::after { transform: scaleX(1); transform-origin: left; }
.nav-actions { display: flex; align-items: center; gap: 0.75rem; flex-shrink: 0; }
.nav-cta { flex-shrink: 0; }
.lang-toggle { display: inline-flex; align-items: center; gap: 0.25rem; font-size: 0.85rem; font-weight: 700; background: var(--off-white); border: 1px solid var(--border); padding: 0.25rem; border-radius: 6px; }
.lang-toggle a { color: var(--text-light); text-decoration: none; padding: 0.2rem 0.5rem; border-radius: 4px; transition: all 0.2s; line-height: 1; }
.lang-toggle a::after { display: none; }
.lang-toggle a.active { color: var(--white); background: var(--green); }
.lang-toggle a:hover:not(.active) { color: var(--green); background: rgba(131,160,66,0.1); }
.hamburger { display: none; background: none; border: none; padding: 0.4rem; color: var(--text); cursor: pointer; border-radius: 4px; line-height: 0; }
.hamburger:hover { background: var(--green-bg); }
.hamburger svg { display: block; }
@media (max-width: 1180px) { .nav-links { gap: 1rem; } .nav-links a { font-size: 0.85rem; } .nav-cta { display: none; } }
@media (max-width: 980px) { .nav-links { gap: 0.8rem; } .nav-links a { font-size: 0.8rem; } }

/* ========== HERO ========== */
.hero { padding: 9rem 0 5rem; background: linear-gradient(135deg, var(--green) 0%, var(--green-dark) 100%); position: relative; overflow: hidden; }
.hero::before { content: ''; position: absolute; right: -10%; top: -30%; width: 60%; height: 160%; background: radial-gradient(ellipse, rgba(255,255,255,0.08) 0%, transparent 70%); pointer-events: none; }
.hero::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 80px; background: linear-gradient(to top, rgba(0,0,0,0.1), transparent); pointer-events: none; }
.hero .container { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 1.5rem; position: relative; z-index: 1; }
.hero-content { max-width: 800px; margin: 0 auto; }
.hero h1 { max-width: 750px; color: #fff; text-shadow: 0 2px 4px rgba(0,0,0,0.15); margin-bottom: 1.25rem; }
.hero p { max-width: 600px; font-size: clamp(1.1rem, 2vw, 1.25rem); color: rgba(255,255,255,0.85); margin-bottom: 2rem; }
.hero-actions { display: flex; gap: 0.75rem; margin-top: 0.5rem; justify-content: center; }

/* ========== PARTNER LOGOS ========== */
.partner-logos { padding: 2.5rem 0; border-bottom: 1px solid var(--border); overflow: hidden; position: relative; } /* Removed opaque bg entirely */
.partner-logos .container { text-align: center; }
.partner-label { font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 2.5px; color: var(--text-light); display: block; margin-bottom: 1.5rem; }

.marquee-container { width: 100%; overflow: hidden; position: relative; display: flex; white-space: nowrap; mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent); -webkit-mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent); }
.marquee-track { display: flex; align-items: center; width: max-content; animation: marquee 30s linear infinite; }
.marquee-track:hover { animation-play-state: paused; }
.partner-row { display: flex; align-items: center; padding-right: 4rem; gap: 4rem; flex-shrink: 0; }
.partner-row img { height: 60px; width: auto; max-width: 140px; display: block; object-fit: contain; filter: none; opacity: 1; transition: all 0.3s var(--ease); flex-shrink: 0; }
.partner-row img:hover { transform: scale(1.1); }

@keyframes marquee {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

/* ========== FEATURE CARDS ========== */
.feature-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.25rem; transition: all 0.35s var(--ease); position: relative; overflow: hidden; display: grid; grid-template-columns: 1fr; gap: 0.4rem; align-items: flex-start; }
.feature-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--green); transform: scaleX(0); transition: transform 0.35s var(--ease); }
.feature-card:hover { border-color: var(--green); box-shadow: var(--shadow-md); transform: translateY(-2px); }
.feature-card:hover::before { transform: scaleX(1); }
.feature-icon { grid-column: 1 / 2; grid-row: 1 / 3; font-size: 1.5rem; margin: 0; color: var(--green); line-height: 1.2; }
.feature-card h3 { grid-column: 1 / -1; margin-bottom: 0.25rem; color: var(--blue); }
.feature-card p { grid-column: 1 / -1; color: var(--text-light); font-size: 0.9rem; margin: 0; line-height: 1.5; }

/* ========== CONTENT BLOCKS ========== */
.content-block { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: center; }
.content-block.reverse .content-media { order: -1; }
.content-text .eyebrow { margin-bottom: 0.75rem; }
.content-text h2 { margin-bottom: 1rem; }
.content-text p { color: var(--text-light); font-size: 0.95rem; }
.content-media { border-radius: var(--radius); overflow: hidden; aspect-ratio: 4/3; box-shadow: var(--shadow-md); border: 1px solid var(--border); }
.content-media img { width: 100%; height: 100%; object-fit: cover; }
.map-container { aspect-ratio: 2 / 1 !important; }

/* ========== GREEN SECTION ========== */
.section-green { background: var(--green); color: #fff; position: relative; overflow: hidden; }
.section-green::before { content: ''; position: absolute; top: -50px; right: -50px; width: 200px; height: 200px; border-radius: 50%; background: rgba(255,255,255,0.06); }
.section-green h2 { color: #fff; }
.section-green p { color: rgba(255,255,255,0.85); }
.section-green .eyebrow { color: rgba(255,255,255,0.7); }

/* ========== DYNAMIC MAP ========== */
/* Map architecture rebuilt entirely bypassing fragile CSS background sizing logic. See HTML inline styles for .map-master-wrapper */

.map-node { width: 10px; height: 10px; background: var(--green); border-radius: 50%; box-shadow: 0 0 0 3px rgba(131,160,66,0.2); z-index: 2; cursor: pointer; transition: all 0.3s; }
.map-node::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: var(--green); border-radius: 50%; animation: ping 2.5s cubic-bezier(0, 0, 0.2, 1) infinite; }
.map-node.hq { width: 18px; height: 18px; box-shadow: 0 0 0 5px rgba(131,160,66,0.3); z-index: 3 !important; }

@keyframes ping { 75%, 100% { transform: scale(2.5); opacity: 0; } }

.node-label { position: absolute; bottom: 100%; margin-bottom: 8px; left: 50%; transform: translateX(-50%); background: var(--heading); color: #fff; padding: 0.3rem 0.6rem; border-radius: 4px; font-size: 0.65rem; font-weight: 500; text-align: center; white-space: nowrap; opacity: 0; pointer-events: none; z-index: 10; line-height: 1.3; box-shadow: var(--shadow-md); transition: opacity 0.3s var(--ease); }
.map-node:hover { z-index: 1000 !important; }
.map-node:hover .node-label { opacity: 1; }
.node-label b { font-weight: 700; font-size: 0.75rem; color: var(--green-light); }
.node-label::after { content: ''; position: absolute; bottom: -4px; left: 50%; transform: translateX(-50%); border-width: 4px 4px 0; border-style: solid; border-color: var(--heading) transparent transparent transparent; }
.map-legend { display: none; margin-top: 1rem; flex-wrap: wrap; justify-content: center; gap: 0.5rem 1rem; }
.legend-item { display: inline-flex; align-items: center; gap: 0.4rem; color: var(--text-light); font-weight: 500; font-size: 0.75rem; }
.legend-color { width: 8px; height: 8px; border-radius: 50%; background: var(--green); }
.legend-color.hq { width: 12px; height: 12px; box-shadow: 0 0 0 2px rgba(131,160,66,0.3); }

@media (max-width: 768px) {
    .node-label { display: none !important; }
    .map-legend { display: flex; }
}

/* ========== CTA BANNER ========== */
.cta-banner { background: var(--green); border-radius: var(--radius); padding: 2rem 2.5rem; display: grid; grid-template-columns: 1fr auto; gap: 0.5rem 2rem; align-items: center; text-align: left; }
.cta-banner h2 { grid-column: 1 / 2; margin: 0; font-size: 1.25rem; color: #fff; }
.cta-banner p { grid-column: 1 / 2; margin: 0; color: rgba(255,255,255,0.9); font-size: 0.9rem; }
.cta-banner .btn { grid-column: 2 / 3; grid-row: 1 / 3; }

/* ========== BROCHURE VIEWER ========== */
.brochure-container { position: relative; max-width: 900px; margin: 0 auto; background: var(--white); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); overflow: hidden; display: flex; flex-direction: column; border: 1px solid var(--border); }
.brochure-container.fullscreen { position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; max-width: none; z-index: 9999; border-radius: 0; justify-content: center; background: rgba(0,0,0,0.95); border: none; }
.brochure-view { flex: 1; display: flex; align-items: center; justify-content: center; background: #eef1f5; min-height: 400px; padding: 0.75rem; position: relative; }
.fullscreen .brochure-view { background: transparent; padding: 2rem; min-height: 100vh; }
#brochure-img { max-width: 100%; max-height: 700px; object-fit: contain; box-shadow: var(--shadow-sm); transition: opacity 0.2s ease; }
.fullscreen #brochure-img { max-height: 90vh; }
.brochure-btn { position: absolute; top: 50%; transform: translateY(-50%); width: 36px; height: 36px; border-radius: var(--radius); background: var(--white); border: 1px solid var(--border); box-shadow: var(--shadow-sm); display: flex; align-items: center; justify-content: center; cursor: pointer; z-index: 10; transition: all 0.2s; color: var(--text); }
.brochure-btn:hover { background: var(--green); color: var(--white); border-color: var(--green); }
.brochure-btn.prev-btn { left: 1rem; }
.brochure-btn.next-btn { right: 1rem; }
.fullscreen .brochure-btn { background: rgba(255,255,255,0.1); color: #fff; border-color: rgba(255,255,255,0.2); }
.fullscreen .brochure-btn:hover { background: var(--green); border-color: var(--green); }
.brochure-controls { display: flex; justify-content: space-between; align-items: center; padding: 1rem 1.5rem; background: var(--white); border-top: 1px solid var(--border); z-index: 11; }
.fullscreen .brochure-controls { position: absolute; bottom: 0; left: 0; width: 100%; background: rgba(0,0,0,0.8); border-top: 1px solid rgba(255,255,255,0.1); color: #fff; }
#brochure-counter { font-weight: 600; font-size: 0.9rem; color: var(--text-light); }
.fullscreen #brochure-counter { color: rgba(255,255,255,0.8); }
.fullscreen #brochure-fullscreen { border-color: #fff; color: #fff; }
.fullscreen #brochure-fullscreen:hover { background: #fff; color: var(--text); }

/* ========== CONTACT ========== */
.contact-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: clamp(1.5rem, 4vw, 3rem); }
.contact-info h3 { margin-bottom: 0.5rem; }
.contact-info p { color: var(--text-light); }
.contact-item { display: flex; gap: 0.75rem; margin-bottom: 1.5rem; align-items: flex-start; }
.contact-item-icon { font-size: 1.15rem; color: var(--green); line-height: 1.2; width: 24px; text-align: center; }
.contact-item-text h4 { font-size: 0.85rem; margin-bottom: 0.15rem; }
.contact-item-text p { font-size: 0.8rem; color: var(--text-light); margin: 0; }
.contact-item-text a { color: var(--green); font-weight: 600; }
.contact-item-text a:hover { text-decoration: underline; }
.contact-form { background: var(--white); border: 2px solid var(--border); border-radius: var(--radius-lg); padding: 1.75rem; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-group { margin-bottom: 1.25rem; }
.form-group label { display: block; font-size: 0.875rem; font-weight: 700; color: var(--heading); margin-bottom: 0.5rem; }
.form-control { width: 100%; padding: 0.8rem 1rem; border: 2px solid var(--border); border-radius: 8px; font-family: inherit; font-size: 0.95rem; transition: all 0.2s var(--ease); background: var(--off-white); }
.form-control:focus { outline: none; border-color: var(--green); box-shadow: 0 0 0 4px rgba(131,160,66,0.12); background: var(--white); }
textarea.form-control { min-height: 120px; resize: vertical; }
.phone-input-group { display: flex; gap: 0; }
.phone-input-group .phone-code { flex: 0 0 100px; width: 100px; padding-left: 0.7rem; padding-right: 0.5rem; border-top-right-radius: 0; border-bottom-right-radius: 0; }
.phone-input-group input[type="tel"] { border-top-left-radius: 0; border-bottom-left-radius: 0; border-left: 0; }

/* ========== FOOTER ========== */
.footer { background: linear-gradient(135deg, #1a2a1a 0%, #2D3436 100%); color: rgba(255,255,255,0.6); padding: 3rem 0 1.5rem; margin-top: 0; }
.footer h4 { color: var(--green-light); font-size: 0.85rem; text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 0.75rem; }
.footer a { color: rgba(255,255,255,0.6); transition: color 0.2s; display: inline-block; margin-bottom: 0.5rem; font-size: 0.85rem; }
.footer a:hover { color: var(--green-light); }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 2rem; margin-bottom: 2rem; }
.footer-brand p { margin-top: 0.5rem; font-size: 0.85rem; line-height: 1.5; }
.footer-bottom { padding-top: 1.5rem; border-top: 1px solid rgba(255,255,255,0.08); text-align: center; font-size: 0.8rem; }

/* ========== GREEN ACCENT BAR ========== */
.green-bar { height: 5px; background: linear-gradient(90deg, var(--green), var(--green-light)); }

/* ========== ANIMATIONS ========== */
/* Content is VISIBLE by default — JS adds .js to <html> to enable fade-in.
   This way, if JS fails or is blocked, all content still shows. */
.js [data-animate] { opacity: 0; transform: translateY(24px); transition: opacity 0.7s var(--ease), transform 0.7s var(--ease); }
.js [data-animate].visible { opacity: 1; transform: translateY(0); }
.js [data-animate][data-delay="1"] { transition-delay: 0.15s; }
.js [data-animate][data-delay="2"] { transition-delay: 0.3s; }
.js [data-animate][data-delay="3"] { transition-delay: 0.45s; }

/* ========== FOOTER LOGO ========== */
.footer .logo-img { height: 54px; margin-bottom: 0.65rem; }

/* ========== HERO SLIDER ========== */
.hero-slider { padding: 0 !important; min-height: clamp(420px, 65vh, 640px); position: relative; overflow: hidden; }
.hero-slider .slides { position: absolute; inset: 0; }
.hero-slider .slide { position: absolute; inset: 0; opacity: 0; transition: opacity 1.2s ease-in-out; background-size: cover; background-position: center; }
.hero-slider .slide.active { opacity: 1; }
.hero-slider .slide::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(108,133,53,0.85) 0%, rgba(43,93,169,0.78) 100%); }
.hero-slider .container { position: relative; z-index: 2; padding-top: 7rem; padding-bottom: 4rem; min-height: clamp(420px, 65vh, 640px); display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; }

/* ========== STATS BAR ========== */
.stats-bar { background: linear-gradient(135deg, var(--blue-dark), var(--blue)); padding: 2.5rem 0; color: #fff; }
.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 1.5rem; text-align: center; }
.stat-item { padding: 0.5rem; }
.stat-number { font-size: clamp(2rem, 4vw, 3rem); font-weight: 800; color: #fff; line-height: 1; margin-bottom: 0.35rem; }
.stat-number .plus { color: var(--green-light); }
.stat-label { font-size: 0.85rem; text-transform: uppercase; letter-spacing: 1.5px; color: rgba(255,255,255,0.85); font-weight: 500; }

/* ========== INTRO BLOCK (text + accent image) ========== */
.intro-block { display: grid; grid-template-columns: 1.2fr 1fr; gap: 2.5rem; align-items: center; }
.intro-block.reverse > div:first-child { order: 2; }
@media (max-width: 800px) { .intro-block { grid-template-columns: 1fr; } .intro-block.reverse > div:first-child { order: 0; } }
.intro-block .intro-art { border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-lg); aspect-ratio: 4/3; }
.intro-block .intro-art img { width: 100%; height: 100%; object-fit: cover; }

/* ========== SERVICES LIST (logistics/consulting) ========== */
.svc-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1rem; }
.svc-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.5rem; transition: all 0.3s var(--ease); position: relative; overflow: hidden; }
.svc-card::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--green); transform: scaleY(0); transform-origin: bottom; transition: transform 0.35s var(--ease); }
.svc-card:hover { border-color: var(--green); box-shadow: var(--shadow-md); transform: translateY(-2px); }
.svc-card:hover::before { transform: scaleY(1); transform-origin: top; }
.svc-card h3 { font-size: 1.05rem; margin-bottom: 0.5rem; color: var(--blue); }
.svc-card p { color: var(--text-light); font-size: 0.9rem; margin: 0; line-height: 1.55; }
.svc-card .svc-icon { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 8px; background: rgba(131,160,66,0.12); color: var(--green); font-size: 1.15rem; margin-bottom: 0.85rem; }

/* ========== CHECK LIST ========== */
.check-list { list-style: none; padding: 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 0.6rem 1rem; }
.check-list li { display: flex; gap: 0.6rem; align-items: flex-start; padding: 0.55rem 0; font-size: 0.9rem; color: var(--text); }
.check-list li::before { content: '✓'; color: var(--green); font-weight: 800; flex-shrink: 0; width: 22px; height: 22px; display: inline-flex; align-items: center; justify-content: center; background: rgba(131,160,66,0.12); border-radius: 50%; font-size: 0.75rem; }

/* ========== TAG GRID (industries) ========== */
.tag-grid { display: grid; grid-template-columns: repeat(4, auto); gap: 0.6rem; justify-content: center; justify-items: center; }
@media (max-width: 900px) { .tag-grid { grid-template-columns: repeat(3, auto); } }
@media (max-width: 600px) { .tag-grid { grid-template-columns: repeat(2, auto); } }
.tag-pill { padding: 0.5rem 1.1rem; background: var(--white); border: 1px solid var(--border); border-radius: 999px; font-size: 0.85rem; color: var(--text); transition: all 0.2s; }
.tag-pill:hover { border-color: var(--green); color: var(--green-dark); background: rgba(131,160,66,0.06); transform: translateY(-1px); }

/* ========== PROCESS STEPS ========== */
.process-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1rem; }
.process-step { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.5rem 1.25rem; position: relative; }
.process-step:hover { border-color: var(--green); transform: translateY(-2px); transition: all 0.3s; }
.step-num { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border-radius: 50%; background: var(--green); color: #fff; font-weight: 800; font-size: 1.1rem; margin-bottom: 0.85rem; }
.process-step h3 { font-size: 1rem; margin-bottom: 0.4rem; color: var(--blue); }
.process-step p { color: var(--text-light); font-size: 0.875rem; margin: 0; line-height: 1.55; }

/* ========== BIG DOWNLOAD CTA (catalogue) ========== */
.download-card { background: var(--white); border: 2px solid var(--green); border-radius: var(--radius-lg); padding: 2rem; display: grid; grid-template-columns: 1fr auto; gap: 1.5rem; align-items: center; box-shadow: var(--shadow-md); }
.download-card-icon { width: 64px; height: 64px; background: var(--green-bg); border-radius: var(--radius); display: inline-flex; align-items: center; justify-content: center; font-size: 1.75rem; color: var(--green); }
.download-card h3 { color: var(--blue); margin-bottom: 0.25rem; font-size: 1.15rem; }
.download-card p { margin: 0; font-size: 0.9rem; color: var(--text-light); }
@media (max-width: 640px) {
  .download-card { grid-template-columns: 1fr; text-align: center; padding: 1.5rem; }
  .download-card-icon { margin: 0 auto; }
}

/* ========== BRAND HERO CARDS (Products) ========== */
.brand-hero-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
@media (max-width: 720px) { .brand-hero-grid { grid-template-columns: 1fr; } }
.brand-hero { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; transition: all 0.35s var(--ease); display: flex; flex-direction: column; }
.brand-hero:hover { border-color: var(--green); box-shadow: var(--shadow-md); transform: translateY(-3px); }
.brand-hero .brand-img { aspect-ratio: 16/10; background: var(--off-white); display: flex; align-items: center; justify-content: center; padding: 1.25rem; border-bottom: 1px solid var(--border); overflow: hidden; }
.brand-hero .brand-img img { max-width: 80%; max-height: 80%; object-fit: contain; transition: transform 0.4s; }
.brand-hero:hover .brand-img img { transform: scale(1.06); }
.brand-hero .brand-body { padding: 1.25rem 1.5rem; flex: 1; display: flex; flex-direction: column; }
.brand-hero h3 { color: var(--blue); margin-bottom: 0.4rem; }
.brand-hero p { color: var(--text-light); font-size: 0.9rem; line-height: 1.55; flex: 1; }
.brand-hero .brand-tags { display: flex; flex-wrap: wrap; gap: 0.35rem; margin-top: 0.85rem; }
.brand-hero .brand-tag { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 1px; color: var(--green-dark); background: var(--green-bg); padding: 0.2rem 0.55rem; border-radius: 4px; font-weight: 600; }

/* ========== PARTNER SHOWCASE GRID (Partners page) ========== */
.partner-showcase { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 1.25rem; }
.partner-tile { position: relative; aspect-ratio: 4/3; background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.5rem; display: flex; align-items: center; justify-content: center; transition: transform 0.4s var(--ease), box-shadow 0.4s var(--ease), border-color 0.3s; overflow: hidden; }
.partner-tile::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(131,160,66,0.06), rgba(43,93,169,0.06)); opacity: 0; transition: opacity 0.4s var(--ease); pointer-events: none; }
.partner-tile::after { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--green), var(--blue)); transform: scaleX(0); transform-origin: left; transition: transform 0.45s var(--ease); }
.partner-tile:hover { border-color: var(--green); transform: translateY(-6px); box-shadow: 0 12px 32px rgba(0,0,0,0.08); }
.partner-tile:hover::before { opacity: 1; }
.partner-tile:hover::after { transform: scaleX(1); }
.partner-tile img { position: relative; z-index: 1; max-height: 75%; max-width: 85%; object-fit: contain; transition: transform 0.45s var(--ease); }
.partner-tile:hover img { transform: scale(1.08); }
.partner-tile.has-flag::after { background: linear-gradient(90deg, var(--green), var(--blue)); }
.partner-flag { position: absolute; top: 0.75rem; right: 0.75rem; font-size: 1.1rem; line-height: 1; opacity: 0.8; z-index: 2; }

/* ========== GEOGRAPHY STRIP ========== */
.geo-strip { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 0.75rem; margin-top: 1.5rem; }
.geo-item { background: rgba(255,255,255,0.5); border: 1px solid var(--border); border-radius: var(--radius); padding: 1rem 1.25rem; display: flex; gap: 0.75rem; align-items: center; transition: all 0.3s; }
.geo-item:hover { background: var(--white); border-color: var(--green); transform: translateY(-2px); }
.geo-item .geo-flag { font-size: 1.5rem; line-height: 1; }
.geo-item .geo-meta { display: flex; flex-direction: column; }
.geo-item .geo-name { font-weight: 700; font-size: 0.9rem; color: var(--blue); line-height: 1.2; }
.geo-item .geo-sub { font-size: 0.75rem; color: var(--text-light); margin-top: 2px; }

/* ========== BRAND SPOTLIGHT (Partners page) ========== */
/* flex (not grid) so the last row centers when not full */
.brand-spotlight-grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 1.25rem; }
.brand-spotlight-grid .brand-spot { flex: 1 1 280px; max-width: 360px; }
.brand-spot { position: relative; background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; transition: transform 0.45s var(--ease), box-shadow 0.45s var(--ease); display: flex; flex-direction: column; }
.brand-spot::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: var(--accent-color, var(--green)); transform: scaleX(0); transform-origin: left; transition: transform 0.55s var(--ease); }
.brand-spot:hover { transform: translateY(-6px); box-shadow: 0 16px 36px rgba(0,0,0,0.10); }
.brand-spot:hover::before { transform: scaleX(1); }
.brand-spot .spot-logo { aspect-ratio: 16/10; padding: 1.5rem; display: flex; align-items: center; justify-content: center; background: var(--off-white); border-bottom: 1px solid var(--border); position: relative; overflow: hidden; }
.brand-spot .spot-logo::after { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at center, transparent 50%, var(--accent-color, var(--green-bg)) 200%); opacity: 0; transition: opacity 0.5s var(--ease); }
.brand-spot:hover .spot-logo::after { opacity: 0.18; }
.brand-spot .spot-logo img { max-width: 75%; max-height: 80%; object-fit: contain; transition: transform 0.5s var(--ease); position: relative; z-index: 1; }
.brand-spot:hover .spot-logo img { transform: scale(1.06); }
.brand-spot .spot-body { padding: 1.5rem; display: flex; flex-direction: column; flex: 1; }
.brand-spot .spot-title-row { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 0.4rem; gap: 0.5rem; }
.brand-spot h3 { color: var(--blue); margin: 0; font-size: 1.2rem; }
.brand-spot .spot-origin { font-size: 0.7rem; color: var(--accent-color, var(--green-dark)); font-weight: 700; text-transform: uppercase; letter-spacing: 1px; padding: 0.2rem 0.55rem; border: 1px solid currentColor; border-radius: 999px; opacity: 0.8; }
.brand-spot .spot-tagline { color: var(--text-light); font-size: 0.92rem; line-height: 1.55; margin: 0 0 1rem; flex: 1; }
.brand-spot .spot-tags { display: flex; flex-wrap: wrap; gap: 0.3rem; margin-bottom: 1rem; }
.brand-spot .spot-tag { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.5px; color: var(--accent-color, var(--green-dark)); background: var(--green-bg); padding: 0.22rem 0.55rem; border-radius: 4px; font-weight: 600; }
.brand-spot .spot-cta { color: var(--accent-color, var(--green-dark)); font-weight: 600; font-size: 0.88rem; text-decoration: none; display: inline-flex; align-items: center; gap: 0.3rem; transition: gap 0.25s; }
.brand-spot:hover .spot-cta { gap: 0.55rem; }

/* Brand-specific color tokens (set inline via style="--accent-color: …") */

/* ========== CHANNELS BY REGION ========== */
.channel-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.25rem; max-width: 900px; margin: 0 auto; }
@media (max-width: 720px) { .channel-grid { grid-template-columns: 1fr; } }
.channel-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.5rem; transition: all 0.4s var(--ease); }
.channel-card:hover { border-color: var(--green); transform: translateY(-3px); box-shadow: var(--shadow-md); }
.channel-card .channel-head { display: flex; align-items: center; gap: 0.7rem; margin-bottom: 0.85rem; padding-bottom: 0.85rem; border-bottom: 1px solid var(--border); }
.channel-card .channel-flag { font-size: 1.75rem; line-height: 1; }
.channel-card .channel-region { font-weight: 700; color: var(--blue); font-size: 1.05rem; line-height: 1.2; }
.channel-card .channel-sub { font-size: 0.75rem; color: var(--text-light); font-weight: 500; text-transform: uppercase; letter-spacing: 1px; margin-top: 2px; }
.channel-card ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.4rem; }
.channel-card li { font-size: 0.88rem; color: var(--text); display: flex; align-items: center; gap: 0.5rem; }
.channel-card li::before { content: ''; flex-shrink: 0; width: 5px; height: 5px; border-radius: 50%; background: var(--green); display: inline-block; }

/* ========== TESTIMONIAL CARD ========== */
.testimonial { background: linear-gradient(135deg, rgba(131,160,66,0.08), rgba(43,93,169,0.06)); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 2rem 2.5rem; position: relative; max-width: 760px; margin: 0 auto; }
.testimonial::before { content: '"'; position: absolute; top: -10px; left: 1.5rem; font-size: 6rem; color: var(--green); line-height: 1; font-family: Georgia, serif; opacity: 0.2; }
.testimonial blockquote { font-size: 1.15rem; line-height: 1.6; color: var(--text); font-style: italic; margin: 0 0 1rem; position: relative; z-index: 1; }
.testimonial cite { display: block; font-style: normal; color: var(--text-light); font-size: 0.9rem; }
.testimonial cite strong { color: var(--blue); font-weight: 700; }

/* ========== SOCIAL ROW ========== */
/* No wrapper circle — let brand glyphs stand on their own */
.social-row { display: flex; flex-wrap: wrap; gap: 0.6rem; align-items: center; }
.social-link { display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; border: 0; background: transparent; transition: transform 0.25s var(--ease), filter 0.25s var(--ease); }
.social-link svg, .social-link img { width: 32px; height: 32px; display: block; transition: transform 0.25s var(--ease); }
.social-link:hover { transform: translateY(-3px); }
.social-link:hover svg, .social-link:hover img { transform: scale(1.05); filter: drop-shadow(0 4px 8px rgba(0,0,0,0.25)); }
.footer .social-link[aria-label="Lazada"] img { filter: brightness(0) invert(1); }
.footer .social-link[aria-label="Lazada"]:hover img { filter: brightness(0) invert(1) drop-shadow(0 4px 8px rgba(0,0,0,0.25)); }

/* light theme variant (contact-info section on white bg) — same scheme works */
.contact-info .social-row .social-link { background: transparent; border: 0; }

/* ========== ENHANCED FOOTER ========== */
.footer-grid { grid-template-columns: 1.6fr 1fr 1fr 1fr; }
.footer .social-row { margin-top: 0.85rem; }

/* ========== EMBEDDED MAP (contact) ========== */
.contact-map { width: 100%; aspect-ratio: 16/9; border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--border); box-shadow: var(--shadow-sm); margin-top: 1rem; }
.contact-map iframe { width: 100%; height: 100%; border: 0; }

/* ========== OFFICE CARDS (3 locations) ========== */
.office-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1rem; }
.office-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.25rem; text-align: center; transition: all 0.3s; }
.office-card:hover { border-color: var(--green); transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.office-card .office-flag { font-size: 1.75rem; margin-bottom: 0.5rem; }
.office-card h4 { color: var(--blue); font-size: 1rem; margin-bottom: 0.35rem; }
.office-card p { color: var(--text-light); font-size: 0.8rem; margin: 0; line-height: 1.5; }

/* ========== TWO-COL FEATURE SECTION ========== */
.section-light { background: var(--off-white); }

/* ========== MOBILE ========== */
@media (max-width: 1024px) {
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .hamburger { display: block; }
  .nav-links { display: none; }
  .nav-cta { display: none; }
  .lang-toggle { display: none; }
  .navbar.is-open { height: auto; }
  .navbar.is-open .nav-inner { height: auto; flex-wrap: wrap; row-gap: 0.75rem; padding-bottom: 1rem; }
  .navbar.is-open .nav-actions { margin-left: auto; }
  .navbar.is-open .lang-toggle { display: inline-flex; }
  .navbar.is-open .nav-links { display: flex; flex-direction: column; align-items: stretch; order: 99; width: 100%; gap: 0.25rem; padding-top: 0.75rem; border-top: 1px solid var(--border); }
  .navbar.is-open .nav-links a { padding: 0.65rem 0.5rem; font-size: 0.95rem; }
  .navbar.is-open .nav-links a::after { display: none; }
  .hero { padding: calc(100px + 2rem) 0 2rem; }
  .hero-actions { flex-direction: column; width: 100%; }
  .hero-actions .btn { width: 100%; justify-content: center; }
  .grid-2, .grid-3 { grid-template-columns: 1fr; }
  .content-block { grid-template-columns: 1fr; }
  .content-block.reverse .content-media { order: 0; }
  .