@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=Inter:wght@300;400;500;600;700&display=swap');
:root {
  --green: #1a5c38;
  --green-dark: #0f3d24;
  --green-light: #e8f5e9;
  --white: #ffffff;
  --off-white: #f7f9f4;
  --orange: #e8772e;
  --orange-hover: #d4641a;
  --text-dark: #1a1a1a;
  --text-mid: #555;
  --text-light: #888;
  --serif: 'DM Serif Display', serif;
  --sans: 'Inter', sans-serif;
  --radius: 8px;
  --radius-sm: 4px;
  --radius-lg: 12px;
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
.hidden { display: none !important; }
html { scroll-behavior:smooth; overflow-x:hidden; width:100%; position:relative; }
body { font-family:var(--sans); color:var(--text-dark); background:var(--white); line-height:1.6; overflow-x:hidden; width:100%; position:relative; }
h1,h2,h3 { font-family:var(--serif); font-weight:400; }
em { font-family:var(--serif); font-style:italic; }
a { text-decoration:none; color:inherit; }
img { max-width:100%; display:block; }
.section-tag { color:var(--green); font-weight:600; text-transform:uppercase; letter-spacing:2px; font-size:.85rem; margin-bottom:1rem; }
.section-subheading { font-family: var(--serif); font-size: 1.8rem; color: var(--green-dark); margin-top: 1.5rem; margin-bottom: 1rem; }
.section-subheading-lg { font-family: var(--serif); font-size: 2rem; color: var(--green-dark); margin-bottom: 1.5rem; }
.flex-col-gap-2 { display: flex; flex-direction: column; gap: 2rem; }
.text-mid-lg { color: var(--text-mid); font-size: 1.1rem; }
.whatsapp-btn-wrapper { padding: 0 15px 10px; text-align: center; }
.whatsapp-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; background: #25D366; color: white; padding: 10px 20px; border-radius: var(--radius); text-decoration: none; font-size: 0.9rem; font-weight: 500; width: 100%; transition: opacity 0.3s; }
.whatsapp-btn:hover { opacity: 0.9; }
.hidden { display: none !important; }

/* BUTTONS */
.btn-cta { display:inline-flex; align-items:center; gap:6px; background:var(--orange); color:#fff; padding:.9rem 2rem; border-radius:var(--radius); font-weight:600; font-size:.95rem; border:none; cursor:pointer; transition:all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275); position: relative; overflow: hidden; }
.btn-cta::after { content: ''; position: absolute; top: 0; left: -100%; width: 50%; height: 100%; background: linear-gradient(to right, rgba(255,255,255,0) 0%, rgba(255,255,255,0.3) 50%, rgba(255,255,255,0) 100%); transform: skewX(-25deg); transition: all 0.7s ease; }
.btn-cta:hover { background:var(--orange-hover); transform:translateY(-4px) scale(1.02); box-shadow:0 12px 24px rgba(232,119,46,.4); }
.btn-cta:hover::after { left: 200%; }
.btn-outline { display:inline-flex; align-items:center; gap:6px; background:transparent; color:#fff; padding:.9rem 2rem; border-radius:var(--radius); font-weight:600; font-size:.95rem; border:2px solid rgba(255,255,255,.5); cursor:pointer; transition:all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275); }
.btn-outline:hover { background:#fff; color:var(--green-dark); border-color:#fff; transform:translateY(-4px); box-shadow:0 10px 20px rgba(255,255,255,.2); }
.btn-outline-dark { display:inline-block; background:transparent; color:var(--text-dark); padding:.8rem 2rem; border-radius:var(--radius); font-weight:600; border:2px solid #ddd; cursor:pointer; transition:all .3s; text-align:center; }
.btn-outline-dark:hover { border-color:var(--text-dark); }
.btn-full { width:100%; justify-content:center; text-align:center; }

/* TOP BAR */
.top-bar { background:var(--green-dark); color:rgba(255,255,255,.85); font-size:.78rem; padding:.5rem 5%; z-index:1001; position:fixed; top:0; width:100%; transition:transform .4s ease; }
.top-bar-inner { display:flex; justify-content:space-between; align-items:center; max-width:1400px; margin:auto; }
.top-bar-left, .top-bar-right { display:flex; align-items:center; gap:.6rem; }
.top-bar-divider { opacity:.4; }

/* NAVBAR */
.navbar { position:fixed; top:32px; width:100%; padding:1rem 5%; display:flex; justify-content:space-between; align-items:center; z-index:1000; transition:all .4s; }
.navbar.scrolled { background:rgba(15,61,36,0.95); -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px); box-shadow:0 4px 20px rgba(0,0,0,.15); padding:.8rem 5%; top:0; }
.navbar.hidden { transform: translateY(-100%); }
.logo { display:flex; align-items:center; text-decoration: none; margin-right: 4rem; }
.nav-logo-img { height: 50px; width: auto; object-fit: contain; mix-blend-mode: screen; border-radius: 5px; }
.nav-links { display:flex; gap:2rem; list-style:none; }
.nav-links a { color:rgba(255,255,255,.8); font-size:.95rem; font-weight:500; transition:all .3s; position:relative; display: inline-block; }
.nav-links a:hover, .nav-links a.nav-active { color:#fff; transform: translateY(-2px); }
.nav-links a.nav-active::after { content:''; position:absolute; bottom:-4px; left:0; width:100%; height:2px; background:var(--orange); border-radius:2px; }
.nav-cta { font-size:.85rem; padding:.7rem 1.5rem; }
.hamburger { display:none; background:none; border:none; cursor:pointer; flex-direction:column; gap:5px; }
.hamburger span { width:24px; height:2px; background:#fff; transition:all .3s; }

/* HERO */
@keyframes slowZoom { 0% { transform: scale(1); } 100% { transform: scale(1.12); } }
.hero { position:relative; min-height:100vh; display:flex; flex-direction:column; justify-content:center; padding:12rem 5% 2rem; overflow:hidden; }
.hero-bg-img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; animation: slowZoom 25s linear infinite alternate; }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(135deg, rgba(15,61,36,.92) 0%, rgba(26,92,56,.75) 50%, rgba(15,61,36,.6) 100%); z-index:1; }
.hero-content { position:relative; z-index:2; max-width:700px; color:#fff; }
.hero-tag { font-size:.9rem; font-weight:600; letter-spacing:1px; margin-bottom:1.5rem; opacity:.9; }
.hero h1 { font-size:clamp(2.5rem,5.5vw,4.5rem); line-height:1.1; margin-bottom:1.5rem; }
.hero-desc { font-size:1.05rem; line-height:1.8; opacity:.85; max-width:550px; margin-bottom:2.5rem; }
.hero-actions { display:flex; gap:1rem; flex-wrap:wrap; }
.stats-ribbon { position:relative; z-index:2; display:flex; justify-content:space-around; background:rgba(255,255,255,.1); -webkit-backdrop-filter:blur(15px); backdrop-filter:blur(15px); border:1px solid rgba(255,255,255,.15); border-radius:var(--radius-lg); padding:2rem; margin-top:auto; max-width:900px; color:#fff; }
.stat { text-align:center; }
.stat-num { font-family:var(--serif); font-size:2.5rem; color:var(--orange); }
.stat-suffix { font-family:var(--serif); font-size:1.8rem; color:var(--orange); }
.stat-label { display:block; font-size:.85rem; opacity:.8; margin-top:4px; }

/* ABOUT */
.about { padding:6rem 5%; background:var(--off-white); }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; max-width:1200px; margin:auto; }
.about-img-wrapper { position:relative; border-radius:var(--radius-lg); overflow:hidden; }
.about-img-wrapper img { width:100%; height:500px; object-fit:cover; transition: transform 0.8s cubic-bezier(0.25, 0.8, 0.25, 1); }
.about-img-wrapper:hover img { transform: scale(1.05); }
.about-badge { position:absolute; bottom:20px; right:20px; background:var(--orange); color:#fff; padding:1.2rem 1.5rem; border-radius:var(--radius); text-align:center; }
.badge-num { display:block; font-family:var(--serif); font-size:2rem; }
.badge-text { font-size:.75rem; line-height:1.3; }
.about-text h2 { font-size:clamp(2rem,4vw,3rem); line-height:1.15; margin-bottom:1.5rem; }
.about-text > p { color:var(--text-mid); margin-bottom:1rem; }
.cert-badges { display:flex; gap:.8rem; margin:1.5rem 0 2rem; flex-wrap:wrap; }
.cert { background:var(--green); color:#fff; padding:.5rem 1.2rem; border-radius:var(--radius-sm); font-size:.8rem; font-weight:600; letter-spacing:1px; }

/* PRODUCTS */
.products { padding:6rem 5%; background:var(--white); }
.products-header { text-align:center; max-width:600px; margin:0 auto 4rem; }
.products-header h2 { font-size:clamp(2rem,4vw,3rem); line-height:1.15; margin-bottom:1rem; }
.products-subtitle { color:var(--text-mid); }
.product-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:2rem; max-width:1200px; margin:auto; }
.product-card { background:var(--off-white); border-radius:var(--radius-lg); overflow:hidden; transition:all 0.5s cubic-bezier(0.25, 0.8, 0.25, 1); border:1px solid #eee; }
.product-card:hover { transform:translateY(-8px); border-color:var(--green); box-shadow:0 20px 40px rgba(0,0,0,.1); }
.product-card-img { height:220px; overflow:hidden; position:relative; display:block; }
.product-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .8s cubic-bezier(0.25, 0.8, 0.25, 1); }
.product-card:hover .product-card-img img { transform:scale(1.15); }
.product-img-overlay { position:absolute; inset:0; background:rgba(15,61,36,0.55); display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity 0.3s; }
.product-img-overlay span { color:#fff; font-weight:600; font-size:1rem; letter-spacing:0.5px; background:rgba(0,0,0,0.25); padding:0.6rem 1.5rem; border-radius:var(--radius); -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px); border:1px solid rgba(255,255,255,0.3); }
.product-card:hover .product-img-overlay { opacity:1; }
.product-card-body { padding:1.5rem; }
.product-card-body h3 { font-size:1.3rem; margin-bottom:.5rem; }
.product-tag { display:inline-block; background:var(--green-light); color:var(--green); font-size:.75rem; font-weight:600; padding:.3rem .8rem; border-radius:var(--radius-sm); margin-bottom:.8rem; }
.product-card-body p { color:var(--text-mid); font-size:.9rem; margin-bottom:1.2rem; line-height:1.6; }
.product-btn { background:var(--green); color:#fff; border:none; padding:.7rem 1.5rem; border-radius:var(--radius); font-weight:600; font-size:.85rem; cursor:pointer; transition:all .3s; width:100%; }
.product-btn:hover { background:var(--green-dark); }

/* SKELETON LOADING */
@keyframes shimmer {
  0%   { background-position: -600px 0; }
  100% { background-position: 600px 0; }
}
.skeleton-base {
  background: linear-gradient(90deg, #e8ede9 25%, #d5e2d7 50%, #e8ede9 75%);
  background-size: 600px 100%;
  animation: shimmer 1.6s infinite linear;
  border-radius: var(--radius-sm);
}
.product-card-skeleton {
  background: var(--off-white);
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid #eee;
}
.skeleton-img {
  height: 220px;
  width: 100%;
}
.skeleton-body {
  padding: 1.5rem;
}
.skeleton-tag {
  height: 22px;
  width: 90px;
  margin-bottom: 0.8rem;
}
.skeleton-title {
  height: 26px;
  width: 75%;
  margin-bottom: 0.6rem;
}
.skeleton-price {
  height: 20px;
  width: 50%;
  margin-bottom: 0.6rem;
}
.skeleton-text {
  height: 14px;
  width: 100%;
  margin-bottom: 0.4rem;
}
.skeleton-text-short {
  height: 14px;
  width: 70%;
  margin-bottom: 1.2rem;
}
.skeleton-btns {
  display: flex;
  gap: 0.5rem;
}
.skeleton-btn {
  height: 38px;
  flex: 1;
  border-radius: var(--radius);
}
/* Fade-in for real cards after skeleton */
.product-card {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.product-card.card-visible {
  opacity: 1;
  transform: translateY(0);
}
/* Override: small mobile keeps grid intact */
@media(max-width:480px) {
  .skeleton-img { height: 120px; }
  .skeleton-btn { height: 30px; }
}

/* LOGISTICS */
.logistics { padding:6rem 5%; background:var(--green-dark); color:#fff; }
.logistics-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; max-width:1200px; margin:auto; }
.logistics-text h2 { font-size:clamp(2rem,4vw,3rem); line-height:1.15; margin-bottom:1.5rem; }
.logistics-text .section-tag { color:var(--orange); }
.logistics-text > p { opacity:.8; margin-bottom:2rem; }
.logistics-features { display:flex; flex-direction:column; gap:1.5rem; }
.lf-item { display:flex; gap:1rem; align-items:flex-start; }
.lf-icon { font-size:1.8rem; flex-shrink:0; }
.lf-item strong { display:block; margin-bottom:2px; }
.lf-item p { font-size:.85rem; opacity:.7; margin:0; }
.logistics-img-wrapper { border-radius:var(--radius-lg); overflow:hidden; }
.logistics-img-wrapper img { width:100%; height:450px; object-fit:cover; transition: transform 0.8s cubic-bezier(0.25, 0.8, 0.25, 1); }
.logistics-img-wrapper:hover img { transform: scale(1.05); }

/* CONTACT */
.contact { padding:6rem 5%; background:var(--off-white); }
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; max-width:1100px; margin:auto; align-items:start; }
.contact-info h2 { font-size:clamp(2rem,4vw,3rem); line-height:1.15; margin-bottom:1rem; }
.contact-info > p { color:var(--text-mid); margin-bottom:2rem; }
.contact-details { display:flex; flex-direction:column; gap:1rem; }
.cd-item { display:flex; align-items:center; gap:12px; font-size:.95rem; }
.cd-item span { font-size:1.3rem; }
.cd-item a, .cd-item p { color:var(--text-mid); margin:0; }
.contact-form-wrapper { background:#fff; padding:2.5rem; border-radius:var(--radius-lg); box-shadow:0 10px 40px rgba(0,0,0,.06); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-group { margin-bottom:1.2rem; }
.form-group label { display:block; font-weight:600; font-size:.85rem; margin-bottom:6px; color:var(--text-dark); }
.form-control { width:100%; padding:.8rem 1rem; border:1px solid rgba(15,61,36,.2); border-radius:var(--radius-sm); font-family:inherit; font-size:.95rem; outline:none; transition:border-color .3s; }
.form-control:focus { border-color:var(--green); }
textarea.form-control { min-height:110px; resize:vertical; }
.checkbox-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0.8rem; margin-top: 0.5rem; }
.checkbox-label { display: flex; align-items: center; gap: 8px; font-size: 0.9rem; cursor: pointer; color: #333; }
.checkbox-label input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--green); cursor: pointer; }

/* FOOTER */
.footer { background:var(--green-dark); color:#fff; padding:4rem 5% 2rem; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr 1fr; gap:3rem; max-width:1200px; margin:auto; padding-bottom:3rem; border-bottom:1px solid rgba(255,255,255,.15); }
.footer-brand p { opacity:.7; margin-top:1rem; font-size:.9rem; line-height:1.7; max-width:300px; }
.footer-logo-img { height: 65px; width: auto; object-fit: contain; margin-bottom: 0.5rem; border-radius: 4px; }
.footer-col h4 { font-size:1rem; margin-bottom:1rem; font-family:var(--sans); }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:.6rem; }
.footer-col a { opacity:.7; font-size:.9rem; transition:opacity .3s, color .3s; position: relative; display: inline-block; }
.footer-col a::after { content: ''; position: absolute; width: 0; height: 2px; bottom: -2px; left: 0; background-color: var(--orange); transition: width 0.3s ease; }
.footer-col a:hover { opacity:1; color:var(--orange); }
.footer-col a:hover::after { width: 100%; }
.footer-bottom { text-align:center; padding-top:2rem; max-width:1200px; margin:auto; }
.footer-bottom p { opacity:.5; font-size:.85rem; }

/* CHATBOT */
.chatbot-toggle { position:fixed; bottom:30px; right:30px; width:60px; height:60px; background:var(--green); border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; box-shadow:0 6px 25px rgba(26,92,56,.4); z-index:1001; border:none; transition:all .3s; }
.chatbot-toggle:hover { transform:scale(1.1); background:var(--green-dark); }
.chatbot-window { position:fixed; bottom:100px; right:30px; width:370px; height:520px; background:#fff; border-radius:var(--radius-lg); box-shadow:0 15px 50px rgba(0,0,0,.2); display:flex; flex-direction:column; z-index:1001; opacity:0; pointer-events:none; transform:translateY(20px) scale(.95); transition:all .3s; overflow:hidden; }
.chatbot-window.active { opacity:1; pointer-events:all; transform:translateY(0) scale(1); }
.chat-header { padding:1rem 1.2rem; background:var(--green); color:#fff; display:flex; justify-content:space-between; align-items:center; }
.chat-header-info { display:flex; align-items:center; gap:10px; }
.chat-avatar { width:36px; height:36px; background:rgba(255,255,255,.2); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.2rem; }
.chat-status { font-size:.75rem; color:#8eff8e; }
.close-chat { background:none; border:none; color:#fff; font-size:1.8rem; cursor:pointer; line-height:1; }
.chat-body { flex-grow:1; padding:1rem; overflow-y:auto; display:flex; flex-direction:column; gap:.8rem; background:#f9f9f9; }
.chat-message { max-width:80%; padding:.8rem 1rem; border-radius:16px; font-size:.88rem; line-height:1.5; }
.chat-message p { margin:0 0 4px; }
.chat-message p:last-child { margin:0; }
.chat-message.bot { background:#fff; align-self:flex-start; border:1px solid #eee; border-bottom-left-radius:4px; color:var(--text-dark); }
.chat-message.user { background:var(--green); color:#fff; align-self:flex-end; border-bottom-right-radius:4px; }
.chat-quick-replies { display:flex; gap:6px; padding:.6rem 1rem; overflow-x:auto; background:#fff; border-top:1px solid #eee; }
.quick-btn { background:var(--green-light); color:var(--green); border:none; padding:.5rem .8rem; border-radius:var(--radius); font-size:.78rem; font-weight:600; cursor:pointer; white-space:nowrap; transition:all .2s; }
.quick-btn:hover { background:var(--green); color:#fff; }
.chat-input { display:flex; padding:.8rem; border-top:1px solid #eee; background:#fff; gap:8px; }
.chat-input input { flex-grow:1; border:1px solid #ddd; padding:.7rem 1rem; border-radius:var(--radius); font-family:inherit; font-size:.9rem; outline:none; }
.chat-input input:focus { border-color:var(--green); }
.chat-input button { width:40px; height:40px; background:var(--green); border:none; border-radius:50%; cursor:pointer; color:#fff; display:flex; align-items:center; justify-content:center; transition:background .3s; flex-shrink:0; }
.chat-input button:hover { background:var(--green-dark); }

/* CHATBOT PRODUCT CHECKBOXES */
.chat-product-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; margin: 10px 0; }
.chat-checkbox-label { display: flex; align-items: center; gap: 6px; font-size: 0.82rem; cursor: pointer; padding: 6px 8px; border-radius: 8px; border: 1px solid #e0e0e0; transition: all 0.2s; background: #fafafa; }
.chat-checkbox-label:hover { border-color: var(--green); background: var(--green-light); }
.chat-checkbox-label:has(input:checked) { border-color: var(--green); background: var(--green-light); font-weight: 600; color: var(--green); }
.chat-product-cb { width: 14px; height: 14px; accent-color: var(--green); cursor: pointer; }
.chat-product-submit { width: 100%; padding: 8px; margin-top: 8px; background: var(--green); color: #fff; border: none; border-radius: 10px; font-size: 0.82rem; font-weight: 600; cursor: pointer; transition: all 0.3s; font-family: inherit; }
.chat-product-submit:hover { background: var(--green-dark); }

/* MODAL */
.modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.6); display:flex; align-items:center; justify-content:center; z-index:2000; opacity:0; pointer-events:none; transition:all .3s; -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px); }
.modal-overlay.active { opacity:1; pointer-events:all; }
.modal-content { background:#fff; padding:2.5rem; border-radius:var(--radius-lg); width:90%; max-width:420px; text-align:center; position:relative; }
.modal-close { position:absolute; top:15px; right:20px; background:none; border:none; font-size:1.5rem; cursor:pointer; color:var(--text-light); }
.modal-icon { font-size:3rem; margin-bottom:1rem; }
.modal-content h3 { font-size:1.5rem; margin-bottom:.8rem; }
.modal-content > p { color:var(--text-mid); font-size:.9rem; margin-bottom:1.5rem; }
.modal-actions { display:flex; flex-direction:column; gap:.8rem; }

/* CHATBOT TYPING INDICATOR */
.typing-indicator p { display:flex; gap:4px; align-items:center; padding:4px 0; }
.typing-indicator .dot { width:8px; height:8px; border-radius:50%; background:var(--text-light); animation:dotBounce 1.4s infinite ease-in-out; }
.typing-indicator .dot:nth-child(2) { animation-delay:0.2s; }
.typing-indicator .dot:nth-child(3) { animation-delay:0.4s; }
@keyframes dotBounce { 0%,80%,100% { transform:scale(0.6); opacity:0.4; } 40% { transform:scale(1); opacity:1; } }

/* LANGUAGE PICKER */
.lang-picker { position:relative; margin-left:auto; margin-right:1rem; z-index:9999; }
.lang-picker-btn { display:flex; align-items:center; gap:7px; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.22); padding:.45rem 1rem; border-radius:var(--radius); color:#fff; cursor:pointer; font-size:.85rem; font-weight:500; transition:all .3s; font-family:inherit; }
.lang-picker-btn:hover { background:rgba(255,255,255,.22); }
.lang-globe { flex-shrink:0; opacity:.85; }
.lang-chevron { flex-shrink:0; opacity:.7; transition:transform .2s; }
.lang-picker.open .lang-chevron { transform:rotate(180deg); }
.lang-picker-label { max-width:100px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

.lang-dropdown { position:absolute; top:calc(100% + 10px); right:0; background:#fff; border-radius:var(--radius-lg); box-shadow:0 12px 40px rgba(0,0,0,.18); width:260px; opacity:0; transform:translateY(-6px) scale(0.95); transition:all .25s ease; pointer-events:none; display:none; }
.lang-picker.open .lang-dropdown { opacity:1; transform:translateY(0) scale(1); pointer-events:all; display:block; }

.lang-search-wrap { display:flex; align-items:center; gap:8px; padding:.7rem 1rem; border-bottom:1px solid #eee; position:sticky; top:0; background:#fff; z-index:1; border-radius:var(--radius-lg) var(--radius-lg) 0 0; }
.lang-search { flex:1; border:none; outline:none; font-size:.9rem; font-family:inherit; color:var(--text-dark); background:transparent; }
.lang-search::placeholder { color:#aaa; }

.lang-list { max-height:290px; overflow-y:auto; padding:.4rem 0; scroll-behavior:smooth; }
.lang-list::-webkit-scrollbar { width:5px; }
.lang-list::-webkit-scrollbar-track { background:transparent; }
.lang-list::-webkit-scrollbar-thumb { background:#ddd; border-radius:10px; }
.lang-list::-webkit-scrollbar-thumb:hover { background:#bbb; }

.lang-item { display:flex; align-items:center; gap:10px; width:100%; padding:.6rem 1rem; border:none; background:none; cursor:pointer; font-size:.88rem; color:var(--text-dark); font-family:inherit; transition:background .15s; text-align:left; }
.lang-item:hover { background:var(--green-light); }
.lang-item.active { background:var(--green-light); color:var(--green); font-weight:600; }
.lang-item-flag { font-size:1.15rem; flex-shrink:0; width:24px; text-align:center; }
.lang-item-names { flex:1; display:flex; flex-direction:column; line-height:1.3; }
.lang-item-native { font-size:.88rem; }
.lang-item-en { font-size:.75rem; color:var(--text-light); font-weight:400; }
.lang-item-check { opacity:0; color:var(--green); font-weight:700; transition:opacity .15s; }
.lang-item.active .lang-item-check { opacity:1; }

.lang-no-results { padding:1.5rem 1rem; text-align:center; color:var(--text-light); font-size:.88rem; }

/* Hide Google Translate UI overlays — keep widget functional */
#google_translate_element { position:absolute!important; left:-9999px!important; top:-9999px!important; }
body { top:0!important; position:static!important; }
.goog-te-banner-frame { display:none!important; }
#goog-gt-tt, .goog-te-balloon-frame { display:none!important; }
/* Collapse the top bar Google injects — but do NOT use display:none or visibility:hidden */
body > .skiptranslate { height:0!important; overflow:hidden!important; position:fixed!important; top:-100px!important; }
/* Aggressively hide new Google Translate popups & headers */
.VIpgJd-ZVi9od-aZ2wEe-wOHMyf, 
.VIpgJd-ZVi9od-aZ2wEe-wOHMyf-ti6hGc,
iframe.goog-te-banner-frame,
div#goog-gt-tt,
.goog-tooltip,
.goog-tooltip:hover {
    display: none !important;
}
.goog-text-highlight { background-color: transparent !important; box-shadow: none !important; }
html { margin-top: 0 !important; top: 0 !important; }

/* ANIMATIONS */
@keyframes fadeInUp { from { opacity:0; transform:translateY(40px); } to { opacity:1; transform:translateY(0); } }
.animate-in { opacity:0; transform:translateY(40px); transition:all 0.8s cubic-bezier(0.25, 1, 0.5, 1); }
.animate-in.visible { opacity:1; transform:translateY(0); }
.animate-delay-1 { transition-delay: 0.1s; }
.animate-delay-2 { transition-delay: 0.2s; }
.animate-delay-3 { transition-delay: 0.3s; }
.animate-delay-4 { transition-delay: 0.4s; }
.animate-scale { opacity:0; transform:scale(0.9); transition:all 0.8s cubic-bezier(0.25, 1, 0.5, 1); }
.animate-scale.visible { opacity:1; transform:scale(1); }
.animate-left { opacity:0; transform:translateX(-50px); transition:all 0.8s cubic-bezier(0.25, 1, 0.5, 1); }
.animate-left.visible { opacity:1; transform:translateX(0); }
.animate-right { opacity:0; transform:translateX(50px); transition:all 0.8s cubic-bezier(0.25, 1, 0.5, 1); }
.animate-right.visible { opacity:1; transform:translateX(0); }

/* RESPONSIVE */
@media(max-width:900px) {
  .top-bar { display:none; }
  .navbar { top:0; }
  .nav-links { display:none; }
  .nav-cta { display:none !important; }
  .hamburger { display:flex; }
  .nav-links.mobile-open { display:flex; position:absolute; top:100%; left:0; width:100%; flex-direction:column; background:var(--green-dark); padding:1.5rem 5%; gap:1rem; }
  .logo { margin-right: 0; }
  .lang-picker { margin-right: 15px; }
  .hero h1 { font-size:2.5rem; }
  .stats-ribbon { flex-wrap:wrap; gap:1.5rem; }
  .stat { flex:1 1 40%; }
  .about-grid, .logistics-grid, .contact-grid, .footer-grid { grid-template-columns:1fr; }
  .about-img-wrapper img, .logistics-img-wrapper img { height:300px; }
  .form-row { grid-template-columns:1fr; }
  .chatbot-window { width:calc(100% - 20px); right:10px; bottom:90px; height:70vh; }
  .lang-picker-label { display:none; }
  .lang-picker-btn { padding:.45rem .7rem; }
  .lang-dropdown { right:-10px; width:calc(100vw - 40px); max-width:280px; }
}

@media(max-width:480px) {
  .hero h1 { font-size:2rem; }
  .hero-desc { font-size: 0.95rem; }
  .hero { padding: 9rem 5% 2rem; }
  .stats-ribbon { padding:1.2rem; flex-direction:column; gap:1rem; text-align: center; }
  .stat { flex:1 1 100%; margin-bottom:10px; }
  .about-img-wrapper img, .logistics-img-wrapper img { height:220px; }
  .product-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .product-card-body { padding: 0.8rem; }
  .product-card-img { height: 120px; }
  .product-card-body h3 { font-size: 0.95rem; line-height: 1.2; margin-bottom: 0.4rem; }
  .product-card-body p { display: none; }
  .product-tag { font-size: 0.65rem; padding: 0.2rem 0.5rem; margin-bottom: 0.4rem; }
  .product-actions { flex-direction: column; gap: 0.4rem !important; }
  .product-btn { padding: 0.4rem; font-size: 0.75rem; width: 100%; border-radius: 8px; }
  .hero-actions { flex-direction:column; width:100%; }
  .btn-cta:not(.nav-cta), .btn-outline { width:100%; display: flex; justify-content: center; }
  .contact-form-wrapper { padding:1.5rem; }
  .page-header { padding:6rem 5% 3rem; }
  .page-header h1 { font-size:1.8rem; }
  /* Make chatbot fullscreen on very small mobile devices to prevent cutoff */
  .chatbot-window { right:0; top:0; bottom:0; width:100%; height:auto; max-height:100%; border-radius:0; z-index:99999; }
  .chatbot-toggle { bottom:20px; right:20px; }
  .product-btn { width: 100%; }
  /* Fix Language picker dropdown cutoff */
  .lang-dropdown { width: calc(100vw - 20px); right: -5px; }
  /* Navbar spacing fixes for thin devices */
  .navbar { padding: 0.8rem 1rem; }
  .navbar.scrolled { padding: 0.6rem 1rem; }
  .logo { margin-right: 0; }
  .nav-logo-img { height: 35px; }
  .lang-picker { margin-right: 10px; }
  .lang-picker-btn { padding: 0.4rem 0.6rem; gap: 4px; }
  .hamburger { transform: scale(0.9); }
}

/* CHATBOT TOOLTIP */
.chatbot-tooltip { position: fixed; bottom: 90px; right: 20px; background: #fff; color: #333; padding: 12px 18px; border-radius: 12px; font-size: 0.95rem; font-weight: 500; box-shadow: 0 10px 25px rgba(0,0,0,0.15); z-index: 9998; opacity: 0; transform: translateY(10px) scale(0.9); transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275); pointer-events: none; cursor: pointer; border: 1px solid #e5e7eb; }
.chatbot-tooltip.show { opacity: 1; transform: translateY(0) scale(1); pointer-events: auto; }
.chatbot-tooltip::after { content: ''; position: absolute; bottom: -8px; right: 20px; width: 0; height: 0; border-left: 8px solid transparent; border-right: 8px solid transparent; border-top: 8px solid #fff; }

/* ==================== TESTIMONIALS ==================== */
.testimonials { padding: 7rem 0 5rem; background: var(--white); overflow: hidden; }
.testimonials-header { text-align: center; padding: 0 5%; margin-bottom: 3.5rem; }
.testimonials-header h2 { font-family: var(--serif); font-size: clamp(2rem, 4vw, 3rem); color: var(--green-dark); margin-bottom: 0.5rem; }
.testimonials-subtitle { color: var(--text-mid); max-width: 580px; margin: 0 auto; font-size: 1rem; }

/* Scrolling track */
.testimonials-track-wrap { position: relative; }
.testimonials-track {
  display: flex;
  gap: 1.8rem;
  padding: 1rem 5% 2rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
}
.testimonials-track::-webkit-scrollbar { display: none; }

/* Testimonial Card */
.tcard {
  flex: 0 0 clamp(300px, 38vw, 440px);
  scroll-snap-align: start;
  background: var(--white);
  border: 1px solid #e8edea;
  border-radius: 20px;
  padding: 2rem;
  box-shadow: 0 4px 20px rgba(0,0,0,0.05);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  position: relative;
}
.tcard::before {
  content: '\201C';
  position: absolute;
  top: 1.2rem; right: 1.8rem;
  font-size: 5rem;
  font-family: var(--serif);
  color: var(--green-light);
  line-height: 1;
}
.tcard:hover { transform: translateY(-6px); box-shadow: 0 16px 40px rgba(0,0,0,0.1); }

.tcard-top { display: flex; align-items: flex-start; gap: 1rem; margin-bottom: 1.2rem; }
.tcard-avatar {
  width: 48px; height: 48px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; font-weight: 700; color: #fff;
  flex-shrink: 0; letter-spacing: 0.5px;
}
.tcard-info { flex: 1; }
.tcard-info strong { display: block; font-size: 0.95rem; color: var(--text-dark); margin-bottom: 2px; }
.tcard-info span { display: block; font-size: 0.78rem; color: var(--text-mid); }
.tcard-location { color: var(--green) !important; font-weight: 500 !important; margin-top: 2px; }
.tcard-stars { color: #f59e0b; font-size: 0.9rem; flex-shrink: 0; }

.tcard-quote { font-size: 0.9rem; line-height: 1.75; color: var(--text-mid); margin-bottom: 1.2rem; font-style: italic; }

.tcard-meta { display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; border-top: 1px solid #f0f5f1; padding-top: 1rem; }
.tcard-product { font-size: 0.75rem; background: var(--green-light); color: var(--green-dark); padding: 3px 10px; border-radius: 20px; font-weight: 600; }
.tcard-volume { font-size: 0.72rem; color: var(--text-mid); background: #f5f5f5; padding: 3px 8px; border-radius: 20px; }
.tcard-verified { font-size: 0.72rem; color: #fff; background: var(--green); padding: 3px 10px; border-radius: 20px; font-weight: 600; margin-left: auto; }

/* Dots navigation */
.testimonials-dots { display: flex; justify-content: center; gap: 8px; margin: 1rem 0 3rem; }
.tdot { width: 8px; height: 8px; border-radius: 50%; background: #d1dbd3; transition: all 0.3s; cursor: pointer; border: none; padding: 0; }
.tdot.active { background: var(--green); width: 24px; border-radius: 4px; }

/* Stats bar */
.testimonials-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  max-width: 900px;
  margin: 0 auto;
  padding: 0 5%;
  border: 1px solid #e8edea;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,0.05);
}
.tstat {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 2rem 1rem;
  border-right: 1px solid #e8edea;
  background: var(--white);
}
.tstat:last-child { border-right: none; }
.tstat-num { font-family: var(--serif); font-size: 2.2rem; color: var(--green-dark); line-height: 1; margin-bottom: 0.4rem; }
.tstat-label { font-size: 0.75rem; color: var(--text-mid); text-align: center; font-weight: 500; text-transform: uppercase; letter-spacing: 0.5px; }

.btn-outline-dark { display: inline-block; padding: 14px 32px; border: 2px solid var(--green-dark); color: var(--green-dark); border-radius: var(--radius-sm); font-weight: 600; text-decoration: none; transition: all 0.3s; font-size: 1rem; }
.btn-outline-dark:hover { background: var(--green-dark); color: #fff; }
.certs-section-tag, .compliance-section-tag { text-align: center; }

/* ==================== SHARED UTILITY CLASSES ==================== */
/* Avatar color variants (testimonials) */
.tcard-avatar-green  { background: #1a5c38; }
.tcard-avatar-orange { background: #c87533; }
.tcard-avatar-blue   { background: #2c3e7a; }
.tcard-avatar-red    { background: #7a2c2c; }
.tcard-avatar-navy   { background: #2c4a7a; }

/* Catalog outline button */
.btn-catalog-outline { padding: 12px 28px; border: 2px solid var(--green-dark); background: transparent; color: var(--green-dark); font-size: 1rem; font-weight: 600; border-radius: 6px; cursor: pointer; transition: all 0.3s; }
.btn-catalog-outline:hover { background: var(--green-dark); color: #fff; }

/* CTA button group */
.cta-btn-group { display: flex; gap: 15px; margin-top: 20px; flex-wrap: wrap; align-items: center; }

/* btn-full */
.btn-full { width: 100%; margin-top: 10px; }

/* Catalog modal */
.catalog-modal-overlay { display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.8); z-index: 9999; align-items: center; justify-content: center; -webkit-backdrop-filter: blur(5px); backdrop-filter: blur(5px); }
.catalog-modal-box { background: #fff; padding: 2rem; border-radius: 12px; width: 90%; max-width: 400px; text-align: center; position: relative; }
.catalog-modal-close { position: absolute; top: 10px; right: 15px; background: none; border: none; font-size: 1.5rem; cursor: pointer; color: #333; }
.catalog-modal-title { color: var(--green-dark); margin-bottom: 10px; }
.catalog-modal-desc { font-size: 0.9rem; color: #666; margin-bottom: 20px; }
.catalog-modal-form { display: flex; flex-direction: column; gap: 10px; }
.catalog-modal-input { padding: 10px; border: 1px solid #ddd; border-radius: 6px; font-size: 1rem; width: 100%; box-sizing: border-box; }
.catalog-modal-msg { display: none; color: var(--green-dark); font-size: 0.9rem; margin-top: 15px; font-weight: 600; }

/* Admin sidebar helpers */
.sidebar-view-site { text-decoration: none; text-align: center; display: block; margin-bottom: 8px; }
.tab-badge-hidden { display: none; }
.variants-label { display: flex; justify-content: space-between; align-items: center; }
.btn-sm-inline { padding: 4px 8px; font-size: 0.8rem; }

@media (max-width: 768px) {
  .testimonials { padding: 5rem 0 3rem; }
  .testimonials-stats { grid-template-columns: 1fr 1fr; }
  .tstat { border-bottom: 1px solid #e8edea; }
  .tstat:nth-child(2n) { border-right: none; }
  .tstat:nth-last-child(-n+2) { border-bottom: none; }
  .tcard { flex: 0 0 85vw; }
}
@media (max-width: 480px) {
  .testimonials-stats { grid-template-columns: 1fr 1fr; }
  .tstat-num { font-size: 1.8rem; }
}
.mt-2rem { margin-top: 2rem; }

