/* ================================================================
   AFRICA GATEWAY · style.css · Full rebuild May 2026
   ================================================================ */

/* ── Variables ───────────────────────────────────────────────── */
:root {
  --bg:      #0a1628;
  --bg2:     #0d1e38;
  --bg3:     #0f2340;
  --gold:    #c9820a;
  --gold-lt: #e09b20;
  --gold-dk: #9a6108;
  --green:   #1a6b3a;
  --grn-lt:  #22874a;
  --cream:   #e8dcc8;
  --cream-d: #b8ad9a;
  --muted:   #4a5e78;
  --border:  rgba(201,130,10,.15);
  --bord2:   rgba(232,220,200,.08);
  --glass:   rgba(13,30,56,.7);
  --fd:      'Cormorant Garamond', Georgia, serif;
  --fu:      'Syne', sans-serif;
  --fm:      'JetBrains Mono', monospace;
  --ease:    cubic-bezier(.16,1,.3,1);
}

/* ── Reset ───────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--cream);font-family:var(--fu);overflow-x:hidden}
@media(pointer:fine){body{cursor:none}}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
ul{list-style:none}

/* ── Cursor ──────────────────────────────────────────────────── */
.cursor-dot,.cursor-ring{display:none}
@media(pointer:fine){
  .cursor-dot,.cursor-ring{display:block;position:fixed;border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%)}
  .cursor-dot{width:6px;height:6px;background:var(--gold)}
  .cursor-ring{width:32px;height:32px;border:1px solid var(--gold);opacity:.5;transition:width .2s var(--ease),height .2s var(--ease),opacity .3s}
  body:has(a:hover) .cursor-ring,body:has(button:hover) .cursor-ring{width:48px;height:48px;opacity:.8;border-color:var(--gold-lt)}
}

/* ── Preloader ───────────────────────────────────────────────── */
.preloader{position:fixed;inset:0;z-index:10000;background:var(--bg);display:flex;align-items:center;justify-content:center;transition:opacity .8s var(--ease);animation:preHide .6s ease 4s forwards}
@keyframes preHide{to{opacity:0;pointer-events:none}}
.preloader.done{opacity:0;pointer-events:none;animation:none}
.pre-inner{text-align:center}
.pre-map{width:88px;height:88px;margin:0 auto 24px;overflow:visible}
.africa-stroke{stroke-dasharray:8000;stroke-dashoffset:8000;animation:drawStroke 2.4s var(--ease) .2s forwards}
.africa-fill{animation:fillFade .6s ease 2.4s forwards}
@keyframes drawStroke{to{stroke-dashoffset:0}}
@keyframes fillFade{to{opacity:.12}}
.pre-text{display:flex;align-items:center;gap:16px;opacity:0;animation:fadeUp .6s var(--ease) 1.8s forwards}
.pre-word{font-family:var(--fd);font-size:22px;letter-spacing:6px;color:var(--cream)}
.pre-div{width:1px;height:20px;background:var(--gold);opacity:.5}
.pre-prog{width:160px;height:1px;background:rgba(201,130,10,.2);margin:20px auto 0;border-radius:2px;overflow:hidden;opacity:0;animation:fadeUp .4s ease 1.8s forwards}
.pre-bar{height:100%;width:0%;background:linear-gradient(90deg,var(--gold-dk),var(--gold-lt));transition:width .05s linear}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* ── Nav ─────────────────────────────────────────────────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:20px 48px;transition:padding .4s var(--ease),background .4s,backdrop-filter .4s}
.nav.scrolled{padding:14px 48px;background:rgba(10,22,40,.93);backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.nav-logo{display:flex;align-items:center}
.nav-logo-img{height:52px;width:auto;border-radius:6px}
.nav-logo-fb{display:flex;flex-direction:column;line-height:1.1}
.nav-logo-af{font-family:var(--fd);font-size:18px;font-weight:700;color:var(--gold);letter-spacing:3px}
.nav-logo-gw{font-family:var(--fm);font-size:9px;color:var(--cream-d);letter-spacing:5px}
.nav-links{display:flex;align-items:center;gap:40px}
.nav-link{font-size:13px;letter-spacing:1.5px;text-transform:uppercase;color:var(--cream-d);position:relative;transition:color .3s}
.nav-link::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:right;transition:transform .3s var(--ease)}
.nav-link:hover,.nav-link.active{color:var(--cream)}
.nav-link:hover::after,.nav-link.active::after{transform:scaleX(1);transform-origin:left}
.nav-link.nav-cta{padding:8px 20px;border:1px solid var(--gold);border-radius:2px;color:var(--gold)}
.nav-link.nav-cta::after{display:none}
.nav-link.nav-cta:hover{background:var(--gold);color:var(--bg)}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.nav-burger span{display:block;width:24px;height:1px;background:var(--cream);transition:transform .3s,opacity .3s}
.nav-burger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* ── Mobile menu ─────────────────────────────────────────────── */
.mobile-menu{position:fixed;inset:0;z-index:999;background:var(--bg);display:flex;align-items:center;justify-content:center;clip-path:circle(0% at calc(100% - 60px) 44px);transition:clip-path .6s var(--ease)}
.mobile-menu.open{clip-path:circle(150% at calc(100% - 60px) 44px)}
.mobile-menu ul{display:flex;flex-direction:column;gap:32px;text-align:center}
.mm-link{font-family:var(--fd);font-size:42px;font-weight:300;color:var(--cream-d);transition:color .2s}
.mm-link:hover{color:var(--gold)}

