/* =====================================================================
   ICBC Global Cashew Hub — International Cashew Business Centre Limited
   Premium institutional agribusiness design system
   Palette: deep forest green, brushed gold, warm white, natural brown, charcoal
   ===================================================================== */

:root{
  --green-900:#0e2a1e;
  --green-800:#143a29;
  --green-700:#1c4d36;
  --green-600:#256b4a;
  --green-500:#2f8a5f;
  --gold-600:#b8860b;
  --gold-500:#c99a2e;
  --gold-400:#d8b24c;
  --cream:#f7f4ec;
  --cream-2:#efe9da;
  --brown:#6b4f2e;
  --brown-2:#8a6a40;
  --charcoal:#23282b;
  --ink:#1b211d;
  --muted:#5d6760;
  --line:#e3ddd0;
  --white:#ffffff;
  --shadow:0 18px 50px -20px rgba(14,42,30,.45);
  --shadow-sm:0 8px 24px -12px rgba(14,42,30,.35);
  --maxw:1240px;
  --radius:14px;
  --serif:"Playfair Display",Georgia,"Times New Roman",serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--cream);line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);line-height:1.18;font-weight:700;color:var(--green-900)}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:88px 0}
.section--tight{padding:58px 0}
.bg-cream2{background:var(--cream-2)}
.bg-green{background:var(--green-900);color:#e9efe9}
.bg-green h1,.bg-green h2,.bg-green h3{color:#fff}

/* ---------- Eyebrow + headings ---------- */
.eyebrow{font-family:var(--sans);text-transform:uppercase;letter-spacing:.22em;font-size:.72rem;font-weight:700;color:var(--gold-600);margin-bottom:14px;display:inline-block}
.bg-green .eyebrow{color:var(--gold-400)}
h1{font-size:clamp(2.1rem,4.6vw,3.5rem)}
h2{font-size:clamp(1.7rem,3.2vw,2.5rem)}
h3{font-size:1.3rem}
.lead{font-size:1.15rem;color:var(--muted);max-width:760px}
.bg-green .lead{color:#c3d2c6}
.center{text-align:center}
.center .lead{margin-left:auto;margin-right:auto}
.divider{width:64px;height:3px;background:var(--gold-500);border-radius:3px;margin:18px 0 26px}
.center .divider{margin-left:auto;margin-right:auto}

/* ---------- Top bar ---------- */
.topbar{background:var(--green-900);color:#bcd0c1;font-size:.8rem}
.topbar .container{display:flex;justify-content:space-between;align-items:center;height:40px;gap:18px}
.topbar a{color:#cfe0d3}
.topbar a:hover{color:var(--gold-400)}
.topbar .tb-right{display:flex;gap:20px;flex-wrap:wrap}
.topbar .tb-left{display:flex;gap:18px}
@media(max-width:820px){.topbar .tb-left{display:none}}

/* ---------- Header / nav (13 items) ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(247,244,236,.94);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px;gap:14px}
.brand{display:flex;align-items:center;gap:12px;flex:none}
.brand-mark{width:44px;height:44px;border-radius:11px;flex:none;background:linear-gradient(145deg,var(--green-700),var(--green-900));color:var(--gold-400);font-family:var(--serif);font-weight:700;display:flex;align-items:center;justify-content:center;font-size:1.2rem;box-shadow:var(--shadow-sm)}
.brand-text strong{display:block;font-family:var(--serif);font-size:1rem;color:var(--green-900);letter-spacing:.01em;line-height:1.05}
.brand-text span{font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-600);font-weight:600}
.menu{display:flex;gap:0;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.menu a{padding:7px 8px;border-radius:7px;font-size:.79rem;font-weight:500;color:var(--green-800);transition:.18s;white-space:nowrap}
.menu a:hover{background:var(--cream-2);color:var(--green-900)}
.menu a.active{color:var(--gold-600);font-weight:600}
.menu .btn{margin-left:8px;padding:8px 15px;font-size:.8rem}
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:9px;font-weight:600;font-size:.93rem;background:var(--gold-500);color:#fff;border:1px solid var(--gold-500);transition:.2s;cursor:pointer}
.btn:hover{background:var(--gold-600);border-color:var(--gold-600);transform:translateY(-1px)}
.btn--ghost{background:transparent;color:var(--green-900);border:1px solid var(--green-700)}
.btn--ghost:hover{background:var(--green-900);color:#fff}
.btn--light{background:#fff;color:var(--green-900);border-color:#fff}
.btn--light:hover{background:var(--gold-400);border-color:var(--gold-400);color:var(--green-900)}
.btn--sm{padding:9px 16px;font-size:.82rem}
.menu-toggle{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.menu-toggle span{width:24px;height:2px;background:var(--green-900);display:block}
@media(max-width:1300px){
  .menu-toggle{display:flex}
  .menu{position:absolute;top:72px;left:0;right:0;flex-direction:column;align-items:stretch;gap:2px;background:var(--cream);border-bottom:1px solid var(--line);padding:14px 24px 22px;display:none;box-shadow:var(--shadow-sm);max-height:80vh;overflow:auto}
  .menu.open{display:flex}
  .menu a{padding:12px 10px;font-size:.95rem}
  .menu .btn{margin:8px 0 0}
}

/* ---------- Hero ---------- */
.hero{position:relative;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(10,30,20,.93) 0%,rgba(12,40,26,.82) 42%,rgba(12,40,26,.4) 100%)}
.hero-inner{position:relative;padding:118px 0 104px;max-width:720px}
.hero h1{color:#fff;letter-spacing:-.01em}
.hero .lead{color:#dbe6dd;margin:22px 0 32px;font-size:1.2rem}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-badges{display:flex;gap:30px;flex-wrap:wrap;margin-top:46px}
.hero-badges .b strong{font-family:var(--serif);font-size:1.8rem;color:var(--gold-400);display:block}
.hero-badges .b span{font-size:.8rem;color:#cddcd0;letter-spacing:.04em}
.hero-caption{position:absolute;bottom:14px;right:18px;z-index:2;font-size:.72rem;color:rgba(255,255,255,.72);font-style:italic;letter-spacing:.02em}

/* page hero */
.page-hero{position:relative;color:#fff;overflow:hidden;background:var(--green-900)}
.page-hero-bg{position:absolute;inset:0;opacity:.32}
.page-hero-bg img{width:100%;height:100%;object-fit:cover}
.page-hero .container{position:relative;padding:82px 0 70px}
.page-hero h1{color:#fff}
.page-hero .lead{color:#cddcd0;margin-top:14px}
.page-hero .hero-caption{bottom:10px}
.breadcrumb{font-size:.82rem;color:var(--gold-400);letter-spacing:.04em;margin-bottom:16px}
.breadcrumb a{color:#bcd0c1}
.breadcrumb a:hover{color:#fff}

/* ---------- Grid ---------- */
.grid{display:grid;gap:28px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split--media-first .media{order:-1}
@media(max-width:860px){.split{grid-template-columns:1fr;gap:32px}}
.media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;object-fit:cover}

/* ---------- Cards ---------- */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.22s;display:flex;flex-direction:column;height:100%}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.card-img{aspect-ratio:4/3;overflow:hidden;background:var(--cream-2);position:relative}
.card-img img{width:100%;height:100%;object-fit:cover;transition:.4s}
.card:hover .card-img img{transform:scale(1.06)}
.card-body{padding:24px;display:flex;flex-direction:column;gap:10px;flex:1}
.card-body h3{font-size:1.18rem}
.card-body p{color:var(--muted);font-size:.95rem;flex:1}
.card-link{color:var(--gold-600);font-weight:600;font-size:.9rem;letter-spacing:.02em}
.card:hover .card-link{color:var(--green-700)}
.card-badges{position:absolute;top:12px;left:12px;z-index:2}
.tag{display:inline-block;background:var(--cream-2);color:var(--green-700);font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:5px 11px;border-radius:50px}

/* feature tiles */
.feature{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;height:100%}
.feature .ico{width:50px;height:50px;border-radius:12px;background:var(--green-900);color:var(--gold-400);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.feature .ico svg{width:24px;height:24px}
.feature h3{font-size:1.15rem;margin-bottom:8px}
.feature p{color:var(--muted);font-size:.95rem}

/* stat strip */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);overflow:hidden}
.stats .s{padding:30px 24px;text-align:center;border-right:1px solid rgba(255,255,255,.12)}
.stats .s:last-child{border-right:0}
.stats .s strong{font-family:var(--serif);font-size:2rem;color:var(--gold-400);display:block}
.stats .s span{font-size:.85rem;color:#c3d2c6;letter-spacing:.03em}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}.stats .s:nth-child(2){border-right:0}}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);background:#fff}
table.spec{width:100%;border-collapse:collapse;font-size:.93rem;min-width:480px}
table.spec caption{text-align:left;padding:18px 22px 0;font-weight:600;color:var(--green-800)}
table.spec th,table.spec td{padding:13px 18px;text-align:left;border-bottom:1px solid var(--line)}
table.spec thead th{background:var(--green-900);color:#fff;font-weight:600;letter-spacing:.02em;font-family:var(--sans);font-size:.82rem;text-transform:uppercase}
table.spec tbody tr:nth-child(even){background:var(--cream)}
table.spec tbody tr:hover{background:var(--cream-2)}
table.spec td:first-child{font-weight:600;color:var(--green-800)}
.subhead-row td{background:var(--green-700)!important;color:#fff!important;font-weight:700;text-transform:uppercase;font-size:.78rem;letter-spacing:.06em}

/* ---------- Gallery ---------- */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:900px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:620px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
.gallery-grid a{display:block;border-radius:10px;overflow:hidden;aspect-ratio:1;background:var(--cream-2);position:relative}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:.4s}
.gallery-grid a:hover img{transform:scale(1.08)}
.gallery-grid a::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(14,42,30,.35));opacity:0;transition:.3s}
.gallery-grid a:hover::after{opacity:1}

/* lightbox */
.lb{position:fixed;inset:0;background:rgba(9,20,14,.93);display:none;align-items:center;justify-content:center;z-index:200;padding:30px}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:88vh;border-radius:8px;box-shadow:var(--shadow)}
.lb-close{position:absolute;top:22px;right:30px;color:#fff;font-size:2.2rem;cursor:pointer;line-height:1}

/* checklist */
.checklist{list-style:none;display:grid;gap:12px}
.checklist li{position:relative;padding-left:34px;color:var(--ink)}
.checklist li::before{content:"";position:absolute;left:0;top:3px;width:20px;height:20px;border-radius:50%;background:var(--green-600);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'%3E%3Cpath d='M5 13l4 4L19 7'/%3E%3C/svg%3E");background-size:13px;background-repeat:no-repeat;background-position:center}

/* pills */
.pills{display:flex;flex-wrap:wrap;gap:10px}
.pill{background:#fff;border:1px solid var(--line);border-radius:50px;padding:8px 16px;font-size:.85rem;font-weight:600;color:var(--green-800)}
.pill--gold{background:var(--green-900);color:var(--gold-400);border-color:var(--green-900)}

/* CTA band */
.cta-band{background:linear-gradient(120deg,var(--green-900),var(--green-700));color:#fff;border-radius:18px;padding:54px 48px;text-align:center;box-shadow:var(--shadow)}
.cta-band h2{color:#fff}
.cta-band p{color:#cbdacf;max-width:640px;margin:14px auto 28px}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
@media(max-width:600px){.cta-band{padding:40px 24px}}

/* spec sidebar */
.spec-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}
.spec-card .hd{background:var(--green-900);color:#fff;padding:16px 22px;font-family:var(--serif);font-size:1.05rem}
.spec-card dl{display:grid;grid-template-columns:1fr 1fr;margin:0}
.spec-card dt,.spec-card dd{padding:12px 22px;border-bottom:1px solid var(--line);font-size:.9rem}
.spec-card dt{font-weight:600;color:var(--muted)}
.spec-card dd{color:var(--green-800);font-weight:600;text-align:right}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr}}
.info-row{display:flex;gap:16px;align-items:flex-start;padding:18px 0;border-bottom:1px solid var(--line)}
.info-row .ico{width:44px;height:44px;flex:none;border-radius:11px;background:var(--green-900);color:var(--gold-400);display:flex;align-items:center;justify-content:center}
.info-row .ico svg{width:20px;height:20px}
.info-row h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-family:var(--sans);margin-bottom:3px}
.info-row p{color:var(--green-900);font-weight:500}
form .field{margin-bottom:16px}
form label{display:block;font-size:.82rem;font-weight:600;color:var(--green-800);margin-bottom:6px}
form input,form textarea,form select{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:9px;font:inherit;font-size:.95rem;background:#fff;color:var(--ink)}
form input:focus,form textarea:focus,form select:focus{outline:none;border-color:var(--green-600);box-shadow:0 0 0 3px rgba(47,138,95,.15)}

/* ---------- Footer ---------- */
.site-footer{background:var(--green-900);color:#b9cabf;padding:64px 0 0}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:40px;padding-bottom:44px}
@media(max-width:860px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}
.site-footer h4{color:#fff;font-family:var(--sans);font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:18px}
.site-footer a{color:#b9cabf;font-size:.92rem;display:block;padding:5px 0}
.site-footer a:hover{color:var(--gold-400)}
.footer-brand .brand-text strong{color:#fff}
.footer-brand p{font-size:.92rem;margin-top:16px;color:#9fb4a7;max-width:320px}
.footer-disclaimer{border-top:1px solid rgba(255,255,255,.12);padding:20px 0 4px;font-size:.76rem;line-height:1.6;color:#8ba294;max-width:1000px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:22px 0;font-size:.8rem;color:#8ba294;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* reveal */
.js-enabled .reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.note{font-size:.85rem;color:var(--muted);font-style:italic}
.prose p{margin-bottom:16px;color:#34403a}
.prose p:last-child{margin-bottom:0}

/* ---------- Notices ---------- */
.notice{border-radius:12px;padding:16px 20px;font-size:.9rem;line-height:1.55;display:flex;gap:12px;align-items:flex-start}
.notice::before{content:"";flex:none;width:20px;height:20px;margin-top:1px;background-repeat:no-repeat;background-position:center;background-size:contain}
.notice--info{background:#eef4ef;border:1px solid #cfe0d4;color:#26503a}
.notice--info::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23256b4a' stroke-width='2' stroke-linecap='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpath d='M12 16v-4M12 8h.01'/%3E%3C/svg%3E")}
.notice--plan{background:#fbf4e4;border:1px solid #ecdcb0;color:#7a5a14}
.notice--plan::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23b8860b' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M12 9v4M12 17h.01M10.29 3.86 1.82 18a2 2 0 0 0 1.71 3h16.94a2 2 0 0 0 1.71-3L13.71 3.86a2 2 0 0 0-3.42 0z'/%3E%3C/svg%3E")}
.notice--lock{background:#eef1f5;border:1px solid #d3dae3;color:#3a4656}
.notice--lock::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%233a4656' stroke-width='2' stroke-linecap='round'%3E%3Crect x='3' y='11' width='18' height='11' rx='2'/%3E%3Cpath d='M7 11V7a5 5 0 0 1 10 0v4'/%3E%3C/svg%3E")}

/* ---------- Classification badges ---------- */
.badge{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:5px 11px;border-radius:50px;line-height:1.3}
.badge--current{background:#e2f0e6;color:#1c4d36;border:1px solid #b9d8c4}
.badge--planned{background:#fbf0d6;color:#8a6410;border:1px solid #ecd79f}
.badge--future{background:#e8edf2;color:#37506b;border:1px solid #c8d5e1}
.badge--byproduct{background:#efe5d8;color:#6b4f2e;border:1px solid #ddc9ac}

/* classification legend */
.legend{display:flex;flex-wrap:wrap;gap:18px;justify-content:center;margin-top:8px}
.legend .lg{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--muted)}
.legend .dot{width:12px;height:12px;border-radius:50%}
.dot--current{background:#256b4a}.dot--planned{background:#c99a2e}.dot--future{background:#37506b}.dot--byproduct{background:#6b4f2e}

/* ---------- Designed placeholder image (no photo available) ---------- */
.ph-img{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;padding:18px;
  background:radial-gradient(120% 120% at 30% 0%,var(--green-700),var(--green-900));overflow:hidden}
.ph-img::before{content:"";position:absolute;inset:0;opacity:.10;background-position:center;background-repeat:no-repeat;background-size:150px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23d8b24c' stroke-width='1'%3E%3Cpath d='M7 14c-3 0-5-2-5-5s3-6 7-6c5 0 9 3 12 3 1.5 0 2-1 2-1s1 3-2 6c-4 4-9 8-13 8-3 0-5-2-5-4s2-3 4-3'/%3E%3C/svg%3E")}
.ph-img svg{width:40px;height:40px;color:var(--gold-400);position:relative;opacity:.92}
.ph-img .ph-name{position:relative;font-family:var(--serif);color:#fff;font-size:1rem;line-height:1.25;max-width:90%}
.ph-img .ph-tag{position:relative;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-400);font-weight:600}

/* ---------- Product ecosystem ---------- */
.filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:14px}
.filter-group{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.filter-btn{background:#fff;border:1px solid var(--line);color:var(--green-800);font-weight:600;font-size:.82rem;padding:9px 16px;border-radius:50px;cursor:pointer;transition:.18s}
.filter-btn:hover{border-color:var(--green-600)}
.filter-btn.active{background:var(--green-900);color:#fff;border-color:var(--green-900)}
.filter-sep{width:1px;height:24px;background:var(--line);align-self:center;margin:0 4px}
.eco-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
@media(max-width:1080px){.eco-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.eco-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.eco-grid{grid-template-columns:1fr}}
.eco-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:.22s}
.eco-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.eco-card .eco-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--cream-2)}
.eco-card .eco-img img{width:100%;height:100%;object-fit:cover;transition:.4s}
.eco-card:hover .eco-img img{transform:scale(1.06)}
.eco-card .eco-badge{position:absolute;top:10px;left:10px;z-index:2}
.eco-body{padding:18px 18px 20px;display:flex;flex-direction:column;gap:8px;flex:1}
.eco-body h3{font-size:1.02rem;line-height:1.25}
.eco-body p{color:var(--muted);font-size:.86rem;flex:1}
.eco-meta{font-size:.74rem;color:var(--brown-2);border-top:1px solid var(--line);padding-top:10px;margin-top:2px}
.eco-meta b{color:var(--green-800);font-weight:600}
.eco-link{font-size:.82rem;font-weight:600;color:var(--gold-600);margin-top:4px}
.eco-card:hover .eco-link{color:var(--green-700)}
.sector-head{display:flex;align-items:center;gap:16px;margin:10px 0 26px}
.sector-head .num{width:46px;height:46px;flex:none;border-radius:12px;background:var(--green-900);color:var(--gold-400);font-family:var(--serif);font-weight:700;font-size:1.2rem;display:flex;align-items:center;justify-content:center}
.sector-head h2{font-size:1.6rem}
.sector-head p{color:var(--muted);font-size:.92rem;margin-top:2px}
.eco-empty{display:none;text-align:center;color:var(--muted);padding:30px 0}

/* ---------- Value chain diagram ---------- */
.vc{display:grid;grid-template-columns:1fr 1.2fr;gap:40px;align-items:center}
@media(max-width:900px){.vc{grid-template-columns:1fr;gap:28px}}
.vc-hub{background:var(--green-900);border-radius:18px;padding:30px;box-shadow:var(--shadow)}
.vc-hub h3{color:#fff;font-size:1.15rem;margin-bottom:6px}
.vc-hub p{color:#a9c0b1;font-size:.85rem;margin-bottom:18px}
.vc-parts{display:flex;flex-wrap:wrap;gap:10px}
.vc-part{background:rgba(216,178,76,.12);border:1px solid rgba(216,178,76,.35);color:var(--gold-400);font-size:.82rem;font-weight:600;padding:9px 14px;border-radius:10px}
.vc-branches{display:grid;gap:14px}
.vc-branch{display:flex;gap:16px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px 22px;transition:.2s;border-left:4px solid var(--gold-500)}
.vc-branch:hover{box-shadow:var(--shadow);transform:translateX(4px)}
.vc-branch .ico{width:46px;height:46px;flex:none;border-radius:11px;background:var(--cream-2);color:var(--green-700);display:flex;align-items:center;justify-content:center}
.vc-branch .ico svg{width:24px;height:24px}
.vc-branch h4{font-size:1.05rem;margin-bottom:3px}
.vc-branch p{color:var(--muted);font-size:.86rem}

/* ---------- Credentials ---------- */
.cred-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
@media(max-width:900px){.cred-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.cred-grid{grid-template-columns:1fr}}
.cred{background:#fff;border:1px solid var(--line);border-radius:12px;padding:22px 18px;text-align:center}
.cred .ico{width:42px;height:42px;border-radius:11px;background:var(--green-900);color:var(--gold-400);display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
.cred .ico svg{width:20px;height:20px}
.cred strong{display:block;font-family:var(--serif);color:var(--green-900);font-size:1rem;margin-bottom:3px}
.cred span{font-size:.82rem;color:var(--muted)}

/* ---------- Timeline ---------- */
.timeline{list-style:none;position:relative;padding-left:34px}
.timeline::before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:2px;background:var(--line)}
.timeline li{position:relative;padding:0 0 26px}
.timeline li:last-child{padding-bottom:0}
.timeline li::before{content:"";position:absolute;left:-30px;top:3px;width:20px;height:20px;border-radius:50%;background:var(--green-600);border:4px solid var(--cream)}
.timeline li.done::before{background:var(--gold-500)}
.timeline h4{font-size:1.05rem;margin-bottom:4px}
.timeline p{color:var(--muted);font-size:.92rem}
.bg-cream2 .timeline li::before{border-color:var(--cream-2)}

/* ---------- Data room ---------- */
.doc-cat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;height:100%}
.doc-cat .hd{display:flex;align-items:center;gap:12px;background:var(--green-900);color:#fff;padding:16px 20px}
.doc-cat .hd .ico{width:34px;height:34px;flex:none;border-radius:9px;background:rgba(216,178,76,.18);color:var(--gold-400);display:flex;align-items:center;justify-content:center}
.doc-cat .hd .ico svg{width:18px;height:18px}
.doc-cat .hd h3{color:#fff;font-size:1.02rem;font-family:var(--serif)}
.doc-list{list-style:none}
.doc-list li{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--line);font-size:.88rem}
.doc-list li:last-child{border-bottom:0}
.doc-name{color:var(--green-900);font-weight:500}
.doc-status{font-size:.62rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:4px 9px;border-radius:50px;white-space:nowrap}
.doc-status--public{background:#e2f0e6;color:#1c4d36}
.doc-status--request{background:#eef4ef;color:#256b4a}
.doc-status--restricted{background:#f6e7e7;color:#9a3b3b}
.req-grid{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.req-btn{font-size:.86rem}

/* ---------- News ---------- */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media(max-width:900px){.news-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.news-grid{grid-template-columns:1fr}}
.news-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:.2s}
.news-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.news-card .news-img{aspect-ratio:16/10;overflow:hidden;background:var(--cream-2);position:relative}
.news-card .news-img img{width:100%;height:100%;object-fit:cover}
.news-cat{position:absolute;top:10px;left:10px;background:var(--green-900);color:var(--gold-400);font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 11px;border-radius:50px}
.news-body{padding:20px;display:flex;flex-direction:column;gap:8px;flex:1}
.news-date{font-size:.76rem;color:var(--muted);letter-spacing:.03em}
.news-body h3{font-size:1.1rem;line-height:1.3}
.news-body p{color:var(--muted);font-size:.9rem;flex:1}

/* image caption */
figure.cap{margin:0}
figure.cap figcaption{font-size:.78rem;color:var(--muted);font-style:italic;margin-top:8px;text-align:center}

/* ---------- Product icon tiles (no-photo fallback) ---------- */
.eco-ph{display:none}
.eco-img.noimg{background:radial-gradient(130% 130% at 28% 0%,var(--green-700),var(--green-900))}
.eco-img.noimg .eco-ph{display:flex;align-items:center;justify-content:center;position:absolute;inset:0;margin:auto;width:78px;height:78px;border-radius:50%;background:rgba(216,178,76,.14);border:1px solid rgba(216,178,76,.42)}
.eco-img.noimg .eco-ph svg{width:36px;height:36px;color:var(--gold-400)}
.eco-img.noimg::after{content:"";position:absolute;inset:0;opacity:.07;background-repeat:no-repeat;background-position:center;background-size:150px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23d8b24c' stroke-width='1'%3E%3Cpath d='M7 14c-3 0-5-2-5-5s3-6 7-6c5 0 9 3 12 3 1.5 0 2-1 2-1s1 3-2 6c-4 4-9 8-13 8-3 0-5-2-5-4s2-3 4-3'/%3E%3C/svg%3E")}

/* ---------- Text-only product cards ---------- */
.eco-card--text{border-top:3px solid var(--gold-500)}
.eco-card--text .eco-body{padding:22px 20px 22px}
.eco-card--text .eco-body .badge{align-self:flex-start;margin-bottom:4px}
.eco-card--text h3{font-size:1.08rem}

/* ===== Compliance page components ===== */
.counters{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:6px}
@media(max-width:900px){.counters{grid-template-columns:repeat(2,1fr)}}
.counter{background:rgba(255,255,255,.06);border:1px solid rgba(216,178,76,.32);border-radius:14px;padding:22px 14px;text-align:center}
.counter strong{display:block;font-family:var(--serif);font-size:2.1rem;color:var(--gold-400);line-height:1}
.counter span{display:block;margin-top:8px;font-size:.8rem;color:#cddcd0;letter-spacing:.02em}
.feature--feat{border:2px solid var(--gold-500)}
.barlist{display:grid;gap:15px;max-width:780px;margin:0 auto}
.barrow .bl{display:flex;justify-content:space-between;font-size:.92rem;margin-bottom:7px;color:var(--green-800);font-weight:600}
.barrow .bl .lv{color:var(--gold-600)}
.track{height:9px;border-radius:50px;background:var(--cream-2);overflow:hidden}
.fill{height:100%;border-radius:50px;background:linear-gradient(90deg,var(--green-600),var(--gold-500));width:0;transition:width 1.1s ease}
.cwall{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
@media(max-width:900px){.cwall{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.cwall{grid-template-columns:repeat(2,1fr)}}
.cwall .w{background:#fff;border:1px solid var(--line);border-radius:12px;padding:15px 10px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:7px;min-height:100px;justify-content:center;transition:.2s}
.cwall .w:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.cwall .w .ico{color:var(--green-700)}
.cwall .w .ico svg{width:30px;height:30px}
.cwall .w b{font-size:.72rem;color:var(--green-900);font-weight:600;line-height:1.25}
.markets{display:grid;grid-template-columns:1.1fr 1fr;gap:34px;align-items:center}
@media(max-width:860px){.markets{grid-template-columns:1fr}}
.mk-grp{margin-bottom:14px}
.mk-grp h4{font-size:.95rem;margin-bottom:8px}
.mk-chip{display:inline-block;margin:4px 6px 0 0;padding:7px 13px;border-radius:50px;font-size:.82rem;font-weight:600;border:1px solid}
.mk-cur{background:#e2f0e6;color:#1c4d36;border-color:#b9d8c4}
.mk-tgt{background:#fbf0d6;color:#8a6410;border-color:#ecd79f}
.mk-exp{background:#e8edf2;color:#37506b;border-color:#c8d5e1}
.cstrip{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.cstrip .cs{background:rgba(255,255,255,.08);border:1px solid rgba(216,178,76,.35);color:var(--gold-400);font-size:.82rem;font-weight:600;padding:9px 15px;border-radius:50px}

.grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
@media(max-width:900px){.grid-5{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.grid-5{grid-template-columns:1fr}}

/* ===== Grouped dropdown nav ===== */
.menu .has-sub{position:relative}
.menu .subtoggle{padding:8px 9px;border-radius:7px;font-size:.83rem;font-weight:500;color:var(--green-800);white-space:nowrap;cursor:default;display:inline-flex;align-items:center;gap:5px}
.menu .has-sub.act .subtoggle{color:var(--gold-600);font-weight:600}
.menu .caret{font-size:.66em;opacity:.65;font-style:normal}
.menu .submenu{position:absolute;top:100%;left:0;min-width:232px;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);padding:8px;display:none;flex-direction:column;z-index:80}
.menu .has-sub.open .submenu{display:flex}
.menu .submenu a{padding:9px 12px;border-radius:7px;font-size:.86rem;color:var(--green-800);white-space:nowrap}
.menu .submenu a:hover{background:var(--cream-2);color:var(--green-900)}
.menu .submenu a.active{color:var(--gold-600);font-weight:600}
@media(max-width:1300px){
  .menu .has-sub{width:100%}
  .menu .subtoggle{display:block;padding:12px 10px;color:var(--gold-600);font-weight:600;border-top:1px solid var(--line)}
  .menu .caret{display:none}
  .menu .submenu{position:static;box-shadow:none;border:0;padding:0 0 6px 12px;min-width:0}
  .menu .submenu a{padding:9px 10px;font-size:.95rem}
}

/* ===== FAQ accordion ===== */
.faq{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:12px;overflow:hidden}
.faq summary{cursor:pointer;padding:16px 20px;font-weight:600;color:var(--green-900);font-size:1rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--gold-600);font-size:1.4rem;font-weight:400;line-height:1}
.faq[open] summary::after{content:"\2212"}
.faq summary:hover{background:var(--cream)}
.faq .faq-a{padding:0 20px 18px;color:#34403a;font-size:.95rem;line-height:1.6}

/* ===== Market intelligence ===== */
.mi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:760px){.mi-grid{grid-template-columns:1fr}}
.mi-stat{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px;border-top:3px solid var(--gold-500)}
.mi-stat .v{font-family:var(--serif);font-size:1.9rem;color:var(--green-800);line-height:1.05}
.mi-stat .l{color:var(--muted);font-size:.9rem;margin:10px 0 10px}
.mi-stat .src{font-size:.74rem;color:var(--muted)}
.mi-stat .src a{color:var(--gold-600)}

/* ===== Government registration logo grid ===== */
.gov-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
@media(max-width:900px){.gov-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.gov-grid{grid-template-columns:repeat(2,1fr)}}
.govtile{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 12px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;transition:.2s}
.govtile:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.govtile.feat{border:2px solid var(--gold-500)}
.govlogo{height:60px;display:flex;align-items:center;justify-content:center;width:100%}
.govlogo img{max-height:60px;max-width:100%;object-fit:contain}
.govfallback{display:none;width:58px;height:58px;border-radius:50%;background:var(--green-900);color:var(--gold-400);align-items:center;justify-content:center;font-family:var(--serif);font-weight:700;font-size:.92rem}
.govname{font-size:.78rem;color:var(--green-900);font-weight:600;line-height:1.25;min-height:30px;display:flex;align-items:center;text-align:center}
.govtile .badge{font-size:.62rem}

/* qualitative status dashboard */
.statrow{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 4px;border-bottom:1px solid var(--line)}
.statrow:last-child{border-bottom:none}
.statname{font-size:.95rem;font-weight:600;color:var(--green-800)}
.statrow .badge{font-size:.72rem;white-space:nowrap}
/* four-tier logo-safe compliance system */
.compliance-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
@media(max-width:980px){.compliance-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.compliance-grid{grid-template-columns:repeat(2,1fr)}}
.compliance-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 13px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:9px;transition:.2s}
.compliance-card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.org-logo{height:58px;display:flex;align-items:center;justify-content:center;width:100%}
.org-logo img{max-height:58px;max-width:100%;object-fit:contain}
.org-fallback{width:56px;height:56px;border-radius:50%;background:var(--green-900);color:var(--gold-400);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:700;font-size:.82rem;text-align:center;line-height:1}
.compliance-card__title{font-size:.82rem;color:var(--green-900);font-weight:700;line-height:1.25;margin:0;min-height:32px;display:flex;align-items:center}
.compliance-card__meta{font-size:.74rem;color:var(--muted);line-height:1.42;margin:0}
.status-badge{font-size:.62rem;font-weight:700;letter-spacing:.01em;padding:4px 9px;border-radius:50px;line-height:1.3;max-width:100%}
.badge--registered{background:#e8f7ee;color:#166534;border:1px solid #b7e4c7}
.badge--pending{background:#fff4e5;color:#9a5b00;border:1px solid #f3c783}
.badge--strategic{background:#fff8db;color:#8a6a00;border:1px solid #ead48a}
.badge--roadmap{background:#f3f4f6;color:#4b5563;border:1px solid #d1d5db}
.policy-note{font-size:.7rem;color:var(--muted);font-style:italic;margin:2px 0 0;line-height:1.4}
.policy-note--block{max-width:820px;margin:16px auto 0;text-align:center}
.disclosure-note{font-size:.78rem;color:var(--muted);max-width:940px;margin:18px auto 0;text-align:center;line-height:1.55}
.compliance-empty{background:#fff;border:1px dashed var(--line);border-radius:14px;padding:26px 22px;text-align:center;color:var(--muted);font-size:.92rem;max-width:760px;margin:0 auto;line-height:1.5}

/* disclosure callout */
.disclosure-callout{max-width:960px;margin:0 auto;background:#fff;border:1px solid var(--line);border-left:4px solid var(--gold-500);border-radius:12px;padding:16px 22px}
.disclosure-callout .disclosure-note{margin:0 0 8px;text-align:left}
.disclosure-callout .disclosure-note:last-child{margin-bottom:0}

/* feature & wall logos (70px, contain) */
.feature-logo{height:70px;display:flex;align-items:center;justify-content:flex-start;margin-bottom:16px}
.feature-logo img{max-height:70px;max-width:100%;object-fit:contain}
.cwall .w .w-logo{height:60px;display:flex;align-items:center;justify-content:center;width:100%}
.cwall .w .w-logo img{max-height:60px;max-width:100%;object-fit:contain}

.feature-logo--custom svg{height:70px;width:auto}

/* centered logo cards (Sections 6 & 7) */
.logos-centered .feature{text-align:center}
.logos-centered .feature .feature-logo{justify-content:center}
.logos-centered .feature .ico{margin-left:auto;margin-right:auto}
.logos-centered .feature-logo img{margin-left:auto;margin-right:auto;object-fit:contain}
/* footer legal links + contact form a11y (security/UX pass) */
.footer-legal{display:flex;flex-wrap:wrap;gap:8px 18px;justify-content:center;padding:14px 0 4px;border-top:1px solid rgba(255,255,255,.08);margin-top:10px}
.footer-legal a{color:var(--gold-400);font-size:.8rem;opacity:.85}
.footer-legal a:hover{opacity:1;text-decoration:underline}
.hp-field{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
.field .req{color:#b8860b}
.field--consent .consent{display:flex;gap:9px;align-items:flex-start;font-size:.86rem;color:var(--muted);font-weight:400;line-height:1.45;cursor:pointer}
.field--consent input{margin-top:3px;flex:none;width:16px;height:16px}
/* ===== Phase 2 accessibility: skip link, focus, reveal failsafe, reduced motion, lightbox, print ===== */
.skip-link{position:absolute;left:8px;top:-52px;z-index:300;background:var(--green-900);color:#fff;padding:10px 16px;border-radius:8px;font-weight:600;transition:top .15s ease}
.skip-link:focus{top:8px;outline:3px solid var(--gold-500);outline-offset:2px}
:focus-visible{outline:3px solid var(--gold-500);outline-offset:3px}
body.nav-open{overflow:hidden}
.menu .subtoggle{background:none;border:0;font:inherit;cursor:pointer}
.menu .has-sub.open>.submenu{display:flex}
.menu .caret{transition:transform .15s ease}
.menu .has-sub.open .caret{transform:rotate(180deg)}
@media(hover:hover) and (min-width:861px){.menu .has-sub:hover>.submenu{display:flex}}
.lb-prev,.lb-next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);color:#fff;font-size:2rem;line-height:1;width:48px;height:48px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}
.lb-prev{left:18px}.lb-next{right:18px}
.lb-close{background:none;border:0}
.lb-cap{position:absolute;bottom:16px;left:0;right:0;text-align:center;color:#e8eee9;font-size:.9rem;padding:0 20px}
.lb-prev:hover,.lb-next:hover,.lb-close:hover{background:rgba(255,255,255,.25)}
.field input:focus-visible,.field textarea:focus-visible,.field select:focus-visible{outline:3px solid var(--gold-500);outline-offset:2px}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .js-enabled .reveal{opacity:1!important;transform:none!important;transition:none!important}
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
}
@media print{
  .topbar,.site-header,.menu,.menu-toggle,.skip-link,.cta-band,.req-grid,.lb,.footer-legal{display:none!important}
  body{color:#000;background:#fff}
  .page-hero-bg,.bg-green::before{display:none!important}
  .page-hero,.bg-green,.bg-cream2,.section{background:#fff!important;color:#000!important}
  .page-hero h1,.page-hero .lead{color:#000!important}
  a[href^="http"]::after{content:" (" attr(href) ")";font-size:.82em;color:#555}
  .feature,.compliance-card,.cwall .w,.doc-cat{break-inside:avoid;page-break-inside:avoid}
}

/* Phase 3: webp picture wrappers keep image layout */
picture{display:contents}
