/* ============================================================
   SUSTAIN TRADE AFRICA — Charte « Forêt & Or »
   Cormorant Garamond · DM Sans · JetBrains Mono
   ============================================================ */

:root{
  --forest:#1A5C38;--forest-dark:#0F3D24;--forest-deep:#0A2D1A;--green:#2E7D52;
  --gold:#B8860B;--gold-light:#D9A526;--gold-pale:#F5E6BC;
  --cream:#F5F0E8;--cream-light:#FBF8F2;--ink:#1A1A1A;
  --muted:rgba(245,240,232,.62);
  --gline:rgba(184,134,11,.32);
  --font-serif:'Cormorant Garamond',serif;
  --font-sans:'DM Sans',sans-serif;
  --font-mono:'JetBrains Mono',monospace;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-sans);background:var(--forest-dark);color:var(--cream);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
.wrap,.container{max-width:1200px;margin:0 auto;padding:0 46px}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3{font-family:var(--font-serif);font-weight:300;line-height:1.04}
ul{list-style:none}

/* Helpers */
.eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-light);font-weight:500;display:inline-flex;align-items:center;gap:14px}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--gold)}
.eyebrow.center{justify-content:center}
.eyebrow.center::before{display:none}
.rn{font-family:var(--font-serif);font-style:italic;color:var(--gold-light);font-size:1.15em;margin-right:.45em}
.gold{color:var(--gold-light)}

.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;padding:15px 28px;cursor:pointer;border:1px solid transparent;transition:.3s;background:none}
.btn-g{background:var(--gold);color:#1a1400}
.btn-g:hover{background:var(--gold-light);transform:translateY(-2px)}
.btn-o{border-color:rgba(245,240,232,.45);color:var(--cream)}
.btn-o:hover{background:var(--cream);color:var(--forest-dark)}
.btn-lg{padding:18px 40px;font-size:13px}
.btn-dark{background:var(--forest-deep);color:var(--cream);border-color:var(--gline)}
.btn-dark:hover{background:var(--forest);transform:translateY(-2px)}

/* ÉCRIN — fixed gold frame */
.ecrin{position:fixed;inset:14px;border:1px solid var(--gline);pointer-events:none;z-index:200}
.ecrin span{position:absolute;width:9px;height:9px;border:1px solid var(--gold)}
.ecrin .tl{top:-1px;left:-1px;border-right:0;border-bottom:0}
.ecrin .tr{top:-1px;right:-1px;border-left:0;border-bottom:0}
.ecrin .bl{bottom:-1px;left:-1px;border-right:0;border-top:0}
.ecrin .br{bottom:-1px;right:-1px;border-left:0;border-top:0}
@media(max-width:600px){.ecrin{inset:8px}}

/* NAV */
header.header{position:sticky;top:0;z-index:150;background:rgba(15,61,36,.82);backdrop-filter:blur(14px);border-bottom:1px solid rgba(184,134,11,.18)}
nav.nav{display:flex;align-items:center;justify-content:space-between;height:82px}
.brand{display:flex;align-items:center;gap:13px}
.brand img{height:38px;width:auto}
.brand .nm{font-weight:700;font-size:12px;letter-spacing:.16em;color:var(--cream);text-transform:uppercase;line-height:1.2}
.brand .nm small{display:block;color:var(--gold-light);font-weight:500;font-size:9px;letter-spacing:.22em;margin-top:1px}
.menu{display:flex;align-items:center;gap:30px}
.menu a{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);transition:.2s;position:relative;white-space:nowrap}
.menu a:hover,.menu a.active{color:var(--cream)}
.menu a::after{content:"";position:absolute;left:0;bottom:-7px;width:0;height:1px;background:var(--gold-light);transition:.25s}
.menu a:hover::after,.menu a.active::after{width:100%}
.right{display:flex;align-items:center;gap:18px}
.lang{position:relative}
.lang>button{background:none;border:1px solid var(--gline);color:var(--muted);font-family:var(--font-mono);font-size:12px;padding:8px 12px;cursor:pointer;display:flex;align-items:center;gap:6px}
.lang>button:hover{border-color:var(--gold);color:var(--cream)}
.lang ul{position:absolute;right:0;top:118%;background:var(--forest);border:1px solid var(--gline);min-width:150px;padding:6px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:.2s;box-shadow:0 18px 40px rgba(0,0,0,.4);z-index:5}
.lang.open ul{opacity:1;visibility:visible;transform:none}
.lang li{padding:9px 12px;font-size:13px;color:var(--muted);cursor:pointer;transition:.15s}
.lang li:hover{background:var(--forest-dark);color:var(--cream)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer}
.burger i{width:22px;height:2px;background:var(--cream);display:block;transition:.25s}