/* ── Hero ────────────────────────────────────────────────────── */
.hero{min-height:100vh;position:relative;display:flex;align-items:center;padding:120px 48px 80px;overflow:hidden}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.hero-grain{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");opacity:.4}
.hero-glow{position:absolute;border-radius:50%;filter:blur(120px);pointer-events:none}
.glow-1{width:600px;height:600px;top:-100px;left:-100px;background:radial-gradient(circle,rgba(201,130,10,.12) 0%,transparent 70%);animation:glowF 8s ease-in-out infinite alternate}
.glow-2{width:500px;height:500px;bottom:0;right:200px;background:radial-gradient(circle,rgba(26,107,58,.1) 0%,transparent 70%);animation:glowF 10s ease-in-out infinite alternate-reverse}
@keyframes glowF{0%{transform:translate(0,0) scale(1)}100%{transform:translate(40px,30px) scale(1.1)}}
.hero-particles{position:absolute;inset:0;width:100%;height:100%}
.hero-content{position:relative;z-index:2;max-width:700px}
.hero-badge{display:inline-flex;align-items:center;gap:10px;padding:8px 18px;border:1px solid var(--border);border-radius:100px;font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--cream-d);margin-bottom:32px;background:var(--glass);backdrop-filter:blur(10px)}
.badge-dot{width:6px;height:6px;border-radius:50%;background:var(--grn-lt);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 4px var(--grn-lt)}50%{box-shadow:0 0 12px var(--grn-lt),0 0 24px rgba(26,107,58,.4)}}
.hero-title{display:flex;flex-direction:column;margin-bottom:28px}
.ht-line{font-family:var(--fd);font-size:clamp(52px,7vw,88px);font-weight:300;line-height:1.05;color:var(--cream);letter-spacing:-1px}
.ht-accent{color:var(--gold);font-style:italic}
.hero-sub{font-size:17px;line-height:1.75;color:var(--cream-d);max-width:520px;margin-bottom:40px;font-weight:300}
.hero-actions{display:flex;align-items:center;gap:20px;margin-bottom:56px}
.hero-stats{display:flex;align-items:center;gap:32px}
.stat{display:flex;flex-direction:column;gap:4px}
.stat-num{font-family:var(--fd);font-size:36px;font-weight:600;color:var(--gold);line-height:1}
.stat-label{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted)}
.stat-div{width:1px;height:48px;background:var(--border)}
.hero-scroll{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:2}
.scroll-line{width:1px;height:60px;background:linear-gradient(to bottom,var(--gold),transparent);animation:scrollD 2s ease-in-out infinite}
@keyframes scrollD{0%,100%{transform:scaleY(1) translateY(0);opacity:.8}50%{transform:scaleY(.5) translateY(10px);opacity:.3}}
.hero-scroll span{font-size:10px;letter-spacing:3px;color:var(--muted);text-transform:uppercase}

/* ── Hero Africa map ─────────────────────────────────────────── */
.hero-africa{position:absolute;right:5%;top:50%;transform:translateY(-50%);z-index:1;pointer-events:none;opacity:0;animation:fadeInR 1.2s var(--ease) 1.4s forwards}
.africa-svg{width:clamp(220px,24vw,400px);filter:drop-shadow(0 0 28px rgba(201,130,10,.14));overflow:visible}
@keyframes fadeInR{from{opacity:0;transform:translateY(-50%) translateX(40px)}to{opacity:1;transform:translateY(-50%) translateX(0)}}
@keyframes tradePulse{0%,100%{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.5)}}

