@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600&display=swap');

:root {
  --white:#FFFFFF; --off:#F7FAF8; --pale:#EEF7F1; --soft:#D4EBDD;
  --gl:#4CAF78; --gm:#1A7A42; --gd:#0D4A2B; --gdp:#072318;
  --gold:#B8780A; --goldb:#D4961A; --goldp:#FEF7E6;
  --td:#0F2017; --tm:#3A5C44; --tmut:#7A9B83;
  --bdr:#D0E8D8; --bdrs:#E8F3EB;
  --sh0:0 1px 4px rgba(13,74,43,.06);
  --sh1:0 4px 20px rgba(13,74,43,.10);
  --sh2:0 16px 56px rgba(13,74,43,.14);
  --r:10px; --rl:18px; --rxl:28px;
  --tr:all .28s cubic-bezier(.4,0,.2,1);
  --fd:'Playfair Display',Georgia,serif;
  --fb:'DM Sans',system-ui,sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fb);background:var(--white);color:var(--td);overflow-x:hidden;-webkit-font-smoothing:antialiased;line-height:1.6}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button,input,select,textarea{font-family:var(--fb);outline:none}
::selection{background:var(--gl);color:#fff}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--off)}
::-webkit-scrollbar-thumb{background:var(--gm);border-radius:3px}

/* LOADER */
#loader{position:fixed;inset:0;z-index:9999;background:#fff;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:18px;transition:opacity .5s,visibility .5s}
#loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.ld-name{font-family:var(--fd);font-size:1.9rem;font-weight:700;color:var(--gd);letter-spacing:-.02em}
.ld-name span{color:var(--gl)}
.ld-bar{width:110px;height:2px;background:var(--bdr);border-radius:1px;overflow:hidden}
.ld-fill{height:100%;width:0;background:linear-gradient(90deg,var(--gm),var(--gl));animation:ldf 1.3s ease forwards}
@keyframes ldf{to{width:100%}}

/* NAV */
#navbar{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(255,255,255,.96);backdrop-filter:blur(18px);border-bottom:1px solid transparent;transition:var(--tr);padding:0 5%}
#navbar.scrolled{border-bottom-color:var(--bdrs);box-shadow:var(--sh0)}
.nav-inner{max-width:1300px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:70px}
.nav-logo{display:flex;align-items:center;gap:10px;cursor:pointer}
.logo-badge{width:34px;height:34px;background:var(--gd);border-radius:8px;display:grid;place-items:center;flex-shrink:0}
.logo-badge svg{width:18px;height:18px;fill:none;stroke:#fff;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.logo-words{line-height:1}
.logo-main{font-family:var(--fd);font-size:1.22rem;font-weight:700;color:var(--gd)}
.logo-main em{font-style:normal;color:var(--gl)}
.logo-tag{font-size:.55rem;letter-spacing:.18em;color:var(--tmut);text-transform:uppercase;margin-top:2px;display:block}
.nav-links{display:flex;align-items:center;gap:1px}
.nav-links a{padding:7px 12px;border-radius:7px;font-size:.81rem;font-weight:500;color:var(--tm);transition:var(--tr);cursor:pointer}
.nav-links a:hover,.nav-links a.act{color:var(--gd);background:var(--pale)}
.nav-links a.act{font-weight:600}
.nav-cta{background:var(--gd)!important;color:#fff!important;padding:9px 20px!important;border-radius:8px!important;font-weight:600!important}
.nav-cta:hover{background:var(--gm)!important;box-shadow:var(--sh1)!important}
.lang-sw{display:flex;gap:2px;padding:3px;border:1px solid var(--bdr);border-radius:8px;background:var(--off)}
.lang-btn{background:none;border:none;cursor:pointer;padding:4px 9px;border-radius:6px;font-size:.7rem;font-weight:700;letter-spacing:.05em;color:var(--tmut);transition:var(--tr)}
.lang-btn.act{background:var(--gd);color:#fff}
.lang-btn:hover:not(.act){color:var(--gd)}
.hburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.hburger span{display:block;width:22px;height:2px;background:var(--td);border-radius:1px;transition:var(--tr)}
.hburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hburger.open span:nth-child(2){opacity:0}
.hburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mob-menu{display:none;position:absolute;top:70px;left:0;right:0;background:#fff;border-bottom:1px solid var(--bdr);padding:10px 5% 18px;flex-direction:column;gap:2px;box-shadow:var(--sh1)}
.mob-menu.open{display:flex}
.mob-menu a{padding:10px 14px;border-radius:8px;font-size:.9rem;color:var(--tm);cursor:pointer;transition:var(--tr)}
.mob-menu a:hover{color:var(--gd);background:var(--pale)}
.mob-lang{display:flex;gap:8px;padding:12px 14px 2px;border-top:1px solid var(--bdr);margin-top:6px}

/* SECTIONS */
section{display:none}
section.active{display:block}
.sw{max-width:1300px;margin:0 auto;padding:92px 5%}
.stag{display:inline-flex;align-items:center;gap:8px;font-size:.71rem;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--gm);margin-bottom:12px}
.stag::before{content:"";width:18px;height:2px;background:var(--gl);border-radius:1px;flex-shrink:0}
.sh2{font-family:var(--fd);font-size:clamp(1.9rem,3.8vw,2.9rem);font-weight:700;color:var(--td);line-height:1.15;margin-bottom:16px}
.sh2 em{font-style:italic;color:var(--gm)}
.ssub{font-size:1.03rem;line-height:1.82;color:var(--tm);max-width:620px;margin-bottom:52px}
.bg-off{background:var(--off)}
.bg-pale{background:var(--pale)}

/* BTNS */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:10px;font-weight:600;font-size:.93rem;cursor:pointer;border:2px solid transparent;transition:var(--tr);letter-spacing:.01em}
.btn-g{background:var(--gd);color:#fff;border-color:var(--gd)}
.btn-g:hover{background:var(--gm);border-color:var(--gm);transform:translateY(-2px);box-shadow:var(--sh2)}
.btn-o{background:transparent;color:var(--gd);border-color:var(--bdr)}
.btn-o:hover{border-color:var(--gm);color:var(--gm)}
.btn-gold{background:var(--gold);color:#fff;border-color:var(--gold)}
.btn-gold:hover{background:var(--goldb);border-color:var(--goldb);transform:translateY(-2px)}

/* FADE UP */
.fu{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.fu.vis{opacity:1;transform:translateY(0)}

/* HERO */
#hero{background:var(--white);min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding-top:70px}
.hero-deco{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.hero-deco-word{position:absolute;right:-2%;top:50%;transform:translateY(-50%) rotate(-6deg);font-family:var(--fd);font-size:clamp(100px,16vw,240px);font-weight:900;color:transparent;-webkit-text-stroke:1px var(--bdrs);letter-spacing:-.05em;line-height:1;white-space:nowrap;user-select:none}
.hero-deco-circle{position:absolute;right:8%;top:12%;width:320px;height:320px;border-radius:50%;border:1.5px solid var(--bdrs);opacity:.7}
.hero-deco-circle2{position:absolute;right:14%;top:18%;width:200px;height:200px;border-radius:50%;background:var(--pale);opacity:.6}
.hero-deco-line{position:absolute;left:5%;bottom:15%;width:1px;height:120px;background:linear-gradient(to bottom,var(--gl),transparent)}
.hero-inner{position:relative;z-index:1;max-width:1300px;margin:0 auto;padding:80px 5%;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;width:100%}
.hero-left{}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--pale);border:1px solid var(--soft);border-radius:100px;padding:7px 16px;font-size:.72rem;font-weight:600;letter-spacing:.08em;color:var(--gm);text-transform:uppercase;margin-bottom:28px}
.hero-badge-dot{width:7px;height:7px;border-radius:50%;background:var(--gl);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}}
.hero-h1{font-family:var(--fd);font-size:clamp(2.4rem,5.5vw,4.2rem);font-weight:700;line-height:1.08;color:var(--td);margin-bottom:22px;letter-spacing:-.02em}
.hero-h1 em{font-style:italic;color:var(--gm);display:block}
.hero-sub{font-size:1.05rem;line-height:1.8;color:var(--tm);margin-bottom:36px;max-width:480px}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:52px}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--bdr);border-radius:var(--r);overflow:hidden;border:1px solid var(--bdr)}
.hstat{background:var(--white);padding:18px 16px;text-align:center}
.hstat-n{font-family:var(--fd);font-size:1.7rem;font-weight:700;color:var(--gd);line-height:1}
.hstat-l{font-size:.72rem;color:var(--tmut);margin-top:4px;line-height:1.3}
.hero-right{display:flex;flex-direction:column;gap:16px}
.hero-card{background:var(--white);border:1px solid var(--bdrs);border-radius:var(--rl);padding:24px 26px;box-shadow:var(--sh0);transition:var(--tr)}
.hero-card:hover{box-shadow:var(--sh1);transform:translateY(-2px)}
.hero-card-top{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.hc-icon{width:40px;height:40px;border-radius:9px;background:var(--pale);display:grid;place-items:center;font-size:1.1rem;flex-shrink:0}
.hc-title{font-weight:600;font-size:.95rem;color:var(--td)}
.hc-sub{font-size:.83rem;color:var(--tmut);line-height:1.5}
.hero-proof{background:var(--pale);border:1px solid var(--soft);border-radius:var(--rl);padding:22px 26px}
.hero-proof-label{font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gm);margin-bottom:10px}
.hero-proof-logos{display:flex;gap:20px;flex-wrap:wrap;align-items:center}
.proof-tag{background:var(--white);border:1px solid var(--bdr);border-radius:100px;padding:6px 14px;font-size:.78rem;font-weight:600;color:var(--tm)}

/* WHY SENEGAL */
#why{background:var(--white)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.why-card{border:1px solid var(--bdrs);border-radius:var(--rl);padding:32px 28px;background:var(--white);transition:var(--tr);position:relative;overflow:hidden}
.why-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gl),var(--gm));transform:scaleX(0);transform-origin:left;transition:transform .35s ease}
.why-card:hover{box-shadow:var(--sh1);transform:translateY(-4px);border-color:var(--soft)}
.why-card:hover::before{transform:scaleX(1)}
.why-icon{width:48px;height:48px;border-radius:11px;background:var(--pale);display:grid;place-items:center;font-size:1.35rem;margin-bottom:18px}
.why-title{font-weight:700;font-size:1rem;color:var(--td);margin-bottom:9px}
.why-body{font-size:.87rem;line-height:1.72;color:var(--tm)}
.why-cta-row{margin-top:56px;background:var(--gd);border-radius:var(--rxl);padding:48px 52px;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.why-cta-text h3{font-family:var(--fd);font-size:1.6rem;font-weight:700;color:#fff;margin-bottom:6px}
.why-cta-text p{font-size:.92rem;color:rgba(255,255,255,.7);max-width:480px}

/* SERVICES */
#services{background:var(--off)}
.svc-tabs{display:flex;gap:8px;margin-bottom:48px;flex-wrap:wrap}
.svc-tab{padding:10px 22px;border-radius:100px;border:2px solid var(--bdr);font-size:.85rem;font-weight:600;color:var(--tm);cursor:pointer;transition:var(--tr);background:var(--white)}
.svc-tab.act{background:var(--gd);border-color:var(--gd);color:#fff}
.svc-panel{display:none}
.svc-panel.act{display:block}
.svc-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.step-card{background:var(--white);border:1px solid var(--bdrs);border-radius:var(--rl);padding:28px 24px;transition:var(--tr)}
.step-card:hover{box-shadow:var(--sh1);transform:translateY(-3px)}
.step-num{font-family:var(--fd);font-size:2.8rem;font-weight:700;color:var(--pale);line-height:1;margin-bottom:8px}
.step-title{font-weight:700;font-size:.97rem;color:var(--gd);margin-bottom:9px}
.step-body{font-size:.85rem;line-height:1.72;color:var(--tm)}
.svc-note{margin-top:36px;border:1px solid var(--soft);border-radius:var(--rl);padding:28px 32px;background:var(--white);display:flex;align-items:flex-start;gap:18px}
.svc-note-icon{font-size:1.5rem;flex-shrink:0;padding-top:2px}
.svc-note-text h4{font-weight:700;font-size:.97rem;color:var(--gd);margin-bottom:6px}
.svc-note-text p{font-size:.85rem;color:var(--tm);line-height:1.7}

/* PACKAGES */
#packages{background:var(--white)}
.pkg-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:64px}
.pkg-card{border:1px solid var(--bdrs);border-radius:var(--rl);padding:26px 22px;background:var(--white);display:flex;flex-direction:column;transition:var(--tr);position:relative;overflow:hidden}
.pkg-card:hover{box-shadow:var(--sh1);transform:translateY(-4px)}
.pkg-card.featured{border-color:var(--gm);background:var(--gd)}
.pkg-card.featured *{color:#fff!important}
.pkg-badge{position:absolute;top:14px;right:-22px;background:var(--gold);color:#fff;font-size:.6rem;font-weight:700;letter-spacing:.08em;padding:4px 30px;transform:rotate(45deg);text-transform:uppercase}
.pkg-icon{font-size:1.6rem;margin-bottom:14px}
.pkg-name{font-family:var(--fd);font-size:1.15rem;font-weight:700;color:var(--td);margin-bottom:3px}
.pkg-for{font-size:.75rem;color:var(--tmut);margin-bottom:16px;font-weight:500}
.pkg-price{font-family:var(--fd);font-size:1.25rem;font-weight:700;color:var(--gd);margin-bottom:18px;line-height:1.2}
.pkg-price small{font-family:var(--fb);font-size:.72rem;color:var(--tmut);font-weight:400;display:block;margin-top:2px}
.pkg-div{height:1px;background:var(--bdrs);margin-bottom:16px}
.pkg-features{flex:1;display:flex;flex-direction:column;gap:9px;margin-bottom:20px}
.pkg-feat{display:flex;align-items:flex-start;gap:8px;font-size:.8rem;color:var(--tm);line-height:1.4}
.pkg-feat::before{content:"✓";color:var(--gl);font-weight:700;flex-shrink:0;margin-top:1px}
.pkg-card.featured .pkg-feat::before{color:var(--gl)}
.pkg-cta{width:100%;padding:11px;border-radius:8px;font-weight:600;font-size:.85rem;cursor:pointer;transition:var(--tr);border:2px solid var(--bdr);background:transparent;color:var(--tm)}
.pkg-card.featured .pkg-cta{background:var(--gl);border-color:var(--gl);color:var(--white)}
.pkg-cta:hover{border-color:var(--gm);color:var(--gd)}
.pkg-card.featured .pkg-cta:hover{background:var(--gm);border-color:var(--gm)}
.crops-wrap{background:var(--pale);border-radius:var(--rxl);padding:44px 48px}
.crops-h3{font-family:var(--fd);font-size:1.5rem;font-weight:700;color:var(--gd);margin-bottom:28px}
.crops-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.crop-pill{background:var(--white);border:1px solid var(--soft);border-radius:var(--r);padding:16px 18px;transition:var(--tr);cursor:default}
.crop-pill:hover{box-shadow:var(--sh0);border-color:var(--gm)}
.crop-n{font-weight:600;font-size:.88rem;color:var(--td);margin-bottom:3px}
.crop-s{font-size:.72rem;color:var(--gl);margin-bottom:2px;font-weight:500}
.crop-m{font-size:.71rem;color:var(--tmut)}

/* CASE STUDIES */
#cases{background:var(--off)}
.case-filters{display:flex;gap:8px;margin-bottom:40px;flex-wrap:wrap}
.cf-btn{padding:8px 18px;border-radius:100px;border:1.5px solid var(--bdr);font-size:.8rem;font-weight:600;color:var(--tm);cursor:pointer;transition:var(--tr);background:var(--white)}
.cf-btn.act{background:var(--gd);border-color:var(--gd);color:#fff}
.cases-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.case-card{background:var(--white);border:1px solid var(--bdrs);border-radius:var(--rl);overflow:hidden;transition:var(--tr)}
.case-card:hover{box-shadow:var(--sh1);transform:translateY(-3px)}
.case-card.hidden{display:none}
.case-head{background:var(--gd);padding:24px 28px}
.case-crop-tag{display:inline-block;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);border-radius:100px;padding:4px 12px;font-size:.68rem;font-weight:600;letter-spacing:.08em;color:#fff;text-transform:uppercase;margin-bottom:10px}
.case-company{font-size:1.05rem;font-weight:700;color:#fff;margin-bottom:3px}
.case-meta{font-size:.78rem;color:rgba(255,255,255,.65)}
.case-body{padding:22px 28px}
.case-highlights{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}
.ch{background:var(--pale);border-radius:8px;padding:10px 14px;font-size:.77rem;color:var(--gm);font-weight:600;display:flex;align-items:center;gap:6px}
.ch::before{content:"→";color:var(--gl)}
.case-excerpt{font-size:.84rem;line-height:1.72;color:var(--tm)}
.case-read{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-size:.8rem;font-weight:600;color:var(--gm);cursor:pointer;transition:var(--tr)}
.case-read:hover{gap:10px;color:var(--gd)}
.case-quote-wrap{margin-top:48px;background:var(--gd);border-radius:var(--rxl);padding:52px;text-align:center}
.case-quote{font-family:var(--fd);font-size:clamp(1.1rem,2.2vw,1.5rem);font-style:italic;color:#fff;line-height:1.65;max-width:800px;margin:0 auto 18px}
.case-quote-attr{font-size:.82rem;color:rgba(255,255,255,.55);font-weight:500}

/* ABOUT */
#about{background:var(--white)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-bottom:64px}
.about-box{border:1px solid var(--bdrs);border-radius:var(--rl);padding:32px}
.about-box-label{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.about-box-body{font-size:.92rem;line-height:1.8;color:var(--tm)}
.vals-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:64px}
.val-card{background:var(--pale);border-radius:var(--rl);padding:26px 22px;text-align:center;transition:var(--tr)}
.val-card:hover{transform:translateY(-3px);box-shadow:var(--sh1)}
.val-icon{font-size:1.7rem;margin-bottom:12px}
.val-title{font-weight:700;font-size:.95rem;color:var(--gd);margin-bottom:8px}
.val-body{font-size:.82rem;line-height:1.65;color:var(--tm)}
.team-h3{font-family:var(--fd);font-size:1.55rem;font-weight:700;color:var(--td);margin-bottom:24px}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.team-card{border:1px solid var(--bdrs);border-radius:var(--r);padding:22px;transition:var(--tr)}
.team-card:hover{box-shadow:var(--sh0);border-color:var(--soft)}
.team-role{font-weight:700;font-size:.9rem;color:var(--gd);margin-bottom:3px}
.team-loc{font-size:.72rem;color:var(--gl);font-weight:600;margin-bottom:8px}
.team-desc{font-size:.82rem;color:var(--tm);line-height:1.55}

/* CONTACT - Primary Focus */
#contact{background:var(--pale)}
.contact-grid{display:grid;grid-template-columns:1fr 420px;gap:48px;align-items:start}
.form-wrap{background:var(--white);border:1px solid var(--bdrs);border-radius:var(--rxl);padding:48px;box-shadow:var(--sh1)}
.form-progress{display:flex;align-items:center;gap:0;margin-bottom:36px}
.fp-step{display:flex;align-items:center;gap:8px}
.fp-dot{width:28px;height:28px;border-radius:50%;border:2px solid var(--bdr);display:grid;place-items:center;font-size:.72rem;font-weight:700;color:var(--tmut);transition:var(--tr);flex-shrink:0}
.fp-dot.act{background:var(--gd);border-color:var(--gd);color:#fff}
.fp-dot.done{background:var(--gl);border-color:var(--gl);color:#fff}
.fp-label{font-size:.75rem;font-weight:600;color:var(--tmut);white-space:nowrap}
.fp-label.act{color:var(--gd)}
.fp-line{flex:1;height:1px;background:var(--bdr);margin:0 8px}
.form-step{display:none}
.form-step.act{display:block}
.form-step-title{font-family:var(--fd);font-size:1.3rem;font-weight:700;color:var(--td);margin-bottom:6px}
.form-step-sub{font-size:.88rem;color:var(--tmut);margin-bottom:28px;line-height:1.6}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--tm);margin-bottom:7px}
.form-input,.form-select,.form-textarea{width:100%;padding:12px 16px;background:var(--off);border:1.5px solid var(--bdrs);border-radius:8px;font-size:.9rem;color:var(--td);transition:var(--tr)}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--gm);background:var(--white);box-shadow:0 0 0 3px rgba(26,122,66,.1)}
.form-select{cursor:pointer;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237A9B83' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.form-select option{background:#fff}
.form-textarea{resize:vertical;min-height:100px;line-height:1.6}
.form-nav{display:flex;justify-content:space-between;align-items:center;margin-top:8px}
.form-submit{width:100%;padding:16px;background:var(--gd);color:#fff;border:none;border-radius:10px;font-weight:700;font-size:1rem;cursor:pointer;transition:var(--tr);margin-top:8px;letter-spacing:.02em}
.form-submit:hover{background:var(--gm);transform:translateY(-2px);box-shadow:var(--sh2)}
.form-success-wrap{display:none;text-align:center;padding:40px 20px}
.form-success-icon{width:64px;height:64px;background:var(--pale);border-radius:50%;display:grid;place-items:center;font-size:1.8rem;margin:0 auto 20px}
.form-success-title{font-family:var(--fd);font-size:1.4rem;font-weight:700;color:var(--gd);margin-bottom:8px}
.form-success-sub{font-size:.92rem;color:var(--tm);line-height:1.7}
.contact-sidebar{display:flex;flex-direction:column;gap:20px}
.sidebar-card{background:var(--white);border:1px solid var(--bdrs);border-radius:var(--rl);padding:28px}
.sidebar-card-title{font-weight:700;font-size:.95rem;color:var(--td);margin-bottom:18px}
.contact-item{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid var(--bdrs)}
.contact-item:last-child{border:none}
.ci-icon{font-size:.95rem;width:30px;height:30px;background:var(--pale);border-radius:7px;display:grid;place-items:center;flex-shrink:0}
.ci-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.07em;color:var(--tmut);font-weight:600;margin-bottom:2px}
.ci-val{font-size:.85rem;color:var(--td);font-weight:500}
.visit-card{background:var(--gd);border-radius:var(--rl);padding:28px}
.visit-title{font-weight:700;color:#fff;margin-bottom:8px;font-size:.97rem}
.visit-body{font-size:.84rem;color:rgba(255,255,255,.7);line-height:1.7;margin-bottom:16px}

/* BLOG */
#blog{background:var(--white)}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card{border:1px solid var(--bdrs);border-radius:var(--rl);overflow:hidden;transition:var(--tr);display:flex;flex-direction:column}
.blog-card:hover{box-shadow:var(--sh1);transform:translateY(-3px)}
.blog-thumb{height:176px;position:relative;overflow:hidden}
.blog-thumb-inner{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.blog-thumb-pattern{position:absolute;inset:0}
.blog-thumb-label{position:relative;z-index:1;font-family:var(--fd);font-size:1.8rem;font-weight:700;color:rgba(255,255,255,.25);letter-spacing:-.02em;text-align:center;padding:16px}
.bt-1{background:linear-gradient(135deg,var(--gd),var(--gm))}
.bt-2{background:linear-gradient(135deg,var(--gm),var(--gl))}
.bt-3{background:linear-gradient(135deg,var(--gdp),var(--gd))}
.blog-meta{display:flex;justify-content:space-between;align-items:center;padding:16px 22px 0;font-size:.72rem}
.blog-date{color:var(--tmut)}
.blog-cat{background:var(--pale);color:var(--gm);padding:3px 10px;border-radius:100px;font-weight:600}
.blog-title{padding:10px 22px;font-size:1.02rem;font-weight:700;color:var(--td);line-height:1.4}
.blog-body{padding:0 22px 16px;font-size:.83rem;line-height:1.72;color:var(--tm);flex:1}
.blog-more{margin:0 22px 22px;display:inline-flex;align-items:center;gap:6px;font-size:.8rem;font-weight:600;color:var(--gm);cursor:pointer;transition:var(--tr)}
.blog-more::after{content:"→";transition:margin .2s}
.blog-more:hover{color:var(--gd)}
.blog-more:hover::after{margin-left:4px}

/* FOOTER */
footer{background:var(--gdp);padding:64px 5% 32px}
.footer-inner{max-width:1300px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:32px}
.footer-brand{}
.footer-logo-text{font-family:var(--fd);font-size:1.6rem;font-weight:700;color:#fff;margin-bottom:10px}
.footer-logo-text em{font-style:normal;color:var(--gl)}
.footer-tagline{font-style:italic;font-size:.85rem;color:rgba(255,255,255,.45);margin-bottom:12px;font-family:var(--fd)}
.footer-desc{font-size:.82rem;color:rgba(255,255,255,.4);line-height:1.75;max-width:280px}
.footer-col-title{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:16px}
.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-links a{font-size:.83rem;color:rgba(255,255,255,.45);transition:var(--tr);cursor:pointer}
.footer-links a:hover{color:var(--gl)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;font-size:.76rem;color:rgba(255,255,255,.3);flex-wrap:wrap;gap:8px}

/* RESPONSIVE */
@media(max-width:1100px){
  .pkg-grid{grid-template-columns:1fr 1fr}
  .crops-grid{grid-template-columns:repeat(3,1fr)}
  .footer-top{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  .nav-links,.lang-sw{display:none}
  .hburger{display:flex}
  .hero-inner{grid-template-columns:1fr}
  .hero-right{display:none}
  .why-grid,.svc-steps{grid-template-columns:1fr}
  .cases-grid{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr}
  .vals-grid{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .crops-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .sw{padding:72px 5%}
  .hero-inner{padding:60px 5%}
  .hero-stats{grid-template-columns:1fr 1fr}
  .pkg-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .vals-grid{grid-template-columns:1fr}
  .crops-grid{grid-template-columns:1fr}
  .case-highlights{grid-template-columns:1fr}
  .why-cta-row{flex-direction:column;padding:36px}
  .footer-bottom{flex-direction:column;text-align:center}
}

/* ── IMAGE ENHANCEMENTS ─────────────────────────────── */

/* HERO with background image */
#hero { background: var(--gd); }
.hero-bg-img {
  position: absolute; inset: 0; z-index: 0;
  background: url('../images/hero_bg.jpg') center center / cover no-repeat;
  opacity: 0.55;
}
.hero-bg-overlay {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(
    105deg,
    rgba(7,35,24,.92) 0%,
    rgba(7,35,24,.78) 45%,
    rgba(13,74,43,.35) 100%
  );
}
.hero-inner { position: relative; z-index: 2; }
.hero-h1 { color: #fff; }
.hero-h1 em { color: var(--gl); }
.hero-sub { color: rgba(255,255,255,.75); }
.hero-badge { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.2); color: rgba(255,255,255,.9); }
.hero-badge-dot { background: var(--gl); }
.hero-stats { background: rgba(7,35,24,.7); backdrop-filter: blur(10px); border-color: rgba(255,255,255,.1); }
.hstat { background: rgba(255,255,255,.06); }
.hstat:hover { background: rgba(255,255,255,.1); }
.hstat-n { color: var(--gold); }
.hstat-l { color: rgba(255,255,255,.55); }
.hero-card { background: rgba(255,255,255,.95); backdrop-filter: blur(8px); }
.hero-proof { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.15); }
.hero-proof-label { color: rgba(255,255,255,.6); }
.proof-tag { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.2); color: rgba(255,255,255,.85); }
.btn-o { border-color: rgba(255,255,255,.3); color: #fff; }
.btn-o:hover { border-color: var(--gl); color: var(--gl); }

/* WHY SENEGAL — image banner */
.why-img-banner {
  width: 100%; height: 340px; border-radius: var(--rxl);
  background: url('../images/why_banner.jpg') center 40% / cover no-repeat;
  margin-bottom: 52px; position: relative; overflow: hidden;
}
.why-img-banner-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to right, rgba(13,74,43,.82) 0%, rgba(13,74,43,.3) 60%, transparent 100%);
  display: flex; align-items: center; padding: 0 48px;
}
.wib-text h3 {
  font-family: var(--fd); font-size: 2rem; font-weight: 700;
  color: #fff; line-height: 1.2; margin-bottom: 10px;
}
.wib-text p { font-size: .95rem; color: rgba(255,255,255,.75); max-width: 480px; line-height: 1.7; }

/* ABOUT — image split */
.about-img-wrap {
  width: 100%; height: 280px; border-radius: var(--rxl);
  background: url('../images/about_team.jpg') center / cover no-repeat;
  margin-bottom: 52px; position: relative; overflow: hidden;
}
.about-img-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to right, rgba(13,74,43,.9) 0%, rgba(13,74,43,.5) 50%, rgba(13,74,43,.15) 100%);
  display: flex; align-items: center; padding: 0 48px;
}
.aio-text { max-width: 520px; }
.aio-text h3 { font-family: var(--fd); font-size: 1.8rem; color: #fff; font-weight: 700; margin-bottom: 8px; }
.aio-text p { font-size: .92rem; color: rgba(255,255,255,.7); line-height: 1.7; }

/* CASE STUDY — crop photo headers */
.case-head-img {
  height: 140px; position: relative; overflow: hidden;
  background-size: cover; background-position: center;
}
.case-head-img-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, rgba(0,0,0,.2), rgba(13,74,43,.85));
  display: flex; flex-direction: column; justify-content: flex-end; padding: 16px 20px;
}

/* CROP PILLS — image backgrounds */
.crop-pill {
  background-size: cover; background-position: center; position: relative; overflow: hidden;
}
.crop-pill-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, rgba(13,74,43,.5), rgba(13,74,43,.82));
}
.crop-pill-content { position: relative; z-index: 1; }
.crop-pill .crop-n { color: #fff; }
.crop-pill .crop-s { color: rgba(255,255,255,.8); }
.crop-pill .crop-m { color: rgba(255,255,255,.6); }

/* BLOG — image thumbnails */
.blog-thumb {
  background-size: cover !important;
  background-position: center !important;
}

/* SERVICES — image strip */
.svc-img-strip {
  width: 100%; height: 220px; border-radius: var(--rl);
  background: url('../images/services_farm.jpg') center 45% / cover no-repeat;
  margin-bottom: 40px; position: relative; overflow: hidden;
}
.svc-img-strip-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to right, rgba(13,74,43,.88), rgba(13,74,43,.4));
  display: flex; align-items: center; padding: 0 40px;
}
.sis-text h4 { font-family: var(--fd); font-size: 1.4rem; color: #fff; font-weight: 700; margin-bottom: 6px; }
.sis-text p { font-size: .88rem; color: rgba(255,255,255,.7); max-width: 480px; line-height: 1.65; }

/* ── REAL IMAGE STYLES ───────────────────────── */

/* HERO with real photo */
#hero { background:var(--gdp); }
.hero-bg-img {
  position:absolute; inset:0; z-index:0;
  background-size:cover; background-position:center;
  background-repeat:no-repeat;
}
.hero-bg-overlay {
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(105deg,rgba(5,20,12,.92) 0%,rgba(7,35,24,.82) 40%,rgba(13,74,43,.45) 100%);
}
.hero-inner { position:relative; z-index:2; }
.hero-h1 { color:#fff; }
.hero-h1 em { color:var(--gl); }
.hero-sub { color:rgba(255,255,255,.78); }
.hero-badge { background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.2); color:rgba(255,255,255,.9); }
.hero-badge-dot { background:var(--gl); }
.hero-stats { background:rgba(5,20,12,.7); backdrop-filter:blur(12px); border-color:rgba(255,255,255,.08); }
.hstat { background:rgba(255,255,255,.05); }
.hstat:hover { background:rgba(255,255,255,.1); }
.hstat-n { color:var(--gold); }
.hstat-l { color:rgba(255,255,255,.5); }
.btn-o { border-color:rgba(255,255,255,.3); color:#fff; }
.btn-o:hover { border-color:var(--gl); color:var(--gl); }
.hero-proof { background:rgba(255,255,255,.07); border-color:rgba(255,255,255,.12); }
.hero-proof-label { color:rgba(255,255,255,.55); }
.proof-tag { background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.18); color:rgba(255,255,255,.8); }

/* HERO PHOTO — farmer portrait */
.hero-photo-wrap {
  border-radius:var(--rxl); overflow:hidden; position:relative;
  box-shadow:0 20px 60px rgba(0,0,0,.5);
}
.hero-photo {
  width:100%; height:380px; object-fit:cover; object-position:center 20%;
  display:block;
}
.hero-photo-badge {
  position:absolute; bottom:14px; left:14px; right:14px;
  background:rgba(5,20,12,.8); backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.1); border-radius:8px;
  padding:10px 14px; font-size:.78rem; color:rgba(255,255,255,.8);
  display:flex; align-items:center; gap:8px;
}
.hero-photo-badge-dot {
  width:7px; height:7px; border-radius:50%; background:var(--gl);
  flex-shrink:0; animation:pulse 2s infinite;
}
.hero-cards-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }

/* WHY SENEGAL banner */
.why-img-banner {
  width:100%; height:320px; border-radius:var(--rxl);
  background-size:cover; background-position:center;
  margin-top:20px; margin-bottom:20px; position:relative; overflow:hidden;
}
.why-img-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to right, rgba(5,20,12,.88) 0%, rgba(7,35,24,.65) 55%, rgba(13,74,43,.2) 100%);
  display:flex; align-items:center; padding:0 52px;
}
.wib-text h3 { font-family:var(--fd); font-size:1.9rem; font-weight:700; color:#fff; margin-bottom:10px; line-height:1.2; }
.wib-text p { font-size:.93rem; color:rgba(255,255,255,.75); max-width:500px; line-height:1.75; }

/* SERVICES image strip */
.svc-img-strip {
  width:100%; height:240px; border-radius:var(--rl);
  background-size:cover; background-position:center;
  margin-bottom:36px; position:relative; overflow:hidden;
}
.svc-img-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to right, rgba(5,20,12,.9) 0%, rgba(7,35,24,.55) 60%, rgba(7,35,24,.1) 100%);
  display:flex; align-items:center; padding:0 40px;
}
.sis-text h4 { font-family:var(--fd); font-size:1.4rem; color:#fff; font-weight:700; margin-bottom:6px; }
.sis-text p { font-size:.87rem; color:rgba(255,255,255,.72); max-width:500px; line-height:1.65; }

/* ABOUT image split */
.about-img-split {
  display:grid; grid-template-columns:1fr 1.5fr; gap:16px;
  margin-bottom:48px; height:380px;
}
.ais-left, .ais-right { border-radius:var(--rl); overflow:hidden; }
.ais-img { width:100%; height:100%; object-fit:cover; object-position:center 20%; display:block; transition:transform .5s ease; }
.ais-img:hover { transform:scale(1.03); }
.ais-img-tall { object-position:center 30%; }

/* ABOUT harvest banner */
.about-harvest-wrap {
  width:100%; height:280px; border-radius:var(--rxl);
  background-size:cover; background-position:center;
  margin:40px 0; position:relative; overflow:hidden;
}
.ahw-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to right, rgba(5,20,12,.9) 0%, rgba(7,35,24,.6) 60%, transparent 100%);
  display:flex; align-items:center; padding:0 52px;
}
.ahw-text h3 { font-family:var(--fd); font-size:1.6rem; font-weight:700; color:#fff; margin-bottom:8px; }
.ahw-text p { font-size:.88rem; color:rgba(255,255,255,.72); max-width:520px; line-height:1.7; }

/* CROP PILLS with photo backgrounds */
.crop-pill {
  background-size:cover !important; background-position:center !important;
  position:relative; overflow:hidden; min-height:100px;
}
.crop-pill-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to bottom, rgba(7,35,24,.45), rgba(7,35,24,.82));
}
.crop-pill-content { position:relative; z-index:1; }
.crop-n { color:#fff !important; font-weight:700 !important; }
.crop-s { color:rgba(255,255,255,.8) !important; }
.crop-m { color:rgba(255,255,255,.6) !important; }

/* CASE STUDY photo headers */
.case-head-img {
  height:160px; position:relative; overflow:hidden;
  background-size:cover; background-position:center;
}
.case-head-img-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to bottom, rgba(0,0,0,.15), rgba(7,35,24,.88));
  display:flex; flex-direction:column; justify-content:flex-end; padding:16px 20px;
}
.case-crop-tag {
  display:inline-block; background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.25); border-radius:100px;
  padding:3px 10px; font-size:.67rem; font-weight:600;
  letter-spacing:.08em; color:#fff; text-transform:uppercase; margin-bottom:6px; width:fit-content;
}
.case-company { color:#fff; font-size:1rem; font-weight:700; }

/* CONTACT real photo */
.contact-real-photo {
  border-radius:var(--rl); height:160px;
  background-size:cover; background-position:center;
  position:relative; overflow:hidden;
}
.crp-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(5,20,12,.85) 0%, rgba(5,20,12,.3) 100%);
  display:flex; flex-direction:column; justify-content:flex-end; padding:16px 18px;
}

/* BLOG thumbs */
.blog-thumb {
  height:200px;
  background-size:cover !important; background-position:center !important;
}

/* RESPONSIVE */
@media(max-width:900px){
  .about-img-split { grid-template-columns:1fr; height:auto; }
  .ais-img { height:220px; }
  .hero-cards-row { grid-template-columns:1fr; }
  .wib-text h3 { font-size:1.4rem; }
  .why-img-overlay { padding:0 28px; }
  .ahw-overlay { padding:0 28px; }
}
@media(max-width:600px){
  .hero-photo { height:260px; }
  .why-img-banner { height:240px; }
  .svc-img-strip { height:180px; }
  .about-harvest-wrap { height:220px; }
}