/* HERO (home) */
.hero{position:relative;min-height:calc(100vh - 82px);display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;background:radial-gradient(circle at 50% 38%, var(--forest) 0%, var(--forest-dark) 55%, var(--forest-deep) 100%)}
.hero .glow{position:absolute;left:50%;top:36%;transform:translate(-50%,-50%);width:680px;height:680px;border-radius:50%;background:radial-gradient(circle,rgba(184,134,11,.22),transparent 60%);pointer-events:none}
.hero .ring{position:absolute;left:50%;top:36%;transform:translate(-50%,-50%);border:1px solid rgba(184,134,11,.18);border-radius:50%;pointer-events:none}
.hero .ring.a{width:430px;height:430px}.hero .ring.b{width:620px;height:620px;border-color:rgba(245,240,232,.06)}
.hero .inner{position:relative;z-index:3;padding:70px 24px;opacity:0;animation:rise 1s .15s forwards}
.hero img{width:128px;margin:0 auto 30px;filter:drop-shadow(0 16px 44px rgba(0,0,0,.45))}
.hero .eyebrow{justify-content:center;margin-bottom:24px}
.hero h1{font-size:clamp(48px,9vw,118px);color:var(--cream);font-weight:300;line-height:.96}
.hero h1 em{font-style:italic;color:var(--gold-light)}
.hero .lede{margin:28px auto 0;max-width:520px;font-size:17px;color:var(--muted);font-weight:300}
.hero .cta-row{margin-top:38px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero .scroll{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:3;font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:8px}
.hero .scroll::after{content:"";width:1px;height:30px;background:linear-gradient(var(--gold),transparent);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:.3}50%{opacity:1}}
@keyframes rise{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}

/* PAGE HERO (inner pages) */
.page-hero{position:relative;overflow:hidden;text-align:center;padding:120px 0 96px;background:radial-gradient(circle at 50% 0%, var(--forest) 0%, var(--forest-dark) 60%, var(--forest-deep) 100%);border-bottom:1px solid var(--gline)}
.page-hero .glow{position:absolute;left:50%;top:-10%;transform:translateX(-50%);width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(184,134,11,.18),transparent 62%);pointer-events:none}
.page-hero .inner{position:relative;z-index:2;max-width:760px;margin:0 auto;padding:0 24px}
.page-hero .eyebrow{justify-content:center;margin-bottom:22px}
.page-hero h1{font-size:clamp(40px,6.5vw,82px);color:var(--cream)}
.page-hero h1 em{font-style:italic;color:var(--gold-light)}
.page-hero p{margin:24px auto 0;max-width:560px;color:var(--muted);font-size:17px;font-weight:300}

/* VALUES STRIP */
.strip{border-top:1px solid var(--gline);border-bottom:1px solid var(--gline);background:var(--forest-deep)}
.strip .wrap{display:flex;align-items:center;justify-content:center;gap:54px;padding:20px 46px;flex-wrap:wrap}
.strip span{font-family:var(--font-mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-pale);display:inline-flex;align-items:center;gap:14px}
.strip span::before{content:"\25C6";color:var(--gold);font-size:8px}