/* ── Buttons ─────────────────────────────────────────────────── */
.btn-primary{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;background:var(--gold);color:var(--bg);font-family:var(--fu);font-size:13px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;border-radius:2px;border:none;cursor:pointer;position:relative;overflow:hidden;--mx:0px;--my:0px;transform:translate(var(--mx),var(--my));transition:transform .3s var(--ease),box-shadow .3s}
.btn-primary::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);transform:translateX(-100%);transition:transform .5s}
.btn-primary:hover::before{transform:translateX(100%)}
.btn-primary:hover{box-shadow:0 12px 40px rgba(201,130,10,.35)}
.btn-primary svg{width:18px;height:18px;transition:transform .3s}
.btn-primary:hover svg{transform:translateX(4px)}
.btn-ghost{display:inline-flex;align-items:center;padding:14px 28px;border:1px solid var(--border);color:var(--cream-d);font-size:13px;letter-spacing:1.5px;text-transform:uppercase;border-radius:2px;cursor:pointer;transition:border-color .3s,color .3s}
.btn-ghost:hover{border-color:var(--cream-d);color:var(--cream)}
.btn-sm{padding:10px 20px;font-size:12px}

/* ── Ticker ──────────────────────────────────────────────────── */
.ticker-wrap{overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg2);padding:14px 0}
.ticker-track{display:flex;white-space:nowrap;animation:ticker 30s linear infinite}
.ticker-item{font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--cream-d);padding:0 24px}
.ticker-sep{color:var(--gold);padding:0 4px;opacity:.6}
.ticker-wrap:hover .ticker-track{animation-play-state:paused}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── Trust bar ───────────────────────────────────────────────── */
.trust-bar{background:var(--bg3);border-top:1px solid var(--bord2);border-bottom:1px solid var(--bord2);padding:20px 0}
.trust-items{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:10px;padding:8px 28px;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--cream-d)}
.trust-item svg{width:18px;height:18px;color:var(--gold);flex-shrink:0}
.trust-div{width:1px;height:28px;background:var(--bord2)}

/* ── Layout ──────────────────────────────────────────────────── */
.container{max-width:1280px;margin:0 auto;padding:0 48px}
.section{padding:120px 0;position:relative}
.section-label{font-family:var(--fm);font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:16px;display:flex;align-items:center;gap:12px}
.section-label::before{content:'';display:block;width:24px;height:1px;background:var(--gold)}
.section-title{font-family:var(--fd);font-size:clamp(36px,4.5vw,64px);font-weight:300;line-height:1.1;color:var(--cream);margin-bottom:24px}
.section-title em{color:var(--gold);font-style:italic}
.section-title.centered{text-align:center}
.section-sub{font-size:16px;color:var(--cream-d);line-height:1.7;text-align:center;max-width:560px;margin:0 auto 64px}
.section-header{text-align:center;margin-bottom:64px}
.section-header .section-label{justify-content:center}
.section-header .section-label::before{display:none}

/* ── About ───────────────────────────────────────────────────── */
.about{background:var(--bg)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-body{font-size:16px;line-height:1.85;color:var(--cream-d);margin-bottom:16px;font-weight:300}
.about-pillars{display:flex;flex-direction:column;gap:20px;margin-top:36px}
.pillar{display:flex;align-items:flex-start;gap:16px;padding:16px 20px;border:1px solid var(--bord2);border-radius:4px;background:rgba(255,255,255,.02);transition:border-color .3s,background .3s,transform .3s var(--ease)}
.pillar:hover{border-color:var(--border);background:rgba(201,130,10,.04);transform:translateX(6px)}
.pillar-icon{color:var(--gold);font-size:18px;margin-top:2px}
.pillar-title{font-size:14px;font-weight:600;color:var(--cream);margin-bottom:4px}
.pillar-desc{font-size:13px;color:var(--muted)}
.about-card{position:relative;border-radius:8px;overflow:hidden;border:1px solid var(--border);background:var(--bg2);transition:transform .4s var(--ease),box-shadow .4s}
.about-card:hover{transform:translateY(-8px);box-shadow:0 40px 80px rgba(0,0,0,.4)}
.about-card-inner{padding:48px 40px;position:relative;z-index:1}
.acard-top{display:flex;align-items:center;gap:12px;margin-bottom:32px}
.acard-flag{font-size:28px}
.acard-location{font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--muted)}
.acard-quote{font-family:var(--fd);font-style:italic;font-size:22px;line-height:1.6;color:var(--cream);margin-bottom:32px;border-left:2px solid var(--gold);padding-left:20px}
.acard-sig{margin-bottom:24px}
.acard-name{font-size:16px;font-weight:700;color:var(--cream);margin-bottom:4px}
.acard-role{font-size:12px;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase}
.acard-contact{display:flex;flex-direction:column;gap:8px;border-top:1px solid var(--bord2);padding-top:20px}
.acard-link{font-family:var(--fm);font-size:13px;color:var(--gold);transition:color .2s}
.acard-link:hover{color:var(--gold-lt)}
.about-card-glow{position:absolute;bottom:-60px;right:-60px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(201,130,10,.15) 0%,transparent 70%);pointer-events:none}

