
/* BavoZulu Commodities — Custom Design System */
:root{
  --bg:#f7f5ef;
  --bg-alt:#efece2;
  --ink:#0e1a14;
  --ink-soft:#33433a;
  --muted:#6b7a72;
  --line:#dfdacb;
  --brand:#1f5d3a;       /* deep agricultural green */
  --brand-2:#143b25;
  --gold:#c8a04a;        /* harvest gold */
  --gold-soft:#e7d8a8;
  --white:#ffffff;
  --shadow-sm:0 1px 2px rgba(14,26,20,.06),0 2px 8px rgba(14,26,20,.04);
  --shadow:0 8px 28px rgba(14,26,20,.10),0 2px 6px rgba(14,26,20,.06);
  --shadow-lg:0 24px 60px rgba(14,26,20,.18);
  --radius:14px;
  --maxw:1240px;
  --serif:"Source Serif 4","Source Serif Pro",Georgia,"Times New Roman",serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);
  line-height:1.6;font-size:16px;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--brand);text-decoration:none;transition:color .2s}
a:hover{color:var(--gold)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.18;color:var(--ink);margin:0 0 .6em}
h1{font-size:clamp(2.1rem,4.6vw,3.6rem);letter-spacing:-.01em}
h2{font-size:clamp(1.6rem,3.2vw,2.4rem);letter-spacing:-.005em}
h3{font-size:1.25rem}
h4{font-size:1.05rem}
p{margin:0 0 1em;color:var(--ink-soft)}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* Top bar */
.topbar{background:var(--brand-2);color:#dfeae2;font-size:.85rem}
.topbar .container{display:flex;justify-content:space-between;align-items:center;padding:8px 24px;gap:16px;flex-wrap:wrap}
.topbar a{color:#dfeae2}
.topbar a:hover{color:var(--gold-soft)}
.topbar .tb-right{display:flex;gap:18px;flex-wrap:wrap}
.topbar .tb-right span{display:inline-flex;align-items:center;gap:6px}

/* Header / nav */
.site-header{position:sticky;top:0;z-index:50;background:rgba(247,245,239,.92);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:20px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-weight:700;font-size:1.25rem;color:var(--ink)}
.brand-mark{
  width:38px;height:38px;border-radius:10px;
  background:linear-gradient(135deg,var(--brand) 0%,var(--brand-2) 100%);
  display:grid;place-items:center;color:#fff;font-weight:700;font-family:var(--serif);
  box-shadow:inset 0 -2px 0 rgba(0,0,0,.15), 0 4px 10px rgba(31,93,58,.25);
}
.brand small{display:block;font-family:var(--sans);font-weight:500;color:var(--muted);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;margin-top:-2px}
.nav-links{display:flex;align-items:center;gap:6px;list-style:none;margin:0;padding:0}
.nav-links a{color:var(--ink);font-weight:500;font-size:.95rem;padding:10px 12px;border-radius:8px;position:relative}
.nav-links a:hover, .nav-links a.active{background:var(--bg-alt);color:var(--brand-2)}
.nav-links li.has-mega{position:static}
.mega{
  position:absolute;left:0;right:0;top:100%;background:#fff;border-top:1px solid var(--line);
  box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(-6px);transition:.25s;
  padding:32px 0;
}
.has-mega:hover .mega, .has-mega:focus-within .mega{opacity:1;visibility:visible;transform:none}
.mega-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.mega h5{font-family:var(--sans);text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;color:var(--muted);margin:0 0 10px}
.mega ul{list-style:none;margin:0;padding:0;display:grid;gap:6px}
.mega a{padding:6px 0;display:block;font-size:.92rem;color:var(--ink-soft)}
.mega a:hover{color:var(--brand)}
.btn{
  display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:999px;
  font-weight:600;font-size:.95rem;border:1px solid transparent;cursor:pointer;transition:.2s;white-space:nowrap;
}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 8px 20px rgba(31,93,58,.25)}
.btn-primary:hover{background:var(--brand-2);color:#fff;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--brand);color:var(--brand)}
.btn-gold{background:var(--gold);color:#1a1408}
.btn-gold:hover{background:#b58a36;color:#1a1408}
.nav-toggle{display:none;background:none;border:1px solid var(--line);width:42px;height:42px;border-radius:10px;cursor:pointer;align-items:center;justify-content:center}
.nav-toggle svg{width:22px;height:22px;stroke:var(--ink)}

@media (max-width: 980px){
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;padding:14px;border-top:1px solid var(--line);box-shadow:var(--shadow)}
  .nav-links.open{display:flex}
  .nav-links a{padding:12px 14px}
  .nav-toggle{display:inline-flex}
  .mega{position:static;box-shadow:none;border:none;padding:6px 0 6px 14px;opacity:1;visibility:visible;transform:none;display:none}
  .has-mega.open .mega{display:block}
  .mega-grid{grid-template-columns:1fr;gap:14px}
  .nav .btn{align-self:flex-start}
}

/* Hero */
.hero{position:relative;overflow:hidden;color:#fff;isolation:isolate}
.hero::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(10,22,16,.55) 0%, rgba(10,22,16,.75) 100%),
            url("../images/hero-port.jpg") center/cover no-repeat;
  z-index:-1;transform:scale(1.02);
}
.hero .container{padding-top:96px;padding-bottom:120px}
.eyebrow{display:inline-flex;align-items:center;gap:10px;padding:6px 14px;border:1px solid rgba(255,255,255,.35);border-radius:999px;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:#f0e9d2;margin-bottom:22px}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--gold)}
.hero h1{color:#fff;max-width:880px}
.hero h1 em{font-style:normal;color:var(--gold-soft);font-weight:500}
.hero p.lede{color:#e7eae5;font-size:clamp(1.05rem,1.4vw,1.2rem);max-width:680px;margin-bottom:30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

/* Sections */
.section{padding:84px 0}
.section-tight{padding:56px 0}
.section-alt{background:var(--bg-alt)}
.section-dark{background:var(--brand-2);color:#dfeae2}
.section-dark h1,.section-dark h2,.section-dark h3{color:#fff}
.section-dark p{color:#c4d2cb}
.section-head{max-width:760px;margin:0 auto 48px;text-align:center}
.section-head .eyebrow{color:var(--brand);border-color:rgba(31,93,58,.3)}
.section-dark .section-head .eyebrow{color:var(--gold-soft);border-color:rgba(255,255,255,.25)}

/* Stat strip */
.stats{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff}
.stat{padding:34px 22px;text-align:center;border-right:1px solid var(--line)}
.stat:last-child{border-right:none}
.stat .num{font-family:var(--serif);font-size:2.4rem;color:var(--brand-2);font-weight:600;display:block;line-height:1}
.stat .lbl{display:block;margin-top:8px;color:var(--muted);font-size:.85rem;letter-spacing:.04em}
@media (max-width:880px){.stats{grid-template-columns:repeat(2,1fr)}.stat{border-right:none;border-bottom:1px solid var(--line)}.stat:nth-child(odd){border-right:1px solid var(--line)}}

/* Feature grid (commodities/services) */
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
@media (max-width:980px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.grid-3,.grid-4,.grid-2{grid-template-columns:1fr}}

.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;transition:transform .25s, box-shadow .25s, border-color .25s;
  position:relative;overflow:hidden;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.card .ico{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,#e9f2ec,#d8e8dc);display:grid;place-items:center;color:var(--brand);margin-bottom:14px}
.card .ico svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:1.6}
.card h3{margin-bottom:6px;color:var(--brand-2)}
.card p{margin:0;font-size:.95rem}
.card .more{display:inline-block;margin-top:14px;font-size:.88rem;color:var(--brand);font-weight:600}

/* Commodity tile w/ image accent */
.commodity{position:relative;border:1px solid var(--line);background:#fff;border-radius:var(--radius);overflow:hidden;transition:.25s}
.commodity:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.commodity .swatch{height:140px;background:linear-gradient(135deg,#e9d9b3,#cdb27a)}
.commodity[data-c="sesame"] .swatch{background:linear-gradient(135deg,#f0e4c4,#d6c08a)}
.commodity[data-c="cashew"] .swatch{background:linear-gradient(135deg,#f3e0c1,#c79a6a)}
.commodity[data-c="soy"] .swatch{background:linear-gradient(135deg,#e8d790,#b89a44)}
.commodity[data-c="maize"] .swatch{background:linear-gradient(135deg,#ffd770,#d29b1f)}
.commodity[data-c="rice"] .swatch{background:linear-gradient(135deg,#fbf5dc,#e5d6a6)}
.commodity[data-c="coffee"] .swatch{background:linear-gradient(135deg,#7b4a2a,#3a200f)}
.commodity[data-c="cocoa"] .swatch{background:linear-gradient(135deg,#6b3a1f,#2c1407)}
.commodity[data-c="ground"] .swatch{background:linear-gradient(135deg,#e1b27a,#8b5a2a)}
.commodity[data-c="sorghum"] .swatch{background:linear-gradient(135deg,#c97a4a,#7a3a1f)}
.commodity[data-c="millet"] .swatch{background:linear-gradient(135deg,#e3c887,#a88735)}
.commodity[data-c="chick"] .swatch{background:linear-gradient(135deg,#dec88a,#a88945)}
.commodity[data-c="mung"] .swatch{background:linear-gradient(135deg,#7ea454,#3c6027)}
.commodity[data-c="pigeon"] .swatch{background:linear-gradient(135deg,#caa46a,#7d5723)}
.commodity[data-c="black"] .swatch{background:linear-gradient(135deg,#2a2a2a,#0a0a0a)}
.commodity[data-c="white"] .swatch{background:linear-gradient(135deg,#f3ede0,#cdc3a8)}
.commodity[data-c="feed"] .swatch{background:linear-gradient(135deg,#b8a070,#6a5530)}
.commodity .body{padding:18px 20px}
.commodity h3{font-size:1.05rem;margin-bottom:4px}
.commodity p{font-size:.85rem;color:var(--muted);margin:0}

/* Split section */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:60px;align-items:center}
@media (max-width:980px){.split{grid-template-columns:1fr;gap:36px}}
.split .media{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg)}
.split .media img{width:100%;height:100%;object-fit:cover;aspect-ratio:5/4}

/* Process steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:s}
@media (max-width:880px){.steps{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.steps{grid-template-columns:1fr}}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;position:relative}
.step::before{counter-increment:s;content:"0" counter(s);position:absolute;top:18px;right:22px;font-family:var(--serif);font-size:1.6rem;color:var(--gold);opacity:.65}
.step h4{margin:6px 0 4px;color:var(--brand-2)}
.step p{font-size:.9rem;margin:0}

/* Testimonials */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:980px){.quotes{grid-template-columns:1fr}}
.quote{background:#fff;border-left:4px solid var(--gold);border-radius:10px;padding:24px;box-shadow:var(--shadow-sm)}
.quote p{font-style:italic;color:var(--ink);font-size:1rem;margin:0 0 12px}
.quote .meta{display:flex;align-items:center;gap:12px}
.quote .av{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;display:grid;place-items:center;font-weight:600;font-size:.85rem}
.quote .meta div{font-size:.85rem}
.quote .meta strong{color:var(--ink);display:block;font-style:normal}
.quote .meta span{color:var(--muted)}

/* FAQ */
.faq{max-width:880px;margin:0 auto;display:grid;gap:10px}
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px 22px;transition:.2s}
.faq details[open]{border-color:var(--brand);box-shadow:var(--shadow-sm)}
.faq summary{cursor:pointer;font-weight:600;color:var(--ink);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--brand);transition:transform .2s;line-height:1}
.faq details[open] summary::after{content:"−"}
.faq p{margin:14px 0 0;color:var(--ink-soft)}

/* Trust badges */
.badges{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.badge{
  display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);
  border-radius:999px;padding:10px 18px;font-size:.88rem;font-weight:500;color:var(--ink-soft);
}
.badge svg{width:18px;height:18px;stroke:var(--brand);fill:none;stroke-width:1.8}

/* Footer */
.site-footer{background:#0a1610;color:#a9b6af;padding:72px 0 28px;margin-top:0}
.site-footer h4{color:#fff;font-family:var(--sans);font-size:.85rem;text-transform:uppercase;letter-spacing:.14em;margin:0 0 16px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px}
@media (max-width:880px){.foot-grid{grid-template-columns:1fr 1fr}}
@media (max-width:540px){.foot-grid{grid-template-columns:1fr}}
.site-footer ul{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.site-footer a{color:#a9b6af;font-size:.92rem}
.site-footer a:hover{color:var(--gold-soft)}
.site-footer .brand{color:#fff;margin-bottom:14px}
.site-footer .brand small{color:#8b9890}
.foot-bottom{margin-top:48px;padding-top:24px;border-top:1px solid #1c2a23;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:.82rem;color:#8b9890}
.foot-bottom a{color:#8b9890}

/* Page hero (interior pages) */
.page-hero{background:linear-gradient(180deg,#143b25 0%,#1f5d3a 100%);color:#fff;padding:72px 0 60px;position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;inset:0;background:url("../images/farmland.jpg") center/cover;opacity:.10;mix-blend-mode:lighten}
.page-hero h1{color:#fff;margin-bottom:10px}
.page-hero p{color:#d6e0db;max-width:680px;font-size:1.1rem;margin:0}
.crumbs{font-size:.82rem;color:#bccbc3;margin-bottom:14px;letter-spacing:.04em}
.crumbs a{color:#dfe7e2}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:46px}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr}}
.form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:540px){.form .row{grid-template-columns:1fr}}
.form label{display:block;font-size:.85rem;font-weight:500;color:var(--ink);margin:14px 0 6px}
.form input,.form textarea,.form select{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;
  font:inherit;color:var(--ink);background:#fbfaf5;transition:.15s;
}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--brand);background:#fff;box-shadow:0 0 0 3px rgba(31,93,58,.15)}
.form textarea{min-height:130px;resize:vertical}
.form button{margin-top:18px;width:100%;justify-content:center}
.contact-block{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;margin-bottom:18px}
.contact-block h3{margin-top:0;color:var(--brand-2);font-size:1.1rem}
.contact-block .line{display:flex;gap:12px;align-items:flex-start;margin:10px 0;font-size:.95rem;color:var(--ink-soft)}
.contact-block .line svg{flex-shrink:0;width:20px;height:20px;stroke:var(--brand);fill:none;stroke-width:1.8;margin-top:2px}
.map{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:#eee}
.map iframe{display:block;width:100%;height:360px;border:0}

/* Article / legal pages */
.article{max-width:820px;margin:0 auto}
.article h2{margin-top:2em}
.article h3{margin-top:1.6em;color:var(--brand-2)}
.article ul{padding-left:22px;color:var(--ink-soft)}
.article ul li{margin-bottom:8px}

/* Blog grid */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:980px){.posts{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.posts{grid-template-columns:1fr}}
.post{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:.25s}
.post:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.post .ph{height:170px;background:linear-gradient(135deg,#1f5d3a,#0e1a14);position:relative;overflow:hidden}
.post .ph::after{content:"";position:absolute;inset:0;background:url("../images/farmland.jpg") center/cover;opacity:.45}
.post[data-img="2"] .ph::after{background-image:url("../images/shipping.jpg")}
.post[data-img="3"] .ph::after{background-image:url("../images/warehouse.jpg")}
.post[data-img="4"] .ph::after{background-image:url("../images/silos.jpg")}
.post[data-img="5"] .ph::after{background-image:url("../images/coffee.jpg")}
.post[data-img="6"] .ph::after{background-image:url("../images/quality.jpg")}
.post[data-img="7"] .ph::after{background-image:url("../images/hero-port.jpg")}
.post[data-img="8"] .ph::after{background-image:url("../images/commodities.jpg")}
.post .body{padding:20px;display:flex;flex-direction:column;gap:8px;flex:1}
.post .tag{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brand);font-weight:600}
.post h3{font-size:1.1rem;margin:0}
.post p{margin:0;font-size:.92rem;color:var(--ink-soft);flex:1}
.post .read{margin-top:10px;font-size:.85rem;color:var(--brand);font-weight:600}

/* World map */
.worldmap{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;text-align:center}
.worldmap svg{max-width:100%;height:auto}
.worldmap .legend{margin-top:18px;display:flex;justify-content:center;gap:18px;flex-wrap:wrap;font-size:.85rem;color:var(--muted)}
.worldmap .legend span{display:inline-flex;align-items:center;gap:6px}
.worldmap .legend i{display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--gold)}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* Cookie banner */
.cookie{
  position:fixed;left:20px;right:20px;bottom:20px;max-width:560px;margin:0 auto;
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 20px;
  box-shadow:var(--shadow-lg);display:flex;gap:14px;align-items:center;z-index:60;
}
.cookie p{margin:0;font-size:.88rem;color:var(--ink-soft);flex:1}
.cookie button{padding:8px 16px;font-size:.85rem}
.cookie.hidden{display:none}

/* Utility */
.center{text-align:center}
.mt-2{margin-top:1rem}.mt-4{margin-top:2rem}.mt-6{margin-top:3rem}
.muted{color:var(--muted)}