/* SECTIONS */
section{padding:120px 0;position:relative}
section.tight{padding-top:0}
.sec-head{max-width:700px;margin-bottom:64px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head .eyebrow{margin-bottom:24px}
.sec-head.center .eyebrow{justify-content:center}
.sec-head h2{font-size:clamp(36px,5.5vw,64px);color:var(--cream)}
.sec-head h2 em{font-style:italic;color:var(--gold-light)}
.sec-head p{margin-top:22px;color:var(--muted);font-size:17px;font-weight:300}

/* ABOUT block */
.about{display:grid;grid-template-columns:.9fr 1.1fr;gap:74px;align-items:center}
.about .vis{aspect-ratio:4/5;position:relative;display:flex;align-items:center;justify-content:center;border:1px solid var(--gline)}
.about .vis::before{content:"";position:absolute;inset:10px;border:1px solid rgba(184,134,11,.2)}
.about .vis::after{content:"";position:absolute;width:80%;height:80%;background:radial-gradient(circle,rgba(184,134,11,.18),transparent 60%)}
.about .vis img{width:58%;position:relative;z-index:2}
.about h2{font-size:clamp(32px,4.4vw,52px);color:var(--cream);margin:18px 0 24px}
.about h2 em{font-style:italic;color:var(--gold-light)}
.about p{color:var(--muted);font-size:16px;font-weight:300;margin-bottom:16px}
.about p strong{color:var(--cream);font-weight:500}
.about .pts{margin-top:28px;display:grid;gap:15px}
.about .pts li{display:flex;gap:14px;padding-bottom:15px;border-bottom:1px solid rgba(245,240,232,.12);font-size:15px}
.about .pts li::before{content:"\25C6";color:var(--gold-light);font-size:9px;margin-top:7px}

/* PROSE (origin text etc.) */
.prose{max-width:820px}
.prose p{color:var(--muted);font-size:17px;font-weight:300;margin-bottom:20px}
.prose p strong{color:var(--cream);font-weight:500}
.prose p em{font-family:var(--font-serif);font-style:italic;color:var(--gold-light);font-size:1.1em}

/* MANIFESTO (cream inset) */
.manifesto{background:var(--cream-light);color:var(--forest-dark);text-align:center}
.manifesto .wrap{padding:100px 46px;position:relative}
.manifesto::before,.manifesto::after{content:"";position:absolute;left:50%;transform:translateX(-50%);width:40px;height:1px;background:var(--gold)}
.manifesto::before{top:46px}.manifesto::after{bottom:46px}
.manifesto p{font-family:var(--font-serif);font-weight:300;font-size:clamp(26px,4vw,44px);line-height:1.3;max-width:860px;margin:0 auto;color:var(--forest)}
.manifesto p em{font-style:italic;color:var(--gold)}
.manifesto .sig{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-top:30px}

/* SERVICES cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);border-left:1px solid var(--gline);border-top:1px solid var(--gline)}
.card{padding:46px 38px;border-right:1px solid var(--gline);border-bottom:1px solid var(--gline);transition:.35s;position:relative}
.card:hover{background:var(--forest)}
.card .rn-big{font-family:var(--font-serif);font-style:italic;font-size:30px;color:var(--gold-light);display:block;margin-bottom:18px}
.card .ic{font-size:26px;color:var(--gold);margin-bottom:18px}
.card h3{font-size:26px;color:var(--cream);margin-bottom:12px}
.card p{color:var(--muted);font-size:14px;font-weight:300}

/* VALUES grid (about page) */
.values{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.value{padding:38px 30px;border:1px solid var(--gline);transition:.3s;background:rgba(245,240,232,.02)}
.value:hover{background:var(--forest);transform:translateY(-4px)}
.value .vic{width:46px;height:46px;color:var(--gold-light);margin-bottom:20px}
.value .vic svg{width:100%;height:100%}
.value h3{font-size:24px;color:var(--cream);margin-bottom:10px}
.value p{color:var(--muted);font-size:14px;font-weight:300}

/* HORIZON section */
.horizon{background:var(--forest-deep);text-align:center;border-top:1px solid var(--gline);border-bottom:1px solid var(--gline)}
.horizon .wrap{position:relative;z-index:2}
.horizon h2{font-size:clamp(34px,5vw,58px);color:var(--cream);max-width:760px;margin:18px auto 22px}
.horizon h2 em{font-style:italic;color:var(--gold-light)}
.horizon p{color:var(--muted);font-size:16px;font-weight:300;max-width:620px;margin:0 auto}
.horizon .bands{max-width:520px;margin:54px auto 0;display:grid;gap:10px}
.horizon .bands i{display:block;height:7px;border-radius:3px;background:linear-gradient(90deg,var(--gold),var(--green))}
.horizon .bands i:nth-child(1){width:100%;opacity:1}
.horizon .bands i:nth-child(2){width:86%;opacity:.85;margin:0 auto}
.horizon .bands i:nth-child(3){width:70%;opacity:.7;margin:0 auto}
.horizon .bands i:nth-child(4){width:52%;opacity:.55;margin:0 auto}
.horizon .bands i:nth-child(5){width:34%;opacity:.4;margin:0 auto}
.horizon .quote{font-family:var(--font-serif);font-style:italic;font-size:clamp(20px,3vw,30px);color:var(--gold-pale);margin-top:54px}

/* STATS */
.stats{background:var(--forest-deep);border-top:1px solid var(--gline);border-bottom:1px solid var(--gline)}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);padding:84px 46px}
.stat{text-align:center;padding:0 20px;border-right:1px solid rgba(245,240,232,.12)}
.stat:last-child{border-right:0}
.stat .n{font-family:var(--font-serif);font-size:66px;color:var(--gold-light);line-height:1;font-weight:300}
.stat .k{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:12px}

/* FILIÈRES */
.filieres{display:flex;flex-wrap:wrap;border-top:1px solid var(--gline);border-left:1px solid var(--gline)}
.filieres span{font-family:var(--font-serif);font-size:23px;color:var(--cream);padding:20px 32px;border-right:1px solid var(--gline);border-bottom:1px solid var(--gline);transition:.25s;flex:1 1 auto;text-align:center;min-width:150px}
.filieres span:hover{background:var(--gold);color:#1a1400}

/* PROCESS */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.step{padding-top:30px;border-top:2px solid var(--gold)}
.step .n{font-family:var(--font-serif);font-style:italic;font-size:48px;color:var(--gold-light)}
.step h3{font-family:var(--font-sans);font-weight:700;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--cream);margin:8px 0 10px}
.step p{color:var(--muted);font-size:14px;font-weight:300}