/* ── Products ────────────────────────────────────────────────── */
.products{background:var(--bg2)}
.products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:8px;overflow:hidden}
.product-card{background:var(--bg);position:relative;overflow:hidden;display:flex;flex-direction:column;transition:background .4s}
.product-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;z-index:2;background:linear-gradient(90deg,var(--gold),var(--green));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.product-card:hover{background:var(--bg3)}
.product-card:hover::after{transform:scaleX(1)}
.pc-img-wrap{position:relative;overflow:hidden;height:200px;flex-shrink:0}
.pc-img{width:100%;height:100%;object-fit:cover;filter:brightness(.75) saturate(.9);transition:transform .6s var(--ease),filter .4s}
.product-card:hover .pc-img{transform:scale(1.06);filter:brightness(.65) saturate(1.1)}
.pc-img-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(10,22,40,.92) 100%)}
.pc-origin{position:absolute;top:14px;right:14px;font-family:var(--fm);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--cream-d);background:rgba(10,22,40,.75);backdrop-filter:blur(8px);border:1px solid var(--border);padding:5px 12px;border-radius:100px}
.pc-body{padding:28px 32px 32px;flex:1;display:flex;flex-direction:column}
.pc-name{font-family:var(--fd);font-size:24px;font-weight:600;color:var(--cream);margin-bottom:10px}
.pc-desc{font-size:13px;line-height:1.7;color:var(--muted);margin-bottom:20px;font-weight:300;flex:1}
.pc-specs{display:flex;flex-direction:column;gap:7px;margin-bottom:24px}
.pc-spec{display:flex;justify-content:space-between;font-size:12px;padding-bottom:7px;border-bottom:1px solid var(--bord2)}
.pc-spec span:first-child{color:var(--muted)}
.pc-spec span:last-child{color:var(--cream-d);font-weight:500}
.pc-btn{font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);cursor:pointer;align-self:flex-start;transition:letter-spacing .3s,color .2s}
.pc-btn:hover{letter-spacing:3px;color:var(--gold-lt)}
.product-card--more{display:flex;align-items:center;justify-content:center;text-align:center;background:var(--bg2);min-height:380px}
.pc-more-inner{display:flex;flex-direction:column;align-items:center;gap:16px}
.pc-more-icon{font-size:48px;font-weight:100;color:var(--muted);line-height:1}
.product-card--more p{font-size:14px;color:var(--muted)}

/* ── Process ─────────────────────────────────────────────────── */
.process{background:var(--bg)}
.process-bg{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at 50% 50%,rgba(201,130,10,.04) 0%,transparent 70%)}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);position:relative;padding-bottom:16px}
.process-line{position:absolute;top:32px;left:10%;right:10%;height:1px;background:var(--border);z-index:0}
.process-line::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,var(--gold),var(--green));transform:scaleX(0);transform-origin:left;animation:lineG 2s var(--ease) .5s forwards}
@keyframes lineG{to{transform:scaleX(1)}}
.process-step{padding:0 32px;position:relative;z-index:1;transition:transform .4s var(--ease)}
.process-step:hover{transform:translateY(-10px)}
.ps-num{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:22px;color:var(--gold);border:1px solid var(--border);background:var(--bg);margin-bottom:20px;transition:background .3s,border-color .3s,color .3s}
.process-step:hover .ps-num{background:var(--gold);color:var(--bg);border-color:var(--gold)}
.ps-content h3{font-family:var(--fd);font-size:22px;font-weight:600;color:var(--cream);margin-bottom:12px}
.ps-content p{font-size:14px;color:var(--muted);line-height:1.7}

/* ── Global Reach ────────────────────────────────────────────── */
.social-proof{background:var(--bg3)}
.sp-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-bottom:48px}
.sp-cta{display:flex;align-items:center;gap:20px;justify-content:center}
.dest-label{font-family:var(--fm);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:16px}
.dest-flags{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.dest-item{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--bg2);border:1px solid var(--bord2);border-radius:4px;font-size:13px;color:var(--cream-d);transition:border-color .2s,background .2s}
.dest-item:hover{border-color:var(--border);background:var(--bg3)}
.dest-item span:first-child{font-size:18px}
.dest-more{color:var(--muted);font-style:italic}
.cert-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 24px}
.cert-item{display:flex;align-items:center;gap:12px;font-size:14px;color:var(--cream-d)}
.cert-check{color:var(--gold);font-weight:700;font-size:14px;width:20px;flex-shrink:0}

