/* =========================================
   Soft Green + Soft UI — Full Stylesheet
   Version: 1.0
   Author: You
   ========================================= */

/* ===============================
   Root variables
   =============================== */
:root {
  /* Brand core */
  --brand-green: #22c55e;
  --brand-red: #e01212;
  --ink: #111827;
  --muted: #64748b;
  --line: #e5e7eb;
  --header-h: 120px;
  --section-bg: #f6fdf9;
  --gold: #d9b76b;

  /* Fonts */
  --serif: "Cinzel", Georgia, "Times New Roman", serif;
  --sans: "Poppins", Arial, Helvetica, sans-serif;

  /* Palette: Purple */
  --purple: #5a0d85;
  --purple-2: #42146b;
  --purple-3: #6b1aa1;
  --hero-purple-1: #3f1361;
  --hero-purple-2: #6a1592;
  --hero-purple-3: #2b0a44;

  /* Palette: Blue */
  --blue: #123f8b;
  --blue-2: #0d3a7a;

  /* Radii + Shadows + Motion */
  --r-xs: 8px;
  --r-sm: 10px;
  --r: 14px;
  --r-lg: 18px;
  --shadow-1: 0 8px 24px rgba(16, 24, 40, 0.08);
  --shadow-2: 0 18px 44px rgba(16, 24, 40, 0.12);
  --shadow-soft: 0 6px 18px rgba(0, 0, 0, 0.06);
  --ease: cubic-bezier(.2, .65, .2, 1);
}

/* ===============================
   Base / Layout
   =============================== */
html, body { height: 100%; }

body {
  font-family: var(--sans);
  color: var(--ink);
  background: #fff;
  padding-top: var(--header-h);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a, .btn, .nav-link, .prod-card, .news-card, .faq-card, .accordion-button {
  transition: all .18s var(--ease);
}

:focus-visible {
  outline: 3px solid rgba(34,197,94,.35);
  outline-offset: 2px;
  border-radius: 6px;
}

/* ===============================
   Header / Topbar / Navbar
   =============================== */
#siteHeader {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1055;
  background: transparent;
}

#siteHeader.scrolled .navbar {
  box-shadow: 0 10px 28px rgba(17, 24, 39, 0.08);
}

.topbar {
  background: #f7faf9;
  border-bottom: 1px solid var(--line);
  padding: 0.35rem 0;
  font-size: 0.9rem;
}

.topbar .form-control {
  height: 32px; border-radius: var(--r-sm);
  padding: 0 0.8rem; font-size: 0.9rem;
}

.topbar .btn {
  height: 32px; border-radius: var(--r-sm);
  padding: 0.1rem 0.6rem;
}

.lang-mini {
  width: auto; border-radius: var(--r-sm);
  height: 32px; font-weight: 600;
}

.navbar {
  background: #fff;
  border-bottom: 1px solid var(--line);
  font-weight: 600;
  letter-spacing: 0.02em;
}

.navbar .nav-link {
  padding: 1.1rem 0.85rem;
  font-size: 0.9rem;
  text-transform: uppercase;
  color: #1f2937;
}

.navbar .nav-link:hover,
.navbar .nav-link:focus,
.navbar .nav-link.active {
  color: var(--brand-green);
}

.navbar .dropdown-toggle::after { margin-left: .3rem; }

.navbar .dropdown-menu {
  border: 1px solid #e6ebf2;
  border-radius: 10px;
  padding: .5rem;
  box-shadow: 0 24px 60px rgba(17,24,39,.08);
  font-weight: 500;
}

.navbar .dropdown-item {
  font-size: 0.92rem;
  padding: 0.65rem 1rem;
  color: #2f3542;
  border-bottom: 1px solid #f0f3f7;
  text-transform: none;
  font-weight: 600;
}
.navbar .dropdown-item:last-child { border-bottom: 0; }
.navbar .dropdown-menu .dropdown-item:hover { color: var(--brand-green); }

.btn-login {
  font-weight: 700;
  letter-spacing: 0.02em;
  padding: 0.45rem 1rem;
  border-radius: var(--r-sm);
  background: var(--brand-green);
  color: #fff; border: 0;
  box-shadow: 0 6px 16px rgba(34,197,94,.22);
}
.btn-login:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(34,197,94,.28);
  filter: brightness(.97);
}