/* NEWS teaser cards (home) */
.news{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.na{display:block;transition:.3s}
.na .top{aspect-ratio:3/2;position:relative;overflow:hidden;display:flex;align-items:flex-end;padding:20px;border:1px solid var(--gline);background:var(--forest)}
.na .top::after{content:"";position:absolute;right:-30%;top:-30%;width:80%;height:80%;background:radial-gradient(circle,rgba(184,134,11,.28),transparent 60%)}
.na .top.t2{background:var(--green)}.na .top.t3{background:var(--forest-deep)}
.na .tag{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-pale);position:relative;z-index:2}
.na h3{font-size:27px;color:var(--cream);margin:18px 0 8px;transition:.25s}
.na:hover h3{color:var(--gold-light)}
.na p{color:var(--muted);font-size:14px;font-weight:300}
.na .more{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-light);margin-top:14px;display:inline-block}

/* ACTUALITÉS page : toolbar + grid + pagination */
.toolbar{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-bottom:54px}
.filter-btn{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);background:none;border:1px solid var(--gline);padding:10px 16px;cursor:pointer;transition:.2s}
.filter-btn:hover{color:var(--cream);border-color:var(--gold)}
.filter-btn.active{background:var(--gold);color:#1a1400;border-color:var(--gold)}
.search{margin-left:auto;background:transparent;border:0;border-bottom:1px solid var(--gline);color:var(--cream);font-family:var(--font-sans);font-size:14px;padding:10px 4px;min-width:220px}
.search::placeholder{color:rgba(245,240,232,.34)}
.search:focus{outline:none;border-color:var(--gold)}
.articles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.article{display:flex;flex-direction:column;border:1px solid var(--gline);background:rgba(245,240,232,.02);transition:.3s}
.article:hover{transform:translateY(-4px);border-color:var(--gold)}
.article .ah{aspect-ratio:16/10;position:relative;overflow:hidden;display:flex;align-items:flex-end;padding:18px;background:var(--forest)}
.article .ah.c-mines{background:var(--forest-deep)}
.article .ah.c-btp{background:var(--green)}
.article .ah.c-logistics{background:linear-gradient(135deg,var(--forest),var(--forest-deep))}
.article .ah.c-regulation{background:linear-gradient(135deg,var(--green),var(--forest-dark))}
.article .ah::after{content:"";position:absolute;right:-26%;top:-26%;width:70%;height:70%;background:radial-gradient(circle,rgba(184,134,11,.28),transparent 60%)}
.article .ah .tag{position:relative;z-index:2;font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-pale)}
.article .ab{padding:26px;display:flex;flex-direction:column;gap:10px;flex:1}
.article .date{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;color:var(--muted)}
.article h3{font-size:25px;color:var(--cream);transition:.25s}
.article:hover h3{color:var(--gold-light)}
.article p{color:var(--muted);font-size:14px;font-weight:300;flex:1}
.article .more{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-light);margin-top:6px}
.empty{grid-column:1/-1;text-align:center;color:var(--muted);font-family:var(--font-serif);font-style:italic;font-size:22px;padding:60px 0}
.pagination{display:flex;justify-content:center;gap:10px;margin-top:54px;flex-wrap:wrap}
.pagination button{font-family:var(--font-mono);font-size:12px;color:var(--muted);background:none;border:1px solid var(--gline);width:42px;height:42px;cursor:pointer;transition:.2s}
.pagination button:hover{color:var(--cream);border-color:var(--gold)}
.pagination button.active{background:var(--gold);color:#1a1400;border-color:var(--gold)}

/* RESSOURCES : études + bandeau accès */
.etudes{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-bottom:80px}
.etude{display:flex;flex-direction:column;border:1px solid var(--gline);padding:36px 32px;transition:.3s;background:rgba(245,240,232,.02)}
.etude:hover{background:var(--forest);transform:translateY(-4px)}
.etude .badge{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-light);margin-bottom:18px;display:flex;align-items:center;gap:10px}
.etude .badge::before{content:"\25A3";font-size:14px}
.etude h3{font-size:26px;color:var(--cream);margin-bottom:12px}
.etude p{color:var(--muted);font-size:14px;font-weight:300;flex:1;margin-bottom:22px}
.etude .dl{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-light);display:inline-flex;align-items:center;gap:8px}
.etude .dl:hover{color:var(--gold-pale)}
/* Ressources quick list (home teaser) */
.res{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--gline);border-left:1px solid var(--gline)}
.rl{display:flex;align-items:center;justify-content:space-between;padding:32px;border-right:1px solid var(--gline);border-bottom:1px solid var(--gline);transition:.25s}
.rl:hover{background:var(--forest)}
.rl .t{display:flex;align-items:center;gap:16px}
.rl .t .d{color:var(--gold-light);font-size:18px}
.rl h3{font-family:var(--font-serif);font-size:23px;color:var(--cream)}
.rl .arr{color:var(--gold-light);transition:.25s}
.rl:hover .arr{transform:translateX(6px)}
.access{margin-top:20px;border:1px solid var(--gline);background:radial-gradient(circle at 80% 20%,var(--forest),var(--forest-deep) 70%);padding:64px 54px;text-align:center;position:relative;overflow:hidden}
.access h3{font-size:clamp(28px,4vw,46px);color:var(--cream);margin-bottom:16px}
.access h3 em{font-style:italic;color:var(--gold-light)}
.access p{color:var(--muted);font-size:16px;font-weight:300;max-width:560px;margin:0 auto 30px}