/* ── FAQ ─────────────────────────────────────────────────────── */
.faq{background:var(--bg2)}
.faq-grid{max-width:860px;margin:0 auto;border:1px solid var(--bord2);border-radius:8px;overflow:hidden}
.faq-item{border-bottom:1px solid var(--bord2)}
.faq-item:last-child{border-bottom:none}
.faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:22px 28px;display:flex;align-items:center;justify-content:space-between;gap:16px;font-family:var(--fu);font-size:15px;font-weight:600;color:var(--cream);transition:background .2s,color .2s}
.faq-q:hover{background:rgba(201,130,10,.04);color:var(--gold)}
.faq-item.open .faq-q{color:var(--gold);background:rgba(201,130,10,.05)}
.faq-icon{font-size:22px;font-weight:300;color:var(--muted);flex-shrink:0;line-height:1;transition:transform .3s var(--ease),color .2s}
.faq-item.open .faq-icon{transform:rotate(45deg);color:var(--gold)}
.faq-a{max-height:0;overflow:hidden;font-size:14px;line-height:1.8;color:var(--muted);padding:0 28px;transition:max-height .4s var(--ease),padding .3s}
.faq-item.open .faq-a{max-height:300px;padding:0 28px 22px}

/* ── Contact ─────────────────────────────────────────────────── */
.contact{background:var(--bg2)}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start}
.contact-sub{font-size:16px;color:var(--cream-d);line-height:1.7;margin-bottom:40px;font-weight:300}
.contact-info{display:flex;flex-direction:column;gap:20px}
.ci-item{display:flex;align-items:center;gap:20px;padding:20px;border:1px solid var(--bord2);border-radius:4px;transition:border-color .3s,transform .3s var(--ease),background .3s}
.ci-item:hover{border-color:var(--border);background:rgba(201,130,10,.04);transform:translateX(6px)}
.ci-icon{width:44px;height:44px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ci-icon svg{width:18px;height:18px;color:var(--gold)}
.ci-label{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.ci-value{font-family:var(--fm);font-size:14px;color:var(--cream-d)}
.contact-form{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:48px 40px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.form-group label{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);transition:color .3s}
.form-group.focused label{color:var(--gold)}
.req{color:var(--gold)}
.form-group input,.form-group select,.form-group textarea{background:var(--bg2);border:1px solid var(--bord2);border-radius:3px;padding:12px 16px;color:var(--cream);font-family:var(--fu);font-size:15px;transition:border-color .3s,box-shadow .3s;outline:none;width:100%;-webkit-appearance:none}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--muted)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,130,10,.1)}
.form-group select option{background:var(--bg2)}
.form-group textarea{resize:vertical;min-height:120px}
.btn-submit{width:100%;justify-content:center;margin-top:8px}
.btn-loader .spin{width:18px;height:18px;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.form-note{font-size:12px;color:var(--muted);text-align:center;margin-top:16px;line-height:1.6}
.form-msg{margin-top:16px;padding:14px 20px;border-radius:4px;font-size:14px;display:none}
.form-msg.success{background:rgba(26,107,58,.2);border:1px solid rgba(26,107,58,.4);color:#4ade80}
.form-msg.error{background:rgba(220,38,38,.15);border:1px solid rgba(220,38,38,.3);color:#f87171}

/* ── Footer ──────────────────────────────────────────────────── */
.footer{background:var(--bg);border-top:1px solid var(--border);position:relative;overflow:hidden}
.footer-glow{position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:600px;height:200px;pointer-events:none;background:radial-gradient(ellipse,rgba(201,130,10,.06) 0%,transparent 70%)}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px;padding:80px 0 60px}
.footer-logo{height:64px;width:auto;margin-bottom:16px;border-radius:6px}
.footer-logo-text{font-family:var(--fd);font-size:22px;letter-spacing:4px;color:var(--gold);margin-bottom:16px}
.footer-tagline{font-size:14px;color:var(--muted);line-height:1.7;margin-bottom:24px}
.footer-social{display:flex;gap:12px}
.social-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--muted);transition:border-color .3s,color .3s,transform .3s var(--ease)}
.social-btn:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-3px)}
.footer-col h4{font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--cream-d);margin-bottom:20px}
.footer-col ul{display:flex;flex-direction:column;gap:12px}
.footer-col li a{font-size:14px;color:var(--muted);transition:color .2s,padding-left .2s}
.footer-col li a:hover{color:var(--cream-d);padding-left:4px}
.footer-certs{display:flex;flex-wrap:wrap;gap:12px;padding:20px 0;border-top:1px solid var(--bord2);border-bottom:1px solid var(--bord2);margin-bottom:24px}
.fcert{font-size:11px;letter-spacing:1px;color:var(--muted);padding:5px 14px;border:1px solid var(--bord2);border-radius:100px;transition:color .2s,border-color .2s}
.fcert:hover{color:var(--cream-d);border-color:var(--border)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding:24px 0;border-top:1px solid var(--bord2);font-size:13px;color:var(--muted)}
.footer-legal{display:flex;gap:24px}
.footer-legal a:hover{color:var(--cream-d)}

