/* ═════════════════════════════════════════════════════
   PND.ci — style.css — VERSION FINALE PROPRE
   Poppins + Montserrat · Orange · Vert · Marine
   NB: menu mobile géré par mobile.css (chargé via components.js)
═════════════════════════════════════════════════════ */

:root {
  --o:#F47920; --od:#D4610A; --ol:#FFF0E5; --om:#FDDCBC;
  --g:#009A44; --gl:#E8F7EE;
  --n:#0D1B35; --nm:#1A2F52; --nl:#EEF1F9;
  --w:#FFFFFF; --ow:#FAF9F7; --bg:#F5F6FA;
  --t:#1A2535; --tm:#3D4F68; --ts:#6B7C93;
  --b:#E4E9F2; --bm:#D0D8E8;
  --ss:0 2px 14px rgba(13,27,53,.07);
  --sm:0 6px 32px rgba(13,27,53,.11);
  --sl:0 16px 64px rgba(13,27,53,.16);
  --r:8px; --rl:16px; --rx:24px;
  --mh:90px;
  --fh:'Montserrat',sans-serif;
  --fb:'Poppins',sans-serif;
  --mx:1240px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fb);color:var(--t);background:var(--w);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{cursor:pointer;font-family:var(--fb)}
.wrap{max-width:var(--mx);margin:0 auto;padding:0 28px}
.section{padding:72px 0}
.sec-sm{padding:48px 0}