/* CONTACT */
.contact-band{background:radial-gradient(circle at 80% 20%, var(--forest), var(--forest-dark) 60%);position:relative;overflow:hidden}
.contact-band::after{content:"";position:absolute;right:-10%;bottom:-40%;width:55%;height:160%;background:radial-gradient(circle,rgba(184,134,11,.16),transparent 60%)}
.contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:start;position:relative;z-index:2}
.contact-grid .lede{color:var(--muted);font-size:16px;font-weight:300;max-width:420px;margin:22px 0 34px}
.cinfo{display:grid;gap:22px}
.cinfo li{display:flex;gap:16px;align-items:flex-start}
.cinfo .ic{width:40px;height:40px;flex:none;border:1px solid var(--gline);display:flex;align-items:center;justify-content:center;color:var(--gold-light);font-size:16px}
.cinfo .lbl{font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-light);margin-bottom:3px}
.cinfo .val,.cinfo .val a{font-family:var(--font-serif);font-style:italic;font-size:20px;color:var(--cream)}
.cinfo .val a:hover{color:var(--gold-light)}
.map-ph{margin-top:30px;border:1px solid var(--gline);height:160px;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);background:repeating-linear-gradient(45deg,rgba(184,134,11,.05) 0 12px,transparent 12px 24px)}

/* FORM (shared) */
.form{background:rgba(245,240,232,.04);border:1px solid var(--gline);padding:42px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.form .fg{margin-bottom:24px}
.form label{display:block;font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-light);margin-bottom:8px}
.form label .req{color:var(--gold)}
.form input,.form textarea,.form select{width:100%;background:transparent;border:0;border-bottom:1px solid rgba(245,240,232,.22);padding:11px 2px;color:var(--cream);font-family:var(--font-sans);font-size:15px;transition:.25s}
.form select option{background:var(--forest-dark);color:var(--cream)}
.form input::placeholder,.form textarea::placeholder{color:rgba(245,240,232,.32)}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--gold)}
.form textarea{resize:vertical;min-height:90px}
.form input[type=file]{font-family:var(--font-mono);font-size:12px;color:var(--muted);border-bottom:0;padding-left:0}
.form .check{display:flex;gap:12px;align-items:flex-start;margin:6px 0 26px;font-size:13px;color:var(--muted)}
.form .check input{width:auto}
.form .btn{width:100%;justify-content:center;margin-top:6px}
.form-success{display:none;margin-top:24px;border:1px solid var(--green);background:rgba(46,125,82,.12);color:var(--gold-pale);padding:18px 22px;font-family:var(--font-mono);font-size:13px;letter-spacing:.04em}
.form-success.show{display:block}

/* CTA final */
.cta-final{background:var(--forest-deep);text-align:center;border-top:1px solid var(--gline)}
.cta-final .ct{font-size:clamp(34px,5vw,60px);color:var(--cream);margin-bottom:34px}
.cta-final .ct em{font-style:italic;color:var(--gold-light)}