/* ── WhatsApp sticky ─────────────────────────────────────────── */
.whatsapp-sticky{position:fixed;bottom:28px;right:28px;width:56px;height:56px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;z-index:500;cursor:pointer;box-shadow:0 4px 24px rgba(37,211,102,.35);transition:transform .3s var(--ease),box-shadow .3s}
.whatsapp-sticky svg{width:28px;height:28px}
.whatsapp-sticky:hover{transform:scale(1.1) translateY(-2px);box-shadow:0 8px 32px rgba(37,211,102,.5)}
.wa-tooltip{position:absolute;right:68px;background:var(--bg2);color:var(--cream);font-size:12px;letter-spacing:1px;padding:6px 14px;border-radius:4px;white-space:nowrap;border:1px solid var(--border);opacity:0;pointer-events:none;transform:translateX(8px);transition:opacity .2s,transform .2s}
.wa-tooltip::after{content:'';position:absolute;right:-6px;top:50%;transform:translateY(-50%);border:5px solid transparent;border-left-color:var(--border)}
.whatsapp-sticky:hover .wa-tooltip{opacity:1;transform:translateX(0)}

/* ── Mobile CTA bar ──────────────────────────────────────────── */
.mobile-cta-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:400;background:var(--bg2);border-top:1px solid var(--border);padding:12px 16px;gap:10px;backdrop-filter:blur(16px)}
.mcta-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 8px;border-radius:4px;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .2s}
.mcta-btn:active{transform:scale(.97)}
.mcta-call{background:var(--bg3);color:var(--cream-d);border:1px solid var(--border)}
.mcta-call svg{width:16px;height:16px}
.mcta-enquire{background:var(--gold);color:var(--bg);border:none}
.mcta-wa{background:#25D366;color:#fff;border:none}
.mcta-wa svg{width:16px;height:16px}

/* ── Reveal animations ───────────────────────────────────────── */
.reveal-up,.reveal-left,.reveal-right{opacity:0;transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal-up{transform:translateY(40px)}
.reveal-left{transform:translateX(-40px)}
.reveal-right{transform:translateX(40px)}
.revealed{opacity:1!important;transform:translate(0)!important}

/* ── Responsive 1024 ─────────────────────────────────────────── */
@media(max-width:1024px){
  .nav{padding:18px 32px}
  .nav.scrolled{padding:12px 32px}
  .nav-links{gap:28px}
  .hero{padding:120px 32px 80px}
  .hero-africa{display:none}
  .container{padding:0 32px}
  .about-grid{grid-template-columns:1fr;gap:48px}
  .products-grid{grid-template-columns:repeat(2,1fr)}
  .process-steps{grid-template-columns:repeat(2,1fr);gap:48px}
  .process-line{display:none}
  .sp-grid{grid-template-columns:1fr;gap:40px}
  .dest-flags{grid-template-columns:repeat(3,1fr)}
  .contact-grid{grid-template-columns:1fr;gap:48px}
  .footer-top{grid-template-columns:1fr 1fr;gap:40px}
  .trust-items{gap:0}
  .trust-item{padding:8px 16px;font-size:11px}
}

/* ── Responsive 768 ──────────────────────────────────────────── */
@media(max-width:768px){
  body{cursor:auto;padding-bottom:72px}
  .cursor-dot,.cursor-ring{display:none}
  .nav{padding:16px 24px}
  .nav.scrolled{padding:12px 24px}
  .nav-links{display:none}
  .nav-burger{display:flex}
  .hero{padding:100px 24px 60px}
  .hero-actions{flex-direction:column;align-items:flex-start;gap:12px}
  .hero-stats{gap:20px}
  .container{padding:0 24px}
  .section{padding:80px 0}
  .products-grid{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .contact-form{padding:32px 24px}
  .footer-top{grid-template-columns:1fr;gap:32px}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center}
  .trust-items{flex-direction:column;align-items:flex-start;gap:4px;padding:0 24px}
  .trust-div{display:none}
  .whatsapp-sticky{display:none}
  .mobile-cta-bar{display:flex}
  .dest-flags{grid-template-columns:repeat(2,1fr)}
  .cert-grid{grid-template-columns:1fr}
  .sp-cta{flex-direction:column;align-items:stretch}
  .faq-q{padding:18px 20px;font-size:14px}
  .faq-a{padding:0 20px}
  .faq-item.open .faq-a{padding:0 20px 18px}
}

/* ================================================================
   PRODUCTS v3 — Commodity Catalogue layout
   Aspect-ratio cards · always-visible strip · hover expand
   ================================================================ */

/* ── Hide ALL previous product CSS classes ────────────────────── */
.region-block,.region-header,.region-flag,.region-label,.region-title,
.country-cards,.country-card,.cc-top,.cc-flag-wrap,.cc-flag,.cc-origin,
.cc-country,.cc-stat-line,.cc-badge,.cc-badge--secondary,.cc-desc,
.cc-spec-grid,.cc-spec-col,.cc-spec-label,.cc-spec-items,.cc-spec-item,
.cc-market-note,.cc-actions,.cc-btn,.cc-incoterms,
.prod-region,.prod-region-hd,.prod-region-line,.prod-region-label,
.prod-region-icon,.prod-region-name,.prod-region-sub,
.prod-grid,.prod-grid--2,.prod-grid--3,.prod-grid--4,
.prod-card,.prod-card--wide,.prod-img-wrap,.prod-img,.prod-img-overlay,
.prod-flag-badge,.prod-hover-panel,.php-title,.php-specs,.php-row,
.php-btn,.prod-body,.prod-commodity,.prod-country,.prod-desc,
.prod-meta,.prod-moq,.prod-incot { display: none !important; }

/* ── Category block ───────────────────────────────────────────── */
.cat-block { margin-bottom: 80px; }

.cat-hd {
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 20px 0 28px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 28px;
}
.cat-num {
  font-family: var(--fd);
  font-size: 56px;
  font-weight: 300;
  color: rgba(201,130,10,.18);
  line-height: 1;
  flex-shrink: 0;
  width: 64px;
  text-align: right;
  letter-spacing: -2px;
}
.cat-info { flex: 1; }
.cat-region {
  font-family: var(--fd);
  font-size: 26px;
  font-weight: 600;
  color: var(--cream);
  line-height: 1.1;
  margin-bottom: 4px;
}
.cat-commodities {
  font-family: var(--fm);
  font-size: 10px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--muted);
}
.cat-count {
  font-family: var(--fm);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  padding: 6px 14px;
  border: 1px solid var(--bord2);
  border-radius: 100px;
  flex-shrink: 0;
}

/* ── Card grids ───────────────────────────────────────────────── */
.pcard-grid {
  display: grid;
  gap: 16px;
}
.pcard-grid--2 { grid-template-columns: 1fr 1fr; }
.pcard-grid--3 { grid-template-columns: repeat(3, 1fr); }
.pcard-grid--4 { grid-template-columns: repeat(4, 1fr); }

/* ── Product card — THE image IS the card ─────────────────────── */
.pcard {
  /* Fixed aspect ratio — image always fills exactly this */
  aspect-ratio: 3 / 4;
  position: relative;
  border-radius: 6px;
  overflow: hidden;
  cursor: pointer;
  /* Subtle gold border on hover */
  outline: 1px solid transparent;
  outline-offset: -1px;
  transition: outline-color .3s, transform .4s var(--ease), box-shadow .4s var(--ease);
}
.pcard:hover {
  outline-color: var(--border);
  transform: translateY(-4px);
  box-shadow: 0 20px 48px rgba(0,0,0,.5);
}

/* Inner wrapper fills the card */
.pcard-inner {
  position: absolute;
  inset: 0;
}

/* Image fills entire card — object-fit covers */
.pcard-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform .6s var(--ease), filter .4s;
  filter: brightness(.78) saturate(.9);
}
.pcard:hover .pcard-img {
  transform: scale(1.05);
  filter: brightness(.55) saturate(1.05);
}