/* Mega menu (PRODUCT) */
.dropdown-mega { position: static; }
.dropdown-mega .dropdown-menu {
  left: 50%; transform: translateX(-50%);
  width: min(1100px, 92vw);
  padding: 1.25rem 1.5rem;
}
.mega-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 32px;
}
.mega-col h6{
  font-weight: 800; font-size: .92rem; color:#2f3747; letter-spacing: .12em;
  text-transform: uppercase; margin: 0 0 .9rem;
  padding-bottom: .55rem; border-bottom: 1px solid #edf1f6;
}
.mega-list .nav-link{
  display: block; padding: .45rem 0; color: #2f3542; font-weight: 700;
  text-transform: uppercase; letter-spacing: .02em; font-size: .95rem;
}
.mega-list .nav-link:hover{ color: var(--brand-green); }

/* Hover to open on desktop */
@media (min-width: 992px){
  .navbar .dropdown:hover > .dropdown-menu { display: block; }
  .navbar .dropdown-toggle:focus { color: var(--brand-green); }
  .navbar .dropdown-menu { margin-top: 0; }
}

/* ===============================
   HERO (Base + Variants)
   =============================== */
.hero { position: relative; overflow: hidden; background: #000; }
.hero-inner { position: relative; z-index: 1; }

/* Right numeric rail */
.hero-rail {
  position: absolute; right: 18px; top: 50%; transform: translateY(-50%);
  z-index: 5; display: flex; flex-direction: column; align-items: flex-end; gap: .35rem;
  user-select: none;
}
.hero-rail .tick {
  font-weight: 700; font-size: .9rem; letter-spacing: .08em; color: #cfd5df; cursor: default;
}
.hero-rail .tick.active { color: #7f8897; }
.hero-rail .bar {
  width: 2px; height: 86px; background: linear-gradient(#e9eef6, #d7deea);
  margin: .4rem 10px; border-radius: 4px;
}

/* Variant: Slider (light/greenish) */
.hero--slider { min-height: 86vh; background: #fff; color: inherit; }
.hero--slider .carousel,
.hero--slider .carousel-item { height: 100%; }
.hero--slider .carousel-item {
  min-height: 86vh; display: flex; align-items: center; position: relative;
}
.slide-bg {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(1100px 480px at 38% 22%, rgba(34,197,94,.18), transparent 60%),
    radial-gradient(800px 360px at 72% 40%, rgba(16,185,129,.12), transparent 60%),
    linear-gradient(#f8fffb, #ffffff);
}
.slide-bg-img {
  position: absolute; inset: 0; z-index: 0;
  background-position: center; background-size: cover; filter: brightness(0.94);
}
.slide-content { position: relative; z-index: 2; width: 100%; }
.hero-copy h1 {
  font-weight: 800; font-size: clamp(24px, 3.2vw, 44px); line-height: 1.25;
  margin-bottom: .5rem; color: #165f3e;
  text-shadow: 0 1px 0 rgba(255,255,255,.75);
}
.hero-copy p {
  font-size: clamp(14px, 1.25vw, 18px); color: #3f5b4b; margin-bottom: 1rem;
}
.hero-tag {
  display: inline-block; background: #fff; border: 2px solid var(--gold);
  color: #5b4a1a; padding: .25rem .7rem; border-radius: 10px; font-weight: 700;
  margin-bottom: .5rem;
}
.mini-phyto {
  display: flex; align-items: center; gap: .5rem; margin-top: .8rem;
  color: #8892a5; font-weight: 600; font-size: .95rem;
}
.mini-phyto img { height: 26px; }
.hero-ribbon { position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: .95; }
.pouch {
  width: min(220px, 38vw); border-radius: 10px; background: #fff;
  box-shadow: 0 20px 50px rgba(0,0,0,.12);
}
.hero-wave {
  position: absolute; left: 0; right: 0; bottom: -1px; height: 160px; z-index: 2; pointer-events: none;
}
.certificate-frame {
  position: relative; display: inline-block; padding: 10px;
  background: linear-gradient(135deg, #f7e9b6, #d9b76b, #fff7cc);
  border-radius: 8px;
}
.certificate {
  width: min(380px, 45vw); transform: rotate(-2deg);
  box-shadow: 0 25px 60px rgba(0,0,0,.18), 0 6px 18px rgba(0,0,0,.12);
  border-radius: 6px; background: #fff;
}

/* Variant: Purple banner (anniversary style) */
.hero--purple {
  min-height: 64vh; display: flex; align-items: center; color: #fff;
  background:
    radial-gradient(1200px 600px at 30% 20%, rgba(255,255,255,.08), transparent 60%),
    linear-gradient(180deg, var(--purple-3) 0%, var(--purple) 60%);
}
.hero--purple::before {
  content:""; position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background: repeating-conic-gradient(from -20deg, rgba(0,0,0,.12) 0 12deg, transparent 12deg 36deg);
  transform: scale(1.4); opacity: .6;
}
.hero--purple::after {
  content:""; position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background:
    linear-gradient(135deg, rgba(255,255,255,.06), transparent 60%) left center/40% 100% no-repeat,
    linear-gradient(-135deg, rgba(255,255,255,.06), transparent 60%) right center/40% 100% no-repeat;
  mix-blend-mode: screen;
}
.hero-slope { position: absolute; left: 0; right: 0; bottom: -1px; height: 110px; z-index: 2; pointer-events: none; }
.hero--purple .lead {
  font-weight: 800; font-size: clamp(26px, 3.2vw, 46px); line-height: 1.15; margin: 0;
  text-shadow: 0 1px 0 rgba(0,0,0,.25);
}
.hero--purple .tag { font-weight: 600; color: #f2e8ff; opacity: .95; }
.hero--purple .badge-img { width: min(420px, 50vw); }
.hero--purple .mini-phyto { display:flex; align-items:center; gap:.5rem; color:#ddd; font-weight:600; }
.hero--purple .mini-phyto img { height: 26px; }
.hero--purple .hero-badge { width: min(320px, 60vw); filter: drop-shadow(0 20px 40px rgba(0,0,0,.35)); }
.hero--purple .hero-title {
  font-weight: 800; letter-spacing: .04em; font-size: clamp(18px, 2vw, 22px); margin-top: 8px; color: #ffeefb;
}
.hero--purple .hero-sub {
  font-size: clamp(28px, 3.6vw, 42px); font-weight: 800; margin-top: 10px;
}
.hero--purple .hero-rail .tick { color: #e0d7ec; }
.hero--purple .hero-rail .tick.active { color: #fff; }

/* Variant: Product hero (blue/gold classy) */
.product-hero {
  position: relative; overflow: hidden;
  background: linear-gradient(180deg, #fff 0%, #fff 50%, #faf6ef 100%);
}
.product-hero .sparkles::before {
  content:""; position:absolute; inset:0; pointer-events:none;
  background-image:
    radial-gradient(2px 2px at 10% 15%, rgba(255,255,255,.7) 40%, transparent 40%),
    radial-gradient(2px 2px at 30% 30%, rgba(255,255,255,.6) 40%, transparent 40%),
    radial-gradient(2px 2px at 50% 20%, rgba(255,255,255,.6) 40%, transparent 40%),
    radial-gradient(2px 2px at 70% 45%, rgba(255,255,255,.7) 40%, transparent 40%),
    radial-gradient(2px 2px at 80% 25%, rgba(255,255,255,.5) 40%, transparent 40%),
    radial-gradient(2px 2px at 20% 60%, rgba(255,255,255,.5) 40%, transparent 40%);
  background-size: 350px 220px; mix-blend-mode: screen;
}
.hero-left img { width: 100%; }
.hero-right .hero-title {
  font-family: var(--serif);
  font-size: clamp(30px, 4.2vw, 56px);
  letter-spacing: 0.18em;
  color: #2b2f3a;
}
.hero-right .hero-sub {
  letter-spacing: 0.22em; color: #777; font-weight: 600; text-transform: uppercase;
}
.gold-badges img{ width: 104px; }
.gold-badges span { font-size: 10px; }

/* ===============================
   Section helpers / titles
   =============================== */
.section { padding: 44px 0; }
.section.narrow { padding: 40px 0; }
.section.alt { background: var(--section-bg); }
.divider { height: 1px; background: var(--line); margin: 20px 0 32px; }

.section-title {
  font-size: clamp(26px, 3.3vw, 40px);
  color: #3a4252; margin-bottom: .4rem; font-weight: 800;
}
.section-sub { color: #6b7487; font-weight: 600; }

.lead-title {
  font-size: clamp(28px, 4.5vw, 48px);
  color: #3a4252; margin-bottom: .75rem; text-align: left; font-weight: 800;
}
.sub-lead {
  color: #6b7487; font-weight: 600; margin-bottom: 1.25rem; text-align: left;
}

.page-title {
  font-weight: 800; font-size: clamp(26px, 3.3vw, 40px); color: #3a4252;
  text-align: center; margin: 26px 0 8px;
}
.skin-title {
  font-weight: 800; font-size: clamp(22px, 3vw, 34px); color: #3a4252;
  text-align: center; margin: 40px 0 20px;
}
.lead-desc { max-width: 780px; margin-inline: auto; color: #4d5668; }

/* ===============================
   Awards collage
   =============================== */
.awards-grid .tile { position: relative; overflow: hidden; border-radius: var(--r); }
.awards-grid img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  filter: contrast(1) saturate(1.05);
}
.awards-grid .overlay {
  position: absolute; inset: 0; display: flex; align-items: flex-end; padding: 14px;
  background: linear-gradient(0deg, rgba(0,0,0,.55), rgba(0,0,0,0) 55%);
  color: #fff; font-weight: 800; letter-spacing: .02em;
}
.awards-grid .cta {
  position: absolute; right: 10px; bottom: 10px; background: rgba(0,0,0,.65);
  color: #fff; padding: .35rem .7rem; border-radius: 20px; font-weight: 700;
  border: 1px solid rgba(255,255,255,.35);
}

/* ===============================
   Announcement / mini carousel
   =============================== */
.ann-card {
  border: 1px solid #e8ecf2; border-radius: var(--r); background: #f7f5ed; padding: 17px;
}
.ann-card .card-header { font-weight: 700; }
.mini-carousel .carousel-item { padding: 16px; }
.mini-carousel .card { border: 0; box-shadow: var(--shadow-1); border-radius: var(--r); }

/* ===============================
   Products grid
   =============================== */
.products .prod-card {
  border: 0; border-radius: var(--r); background: #fff; box-shadow: var(--shadow-1);
  transition: transform .15s var(--ease), box-shadow .15s var(--ease);
  position: relative; overflow: hidden;
}
.products .prod-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-2); }
.prod-img-wrap {
  height: 180px; display: flex; align-items: center; justify-content: center; padding: 10px;
  background: linear-gradient(180deg, #fff, #fafafa);
}
.prod-img { max-height: 170px; max-width: 95%; object-fit: contain; }
.prod-title { font-weight: 700; font-size: 1rem; color: #2d3748; margin-bottom: .1rem; }
.prod-tag { font-size: .9rem; color: #6b7487; }

.badge-gold {
  position: absolute; right: 12px; top: 12px; width: 38px; height: 38px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #fff6cc, #e2c77a 60%, #b0893d);
  display: flex; align-items: center; justify-content: center;
  color: #6b4f18; font-weight: 800; font-size: .8rem; border: 2px solid rgba(255,255,255,.8);
  box-shadow: 0 6px 14px rgba(0,0,0,.08);
}

/* ===============================
   Why Choose Us
   =============================== */
.why {
  position: relative; overflow: hidden; color: #2e3a4a;
  background: linear-gradient(180deg, #fff, rgba(255,255,255,.7)),
    url("https://images.unsplash.com/photo-1521737604893-d14cc237f11d?q=80&w=1400&auto=format&fit=crop") center/cover no-repeat;
  border-radius: var(--r);
}
.why .point { display: flex; gap: .7rem; align-items: flex-start; margin: .6rem 0; }
.why .icon {
  flex: 0 0 36px; height: 36px; width: 36px; border-radius: 50%; display: inline-flex; align-items:center; justify-content:center;
  background: #eafaf1; color: var(--brand-green); font-size: 18px;
}

/* ===============================
   News cards
   =============================== */
.news-card {
  border: 0; border-radius: var(--r); box-shadow: var(--shadow-1); overflow: hidden; height: 100%; background: #fff;
}
.news-card img { height: 150px; width: 100%; object-fit: cover; }
.news-card .card-body { padding: 14px; }
.news-card .title { font-weight: 700; color: #2b3445; font-size: 1rem; }
.news-card .meta { font-size: .85rem; color: #6b7487; }

/* ===============================
   Company profile content
   =============================== */
.content p { color: #4d5668; line-height: 1.9; margin-bottom: 1rem; }
.content h5 {
  margin-top: 1.9rem; margin-bottom: .5rem; font-weight: 800; color: #3a4252;
}
.content ul { padding-left: 1.2rem; }
.content ul li { margin: .3rem 0; color: #4d5668; }

/* ===============================
   Gallery
   =============================== */
.gallery .card { border: none; background: transparent; }
.gallery .card img { border-radius: var(--r); box-shadow: 0 10px 26px rgba(0,0,0,.08); }
.gallery .caption {
  margin-top: .65rem; font-weight: 600; color: #2f3542; text-align: center;
}
.gallery .meta {
  margin-top: .15rem; font-size: .95rem; color: #6b7487; text-align: center;
}

/* ===============================
   FAQ / Accordion
   =============================== */
.faq-wrap { padding: 20px 0 70px; }
.faq-card {
  border: 1px solid #e8ecf2; border-radius: var(--r); background: #fff; box-shadow: var(--shadow-1);
}
.accordion-button {
  font-weight: 700; color: #2e3a4a; background: #fff;
}
.accordion-button:not(.collapsed) {
  background: #f0fdf4; color: #14532d; box-shadow: inset 3px 0 0 0 var(--brand-green);
}
.accordion-body { color: #465269; }
.accordion .note { font-size: .95rem; color: #5e6a7c; }

.accordion-flush .accordion-item { border: 0; }
.accordion-flush .accordion-button {
  padding: .55rem .25rem; font-weight: 600; color: #2b3450; background: transparent;
}
.accordion-flush .accordion-button:not(.collapsed) { background: #f8fafc; }
.q-num { color: var(--brand-green); font-weight: 800; margin-right: .35rem; }

/* ===============================
   Ingredients / Benefits / How-to
   =============================== */
.ingred-feature{
  display:flex; align-items:center; justify-content:center; gap:clamp(16px, 4vw, 56px);
  margin:24px 0; flex-wrap:nowrap;
}
.ingred-feature img{ display:block; height:auto; max-width:100%; }
.ingred-feature img:first-child,
.ingred-feature img:last-child{ width:clamp(220px, 32vw, 420px); }
.ingred-feature img:nth-child(2){
  width:clamp(42px, 6vw, 70px); margin:0 !important; flex:0 0 auto; opacity:.95;
}
@media (max-width: 576px){
  .ingred-feature{ flex-direction:column; gap:12px; }
  .ingred-feature img:first-child,
  .ingred-feature img:last-child{ width:min(420px, 92%); }
  .ingred-feature img:nth-child(2){ transform: rotate(90deg); }
}

.ppf {
  font-weight: 800; font-size: clamp(20px, 2.4vw, 28px); color: #2b3445;
  letter-spacing: .04em; display:flex; align-items:center; gap:.5rem;
}
.ing-card { padding: 16px; background:#fff; height: 100%; border-radius: var(--r); border: 1px solid #eef2f6; }
.ing-card img {
  width: 80%; object-fit: cover; border: 1px solid #dfe3ea; border-radius: var(--r-sm);
}
.ing-title { font-weight: 800; color: #2b3445; margin: .6rem 0 .3rem; font-size: 1.05rem; }
.ing-note { color: #4f5a6f; font-size: .95rem; }

.benefit h5 { font-weight: 800; color: #2b3445; }
.benefit p { color: #81858c; font-size: 15px; text-align: justify; }
.benefit .img-wrap img {
  width:100%; border-radius: var(--r); box-shadow: 0 12px 30px rgba(0,0,0,.08);
}
.benefit .img-wrap { margin-top: .5rem; }

.how .title { font-weight: 800; color: #2b3445; }
.how .step { display:flex; gap:.7rem; align-items:flex-start; margin:.4rem 0; }
.how .step .icon {
  flex: 0 0 34px; width:34px; height:34px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:#eef6ff; color:#0d6efd;
}

/* ===============================
   Credits
   =============================== */
.credit .person {
  display:flex; flex-direction:column; align-items:center; gap:.35rem; text-align:center;
}
.credit .person img {
  width:120px; height:120px; object-fit:cover; border-radius:10px; box-shadow:0 8px 18px rgba(0,0,0,.1);
}
.credit .name { font-weight:700; }
.credit .flag { font-size:.9rem; color:#6b7487; }

/* ===============================
   Downloads / Packaging
   =============================== */
.download-link { display:inline-flex; align-items:center; gap:.4rem; font-weight:600; }
.download-link i { font-size: 18px; }

.pack .thumb {
  border: 1px solid #e9edf3; border-radius: var(--r); padding: 10px; background:#fff;
  height: 100%; display:flex; align-items:center; justify-content:center; box-shadow: var(--shadow-1);
}
.pack .thumb img { max-height: 260px; max-width: 100%; object-fit: contain; }
.pack .cap { text-align:center; margin-top:.5rem; color:#6b7487; font-weight:600; }

/* ===============================
   Connect / Contact / Branch
   =============================== */
.connect-title {
  font-weight: 800; font-size: clamp(28px, 3.6vw, 40px); color: #3a4252; letter-spacing: .02em;
}
.connect-accent { color: var(--brand-green); font-weight: 700; }

.contact-list .item {
  display:flex; gap:.75rem; margin:.6rem 0; align-items:flex-start; color:#4a5568;
}
.contact-list .icon {
  flex:0 0 38px; width:38px; height:38px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:#e9f7ef; color:#256f4a;
}

.office-hours p { margin:.2rem 0; color:#4a5568; }
.branch .label { font-weight:700; }
.branch p { margin:.25rem 0; color:#4a5568; }

.form-control { border-radius: 8px; }
.btn-pill {
  border-radius: 24px; padding: .55rem 1.1rem; font-weight: 700; background: var(--brand-green); color: #fff; border: 0;
}
.btn-pill:hover { filter: brightness(.97); transform: translateY(-1px); }

/* ===============================
   Footer
   =============================== */
footer {
  background: #f5fbf7; padding: 50px 0 0; border-top: 1px solid #e0f0e8;
}
footer h5 { font-weight: 800; color: #3a4252; }
footer p, footer a { color: #4b5568; text-decoration: none; }
footer a:hover { color: #256f4a; }
.footer-logo { max-width: 200px; }
.footer-small { font-size: .9rem; color: #6b7487; }
.newsletter .form-control { border-radius: 8px; }
.newsletter .btn { border-radius: 8px; }
.footer-bottom {
  border-top: 1px solid #ddefe6; margin-top: 28px; padding: 16px 0; font-size: .9rem; color:#6b7487;
}

/* ===============================
   Utilities
   =============================== */
.scroll-top {
  position: fixed; right: 20px; bottom: 20px; z-index: 10;
  width: 45px; height: 45px; border-radius: 50%; border: none;
  background: var(--brand-green); color: #fff; font-size: 18px;
  box-shadow: 0 2px 5px rgba(0,0,0,.3);
}

.blue-label {
  display: inline-block; background: var(--brand-green); color: #fff;
  padding: .42rem .8rem; border-radius: 6px; font-weight: 700; font-size: .95rem;
  box-shadow: 0 2px 0 rgba(0,0,0,.08);
}

.subtle { color: #6b7487; }

.strip {
  color: var(--brand-green); border-radius: 4px; text-transform: uppercase; font-size: 26px;
}
.strips {
  background: #0c2e8a; border: 1px solid #e6eaf0; padding: .55rem .9rem; font-weight: 700;
  color: #fff; border-radius: 4px; text-transform: uppercase; font-size: 18px;
}
.product-title {
  text-align: center; font-weight: bold; color: #131833; font-size: 18px; text-transform: uppercase; margin-top: 0;
  background-color: #F4F4F4; padding: 10px;
}
.shadow-soft { box-shadow: var(--shadow-soft); }

/* ===============================
   Simple 3-image hero slider
   =============================== */
.hero { position: relative; min-height: 86vh; overflow: hidden; background: #000; }
.hero .carousel,
.hero .carousel-inner,
.hero .carousel-item { height: 100%; min-height: 86vh; }
.hero .carousel-item { position: relative; }
.hero .hero-img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: brightness(.95);
}

/* ===============================
   TEAM SECTION
   =============================== */
.lead-title { font-size: clamp(28px, 4.5vw, 48px); color: #3a4252; margin-bottom: .75rem; text-align: center; font-weight: 800; }
.sub-lead { text-align: center; color: #6b7487; font-weight: 600; margin-bottom: 1.25rem; }

.leader-card { padding-bottom: 2.2rem; border-bottom: 1px solid #eef2f6; margin-bottom: 2.2rem; }
.leader-photo {
  width: 100%; border-radius: 10px; box-shadow: 0 14px 36px rgba(0,0,0,.08);
  object-fit: cover; aspect-ratio: 3/4; background: #f4f6fa;
}
.leader-name { font-size: 20px; color: #3a4252; margin-bottom: 13px; font-weight: 700; }
.leader-role {
  text-transform: uppercase; letter-spacing: .08em; color: #3a4252; margin-bottom: 1rem; font-weight: 700;
}
.leader-body p { color:#4b5669; line-height:1.9; margin-bottom:1rem; text-align: justify; }
.leader-divider { width:70px; height:3px; background:#274690; border-radius:3px; margin:1.2rem 0 .8rem; }
.sub-title { text-align: justify; font-size: 15px; color: #3a4252; }

/* ===============================
   Accessibility: reduced motion
   =============================== */
@media (prefers-reduced-motion: reduce) {
  .carousel, .carousel-item, .accordion-button, .prod-card, .news-card, .btn, .nav-link {
    transition: none !important;
  }
}

/* ===============================
   Dark Mode (optional)
   Usage: <body class="theme-dark">
   =============================== */
.theme-dark{
  --ink:#e5e7eb; --muted:#94a3b8; --line:#233044; --section-bg:#0f172a;
  background:#0b1020; color:var(--ink);
}
.theme-dark .topbar{background:#0f172a; border-color:#1e293b;}
.theme-dark .navbar{background:#0f172a; border-color:#1e293b;}
.theme-dark .navbar .nav-link{color:#cbd5e1;}
.theme-dark .navbar .nav-link:hover{color:var(--brand-green);}
.theme-dark .dropdown-menu{background:#0f172a; border-color:#1e293b;}
.theme-dark .dropdown-item{color:#cbd5e1; border-color:#172132;}
.theme-dark .dropdown-item:hover{color:var(--brand-green); background:#0b1426;}

.theme-dark .section.alt{background:#0e172a;}
.theme-dark .prod-img-wrap{background:linear-gradient(180deg,#0f172a,#0b1325);}
.theme-dark .products .prod-card,
.theme-dark .news-card,
.theme-dark .faq-card,
.theme-dark .pack .thumb{background:#0f172a; box-shadow:0 12px 30px rgba(0,0,0,.45); border-color:#1e293b;}
.theme-dark .ing-card{background:#0f172a; border-color:#1e293b;}
.theme-dark .news-card .title{color:#e5e7eb;}
.theme-dark .news-card .meta{color:#94a3b8;}
.theme-dark .why{background:linear-gradient(180deg, #0b1020, rgba(11,16,32,.6)), url("https://images.unsplash.com/photo-1521737604893-d14cc237f11d?q=80&w=1400&auto=format&fit=crop") center/cover no-repeat;}
.theme-dark .accordion-button{background:#0f172a; color:#e5e7eb;}
.theme-dark .accordion-button:not(.collapsed){background:#0e1b14; color:#d1fae5; box-shadow: inset 3px 0 0 0 var(--brand-green);}
.theme-dark .accordion-body{color:#cbd5e1;}

.theme-dark footer{background:#0b1325; border-color:#1e293b;}
.theme-dark .footer-bottom{border-color:#1e293b; color:#94a3b8;}
.theme-dark .hero--slider .slide-bg{
  background:
    radial-gradient(1100px 480px at 38% 22%, rgba(34,197,94,.16), transparent 60%),
    linear-gradient(#0b1325, #0b1020);
}
.theme-dark .blue-label{background:var(--brand-green);}
.theme-dark .strip{color:var(--brand-green);}
.theme-dark .contact-list .icon{background:#0e1b14; color:#22c55e;}

/* ===============================
   News & Events Module
   =============================== */
.news-wrap { padding: 32px 0 64px; }

.news-toolbar{
  display:flex; flex-wrap:wrap; gap:10px;
  align-items:center; justify-content:space-between;
  margin-bottom:16px;
}
.news-toolbar .search{
  display:flex; align-items:center; gap:8px;
  background:#fff; border:1px solid var(--line); border-radius:10px; padding:6px 10px;
  box-shadow:0 4px 12px rgba(0,0,0,.04);
}
.news-toolbar .search input{
  border:0; outline:none; min-width:220px; font-size:14px; color:var(--ink);
}
.news-toolbar .chip{
  display:inline-flex; align-items:center; gap:6px;
  background:#f0fdf4; color:#166534; border:1px solid rgba(34,197,94,.25);
  padding:.25rem .6rem; border-radius:999px; font-weight:700; font-size:.85rem; cursor:pointer;
}
.news-toolbar .chip.is-active{ background:#dcfce7; border-color:rgba(34,197,94,.45); }

/* Grid */
.news-grid{
  display:grid; gap:22px;
  grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
  align-items: stretch;
}

/* Card */
.news-card{
  background:#fff; border:1px solid #edf2f7; border-radius:var(--r);
  box-shadow:var(--shadow-1);
  display:flex; flex-direction:column; overflow:hidden;
  transition:transform .18s var(--ease), box-shadow .18s var(--ease);
}
.news-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-2); }

.news-thumb{
  aspect-ratio:16/9; background:#f3f4f6; overflow:hidden; position:relative;
  border-bottom:1px solid var(--line);
}
.news-thumb img{
  width:100%; height:100%; object-fit:cover;
  transform:scale(1.0);
  transition:transform .4s var(--ease), filter .4s var(--ease);
}
.news-card:hover .news-thumb img{ transform:scale(1.05); filter:saturate(1.05) contrast(1.02); }
.news-thumb.empty{
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(140deg,#f6f9f7,#eef6f1); color:#6b7487; font-weight:700; font-size:.95rem;
}

/* Body */
.news-body{ padding:14px; display:flex; flex-direction:column; flex:1; }
.news-date{
  font-size:.9rem; color:#6b7487; margin:0 0 6px; display:flex; align-items:center; gap:6px;
}
.news-title{
  font-weight:800; color:#2b3445; font-size:1rem; line-height:1.4; margin:0 0 10px;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
  min-height:calc(1.4em * 2);
}
.news-excerpt{
  color:#4d5668; font-size:.95rem; margin:0 0 12px;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.news-footer{
  margin-top:auto; display:flex; justify-content:space-between; align-items:center; gap:10px;
}
.news-cat{
  display:inline-flex; align-items:center; gap:6px;
  background:#f0fdf4; color:#166534; font-weight:700; padding:.25rem .55rem;
  border-radius:20px; font-size:.85rem; border:1px solid rgba(34,197,94,.25);
}

/* Buttons */
.btn-read{
  border:1px solid var(--line); background:#fff; color:#1f2937; font-weight:700;
  padding:.45rem .9rem; border-radius:8px; line-height:1; white-space:nowrap;
  box-shadow:0 2px 6px rgba(0,0,0,.05);
  transition:all .18s var(--ease);
}
.btn-read:hover{
  border-color:var(--brand-green); color:var(--brand-green);
  box-shadow:0 6px 16px rgba(34,197,94,.18); transform:translateY(-1px);
}

/* Pager */
.news-pager{
  margin-top:26px; display:flex; justify-content:center; gap:8px; flex-wrap:wrap;
}
.news-pager .page{
  min-width:40px; height:40px; display:inline-flex; align-items:center; justify-content:center;
  border:1px solid var(--line); background:#fff; color:#1f2937; border-radius:10px; font-weight:700;
}
.news-pager .page.is-active, .news-pager .page:hover{
  border-color:var(--brand-green); color:var(--brand-green); box-shadow:0 6px 16px rgba(34,197,94,.15);
}

/* Small screen tweaks */
@media (max-width: 576px){
  .news-toolbar .search input{ min-width:160px; }
}