/* 404 */
.notfound{min-height:70vh;display:flex;align-items:center;justify-content:center;text-align:center;background:radial-gradient(circle at 50% 30%,var(--forest),var(--forest-deep) 70%)}
.notfound .num{font-family:var(--font-serif);font-size:clamp(120px,26vw,260px);color:var(--gold-light);line-height:1;font-weight:300}
.notfound h1{font-size:clamp(30px,5vw,52px);color:var(--cream);margin:6px 0 14px}
.notfound p{color:var(--muted);font-size:16px;font-weight:300;max-width:440px;margin:0 auto 30px}
.notfound .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* FOOTER */
footer.footer{background:var(--forest-deep);border-top:1px solid var(--gline);padding:72px 0 36px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:44px}
.foot .brand{margin-bottom:18px}
.foot .desc{color:var(--muted);font-size:14px;font-weight:300;max-width:280px}
.foot h4{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-light);margin-bottom:18px}
.foot ul{display:grid;gap:11px}
.foot ul a{color:var(--muted);font-size:14px}.foot ul a:hover{color:var(--cream)}
.news-in{display:flex;margin-top:12px;border:1px solid var(--gline)}
.news-in input{flex:1;background:transparent;border:0;padding:12px 14px;color:var(--cream);font-size:13px;min-width:0}
.news-in input:focus{outline:none}.news-in input::placeholder{color:rgba(245,240,232,.3)}
.news-in button{background:var(--gold);border:0;color:#1a1400;padding:0 18px;cursor:pointer;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em}
.socials{display:flex;gap:10px;margin-top:16px}
.socials a{width:38px;height:38px;border:1px solid var(--gline);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:.25s}
.socials a:hover{border-color:var(--gold);color:var(--gold-light)}
.foot-bottom{margin-top:50px;padding-top:26px;border-top:1px solid rgba(245,240,232,.1);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;color:var(--muted)}
.foot-bottom a:hover{color:var(--gold-light)}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(30px);transition:.8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ============================ RTL ============================ */
[dir=rtl] body{text-align:right}
[dir=rtl] .eyebrow::before{margin-left:0}
[dir=rtl] .rn{margin-right:0;margin-left:.45em}
[dir=rtl] .lang ul{right:auto;left:0}
[dir=rtl] .rl:hover .arr{transform:translateX(-6px)}
[dir=rtl] .article .ah::after,[dir=rtl] .na .top::after{right:auto;left:-26%}
[dir=rtl] .ecrin .tl{left:auto;right:-1px;border-right:1px solid var(--gold);border-left:0}
[dir=rtl] .step{border-top:2px solid var(--gold)}
[dir=rtl] .search{margin-left:0;margin-right:auto}

/* ============================ RESPONSIVE ============================ */
@media(max-width:960px){
  .wrap,.container{padding:0 32px}
  .about,.contact-grid{grid-template-columns:1fr;gap:44px}
  .cards,.news,.res,.articles-grid,.etudes,.values{grid-template-columns:1fr 1fr}
  .stats .wrap,.steps{grid-template-columns:1fr 1fr;gap:40px 0}
  .stat{padding:18px;border-bottom:1px solid rgba(245,240,232,.12)}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .wrap,.container{padding:0 24px}
  .menu{display:none}.burger{display:flex}
  .menu.show{display:flex;position:absolute;top:82px;left:0;right:0;flex-direction:column;align-items:flex-start;background:var(--forest);padding:24px;gap:18px;border-bottom:1px solid var(--gline)}
  .cards,.news,.res,.foot-grid,.steps,.stats .wrap,.articles-grid,.etudes,.values{grid-template-columns:1fr}
  .form .row{grid-template-columns:1fr;gap:0}
  .search{margin-left:0;width:100%}
}

/* ============================================================
   AJOUTS : carrousel filières · offres à onglets · images actus
   ============================================================ */

/* --- Carrousel dans le bloc À-propos (remplace le logo) --- */
.about-carousel{position:relative;width:100%;aspect-ratio:4/5;overflow:hidden;border:1px solid var(--gline);background:var(--forest-deep)}
.ac-track{display:flex;height:100%;transition:transform .8s cubic-bezier(.7,0,.2,1)}
.ac-slide{position:relative;min-width:100%;height:100%}
.ac-slide img{width:100%;height:100%;object-fit:cover;filter:saturate(.96) brightness(.8)}
.ac-slide::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,45,26,.94),rgba(10,45,26,.12) 55%,rgba(10,45,26,.4));z-index:1}
.ac-cap{position:absolute;left:0;right:0;bottom:0;padding:28px 26px;z-index:2}
.ac-cap .eyebrow{margin-bottom:10px}
.ac-cap h4{font-family:var(--font-serif);font-weight:400;font-size:27px;color:var(--cream);line-height:1.05}
.ac-cap p{color:var(--gold-pale);font-size:13px;font-weight:300;margin-top:7px}
.ac-frame{position:absolute;inset:10px;border:1px solid rgba(184,134,11,.4);z-index:3;pointer-events:none}
.ac-dots{position:absolute;bottom:18px;right:20px;display:flex;gap:7px;z-index:4}
.ac-dots button{width:7px;height:7px;border-radius:50%;border:0;background:rgba(245,240,232,.4);cursor:pointer;padding:0;transition:.25s}
.ac-dots button.active{background:var(--gold-light);width:20px;border-radius:4px}
.ac-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:40px;height:40px;border:1px solid var(--gline);background:rgba(10,45,26,.45);color:var(--cream);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.25s;backdrop-filter:blur(4px)}
.ac-arrow:hover{background:var(--gold);color:#1a1400;border-color:var(--gold)}
.ac-arrow.prev{left:12px}.ac-arrow.next{right:12px}

/* --- Offres à onglets (Acheteurs / Producteurs) --- */
.offers-tabs{display:flex;width:max-content;max-width:100%;margin:0 auto 48px;border:1px solid var(--gline)}
.offers-tabs .tab{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);background:none;border:0;padding:15px 30px;cursor:pointer;transition:.25s;display:flex;align-items:center;gap:9px}
.offers-tabs .tab .ti{width:16px;height:16px}
.offers-tabs .tab.active{background:var(--gold);color:#1a1400}
.offers-tabs .tab:not(.active):hover{color:var(--cream)}
.offer-panel{display:none}
.offer-panel.active{display:block;animation:fadeUp .5s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.offers-grid{display:grid;grid-template-columns:repeat(4,1fr);border-left:1px solid var(--gline);border-top:1px solid var(--gline)}
.offer-card{padding:38px 30px;border-right:1px solid var(--gline);border-bottom:1px solid var(--gline);transition:.3s}
.offer-card:hover{background:var(--forest)}
.offer-card .oic{width:40px;height:40px;color:var(--gold-light);margin-bottom:20px}
.offer-card .oic svg{width:100%;height:100%}
.offer-card h3{font-size:23px;color:var(--cream);margin-bottom:10px}
.offer-card p{color:var(--muted);font-size:14px;font-weight:300;margin-bottom:16px}
.offer-card .tag{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-light);border:1px solid var(--gline);padding:5px 11px;display:inline-block}
.offers-cta{text-align:center;margin-top:42px}

/* --- Images dans les cartes d'actualités --- */
.article .ah img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.article .ah .ov{position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(10,45,26,.92),rgba(10,45,26,.1) 70%)}
.article .ah .tag{z-index:2}
.article:hover .ah img{transform:scale(1.05)}
.article .ah img{transition:transform .6s ease}