/* Permanent gradient — content always readable */
.pcard-gradient {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      to bottom,
      transparent 20%,
      rgba(10,22,40,.4) 50%,
      rgba(10,22,40,.92) 80%,
      rgba(10,22,40,.98) 100%
    );
  pointer-events: none;
  z-index: 1;
}

/* Content lives at the bottom — always visible strip + expandable specs */
.pcard-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 2;
  padding: 0 18px 18px;
}

/* Top row: flag · origin · MOQ badge */
.pcard-top {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}
.pcard-flag { font-size: 16px; line-height: 1; flex-shrink: 0; }
.pcard-origin {
  font-family: var(--fm);
  font-size: 10px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--cream-d);
  flex: 1;
}
.pcard-moq {
  font-family: var(--fm);
  font-size: 9px;
  letter-spacing: 1px;
  color: var(--gold);
  background: rgba(201,130,10,.15);
  border: 1px solid rgba(201,130,10,.25);
  padding: 3px 9px;
  border-radius: 100px;
  white-space: nowrap;
  flex-shrink: 0;
}

/* Product name — always visible */
.pcard-name {
  font-family: var(--fd);
  font-size: 22px;
  font-weight: 600;
  color: var(--cream);
  line-height: 1.15;
  margin-bottom: 0;
  transition: margin-bottom .35s var(--ease);
}
/* On hover, push name up to make room for specs */
.pcard:hover .pcard-name {
  margin-bottom: 14px;
}