/* ══ GOVBAR ══ */
.govbar{background:var(--n);height:34px;min-height:34px;max-height:34px;overflow:hidden;display:flex;align-items:center}
.gb-in{max-width:var(--mx);margin:0 auto;padding:0 28px;width:100%;display:flex;align-items:center;justify-content:space-between;flex-wrap:nowrap;overflow:hidden}
.gb-left{display:flex;align-items:center;gap:8px;flex-shrink:0;overflow:hidden}
.flag{display:flex;width:22px;min-width:22px;height:14px;border-radius:2px;overflow:hidden;flex-shrink:0}
.flag span{flex:1;display:block}
.gb-name{font-family:var(--fb);font-size:10px;font-weight:500;color:rgba(255,255,255,.5);letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gb-links{display:flex;gap:16px;flex-shrink:0}
.gb-link{font-size:11px;color:rgba(255,255,255,.4);text-decoration:none;white-space:nowrap}
.gb-link:hover{color:rgba(255,255,255,.85)}

/* ══ NOTIF BAR ══ */
.notif{background:var(--g);padding:9px 48px 9px 20px;display:flex;align-items:center;gap:10px;justify-content:center;position:relative}
.notif-ico{font-size:15px;flex-shrink:0}
.notif-txt{font-size:13px;color:#fff;font-weight:500;line-height:1.4;text-align:center}
.notif-x{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.2);border:none;color:#fff;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;line-height:1}

/* ══ SITE HEADER — Centered logos + Orange nav bar ══ */
.site-header{background:var(--w);position:sticky;top:0;z-index:200;transition:box-shadow .3s}
.header-top{border-bottom:1px solid var(--b); background: #fff;}
.hi{max-width:var(--mx);margin:0 auto;padding:16px 28px;display:flex;align-items:center;justify-content:center;gap:20px;position:relative}
.header-flag{position:absolute;left:28px;top:50%;transform:translateY(-50%);display:flex;gap:3px}
.header-flag span{width:8px;height:28px;border-radius:2px}
.header-center{display:flex;align-items:center;gap:16px}
.header-coat{height:81px;width:auto;flex-shrink:0}
.header-sep{width:1.5px;height:42px;background:var(--b);flex-shrink:0}
.header-logo-img{height:95px;width:auto;flex-shrink:0}
.header-sep2{width:1.5px;height:42px;background:var(--b);flex-shrink:0}
.header-text{text-align:left;flex-shrink:0}
.header-text-title{font-family:var(--fh);font-size:14px;font-weight:800;color:var(--n);line-height:1.25}
.header-text-sub{font-size:10.5px;color:var(--ts);font-weight:500;letter-spacing:.02em;margin-top:2px}
.header-text-country{font-size:9.5px;color:var(--o);font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-top:3px}
.h-btns{position:absolute;right:28px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:10px}

/* ── Orange navigation bar ── */
.nav-bar{background:#F47920;width:100%}
.nav-bar-inner{max-width:var(--mx);margin:0 auto;padding:0 28px;display:flex;align-items:center;justify-content:center}
.main-nav{display:flex;align-items:center;gap:0;flex-wrap:nowrap}
.nav-item{position:relative}
.nav-link{display:flex;align-items:center;gap:5px;padding:14px 16px;font-size:13px;font-weight:600;color:rgba(255,255,255,.85);border:none;background:none;transition:all .15s;white-space:nowrap;font-family:var(--fb);cursor:pointer;text-decoration:none;letter-spacing:.01em}
.nav-link:hover{color:#fff;background:rgba(255,255,255,.12)}
.nav-link.active{color:#fff;background:rgba(0,0,0,.12);font-weight:600}
.nav-chev{opacity:.5;transition:transform .25s;flex-shrink:0}
.nav-item:hover .nav-chev{transform:rotate(180deg);opacity:1}
.dropdown{position:absolute;top:100%;left:0;background:var(--w);border:1px solid var(--b);border-radius:0 0 var(--rl) var(--rl);box-shadow:var(--sl);min-width:280px;opacity:0;visibility:hidden;transform:translateY(-4px);transition:all .22s cubic-bezier(.16,1,.3,1);z-index:400;padding:8px}
.nav-item:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.ddi{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--r);transition:background .15s;font-size:13px;color:var(--tm);text-decoration:none;width:100%;font-family:var(--fb)}
.ddi:hover{background:var(--ol);color:var(--o)}
.ddi-ico{width:32px;height:32px;border-radius:var(--r);background:var(--ol);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.ddi-lbl{font-weight:600;font-size:13px;line-height:1.25}
.ddi-sub{font-size:11.5px;color:var(--ts)}

/* ── Header actions ── */
.btn-srch{width:36px;height:36px;border-radius:var(--r);border:1.5px solid var(--b);background:var(--w);color:var(--ts);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}
.btn-srch:hover{border-color:var(--o);color:var(--o)}
.btn-act{background:var(--n);color:#fff;border:none;padding:9px 18px;border-radius:var(--r);font-size:12px;font-weight:600;transition:background .2s;white-space:nowrap;text-decoration:none;display:inline-flex;align-items:center}
.btn-act:hover{background:#1A2F52}

/* ══ SEARCH ══ */
.search-overlay{display:none;position:fixed;inset:0;background:rgba(13,27,53,.72);z-index:9990;align-items:flex-start;justify-content:center;padding-top:100px;backdrop-filter:blur(4px)}
.search-box{background:#fff;border-radius:16px;width:90%;max-width:620px;padding:24px;box-shadow:0 24px 80px rgba(0,0,0,.28)}
.search-input-row{display:flex;gap:10px;margin-bottom:16px}
.search-input{flex:1;border:1.5px solid var(--b);border-radius:var(--r);padding:12px 16px;font-size:15px;font-family:var(--fb);outline:none;transition:border .2s}
.search-input:focus{border-color:var(--o)}
.search-close{background:var(--bg);border:none;border-radius:var(--r);padding:12px 16px;font-size:15px;cursor:pointer;color:var(--ts)}
.search-quick{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.search-quick-label{font-size:12px;color:var(--ts)}
.search-tag{font-size:12.5px;font-weight:600;color:var(--o);background:var(--ol);padding:5px 12px;border-radius:20px;text-decoration:none}

/* ══ HERO SLIDER ══ */
.hero-slider{position:relative;height:680px;overflow:hidden;background:var(--n)}
.slide{position:absolute;inset:0;opacity:0;transition:opacity .8s ease}
.slide.active{opacity:1}
.slide-img{width:100%;height:100%;object-fit:cover}
.slide-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(13,27,53,.85) 0%,rgba(13,27,53,.28) 100%)}
.slide-content{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;padding:0 60px}
.slide-text{max-width:640px}
.slide-eye{display:inline-block;font-size:11px;font-weight:700;color:var(--o);text-transform:uppercase;letter-spacing:.12em;margin-bottom:14px}
.slide-line{width:32px;height:2px;background:var(--o);display:inline-block;vertical-align:middle;margin-right:10px}
.slide-title{font-family:var(--fh);font-size:3.4rem;font-weight:900;color:#fff;line-height:1.08;margin-bottom:18px}
.slide-desc{font-size:16px;color:rgba(255,255,255,.65);line-height:1.7;margin-bottom:28px;max-width:520px}
.slide-cta{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.btn-hp{display:inline-flex;align-items:center;gap:8px;padding:14px 26px;border-radius:var(--r);font-size:14.5px;font-weight:700;font-family:var(--fb);transition:all .2s;text-decoration:none;cursor:pointer;border:none}
.btn-hp-p{background:var(--o);color:#fff}
.btn-hp-p:hover{background:var(--od);transform:translateY(-2px)}
.btn-hp-s{background:rgba(255,255,255,.1);color:#fff;border:1.5px solid rgba(255,255,255,.3)}
.btn-hp-s:hover{background:rgba(255,255,255,.18)}
.s-arr{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.25);border-radius:50%;color:#fff;font-size:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;z-index:10}
.s-arr:hover{background:rgba(255,255,255,.22)}
.s-prev{left:24px}
.s-next{right:24px}
.s-prog{position:absolute;bottom:0;left:0;height:3px;width:0;background:var(--o);z-index:10;transition:none}
.s-dot{width:8px;height:8px;border-radius:4px;background:rgba(255,255,255,.35);cursor:pointer;transition:all .3s}
.s-dot.active{background:var(--o);width:28px}
.s-thumbs{position:absolute;right:32px;bottom:24px;display:flex;gap:8px;z-index:10}
.s-thumb{width:72px;height:44px;border-radius:6px;object-fit:cover;cursor:pointer;opacity:.5;border:2px solid transparent;transition:all .25s}
.s-thumb.active{opacity:1;border-color:var(--o)}

/* ══ STATS BAND ══ */
.stats-band{border-bottom:1px solid var(--b)}
.sb-inner,.grid-stats{display:grid;grid-template-columns:repeat(4,1fr)}
.stat-it{display:flex;align-items:center;gap:14px;padding:22px 24px;border-right:1px solid var(--b)}
.stat-it:last-child{border-right:none}
.stat-ico{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.ico-o{background:var(--ol)} .ico-g{background:var(--gl)} .ico-n{background:var(--nl)} .ico-gd{background:#FDF4E3}
.sv{font-family:var(--fh);font-size:2rem;font-weight:800;line-height:1;margin-bottom:3px}
.sv-o{color:var(--o)} .sv-g{color:var(--g)} .sv-n{color:var(--n)} .sv-gd{color:#C8922A}
.sl_{font-size:13px;color:var(--ts);line-height:1.35}
.ticker{background:var(--o);height:40px;display:flex;align-items:center;overflow:hidden;position:fixed;bottom:0;left:0;right:0;z-index:180}
.tk-lbl{padding:0 18px;font-size:11px;font-weight:700;color:rgba(255,255,255,.8);text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;border-right:1px solid rgba(255,255,255,.25);flex-shrink:0}
.tk-track{display:flex;align-items:center;animation:ticker 38s linear infinite;white-space:nowrap}
.tk-item{font-size:13px;color:rgba(255,255,255,.9);font-weight:500;padding:0 28px}
.tk-sep{color:rgba(255,255,255,.4);padding:0 4px}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ══ SECTION HELPERS ══ */
.sh{margin-bottom:40px}
.sh-flex{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:40px}
.s-tag{display:inline-flex;align-items:center;gap:8px;font-size:11.5px;font-weight:700;color:var(--o);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px}
.s-tag::before{content:'';width:18px;height:2px;background:currentColor;flex-shrink:0}
.s-title{font-family:var(--fh);font-size:2.2rem;font-weight:800;color:var(--n);line-height:1.15;margin-bottom:12px}
.s-title.lgt{color:#fff}
.s-sub{font-size:15px;color:var(--ts);line-height:1.75}
.s-sub.lgt{color:rgba(255,255,255,.55)}
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:var(--r);font-size:14px;font-weight:700;font-family:var(--fb);text-decoration:none;border:none;cursor:pointer;transition:all .2s}
.btn-p{background:var(--o);color:#fff}
.btn-p:hover{background:var(--od)}
.btn-ol{background:var(--ol);color:var(--o);border:1.5px solid var(--o)}
.btn-ol:hover{background:var(--o);color:#fff}
.btn-w{background:#fff;color:var(--n)}
.btn-w:hover{background:var(--ow)}
.btn-sm{padding:9px 18px;font-size:13px}

/* ══ PILIERS GRID ══ */
.axes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.axe-card{background:var(--w);border:1px solid var(--b);border-radius:var(--rx);overflow:hidden;transition:box-shadow .25s,transform .25s}
.axe-card:hover{box-shadow:var(--sm);transform:translateY(-4px)}
.axe-img-wrap{position:relative;height:180px;overflow:hidden}
.axe-img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.axe-card:hover .axe-img{transform:scale(1.04)}
.axe-img-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,27,53,.8) 0%,rgba(13,27,53,.1) 100%)}
.axe-num{position:absolute;top:14px;right:16px;font-family:var(--fh);font-size:2rem;font-weight:900;color:rgba(255,255,255,.25);line-height:1}
.axe-num.g{color:rgba(0,154,68,.4)}
.axe-img-title{position:absolute;bottom:14px;left:16px;right:16px;font-family:var(--fh);font-size:14px;font-weight:700;color:#fff;line-height:1.3}
.axe-body{padding:18px 20px}
.axe-sub{font-size:13px;color:var(--ts);line-height:1.6;margin-bottom:12px}
.axe-foot{display:flex;align-items:center;justify-content:space-between;margin-top:4px}
.axe-arrow{font-size:16px;color:var(--o)}

/* ══ CHIFFRES CLÉS ══ */
.nums-grid{display:grid;grid-template-columns:repeat(5,1fr);border:1px solid rgba(255,255,255,.08);border-radius:var(--rx);overflow:hidden}
.num-it{padding:36px 24px;border-right:1px solid rgba(255,255,255,.08);text-align:center}
.num-it:last-child{border-right:none}
.num-val{font-family:var(--fh);font-size:3rem;font-weight:900;color:var(--o);line-height:1;margin-bottom:8px}
.num-val.g{color:var(--g)}
.num-lbl{font-size:12.5px;color:rgba(255,255,255,.5);line-height:1.4}

/* ══ NEWS CAROUSEL ══ */
.news-carousel{overflow:hidden}
.news-track{display:flex;gap:20px;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.news-slide{flex:0 0 calc(33.333% - 14px);background:var(--w);border:1px solid var(--b);border-radius:var(--rl);overflow:hidden;transition:box-shadow .25s}
.news-slide:hover{box-shadow:var(--sm)}
.nc-img{width:100%;height:180px;object-fit:cover}
.nc-body{padding:18px}
.nc-date{font-size:11.5px;color:var(--ts);margin-bottom:8px}
.nc-tag{font-size:11px;font-weight:700;color:var(--o);text-transform:uppercase;margin-bottom:8px}
.nc-title{font-family:var(--fh);font-size:14px;font-weight:700;color:var(--n);line-height:1.4}
.car-dots{display:flex;gap:8px;justify-content:center;margin-top:20px}
.car-dot{width:8px;height:8px;border-radius:50%;background:var(--b);cursor:pointer;transition:all .2s}
.car-dot.active{background:var(--o);width:24px;border-radius:4px}
.car-arr{width:38px;height:38px;border:1.5px solid var(--b);border-radius:var(--r);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;background:var(--w)}
.car-arr:hover{border-color:var(--o);color:var(--o)}

/* ══ NEWSLETTER + FOOTER ══ */
.nl-section{background:var(--o);padding:40px 0}
.nl-inner{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.nl-h{font-family:var(--fh);font-size:1.5rem;font-weight:800;color:#fff;margin-bottom:6px}
.nl-s{font-size:13.5px;color:rgba(255,255,255,.7)}
.nl-form{display:flex;gap:10px}
.nl-inp{padding:12px 18px;border-radius:var(--r);border:none;font-size:14px;font-family:var(--fb);width:280px}
.nl-btn{background:var(--n);color:#fff;border:none;padding:12px 22px;border-radius:var(--r);font-size:14px;font-weight:700;font-family:var(--fb);cursor:pointer;white-space:nowrap}
.footer{background:var(--n);padding:56px 0 0}
.fg{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.07)}
.f-flag{display:flex;height:16px;width:36px;border-radius:2px;overflow:hidden;margin-top:16px}
.f-flag span{flex:1;display:block}
.fb-desc{font-size:13.5px;color:rgba(255,255,255,.38);line-height:1.7;margin-top:10px}
.fc-t{font-family:var(--fh);font-size:12px;font-weight:700;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}
.fl{display:flex;flex-direction:column;gap:10px}
.fl a{font-size:13.5px;color:rgba(255,255,255,.4);text-decoration:none;transition:color .2s}
.fl a:hover{color:#fff}
.fb-bot{display:flex;align-items:center;justify-content:space-between;padding:20px 0}
.fb-copy{font-size:12.5px;color:rgba(255,255,255,.25)}
.fb-leg{display:flex;gap:20px}
.fb-leg a{font-size:12px;color:rgba(255,255,255,.25);text-decoration:none}
.fb-leg a:hover{color:rgba(255,255,255,.55)}
.back-top{position:fixed;bottom:56px;right:24px;width:44px;height:44px;background:var(--n);color:#fff;border:none;border-radius:50%;font-size:18px;display:none;align-items:center;justify-content:center;cursor:pointer;z-index:170;box-shadow:var(--sm)}
.back-top.show{display:flex}
.back-top:hover{background:var(--o)}
.social-float{position:fixed;bottom:110px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:170;transition:opacity .3s}
.sf-btn{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;border:none;cursor:pointer;box-shadow:var(--sm);transition:transform .2s,box-shadow .2s;text-decoration:none}
.sf-btn:hover{transform:scale(1.12);box-shadow:var(--sl)}
.sf-wa{background:#25D366}.sf-fb{background:#1877F2}.sf-li{background:#0A66C2}.sf-yt{background:#FF0000}.sf-ig{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}
body{padding-bottom:40px}

/* ══ HELPERS PARTAGÉS ══ */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px}
.kpi-box{background:var(--w);border:1px solid var(--b);border-radius:var(--rl);padding:20px;text-align:center}
.kpi-box.g{border-top:4px solid var(--g)} .kpi-box.n{border-top:4px solid var(--n)} .kpi-box.gd{border-top:4px solid #C8922A}
.kpi-val{font-family:var(--fh);font-size:2rem;font-weight:800;color:var(--o);line-height:1;margin-bottom:4px}
.kpi-box.g .kpi-val{color:var(--g)} .kpi-box.n .kpi-val{color:var(--n)} .kpi-box.gd .kpi-val{color:#C8922A}
.kpi-lbl{font-size:12.5px;color:var(--ts);line-height:1.35}
.breadcrumb{background:var(--ow);border-bottom:1px solid var(--b);padding:10px 0}
.bc-inner{max-width:var(--mx);margin:0 auto;padding:0 28px;display:flex;align-items:center;gap:8px;font-size:13px}
.bc-link{color:var(--ts);text-decoration:none}
.bc-link:hover{color:var(--o)}
.bc-sep{color:var(--bm)}
.bc-cur{color:var(--n);font-weight:600}
.page-hero{background:linear-gradient(110deg,var(--n) 0%,var(--nm) 100%);padding:48px 0;border-bottom:4px solid var(--o)}
.ph-inner{max-width:var(--mx);margin:0 auto;padding:0 28px}
.ph-tag{font-size:11px;font-weight:700;color:var(--o);text-transform:uppercase;letter-spacing:.12em;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.ph-tag::before{content:'';width:16px;height:2px;background:var(--o)}
.page-hero h1{font-family:var(--fh);font-size:2.4rem;font-weight:900;color:#fff;margin-bottom:10px;line-height:1.1}
.page-hero p{font-size:16px;color:rgba(255,255,255,.5);line-height:1.7;max-width:680px}
.bg-bg{background:var(--bg)} .bg-ow{background:var(--ow)} .bg-w{background:var(--w)} .bg-n{background:var(--n)}
.logo-slot{background:var(--ow);border:1px solid var(--b);border-radius:var(--rl);height:72px;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--ts)}

/* ══ GRILLES RESPONSIVES (index.html) ══ */
.fin-main-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center;margin-bottom:40px}
.peda-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.contrib-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.contrib-form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.partners-logo-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:20px}
.carto-index-grid{display:grid;grid-template-columns:1fr 280px;gap:20px;align-items:start}
.vision-sec-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.cards-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.cards-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.layout-sb{display:grid;grid-template-columns:1fr 300px;gap:32px;align-items:start}
.filter-bar{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px;align-items:center}
.f-input{flex:1;min-width:220px;border:1.5px solid var(--b);border-radius:var(--r);padding:10px 14px;font-size:13.5px;font-family:var(--fb)}
.f-select{border:1.5px solid var(--b);border-radius:var(--r);padding:10px 14px;font-size:13.5px;font-family:var(--fb);background:var(--w)}
.f-btn{background:var(--ow);border:1.5px solid var(--b);border-radius:var(--r);padding:10px 16px;font-size:13px;cursor:pointer}
.pag{display:flex;gap:6px;justify-content:center;margin-top:32px}
.pag-btn{border:1.5px solid var(--b);border-radius:var(--r);padding:8px 14px;font-size:13px;cursor:pointer;background:var(--w)}
.pag-btn.active{background:var(--o);border-color:var(--o);color:#fff}
.tab-bar{display:flex;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.tab-btn-pg{padding:10px 18px;border-radius:20px;font-size:13px;font-weight:600;border:1.5px solid var(--b);background:var(--w);color:var(--tm);cursor:pointer;white-space:nowrap}
.tab-btn-pg.active{background:var(--o);border-color:var(--o);color:#fff}
.data-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--rl);border:1px solid var(--b)}
.data-table{width:100%;border-collapse:collapse;font-size:13.5px}
.data-table thead th{background:var(--n);color:#fff;padding:13px 16px;text-align:left;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}
.data-table tbody td{padding:13px 16px;border-bottom:1px solid var(--b);color:var(--tm);vertical-align:top}
.data-table tbody tr:hover{background:var(--ow)}
.badge{display:inline-block;font-size:11px;font-weight:700;padding:3px 10px;border-radius:12px}
.b-warn{background:var(--ol);color:var(--o)} .b-ok{background:var(--gl);color:var(--g)} .b-info{background:var(--nl);color:var(--n)}
.td-strong{font-weight:600;color:var(--n)}
.content-card{background:var(--w);border:1px solid var(--b);border-radius:var(--rl);padding:28px;margin-bottom:24px}
.content-h2{display:flex;align-items:center;gap:12px;font-family:var(--fh);font-size:1.2rem;font-weight:800;color:var(--n);margin-bottom:16px}
.content-h2 .icon{font-size:22px}
.content-p{font-size:14.5px;color:var(--tm);line-height:1.8;margin-bottom:14px}
.info-box{background:var(--ol);border-radius:var(--rl);padding:16px 18px;border-left:4px solid var(--o)}
.info-box.green{background:var(--gl);border-left-color:var(--g)}
.info-box.navy{background:var(--nl);border-left-color:var(--n)}
.info-box__title{font-weight:700;color:var(--n);margin-bottom:6px;font-size:13.5px}
.info-box__text{font-size:13.5px;color:var(--tm);line-height:1.7}
.sidebar{position:sticky;top:110px}
.timeline{display:flex;flex-direction:column;gap:0}
.tl-item{display:flex;gap:20px;padding-bottom:28px}
.tl-dot{width:14px;height:14px;border-radius:50%;background:var(--o);flex-shrink:0;margin-top:4px;position:relative;z-index:1}
.tl-dot::before{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);width:2px;height:100%;background:var(--b);z-index:-1}
.tl-item:last-child .tl-dot::before{display:none}
.tl-dot.g{background:var(--g)}
.tl-date{font-size:11.5px;color:var(--ts);font-weight:700;min-width:55px;flex-shrink:0}
.tl-title{font-size:14px;font-weight:700;color:var(--n);margin-bottom:4px}
.tl-text{font-size:13.5px;color:var(--tm);line-height:1.65}
.prog-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0;border-bottom:1px solid var(--b)}
.prog-label{font-size:14px;font-weight:600;color:var(--n)}
.prog-sub{font-size:12px;color:var(--ts);margin-top:2px}

/* ══ RESPONSIVE GLOBAL (mobile.css gère le menu) ══ */
@media (max-width: 1024px) {
  .main-nav{display:none!important}
  .btn-act{display:none!important}
  .axes-grid{grid-template-columns:repeat(2,1fr)}
  .nums-grid{grid-template-columns:repeat(3,1fr)}
  .fg{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width: 768px) {
  .wrap{padding:0 16px!important}
  .section{padding:48px 0}
  .sec-sm{padding:32px 0}
  .hero-slider{height:440px}
  .slide-content{padding:0 20px}
  .slide-title{font-size:clamp(1.6rem,6vw,2.4rem)}
  .slide-desc{font-size:14px;margin-bottom:18px}
  .slide-cta{flex-wrap:wrap;gap:8px}
  .btn-hp{padding:11px 18px;font-size:13px}
  .s-thumbs{display:none!important}
  .s-arr{width:36px;height:36px;font-size:18px}
  .s-prev{left:12px}
  .s-next{right:12px}
  .sb-inner,.grid-stats{grid-template-columns:repeat(2,1fr)!important}
  .stat-it{padding:16px 12px!important}
  .stat-it:nth-child(2){border-right:none!important}
  .stat-it:nth-child(3){border-right:1px solid var(--b)!important;border-top:1px solid var(--b)}
  .stat-it:nth-child(4){border-top:1px solid var(--b)}
  .sv{font-size:1.45rem!important}
  .stat-ico{width:40px!important;height:40px!important;font-size:17px!important}
  .tk-lbl{display:none}
  .axes-grid{grid-template-columns:1fr!important;gap:14px!important}
  .nums-grid{grid-template-columns:repeat(2,1fr)!important}
  .num-it{padding:24px 14px!important}
  .num-val{font-size:2rem!important}
  .num-it:nth-child(2n){border-right:none!important}
  .num-it:nth-child(n+3){border-top:1px solid rgba(255,255,255,.08)}
  .news-slide{flex:0 0 100%!important}
  .carto-index-grid{grid-template-columns:1fr!important}
  #hpMap{height:280px!important}
  .fin-main-grid{grid-template-columns:1fr!important;gap:20px!important}
  .peda-grid{grid-template-columns:1fr!important;gap:14px!important}
  .contrib-grid{grid-template-columns:1fr!important;gap:24px!important}
  .contrib-form-row{grid-template-columns:1fr!important}
  .partners-logo-grid{grid-template-columns:repeat(3,1fr)!important}
  .vision-sec-grid{grid-template-columns:1fr!important;gap:24px!important}
  .cards-grid-2,.cards-grid-3{grid-template-columns:1fr!important}
  .layout-sb{grid-template-columns:1fr!important}
  .sidebar{position:static!important;top:auto!important}
  .kpi-row{grid-template-columns:repeat(2,1fr)!important;gap:10px!important}
  .kpi-val{font-size:1.7rem!important}
  .nl-inner{flex-direction:column;gap:20px}
  .nl-form{width:100%;flex-direction:column}
  .nl-inp,.nl-btn{width:100%}
  .fg{grid-template-columns:1fr 1fr!important;gap:24px}
  .fb-bot{flex-direction:column;align-items:center;text-align:center;gap:8px}
  .fb-leg{flex-wrap:wrap;justify-content:center;gap:12px}
  .sh-flex{flex-direction:column!important;align-items:flex-start!important;gap:12px}
  .sh-flex .btn,.sh-flex a.btn{width:100%;justify-content:center;box-sizing:border-box}
  .page-hero{padding:28px 0}
  .page-hero h1{font-size:clamp(1.4rem,5vw,2rem)}
  .ph-inner{padding:0 16px}
  .breadcrumb{display:none}
  .tab-btn-pg{font-size:12px;padding:8px 13px;flex-shrink:0}
  .filter-bar{flex-direction:column}
  .f-input,.f-select{width:100%;min-width:auto}
  .modal-mask,#hpModal,#rgModal{align-items:flex-end!important;padding:0!important}
  .modal-box,#hpModalBox{border-radius:20px 20px 0 0!important;max-height:92vh!important;width:100%!important;max-width:100%!important}
  .back-top{bottom:14px;right:14px;width:40px;height:40px}
}
@media (max-width: 480px) {
  .hero-slider{height:380px}
  .slide-title{font-size:1.5rem}
  .slide-desc{display:none}
  .slide-cta{flex-direction:column}
  .btn-hp{width:100%;display:flex;justify-content:center}
  .sv{font-size:1.3rem!important}
  .num-val{font-size:1.75rem!important}
  .partners-logo-grid{grid-template-columns:repeat(2,1fr)!important}
  .fg{grid-template-columns:1fr!important}
  .kpi-val{font-size:1.5rem!important}
  .gb-name{display:none}
}