/* --- RTL pour les ajouts --- */
[dir=rtl] .ac-cap,[dir=rtl] .offer-card{text-align:right}
[dir=rtl] .ac-dots{right:auto;left:20px}
[dir=rtl] .ac-arrow.prev{left:auto;right:12px}
[dir=rtl] .ac-arrow.next{right:auto;left:12px}

/* --- Responsive pour les ajouts --- */
@media(max-width:960px){
  .offers-grid{grid-template-columns:1fr 1fr}
  .about-carousel{aspect-ratio:16/10}
}
@media(max-width:600px){
  .offers-grid{grid-template-columns:1fr}
  .offers-tabs{width:100%;flex-direction:column}
  .offers-tabs .tab{flex:1;justify-content:center;padding:14px 8px}
  .about-carousel{aspect-ratio:4/3}
}

/* --- Parcours BTP : arguments + étapes vers les marchés publics --- */
.btp-intro-p{text-align:center;max-width:720px;margin:0 auto 26px;color:var(--muted);font-size:17px;font-weight:300}
.btp-args{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:56px}
.btp-args li{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-pale);border:1px solid var(--gline);padding:9px 16px;display:flex;align-items:center;gap:9px;background:rgba(245,240,232,.02)}
.btp-args li::before{content:"\2713";color:var(--gold-light);font-size:12px}
.btp-steps{display:grid;grid-template-columns:repeat(5,1fr)}
.btp-step{position:relative;padding:0 16px;text-align:center}
.btp-step .bs-n{width:56px;height:56px;border-radius:50%;border:1px solid var(--gold);color:var(--gold-light);font-family:var(--font-serif);font-size:22px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;background:var(--forest-deep);position:relative;z-index:2}
.btp-step::before{content:"";position:absolute;top:28px;left:-50%;width:100%;height:1px;background:linear-gradient(90deg,var(--gold),var(--gline));z-index:1}
.btp-step:first-child::before{display:none}
.btp-step h4{font-family:var(--font-sans);font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--cream);margin-bottom:9px}
.btp-step p{color:var(--muted);font-size:13px;font-weight:300}
.btp-accomp{text-align:center;margin-top:50px;font-family:var(--font-serif);font-style:italic;font-size:clamp(20px,3vw,28px);color:var(--gold-pale)}
.btp-accomp::before{content:"";display:block;width:40px;height:1px;background:var(--gold);margin:0 auto 22px}

[dir=rtl] .btp-step::before{left:auto;right:-50%;background:linear-gradient(270deg,var(--gold),var(--gline))}

@media(max-width:960px){
  .btp-steps{grid-template-columns:1fr 1fr;gap:40px 0}
  .btp-step::before{display:none}
}
@media(max-width:600px){
  .btp-steps{grid-template-columns:1fr;gap:34px}
}