/* Expandable specs block — hidden by default, slides in on hover */
.pcard-expand {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows .4s var(--ease), opacity .35s;
  opacity: 0;
}
.pcard:hover .pcard-expand {
  grid-template-rows: 1fr;
  opacity: 1;
}
/* Inner wrapper needed for grid-template-rows collapse */
.pcard-expand > * {
  overflow: hidden;
}
/* But we want pcard-specs/note/cta inside a single element — use wrapper div trick */
.pcard-specs {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 10px;
  border-top: 1px solid rgba(232,220,200,.12);
  padding-top: 10px;
}
.pspec {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 11px;
  padding: 4px 0;
  border-bottom: 1px solid rgba(232,220,200,.07);
}
.pspec:last-child { border-bottom: none; }
.pspec span:first-child { color: var(--muted); }
.pspec span:last-child { color: var(--cream-d); text-align: right; font-size: 10.5px; max-width: 55%; }

.pcard-note {
  font-size: 10.5px;
  color: var(--muted);
  line-height: 1.55;
  margin-bottom: 12px;
}

.pcard-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--fm);
  font-size: 11px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--gold);
  border-top: 1px solid rgba(201,130,10,.25);
  padding-top: 10px;
  width: 100%;
  transition: letter-spacing .25s, color .2s;
}
.pcard-cta:hover { letter-spacing: 2.5px; color: var(--gold-lt); }
.pcard-cta span { margin-left: auto; transition: transform .25s; }
.pcard-cta:hover span { transform: translateX(4px); }

/* Wrap expand content for grid-rows trick */
.pcard-expand .pcard-specs,
.pcard-expand .pcard-note,
.pcard-expand .pcard-cta {
  overflow: visible;
}

/* ── More CTA ─────────────────────────────────────────────────── */
.prod-more-cta {
  border: 1px dashed rgba(201,130,10,.22);
  border-radius: 8px;
  padding: 28px 36px;
  background: rgba(201,130,10,.025);
}
.pmc-inner {
  display: flex;
  align-items: center;
  gap: 28px;
}
.pmc-icon {
  font-size: 44px;
  font-weight: 100;
  color: var(--muted);
  line-height: 1;
  flex-shrink: 0;
}
.pmc-text { flex: 1; }
.pmc-text h4 {
  font-family: var(--fd);
  font-size: 20px;
  font-weight: 600;
  color: var(--cream);
  margin-bottom: 6px;
}
.pmc-text p { font-size: 12px; color: var(--muted); line-height: 1.65; }

/* ── Responsive ───────────────────────────────────────────────── */
@media(max-width:1280px){
  .pcard-grid--4 { grid-template-columns: repeat(2,1fr); }
  .cat-num { font-size: 44px; }
}
@media(max-width:1024px){
  .pcard-grid--3 { grid-template-columns: repeat(2,1fr); }
  .pcard-grid--2 { grid-template-columns: 1fr; }
  .cat-hd { gap: 16px; }
  .cat-num { font-size: 36px; width: 48px; }
  .cat-region { font-size: 22px; }
}
@media(max-width:768px){
  .cat-block { margin-bottom: 56px; }
  .cat-hd { padding: 14px 0 20px; }
  .cat-num { display: none; }
  .cat-count { display: none; }
  .pcard-grid--2,
  .pcard-grid--3,
  .pcard-grid--4 { grid-template-columns: repeat(2,1fr); }
  .pcard { aspect-ratio: 2/3; }
  .pcard-name { font-size: 17px; }
  .pcard-expand { display: none; }
  .pcard:hover .pcard-name { margin-bottom: 0; }
  .pmc-inner { flex-direction: column; align-items: flex-start; gap: 16px; }
  .prod-more-cta { padding: 20px 24px; }
}
@media(max-width:480px){
  .pcard-grid--2,
  .pcard-grid--3,
  .pcard-grid--4 { grid-template-columns: 1fr; }
  .pcard { aspect-ratio: 4/3; }
}