/* --- Bouton flottant WhatsApp --- */
.wa-float{position:fixed;bottom:24px;right:24px;z-index:300;display:flex;align-items:center;background:#25D366;color:#fff;border-radius:50px;box-shadow:0 10px 30px rgba(0,0,0,.35);transition:.3s;overflow:hidden;text-decoration:none}
.wa-float svg{width:28px;height:28px;margin:15px;flex:none;fill:#fff}
.wa-float .wa-txt{font-family:var(--font-mono);font-size:12px;letter-spacing:.05em;white-space:nowrap;max-width:0;opacity:0;transition:.35s;overflow:hidden}
.wa-float:hover{box-shadow:0 14px 40px rgba(0,0,0,.45)}
.wa-float:hover .wa-txt{max-width:260px;opacity:1;padding-right:22px}
[dir=rtl] .wa-float{right:auto;left:24px}
[dir=rtl] .wa-float .wa-txt{padding-left:0}
[dir=rtl] .wa-float:hover .wa-txt{padding-right:0;padding-left:22px}
@media(max-width:600px){
  .wa-float{bottom:16px;right:16px}
  [dir=rtl] .wa-float{left:16px}
  .wa-float:hover .wa-txt{max-width:0;opacity:0;padding:0}
}

/* --- Assistant de qualification --- */
.qa-launch{position:fixed;bottom:84px;right:24px;z-index:300;display:flex;align-items:center;gap:10px;background:var(--gold);color:#1a1400;border:0;border-radius:50px;padding:13px 18px 13px 14px;font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;cursor:pointer;box-shadow:0 10px 30px rgba(0,0,0,.35);transition:.3s}
.qa-launch:hover{background:var(--gold-light);transform:translateY(-2px)}
.qa-launch svg{width:20px;height:20px;fill:none;stroke:#1a1400;stroke-width:1.8}
.qa-launch.hide{display:none}
[dir=rtl] .qa-launch{right:auto;left:24px}

.qa-panel{position:fixed;bottom:24px;right:24px;z-index:320;width:370px;max-width:calc(100vw - 32px);height:560px;max-height:calc(100vh - 48px);background:var(--forest-deep);border:1px solid var(--gold);border-radius:14px;box-shadow:0 30px 80px rgba(0,0,0,.55);display:flex;flex-direction:column;overflow:hidden;animation:qaIn .3s ease}
@keyframes qaIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
[dir=rtl] .qa-panel{right:auto;left:24px}
.qa-panel[hidden]{display:none}
.qa-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;background:linear-gradient(135deg,var(--forest),var(--forest-deep));border-bottom:1px solid var(--gline)}
.qa-head .qh-t{display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-light)}
.qa-head .qh-t::before{content:"";width:8px;height:8px;border-radius:50%;background:#25D366;box-shadow:0 0 0 3px rgba(37,211,102,.25)}
.qa-close{background:none;border:0;color:var(--muted);font-size:24px;line-height:1;cursor:pointer;transition:.2s}
.qa-close:hover{color:var(--cream)}
.qa-body{flex:1;overflow-y:auto;padding:20px 18px;display:flex;flex-direction:column;gap:14px}
.qa-body::-webkit-scrollbar{width:6px}.qa-body::-webkit-scrollbar-thumb{background:var(--gline);border-radius:3px}
.qa-msg{max-width:85%;padding:12px 15px;border-radius:14px;font-size:14px;line-height:1.55;animation:qaMsg .25s ease}
@keyframes qaMsg{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.qa-bot{align-self:flex-start;background:rgba(245,240,232,.06);color:var(--cream);border:1px solid var(--gline);border-bottom-left-radius:4px}
.qa-user{align-self:flex-end;background:var(--gold);color:#1a1400;border-bottom-right-radius:4px;font-weight:500}
.qa-recap{align-self:flex-start;width:100%;max-width:100%;background:rgba(184,134,11,.08);border:1px solid var(--gline);border-radius:12px;padding:14px 16px}
.qa-recap .rr{display:flex;justify-content:space-between;gap:12px;padding:6px 0;border-bottom:1px solid rgba(245,240,232,.1);font-size:13px}
.qa-recap .rr:last-child{border-bottom:0}
.qa-recap .rr .k{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-light)}
.qa-recap .rr .v{color:var(--cream);text-align:right}
.qa-foot{padding:14px 16px;border-top:1px solid var(--gline);display:flex;flex-direction:column;gap:9px}
.qa-opts{display:flex;flex-wrap:wrap;gap:8px}
.qa-opt{background:none;border:1px solid var(--gline);color:var(--cream);font-family:var(--font-sans);font-size:13px;padding:9px 14px;border-radius:30px;cursor:pointer;transition:.2s}
.qa-opt:hover{border-color:var(--gold);background:var(--forest);color:var(--gold-light)}
.qa-inrow{display:flex;gap:8px}
.qa-inrow input{flex:1;background:rgba(245,240,232,.04);border:1px solid var(--gline);border-radius:8px;color:var(--cream);font-family:var(--font-sans);font-size:14px;padding:11px 13px;min-width:0}
.qa-inrow input:focus{outline:none;border-color:var(--gold)}
.qa-inrow input::placeholder{color:rgba(245,240,232,.34)}
.qa-inrow button{background:var(--gold);border:0;color:#1a1400;padding:0 16px;border-radius:8px;font-family:var(--font-mono);font-size:12px;cursor:pointer;transition:.2s}
.qa-inrow button:hover{background:var(--gold-light)}
.qa-act{display:block;width:100%;text-align:center;border-radius:8px;padding:12px;font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;cursor:pointer;transition:.25s;border:1px solid var(--gline);text-decoration:none}
.qa-act.primary{background:var(--gold);color:#1a1400;border-color:var(--gold)}
.qa-act.primary:hover{background:var(--gold-light)}
.qa-act.wa{background:#25D366;color:#fff;border-color:#25D366}
.qa-act.wa:hover{filter:brightness(1.08)}
.qa-act.ghost{background:none;color:var(--muted)}
.qa-act.ghost:hover{color:var(--cream);border-color:var(--gold)}
@media(max-width:600px){
  .qa-launch{bottom:74px;right:16px}
  [dir=rtl] .qa-launch{left:16px}
  .qa-panel{right:8px;left:8px;bottom:8px;width:auto;max-width:none;height:calc(100vh - 16px)}
}
