/* ═════════════════════════════════════════════
   PND.ci — Pages internes CSS partagé
   Extends style.css for inner pages
═════════════════════════════════════════════ */

/* ── PAGE HERO BANNER ── */
.page-hero {
  background: linear-gradient(135deg, var(--n) 0%, #1A2F52 100%);
  padding: 56px 0;
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 6px;
  background: linear-gradient(to bottom, var(--o), var(--g));
}
.page-hero::after {
  content: '';
  position: absolute;
  right: 0; top: 0;
  width: 50%;
  height: 100%;
  background: radial-gradient(ellipse at right center, rgba(244,121,32,.08) 0%, transparent 65%);
}
.ph-inner { position: relative; z-index: 1; }
.ph-tag {
  font-size: 11.5px; font-weight: 700;
  color: var(--o);
  text-transform: uppercase; letter-spacing: .12em;
  margin-bottom: 10px;
  display: flex; align-items: center; gap: 8px;
  font-family: var(--fb);
}
.ph-tag::before { content: ''; width: 24px; height: 2px; background: var(--o); }
.page-hero h1 {
  font-family: var(--fh);
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  font-weight: 800;
  color: #fff;
  margin-bottom: 12px;
  line-height: 1.15;
  letter-spacing: -.02em;
}
.page-hero p {
  font-size: 15.5px;
  color: rgba(255,255,255,.55);
  max-width: 580px;
  line-height: 1.75;
}

/* ── BREADCRUMB ── */
.breadcrumb {
  background: var(--ow);
  border-bottom: 1px solid var(--b);
}
.bc-inner {
  max-width: var(--mx);
  margin: 0 auto;
  padding: 11px 28px;
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--ts);
}
.bc-link { cursor: pointer; transition: color .2s; }
.bc-link:hover { color: var(--o); }
.bc-sep { opacity: .4; }
.bc-cur { color: var(--o); font-weight: 600; }

/* ── SIDEBAR LAYOUT ── */
.layout-sb {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 36px;
  align-items: start;
}
.sidebar { position: sticky; top: calc(var(--mh) + 20px); }
.sb-nav {
  background: var(--w);
  border: 1px solid var(--b);
  border-radius: var(--rl);
  overflow: hidden;
  margin-bottom: 16px;
}
.sb-nav-title {
  padding: 13px 18px;
  background: var(--n);
  color: #fff;
  font-size: 11.5px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .07em;
  font-family: var(--fh);
}
.sb-nav-item {
  padding: 11px 18px;
  border-bottom: 1px solid var(--b);
  font-size: 13.5px;
  cursor: pointer;
  display: flex; align-items: center; gap: 10px;
  color: var(--tm);
  transition: all .15s;
  border-left: 3px solid transparent;
  text-decoration: none;
}
.sb-nav-item:last-child { border-bottom: none; }
.sb-nav-item:hover,
.sb-nav-item.active {
  background: var(--ol);
  color: var(--o);
  border-left-color: var(--o);
  padding-left: 15px;
}

/* ── CONTENT CARD ── */
.content-card {
  background: var(--w);
  border: 1px solid var(--b);
  border-radius: var(--rx);
  padding: 36px;
  margin-bottom: 24px;
}
.content-h2 {
  font-family: var(--fh);
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--n);
  margin-bottom: 16px;
  letter-spacing: -.01em;
  padding-bottom: 14px;
  border-bottom: 2px solid var(--ol);
  display: flex; align-items: center; gap: 12px;
}
.content-h2 .icon {
  width: 40px; height: 40px;
  border-radius: var(--r);
  background: var(--ol);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; flex-shrink: 0;
}
.content-h3 {
  font-family: var(--fh);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--n);
  margin: 24px 0 10px;
}
.content-p {
  font-size: 14.5px;
  color: var(--tm);
  line-height: 1.85;
  margin-bottom: 16px;
}
.content-ul {
  list-style: none;
  margin-bottom: 20px;
}
.content-ul li {
  padding: 7px 0 7px 24px;
  position: relative;
  font-size: 14px;
  color: var(--tm);
  border-bottom: 1px solid var(--b);
  line-height: 1.6;
}
.content-ul li:last-child { border-bottom: none; }
.content-ul li::before {
  content: '';
  position: absolute;
  left: 0; top: 50%;
  transform: translateY(-50%);
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--o);
}

/* ── INFO BOXES ── */
.info-box {
  background: var(--ol);
  border: 1px solid var(--om);
  border-radius: var(--rl);
  padding: 20px 24px;
  border-left: 4px solid var(--o);
  margin-bottom: 20px;
}
.info-box.green { background: var(--gl); border-color: var(--g); border-left-color: var(--g); }
.info-box.navy  { background: var(--nl); border-color: #C4D2EE; border-left-color: var(--n); }
.info-box.gold  { background: #FDF4E3; border-color: #F0D89A; border-left-color: #C8922A; }
.info-box__title { font-family: var(--fh); font-size: 14px; font-weight: 700; color: var(--n); margin-bottom: 6px; }
.info-box__text  { font-size: 13.5px; color: var(--tm); line-height: 1.7; }

/* ── TIMELINE ── */
.timeline { position: relative; padding-left: 32px; }
.timeline::before { content: ''; position: absolute; left: 8px; top: 10px; bottom: 0; width: 2px; background: var(--b); }
.tl-item { position: relative; padding-bottom: 28px; }
.tl-dot {
  position: absolute; left: -28px; top: 5px;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--o);
  border: 3px solid var(--w);
  box-shadow: 0 0 0 2px var(--o);
}
.tl-dot.g { background: var(--g); box-shadow: 0 0 0 2px var(--g); }
.tl-dot.n { background: var(--n); box-shadow: 0 0 0 2px var(--n); }
.tl-dot.gray { background: var(--b); box-shadow: 0 0 0 2px var(--bm); }
.tl-date { font-size: 11.5px; font-weight: 700; color: var(--o); text-transform: uppercase; letter-spacing: .07em; margin-bottom: 4px; }
.tl-title { font-size: 14.5px; font-weight: 600; color: var(--n); margin-bottom: 4px; }
.tl-text  { font-size: 13.5px; color: var(--ts); line-height: 1.65; }

/* ── STAT CARDS GRID ── */
.kpi-row {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 18px;
  margin-bottom: 36px;
}
.kpi-box {
  background: var(--w);
  border: 1px solid var(--b);
  border-radius: var(--rl);
  padding: 22px 20px;
  text-align: center;
  border-top: 3px solid var(--o);
  transition: box-shadow .2s, transform .2s;
}
.kpi-box:hover { box-shadow: var(--sm); transform: translateY(-2px); }
.kpi-box.g { border-top-color: var(--g); }
.kpi-box.n { border-top-color: var(--n); }
.kpi-box.gd{ border-top-color: #C8922A; }
.kpi-val {
  font-family: var(--fh);
  font-size: 2.2rem; font-weight: 800;
  color: var(--o); line-height: 1;
  letter-spacing: -.02em; margin-bottom: 6px;
}
.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); }
.kpi-up  { font-size: 11.5px; color: var(--g); font-weight: 600; margin-top: 4px; }

/* ── PROGRESS FULL ── */
.prog-row {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 16px;
  padding: 14px 18px;
  background: var(--w);
  border: 1px solid var(--b);
  border-radius: var(--r);
  transition: box-shadow .2s;
}
.prog-row:hover { box-shadow: var(--ss); }
.prog-label { font-size: 13.5px; font-weight: 500; color: var(--n); min-width: 240px; }
.prog-sub { font-size: 12px; color: var(--ts); margin-top: 2px; }
.prog-track { flex: 1; height: 8px; background: var(--bg); border-radius: 4px; overflow: hidden; }
.prog-bar { height: 100%; border-radius: 4px; background: var(--o); transition: width 1.2s cubic-bezier(.4,0,.2,1); }
.pb-g { background: var(--g); }
.pb-n { background: var(--n); }
.pb-gd{ background: #C8922A; }
.prog-pct { font-size: 13px; font-weight: 700; color: var(--o); min-width: 38px; text-align: right; }
.prog-pct.g { color: var(--g); }
.prog-pct.n { color: var(--n); }
.prog-badge { flex-shrink: 0; }

/* ── DATA TABLE ── */
.data-table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.data-table thead th {
  background: var(--n);
  color: rgba(255,255,255,.9);
  padding: 12px 16px;
  text-align: left;
  font-weight: 600;
  font-size: 12px;
  letter-spacing: .04em;
  text-transform: uppercase;
  font-family: var(--fh);
}
.data-table tbody td {
  padding: 13px 16px;
  border-bottom: 1px solid var(--b);
  vertical-align: middle;
  color: var(--tm);
}
.data-table tbody tr:nth-child(even) td { background: var(--ow); }
.data-table tbody tr:hover td { background: var(--ol); }
.td-strong { font-weight: 600; color: var(--n); }

/* ── STATUS BADGES ── */
.badge {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11.5px; font-weight: 600;
  padding: 4px 10px;
  border-radius: 20px;
}
.b-ok   { background: var(--gl); color: var(--g); }
.b-warn { background: #FDF4E3; color: #C8922A; }
.b-err  { background: #FDECEA; color: #C0392B; }
.b-info { background: var(--nl); color: var(--n); }

/* ── FILTER BAR ── */
.filter-bar {
  display: flex; gap: 10px; align-items: center; flex-wrap: wrap;
  padding: 16px 20px;
  background: var(--ow);
  border: 1px solid var(--b);
  border-radius: var(--rl);
  margin-bottom: 24px;
}
.f-select, .f-input {
  border: 1px solid var(--b);
  background: var(--w);
  padding: 9px 13px;
  border-radius: var(--r);
  font-size: 13.5px;
  color: var(--t);
  font-family: var(--fb);
  transition: border .2s;
}
.f-input { flex: 1; min-width: 180px; }
.f-input::placeholder { color: var(--ts); }
.f-select:focus, .f-input:focus { outline: none; border-color: var(--o); }
.f-btn {
  background: var(--o); color: #fff;
  border: none; padding: 9px 22px;
  border-radius: var(--r);
  font-size: 13.5px; font-weight: 700;
  cursor: pointer; font-family: var(--fb);
  transition: background .2s;
}
.f-btn:hover { background: var(--od); }

/* ── CARD GRID ── */
.cards-grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.cards-grid-2 { display: grid; grid-template-columns: repeat(2,1fr); gap: 24px; }
.pg-card {
  background: var(--w);
  border: 1px solid var(--b);
  border-radius: var(--rx);
  overflow: hidden;
  transition: box-shadow .25s, transform .25s;
}
.pg-card:hover { box-shadow: var(--sm); transform: translateY(-3px); }
.pg-card__img { width: 100%; height: 185px; object-fit: cover; display: block; background: var(--bg); }
.pg-card__body { padding: 20px; }
.pg-card__tag { font-size: 10.5px; font-weight: 700; color: var(--o); text-transform: uppercase; letter-spacing: .07em; margin-bottom: 8px; }
.pg-card__tag.g { color: var(--g); }
.pg-card__tag.n { color: var(--n); }
.pg-card__title { font-family: var(--fh); font-size: 1rem; font-weight: 700; color: var(--n); line-height: 1.42; margin-bottom: 8px; }
.pg-card__text  { font-size: 13.5px; color: var(--ts); line-height: 1.65; }
.pg-card__foot  { margin-top: 14px; padding-top: 13px; border-top: 1px solid var(--b); display: flex; align-items: center; justify-content: space-between; font-size: 12.5px; color: var(--ts); }
.pg-card__arrow { color: var(--o); font-size: 18px; transition: transform .2s; }
.pg-card:hover .pg-card__arrow { transform: translateX(5px); }

/* ── DOC LIST ── */
.doc-list { display: flex; flex-direction: column; gap: 8px; }
.doc-row {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 18px;
  background: var(--w);
  border: 1px solid var(--b);
  border-radius: var(--r);
  cursor: pointer;
  transition: all .2s;
}
.doc-row:hover { border-color: var(--o); box-shadow: var(--ss); }
.doc-ico {
  width: 42px; height: 42px;
  border-radius: var(--r);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; flex-shrink: 0;
}
.di-r { background: #FDE8E8; }
.di-g { background: var(--gl); }
.di-b { background: var(--nl); }
.di-gd{ background: #FDF4E3; }
.doc-nm { font-size: 13.5px; font-weight: 600; color: var(--n); }
.doc-mt { font-size: 11.5px; color: var(--ts); margin-top: 2px; }
.doc-dl { color: var(--ts); font-size: 18px; margin-left: auto; transition: color .2s; flex-shrink: 0; }
.doc-row:hover .doc-dl { color: var(--o); }

/* ── CONTACT FORM ── */
.form-group { margin-bottom: 20px; }
.form-label { display: block; font-size: 13.5px; font-weight: 600; color: var(--n); margin-bottom: 7px; font-family: var(--fh); }
.form-label .req { color: var(--o); }
.form-ctrl {
  width: 100%;
  border: 1.5px solid var(--b);
  border-radius: var(--r);
  padding: 11px 15px;
  font-size: 14px;
  color: var(--t);
  font-family: var(--fb);
  background: var(--w);
  transition: border .2s, box-shadow .2s;
}
.form-ctrl:focus { outline: none; border-color: var(--o); box-shadow: 0 0 0 3px rgba(244,121,32,.1); }
.form-ctrl::placeholder { color: var(--ts); }
textarea.form-ctrl { min-height: 130px; resize: vertical; }
.form-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-submit {
  background: var(--o); color: #fff;
  border: none; padding: 13px 32px;
  border-radius: var(--r);
  font-size: 15px; font-weight: 700;
  cursor: pointer; font-family: var(--fb);
  transition: background .2s, transform .15s;
}
.form-submit:hover { background: var(--od); transform: translateY(-1px); }

/* ── PAGINATION ── */
.pag { display: flex; gap: 5px; align-items: center; justify-content: center; margin-top: 32px; }
.pag-btn {
  width: 38px; height: 38px;
  border: 1.5px solid var(--b);
  border-radius: var(--r);
  background: var(--w);
  font-size: 13.5px; color: var(--tm);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all .15s; font-family: var(--fb);
}
.pag-btn:hover, .pag-btn.active { background: var(--o); color: #fff; border-color: var(--o); }

/* ── TABS ── */
.tab-bar {
  display: flex; gap: 0;
  border-bottom: 2px solid var(--b);
  margin-bottom: 28px;
}
.tab-btn-pg {
  padding: 11px 20px;
  font-size: 14px; font-weight: 600;
  color: var(--ts);
  background: none; border: none;
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  font-family: var(--fb);
  transition: all .2s;
}
.tab-btn-pg:hover { color: var(--n); }
.tab-btn-pg.active { color: var(--o); border-bottom-color: var(--o); }
.tab-pane { display: none; }
.tab-pane.active { display: block; }

/* ── MAP ── */
.map-full {
  border-radius: var(--rx);
  overflow: hidden;
  border: 1px solid var(--b);
  box-shadow: var(--ss);
  position: relative;
}
.map-bg {
  background: linear-gradient(135deg,#D8EFE3,#C4D9EF 50%,#D0E4F4);
  position: relative;
}
.map-legend-box {
  position: absolute; bottom: 16px; left: 16px;
  background: rgba(255,255,255,.95);
  border: 1px solid var(--b);
  border-radius: var(--r);
  padding: 12px 16px;
  box-shadow: var(--ss);
  display: flex; flex-direction: column; gap: 7px;
}
.ml-row { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--tm); }
.ml-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }

/* ── ALERT ── */
.alert {
  padding: 14px 18px;
  border-radius: var(--r);
  display: flex; align-items: flex-start; gap: 10px;
  margin-bottom: 20px; font-size: 13.5px;
}
.al-info    { background: var(--nl); border-left: 4px solid var(--n); color: var(--n); }
.al-success { background: var(--gl); border-left: 4px solid var(--g); color: var(--g); }
.al-warn    { background: #FDF4E3;   border-left: 4px solid #C8922A; color: #C8922A; }
.al-err     { background: #FDECEA;   border-left: 4px solid #C0392B; color: #C0392B; }

@media(max-width:900px){
  .layout-sb { grid-template-columns: 1fr; }
  .sidebar { position: static; }
  .kpi-row  { grid-template-columns: repeat(2,1fr); }
  .cards-grid-3,.cards-grid-2 { grid-template-columns: 1fr; }
}

/* Fix .ddi for anchor tags */
a.ddi { text-decoration: none; display: flex; }

/* ── ci-developpe.html ── */
body{margin:0;overflow-x:hidden}

/* ─── Page hero ─── */
.ci-hero{background:linear-gradient(110deg,var(--n) 0%,#1A2F52 100%);padding:20px 0;border-bottom:4px solid var(--o)}

/* ─── Pilier select bar ─── */
.pil-bar{background:var(--w);border-bottom:2px solid var(--b);box-shadow:var(--ss)}
.pil-bar-inner{max-width:var(--mx);margin:0 auto;padding:14px 28px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.pil-select{flex:1;min-width:260px;border:2px solid var(--o);border-radius:var(--r);padding:11px 16px;font-size:14px;font-family:var(--fb);color:var(--n);background:var(--w);cursor:pointer;font-weight:600;outline:none}
.pil-btn{background:var(--o);color:#fff;border:none;padding:11px 24px;border-radius:var(--r);font-size:14px;font-weight:700;cursor:pointer;font-family:var(--fb);white-space:nowrap;transition:background .2s}
.pil-btn:hover{background:var(--od)}
.pil-info{display:flex;align-items:center;gap:14px;margin-left:auto;flex-shrink:0}
.pi-stat{text-align:center}
.pi-stat-v{font-family:var(--fh);font-size:1.2rem;font-weight:800;color:var(--o);line-height:1}
.pi-stat-l{font-size:10.5px;color:var(--ts)}

/* ─── Quick pills ─── */
.pill-row{background:var(--ow);border-bottom:1px solid var(--b);padding:10px 28px;display:flex;gap:7px;flex-wrap:wrap}
.qpill{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:700;border:2px solid var(--b);background:var(--w);color:var(--tm);cursor:pointer;transition:all .18s;font-family:var(--fb)}
.qpill.active{color:#fff}

/* ─── Layout: sidebar + map ─── */
.ci-layout{display:grid;grid-template-columns:320px 1fr;height:calc(100vh - 178px);min-height:560px}
#ciLeaflet{width:100%;height:100%;z-index:1}

/* ─── Sidebar ─── */
.ci-sb{background:var(--w);border-right:1px solid var(--b);display:flex;flex-direction:column;overflow:hidden;z-index:2;box-shadow:4px 0 20px rgba(13,27,53,.07)}
.sb-top{padding:13px 16px;border-bottom:1px solid var(--b);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:8px}
.sb-top-title{font-family:var(--fh);font-size:13px;font-weight:700;color:var(--n)}
.sb-top-count{font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;background:var(--ol);color:var(--o);white-space:nowrap}
.sb-search{padding:10px 14px;border-bottom:1px solid var(--b);flex-shrink:0}
.sb-search input{width:100%;border:1.5px solid var(--b);border-radius:var(--r);padding:8px 12px;font-size:13px;font-family:var(--fb);background:var(--ow);box-sizing:border-box;transition:border .2s}
.sb-search input:focus{outline:none;border-color:var(--o)}
.sb-list{flex:1;overflow-y:auto}
.sb-list::-webkit-scrollbar{width:3px}
.sb-list::-webkit-scrollbar-thumb{background:var(--bm);border-radius:2px}

/* ─── Region item in sidebar ─── */
.rg-item{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--b);cursor:pointer;transition:all .15s;border-left:3px solid transparent}
.rg-item:hover{background:var(--ow);border-left-color:var(--o)}
.rg-item.sel{background:var(--ol);border-left-color:var(--o)}
.rg-badge{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:11px;font-weight:800;flex-shrink:0;color:#fff}
.rg-name{font-size:13px;font-weight:600;color:var(--n);line-height:1.2}
.rg-dist{font-size:11px;color:var(--ts);margin-top:2px}
.rg-nb{font-family:var(--fh);font-size:15px;font-weight:800;flex-shrink:0;margin-left:auto}

/* ─── Map controls ─── */
.mc-wrap{position:absolute;top:14px;right:14px;z-index:1000;display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.mc-btn{background:#fff;border:1.5px solid var(--b);border-radius:var(--r);padding:7px 13px;font-size:12px;font-weight:600;color:var(--n);cursor:pointer;box-shadow:var(--ss);font-family:var(--fb);transition:all .2s;white-space:nowrap}
.mc-btn:hover,.mc-btn.on{background:var(--o);color:#fff;border-color:var(--o)}
.map-legend-box{background:rgba(255,255,255,.96);border:1px solid var(--b);border-radius:12px;padding:13px 15px;box-shadow:var(--sm);min-width:145px}
.mleg-t{font-size:10.5px;font-weight:700;color:var(--n);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;font-family:var(--fh)}
.mleg-i{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--tm);margin-bottom:5px}
.mleg-sw{width:12px;height:12px;border-radius:3px;flex-shrink:0}
.pilier-badge-map{background:rgba(255,255,255,.96);border:1px solid var(--b);border-radius:10px;padding:12px 14px;box-shadow:var(--sm);max-width:190px;display:none}
.pbm-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:3px}
.pbm-name{font-family:var(--fh);font-size:12.5px;font-weight:800;color:var(--n);margin-bottom:3px;line-height:1.3}
.pbm-nb{font-size:11.5px;color:var(--ts)}

/* ─── MODAL ─── */
.modal-mask{position:fixed;inset:0;background:rgba(13,27,53,.6);z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .3s;box-sizing:border-box}
.modal-mask.show{opacity:1;pointer-events:all}
.modal-box{background:var(--w);border-radius:20px;width:100%;max-width:700px;max-height:88vh;display:flex;flex-direction:column;box-shadow:0 28px 90px rgba(0,0,0,.3);transform:translateY(18px);transition:transform .35s cubic-bezier(.16,1,.3,1)}
.modal-mask.show .modal-box{transform:translateY(0)}

/* Modal header */
.modal-hdr{padding:22px 26px 16px;border-bottom:1px solid var(--b);flex-shrink:0;position:relative}
.modal-region-name{font-family:var(--fh);font-size:1.2rem;font-weight:800;color:var(--n);margin-bottom:2px}
.modal-district{font-size:12px;color:var(--ts)}
.modal-x{position:absolute;top:18px;right:18px;width:30px;height:30px;border-radius:50%;border:1.5px solid var(--b);background:var(--w);font-size:16px;color:var(--ts);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}
.modal-x:hover{background:var(--o);color:#fff;border-color:var(--o)}

/* Modal stats row */
.modal-stats{display:flex;gap:10px;padding:12px 26px;border-bottom:1px solid var(--b);flex-shrink:0;background:var(--ow)}
.mst{text-align:center;flex:1;background:var(--w);border-radius:var(--r);padding:10px 6px;border:1px solid var(--b)}
.mst-v{font-family:var(--fh);font-size:1.1rem;font-weight:800;line-height:1;color:var(--o)}
.mst-l{font-size:10px;color:var(--ts);margin-top:3px}

/* Modal pilier tabs */
.modal-pi-row{padding:12px 26px;border-bottom:1px solid var(--b);display:flex;gap:6px;flex-wrap:wrap;flex-shrink:0;background:var(--w)}
.mpi-tab{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:700;border:2px solid var(--b);background:var(--w);color:var(--tm);cursor:pointer;transition:all .15s;font-family:var(--fb)}
.mpi-tab.on{color:#fff}

/* Modal body scrollable */
.modal-body{flex:1;overflow-y:auto;padding:16px 26px 20px}
.modal-body::-webkit-scrollbar{width:4px}
.modal-body::-webkit-scrollbar-thumb{background:var(--bm);border-radius:2px}

/* Project card in modal */
.mp-card{background:var(--ow);border:1px solid var(--b);border-radius:var(--rl);padding:14px 16px;margin-bottom:10px;transition:box-shadow .15s;border-left:4px solid var(--o)}
.mp-card:hover{box-shadow:var(--ss)}
.mp-title{font-size:13.5px;font-weight:700;color:var(--n);margin-bottom:6px;line-height:1.4}
.mp-min{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;color:var(--tm);background:var(--w);border:1px solid var(--b);border-radius:20px;padding:4px 12px;margin-top:4px}
.mp-pi-tag{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:3px 10px;border-radius:12px;float:right;margin-top:-2px}
.modal-empty{text-align:center;padding:36px;color:var(--ts)}

/* Modal footer */
.modal-foot{padding:14px 26px;border-top:1px solid var(--b);flex-shrink:0;display:flex;justify-content:space-between;align-items:center;background:var(--w)}

/* Leaflet popup */
.leaflet-popup-content-wrapper{border-radius:12px!important;box-shadow:0 8px 32px rgba(13,27,53,.18)!important;font-family:var(--fb);border:1px solid var(--b)}
.leaflet-popup-tip-container{display:none}
.cpop .leaflet-popup-content{margin:0;padding:0}
.pop-wrap{padding:14px 16px;min-width:195px}
.pop-rn{font-family:var(--fh);font-size:14px;font-weight:800;color:var(--n);margin-bottom:3px}
.pop-dist{font-size:11px;color:var(--ts);margin-bottom:8px}
.pop-row{display:flex;gap:8px;margin-bottom:8px}
.pop-s{background:var(--ow);border-radius:7px;padding:8px 10px;text-align:center;flex:1}
.pop-sv{font-family:var(--fh);font-size:1rem;font-weight:800;color:var(--o)}
.pop-sl{font-size:9.5px;color:var(--ts)}
.pop-open{width:100%;background:var(--o);color:#fff;border:none;padding:9px;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;font-family:var(--fb);transition:background .2s}
.pop-open:hover{background:var(--od)}

@media(max-width:900px){.ci-layout{grid-template-columns:1fr;grid-template-rows:280px 1fr}.modal-box{max-height:92vh}}

/* ── financement.html ── */
.fin-hero-stat{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:18px 24px;text-align:center}
.fhs-val{font-family:var(--fh);font-size:2rem;font-weight:900;line-height:1;margin-bottom:4px}
.fhs-lbl{font-size:11.5px;color:rgba(255,255,255,.5)}
.source-card{background:var(--w);border:1px solid var(--b);border-radius:var(--rx);overflow:hidden;transition:box-shadow .25s,transform .25s}
.source-card:hover{box-shadow:var(--sm);transform:translateY(-3px)}
.sc-top{height:8px}
.sc-body{padding:24px 26px}
.sc-ico{width:54px;height:54px;border-radius:var(--rl);display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:16px}
.sc-pct{font-family:var(--fh);font-size:2.4rem;font-weight:900;line-height:1;margin-bottom:4px}
.sc-label{font-size:14px;font-weight:700;color:var(--n);margin-bottom:8px}
.sc-desc{font-size:13.5px;color:var(--ts);line-height:1.7;margin-bottom:14px}
.sc-amount{font-family:var(--fh);font-size:1.1rem;font-weight:800;padding:8px 16px;border-radius:var(--r);display:inline-block}
.ptf-card{background:var(--w);border:1px solid var(--b);border-radius:var(--rl);padding:20px;display:flex;gap:16px;align-items:flex-start;transition:box-shadow .2s}
.ptf-card:hover{box-shadow:var(--ss)}
.ptf-flag{font-size:28px;flex-shrink:0}
.ptf-name{font-family:var(--fh);font-size:14.5px;font-weight:800;color:var(--n);margin-bottom:4px}
.ptf-focus{font-size:12.5px;color:var(--ts);margin-bottom:8px;line-height:1.5}
.ptf-amount{font-size:11.5px;font-weight:700;padding:4px 12px;border-radius:12px;display:inline-block}
.timeline-fin{display:flex;gap:0;border-radius:var(--rl);overflow:hidden;margin:24px 0}
.tf-step{flex:1;padding:20px 16px;text-align:center;border-right:1px solid var(--b)}
.tf-step:last-child{border-right:none}
.tf-year{font-family:var(--fh);font-size:1.4rem;font-weight:800;margin-bottom:4px}
.tf-amount{font-size:13.5px;font-weight:700;margin-bottom:4px}
.tf-desc{font-size:11.5px;color:var(--ts);line-height:1.4}
.opport-card{background:var(--w);border:1px solid var(--b);border-radius:var(--rl);padding:22px;border-top:4px solid}
.oc-pilier{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;font-family:var(--fh)}
.oc-title{font-family:var(--fh);font-size:1.05rem;font-weight:800;color:var(--n);margin-bottom:8px}
.oc-amount{font-family:var(--fh);font-size:1.6rem;font-weight:900;margin-bottom:4px}
.oc-desc{font-size:13px;color:var(--ts);line-height:1.65;margin-bottom:12px}
.oc-sectors{display:flex;gap:5px;flex-wrap:wrap}
.oc-tag{font-size:11px;font-weight:600;padding:3px 10px;border-radius:12px}

/* ── projets-liste.html ── */
.proj-card-full{background:var(--w);border:1px solid var(--b);border-radius:var(--rl);overflow:hidden;margin-bottom:12px;transition:box-shadow .2s;border-left:5px solid}
.proj-card-full:hover{box-shadow:var(--sm)}
.pcf-head{padding:16px 20px;display:flex;align-items:flex-start;gap:16px;cursor:pointer}
.pcf-num{font-family:var(--fh);font-size:13px;font-weight:800;color:var(--ts);min-width:32px}
.pcf-main{flex:1;min-width:0}
.pcf-title{font-family:var(--fh);font-size:14.5px;font-weight:700;color:var(--n);margin-bottom:6px;line-height:1.35}
.pcf-meta{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.pcf-tag{font-size:11px;font-weight:700;padding:3px 10px;border-radius:12px}
.pcf-min{font-size:12px;color:var(--ts)}
.pcf-budget{font-family:var(--fh);font-size:1.1rem;font-weight:800;color:var(--o);flex-shrink:0}
.pcf-toggle{font-size:18px;color:var(--ts);transition:transform .25s;flex-shrink:0;margin-top:2px}
.pcf-toggle.open{transform:rotate(180deg)}
.pcf-body{display:none;padding:0 20px 18px;border-top:1px solid var(--b)}
.pcf-body.open{display:block}
.pcf-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:14px 0}
.pdg-item{background:var(--ow);border-radius:var(--r);padding:10px 14px}
.pdg-label{font-size:10.5px;color:var(--ts);text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px;font-family:var(--fh);font-weight:600}
.pdg-val{font-size:13.5px;font-weight:600;color:var(--n)}
.filter-btn{padding:8px 16px;border:1.5px solid var(--b);border-radius:20px;font-size:12.5px;font-weight:600;background:var(--w);color:var(--tm);cursor:pointer;transition:all .15s;font-family:var(--fb)}
.filter-btn.on{background:var(--o);border-color:var(--o);color:#fff}

/* ── vision-gouvernement.html ── */
.vision-hero{background:linear-gradient(135deg,var(--n) 0%,#1A2F52 100%);padding:80px 0;text-align:center;position:relative;overflow:hidden}
.vision-hero::after{content:'"';position:absolute;top:-40px;left:50%;transform:translateX(-50%);font-size:320px;color:rgba(244,121,32,.05);font-family:Georgia,serif;line-height:1;pointer-events:none}
.vision-quote-big{font-family:var(--fh);font-size:clamp(1.4rem,3vw,2.2rem);font-weight:800;color:#fff;line-height:1.45;max-width:800px;margin:0 auto 24px;position:relative;z-index:1}
.vision-quote-big em{color:var(--o);font-style:normal}
.pillar-full{background:var(--w);border:1px solid var(--b);border-radius:var(--rx);overflow:hidden;margin-bottom:20px;transition:box-shadow .25s}
.pillar-full:hover{box-shadow:var(--sm)}
.pillar-full-hdr{display:grid;grid-template-columns:72px 1fr;gap:0}
.pillar-num{display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:1.8rem;font-weight:900}
.pillar-info{padding:22px 24px}
.pillar-title{font-family:var(--fh);font-size:1.2rem;font-weight:800;color:var(--n);margin-bottom:6px}
.pillar-desc{font-size:14px;color:var(--ts);line-height:1.65}
.pillar-kpis{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.pkpi{background:var(--ow);border-radius:var(--r);padding:8px 14px;font-size:12px;font-weight:600;color:var(--tm)}
.pillar-proj-link{display:inline-flex;align-items:center;gap:6px;margin-top:12px;font-size:13px;font-weight:700;color:var(--o);transition:gap .2s}
.pillar-proj-link:hover{gap:10px}
.timeline-h{display:flex;gap:0;position:relative;margin-bottom:48px;overflow:hidden;border-radius:var(--rl)}
.timeline-h::before{content:'';position:absolute;top:50%;left:0;right:0;height:3px;background:var(--ol);transform:translateY(-50%)}
.th-step{flex:1;text-align:center;padding:16px 12px;background:var(--w);border:1px solid var(--b);position:relative;z-index:1;transition:background .2s}
.th-step:not(:last-child){border-right:none}
.th-dot{width:28px;height:28px;border-radius:50%;margin:0 auto 10px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}
.th-label{font-size:12px;font-weight:600;color:var(--n);margin-bottom:4px}
.th-sub{font-size:11px;color:var(--ts)}

/* ── resultats.html ── */
.chart-bars { display: flex; align-items: flex-end; gap: 14px; height: 160px; padding-top: 10px; }
.bar-wrap { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 5px; height: 100%; justify-content: flex-end; }
.bar-inner { width: 100%; border-radius: 6px 6px 0 0; min-height: 4px; transition: height 1s ease; }
.bar-val { font-size: 12px; font-weight: 700; color: var(--tm); }
.bar-lbl { font-size: 11px; color: var(--ts); white-space: nowrap; }

/* ── acteurs.html ── */
.actor-card { background: var(--w); border: 1px solid var(--b); border-radius: var(--rl); padding: 22px; display: flex; gap: 16px; align-items: flex-start; transition: box-shadow .2s, transform .2s; }
.actor-card:hover { box-shadow: var(--sm); transform: translateY(-2px); }
.actor-icon { width: 52px; height: 52px; border-radius: var(--rl); display: flex; align-items: center; justify-content: center; font-size: 22px; flex-shrink: 0; }
.actor-name { font-family: var(--fh); font-size: 14px; font-weight: 700; color: var(--n); margin-bottom: 5px; }
.actor-role { font-size: 12.5px; color: var(--ts); margin-bottom: 8px; line-height: 1.5; }
.actor-axes { display: flex; gap: 5px; flex-wrap: wrap; }
.actor-axe { font-size: 10.5px; font-weight: 600; padding: 3px 9px; border-radius: 12px; }
.aa-o { background: var(--ol); color: var(--o); }
.aa-g { background: var(--gl); color: var(--g); }
.aa-n { background: var(--nl); color: var(--n); }
.category-title { font-family: var(--fh); font-size: 1.1rem; font-weight: 800; color: var(--n); margin: 32px 0 16px; padding-bottom: 10px; border-bottom: 2px solid var(--ol); display: flex; align-items: center; gap: 10px; }

/* ── actualites.html ── */
.article-card { display: flex; gap: 0; background: var(--w); border: 1px solid var(--b); border-radius: var(--rx); overflow: hidden; margin-bottom: 20px; transition: box-shadow .25s, transform .25s; }
.article-card:hover { box-shadow: var(--sm); transform: translateY(-2px); }
.article-img { width: 240px; flex-shrink: 0; object-fit: cover; height: 100%; min-height: 160px; }
.article-body { padding: 22px 24px; flex: 1; display: flex; flex-direction: column; }
.article-meta { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-bottom: 10px; }
.article-title { font-family: var(--fh); font-size: 1.1rem; font-weight: 700; color: var(--n); line-height: 1.38; margin-bottom: 10px; }
.article-text { font-size: 14px; color: var(--ts); line-height: 1.7; flex: 1; }
.article-link { display: inline-flex; align-items: center; gap: 6px; margin-top: 14px; font-size: 13.5px; font-weight: 700; color: var(--o); transition: gap .2s; }
.article-card:hover .article-link { gap: 10px; }

/* ── presse.html ── */
.press-card { background: var(--w); border: 1px solid var(--b); border-radius: var(--rx); padding: 32px; text-align: center; transition: box-shadow .25s, transform .25s; }
.press-card:hover { box-shadow: var(--sm); transform: translateY(-3px); }
.press-icon { font-size: 40px; margin-bottom: 16px; }
.press-title { font-family: var(--fh); font-size: 1.1rem; font-weight: 700; color: var(--n); margin-bottom: 10px; }
.press-text { font-size: 13.5px; color: var(--ts); line-height: 1.7; margin-bottom: 18px; }
.media-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; }
.media-thumb { background: var(--bg); border: 1px solid var(--b); border-radius: var(--rl); overflow: hidden; cursor: pointer; transition: box-shadow .2s; }
.media-thumb:hover { box-shadow: var(--sm); }
.media-thumb img { width: 100%; height: 120px; object-fit: cover; display: block; }
.media-thumb-body { padding: 10px 12px; font-size: 12px; color: var(--ts); }

/* ── axes.html ── */
.axe-detail { background: var(--w); border: 1px solid var(--b); border-radius: var(--rx); overflow: hidden; margin-bottom: 28px; scroll-margin-top: 100px; }
.axe-detail:hover { box-shadow: var(--sm); }
.axe-detail-header { display: grid; grid-template-columns: 340px 1fr; }
.axe-img-block { position: relative; height: 260px; overflow: hidden; }
.axe-img-block img { width: 100%; height: 100%; object-fit: cover; }
.axe-img-overlay { position: absolute; inset: 0; background: linear-gradient(to right, rgba(13,27,53,.6) 0%, transparent 60%); }
.axe-num-badge { position: absolute; top: 20px; left: 20px; width: 52px; height: 52px; border-radius: 12px; background: #fff; display: flex; align-items: center; justify-content: center; font-family: var(--fh); font-size: 20px; font-weight: 800; box-shadow: var(--ss); }
.axe-info-block { padding: 28px 32px; display: flex; flex-direction: column; justify-content: center; }
.axe-tag { font-size: 11px; font-weight: 700; color: var(--o); text-transform: uppercase; letter-spacing: .1em; margin-bottom: 10px; font-family: var(--fb); }
.axe-tag.g { color: var(--g); } .axe-tag.n { color: var(--n); } .axe-tag.gd { color: #C8922A; }
.axe-name { font-family: var(--fh); font-size: 1.5rem; font-weight: 800; color: var(--n); margin-bottom: 10px; letter-spacing: -.01em; }
.axe-desc { font-size: 14px; color: var(--ts); line-height: 1.75; margin-bottom: 18px; }
.axe-prog-inline { display: flex; align-items: center; gap: 12px; }
.api-label { font-size: 13px; color: var(--ts); }
.api-track { flex: 1; height: 8px; background: var(--bg); border-radius: 4px; overflow: hidden; }
.api-bar { height: 100%; border-radius: 4px; background: var(--o); transition: width 1.2s ease; }
.api-pct { font-size: 14px; font-weight: 800; color: var(--o); font-family: var(--fh); min-width: 44px; text-align: right; }
.axe-detail-body { padding: 24px 32px 28px; border-top: 1px solid var(--b); background: var(--ow); }
.axe-obj-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; margin-top: 16px; }
.obj-chip { background: var(--w); border: 1px solid var(--b); border-radius: var(--r); padding: 12px 16px; }
.obj-chip__val { font-family: var(--fh); font-size: 1.4rem; font-weight: 800; color: var(--o); margin-bottom: 4px; }
.obj-chip__val.g { color: var(--g); } .obj-chip__val.n { color: var(--n); }
.obj-chip__lbl { font-size: 12px; color: var(--ts); line-height: 1.4; }
.filter-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 32px; }
.ft-btn { padding: 9px 20px; border: 1.5px solid var(--b); border-radius: 30px; font-size: 13.5px; font-weight: 600; background: var(--w); color: var(--tm); cursor: pointer; transition: all .2s; font-family: var(--fb); }
.ft-btn:hover, .ft-btn.active { background: var(--o); color: #fff; border-color: var(--o); }

/* ── piliers.html ── */
.axe-detail { background: var(--w); border: 1px solid var(--b); border-radius: var(--rx); overflow: hidden; margin-bottom: 28px; scroll-margin-top: 100px; }
.axe-detail:hover { box-shadow: var(--sm); }
.axe-detail-header { display: grid; grid-template-columns: 340px 1fr; }
.axe-img-block { position: relative; height: 260px; overflow: hidden; }
.axe-img-block img { width: 100%; height: 100%; object-fit: cover; }
.axe-img-overlay { position: absolute; inset: 0; background: linear-gradient(to right, rgba(13,27,53,.6) 0%, transparent 60%); }
.axe-num-badge { position: absolute; top: 20px; left: 20px; width: 52px; height: 52px; border-radius: 12px; background: #fff; display: flex; align-items: center; justify-content: center; font-family: var(--fh); font-size: 20px; font-weight: 800; box-shadow: var(--ss); }
.axe-info-block { padding: 28px 32px; display: flex; flex-direction: column; justify-content: center; }
.axe-tag { font-size: 11px; font-weight: 700; color: var(--o); text-transform: uppercase; letter-spacing: .1em; margin-bottom: 10px; font-family: var(--fb); }
.axe-tag.g { color: var(--g); } .axe-tag.n { color: var(--n); } .axe-tag.gd { color: #C8922A; }
.axe-name { font-family: var(--fh); font-size: 1.5rem; font-weight: 800; color: var(--n); margin-bottom: 10px; letter-spacing: -.01em; }
.axe-desc { font-size: 14px; color: var(--ts); line-height: 1.75; margin-bottom: 18px; }
.axe-prog-inline { display: flex; align-items: center; gap: 12px; }
.api-label { font-size: 13px; color: var(--ts); }
.api-track { flex: 1; height: 8px; background: var(--bg); border-radius: 4px; overflow: hidden; }
.api-bar { height: 100%; border-radius: 4px; background: var(--o); transition: width 1.2s ease; }
.api-pct { font-size: 14px; font-weight: 800; color: var(--o); font-family: var(--fh); min-width: 44px; text-align: right; }
.axe-detail-body { padding: 24px 32px 28px; border-top: 1px solid var(--b); background: var(--ow); }
.axe-obj-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; margin-top: 16px; }
.obj-chip { background: var(--w); border: 1px solid var(--b); border-radius: var(--r); padding: 12px 16px; }
.obj-chip__val { font-family: var(--fh); font-size: 1.4rem; font-weight: 800; color: var(--o); margin-bottom: 4px; }
.obj-chip__val.g { color: var(--g); } .obj-chip__val.n { color: var(--n); }
.obj-chip__lbl { font-size: 12px; color: var(--ts); line-height: 1.4; }
.filter-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 32px; }
.ft-btn { padding: 9px 20px; border: 1.5px solid var(--b); border-radius: 30px; font-size: 13.5px; font-weight: 600; background: var(--w); color: var(--tm); cursor: pointer; transition: all .2s; font-family: var(--fb); }
.ft-btn:hover, .ft-btn.active { background: var(--o); color: #fff; border-color: var(--o); }

/* ── vision.html ── */
.vision-quote { background: linear-gradient(135deg, var(--n) 0%, #1A2F52 100%); padding: 56px 48px; border-radius: var(--rx); position: relative; overflow: hidden; margin-bottom: 32px; }
.vision-quote::before { content: '"'; position: absolute; top: -20px; left: 30px; font-size: 180px; color: rgba(244,121,32,.12); font-family: Georgia, serif; line-height: 1; }
.vision-quote__text { font-family: var(--fh); font-size: 1.5rem; font-weight: 700; color: #fff; line-height: 1.5; position: relative; z-index: 1; margin-bottom: 16px; }
.vision-quote__author { font-size: 13px; color: rgba(255,255,255,.5); position: relative; z-index: 1; }
.pilier-card { background: var(--w); border: 1px solid var(--b); border-radius: var(--rl); padding: 28px; transition: box-shadow .25s, transform .25s; }
.pilier-card:hover { box-shadow: var(--sm); transform: translateY(-3px); }
.pilier-icon { width: 56px; height: 56px; border-radius: var(--rl); display: flex; align-items: center; justify-content: center; font-size: 24px; margin-bottom: 16px; }
.pilier-title { font-family: var(--fh); font-size: 1.05rem; font-weight: 700; color: var(--n); margin-bottom: 8px; }
.pilier-text { font-size: 13.5px; color: var(--ts); line-height: 1.7; }

/* ── index.html ── */
/* ═══════════════════════════════════════════════
   PND.ci — Accueil v2
   Poppins + Montserrat | Blanc · Orange · Marine
   Sans fond noir — backgrounds: white, orange-light, off-white, navy
═══════════════════════════════════════════════ */
: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:74px; --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}

/* ── GOV BAR ── */
.govbar{background:var(--n);height:34px;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}
.flag{display:flex;width:26px;height:17px;border-radius:2px;overflow:hidden;box-shadow:0 0 0 1px rgba(255,255,255,.15)}
.flag span{flex:1;display:block}
.gb-name{font-family:var(--fb);font-size:11px;font-weight:500;color:#fff;letter-spacing:.07em;text-transform:uppercase;margin-left:10px}
.gb-links{display:flex;gap:18px}
.gb-link{font-size:11px;color:#fff;transition:color .2s}
.gb-link:hover{color:rgba(255,255,255,.8)}

/* ── NOTIF BAR ── */
.notif{background:var(--g);padding:9px 28px;display:flex;align-items:center;gap:12px;justify-content:center;position:relative}
.notif span{font-size:13px;color:#fff;font-weight:500}
.notif a{font-size:12.5px;color:#fff;border:1px solid rgba(255,255,255,.5);padding:4px 14px;border-radius:20px;font-weight:600;transition:background .2s}
.notif a:hover{background:rgba(255,255,255,.15)}
.notif-x{position:absolute;right:20px;background:none;border:none;color:rgba(255,255,255,.7);font-size:20px;line-height:1}

/* ── HEADER ── */
.site-header{background:var(--w);height:var(--mh);position:sticky;top:0;z-index:200;border-bottom:1px solid var(--b);box-shadow:var(--ss);transition:box-shadow .3s}
.hi{max-width:var(--mx);margin:0 auto;padding:0 28px;height:100%;display:flex;align-items:center;gap:24px}
.logo{display:flex;align-items:center;gap:14px;flex-shrink:0;text-decoration:none}
.logo-badge{background:var(--n);width:48px;height:48px;border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden}
.logo-badge::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(to bottom,var(--o),var(--g))}
.lb-pnd{font-family:var(--fh);font-size:14px;font-weight:800;color:#fff;line-height:1}
.lb-ci{font-size:10px;color:var(--o);font-weight:600;line-height:1;margin-top:2px}
.logo-sep{width:1px;height:36px;background:var(--b)}
.logo-nm{display:flex;flex-direction:column}
.logo-nm-main{font-family:var(--fh);font-size:14px;font-weight:700;color:var(--n);line-height:1.2}
.logo-nm-sub{font-size:10px;color:var(--ts);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}

/* NAV */
.main-nav{display:flex;align-items:center;flex:1;justify-content:center;gap:2px}
.nav-item{position:relative}
.nav-link{display:flex;align-items:center;gap:5px;padding:12px 14px;font-size:13.5px;font-weight:500;color:#fff;border-radius:0;border:none;background:none;transition:all .2s;white-space:nowrap;font-family:var(--fb);cursor:pointer; font-weight: 700; text-transform: uppercase;}
.nav-link:hover,.nav-link.active{color:var(--o);background:var(--ol)}
.nav-chev{width:11px;height:11px;opacity:.4;transition:transform .25s}
.nav-item:hover .nav-chev{transform:rotate(180deg)}
.dropdown{position:absolute;top:calc(100% + 10px);left:0;background:var(--w);border:1px solid var(--b);border-radius:var(--rl);box-shadow:var(--sl);min-width:268px;opacity:0;visibility:hidden;transform:translateY(-8px);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);cursor:pointer;transition:background .15s;font-size:13.5px;color:var(--t);border:none;background:none;text-decoration:none;font-family:var(--fb)}
.ddi:hover{background:var(--ow);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;transition:background .15s}
.ddi:hover .ddi-ico{background:var(--o)}
.ddi-lbl{font-weight:600;font-size:13px;line-height:1.2}
.ddi-sub{font-size:11.5px;color:var(--ts)}

.h-btns{display:flex;align-items:center;gap:10px;flex-shrink:0}
.btn-srch{width:38px;height:38px;border-radius:var(--r);border:1.5px solid var(--b);background:var(--w);color:var(--ts);display:flex;align-items:center;justify-content:center;transition:all .2s}
.btn-srch:hover{border-color:var(--o);color:var(--o)}
.btn-act{background:var(--o);color:#fff;border:none;padding:10px 22px;border-radius:var(--r);font-size:13.5px;font-weight:600;transition:background .2s,transform .15s;white-space:nowrap}
.btn-act:hover{background:var(--od);transform:translateY(-1px)}

/* ══════════════════════════════════
   HERO SLIDER
══════════════════════════════════ */
.hero-slider{position:relative;height:640px;overflow:hidden;background:var(--n)}
.hero-slider::before{content:'';position:absolute;left:0;top:0;bottom:0;width:6px;background:linear-gradient(to bottom,var(--o) 60%,var(--g) 100%);z-index:10}
.slide{position:absolute;inset:0;opacity:0;transition:opacity 1s ease}
.slide.active{opacity:1;z-index:2}
.slide-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
.slide-overlay{position:absolute;inset:0;background:linear-gradient(100deg,rgba(13,27,53,.9) 0%,rgba(13,27,53,.65) 45%,rgba(13,27,53,.2) 100%)}
.slide-content{position:relative;z-index:5;max-width:var(--mx);margin:0 auto;padding:0 28px;height:100%;display:flex;align-items:flex-start}
.slide-text{max-width:680px}
.slide-eye{display:inline-flex;align-items:center;gap:10px;font-size:11.5px;font-weight:600;color:var(--o);text-transform:uppercase;letter-spacing:.12em;margin-bottom:18px;font-family:var(--fb)}
.slide-eye::before{content:'';width:28px;height:2px;background:var(--o)}
.slide-title{font-family:var(--fh);font-size:clamp(2.4rem,4.5vw,3.6rem);font-weight:900;color:#fff;line-height:1.1;margin-bottom:18px;letter-spacing:-.02em}
.slide-title em{color:var(--o);font-style:normal}
.slide-desc{font-size:16.5px;font-weight:400;color:rgba(255,255,255,.62);line-height:1.75;margin-bottom:32px;max-width:540px}
.slide-cta{display:flex;gap:14px;flex-wrap:wrap}
.btn-hp{padding:14px 30px;border-radius:var(--r);font-size:14.5px;font-weight:700;font-family:var(--fb);border:none;transition:all .22s;cursor:pointer}
.btn-hp-p{background:var(--o);color:#fff}
.btn-hp-p:hover{background:var(--od);transform:translateY(-2px);box-shadow:0 8px 24px rgba(244,121,32,.4)}
.btn-hp-g{background:rgba(255,255,255,.1);color:rgba(255,255,255,.85);border:1.5px solid rgba(255,255,255,.22)}
.btn-hp-g:hover{background:rgba(255,255,255,.18)}
.slide-ctr{position:absolute;top:36px;right:40px;z-index:8;font-family:var(--fh);font-size:13px;color:rgba(255,255,255,.4)}
.slide-ctr strong{font-size:28px;font-weight:900;color:rgba(255,255,255,.75);display:block;line-height:1}

/* Thumbnails */
.s-thumbs{position:absolute;bottom:28px;right:28px;z-index:10;display:flex;gap:8px}
.s-thumb{width:66px;height:42px;border-radius:6px;overflow:hidden;opacity:.4;border:2px solid transparent;cursor:pointer;transition:all .3s;flex-shrink:0}
.s-thumb img{width:100%;height:100%;object-fit:cover}
.s-thumb.active{opacity:1;border-color:var(--o)}

/* Dots */
.s-dots{position:absolute;bottom:38px;left:50%;transform:translateX(-50%);z-index:10;display:flex;gap:9px;align-items:center}
.s-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.3);border:none;cursor:pointer;transition:all .3s;padding:0}
.s-dot.active{background:var(--o);width:28px;border-radius:4px}

/* Arrows */
.s-arrows{position:absolute;bottom:28px;left:28px;z-index:10;display:flex;gap:8px}
.s-arr{width:46px;height:46px;border-radius:50%;border:1.5px solid rgba(255,255,255,.22);background:rgba(255,255,255,.1);color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;transition:all .2s;backdrop-filter:blur(4px)}
.s-arr:hover{background:var(--o);border-color:var(--o)}

/* Progress */
.s-prog{position:absolute;bottom:0;left:0;height:4px;background:var(--o);z-index:10;transition:width 0s}

/* ── STATS BAND ── */
.stats-band{background:var(--w);border-bottom:1px solid var(--b);box-shadow:var(--ss)}
.sb-inner{max-width:var(--mx);margin:0 auto;padding:0 28px;display:grid;grid-template-columns:repeat(4,1fr)}
.stat-it{padding:24px 0;display:flex;align-items:center;gap:18px;border-right:1px solid var(--b)}
.stat-it:not(:first-child){padding-left:24px}
.stat-it:last-child{border-right:none}
.stat-ico{width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;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:2.1rem;font-weight:800;line-height:1;letter-spacing:-.02em}
.sv-o{color:var(--o)} .sv-g{color:var(--g)} .sv-n{color:var(--n)} .sv-gd{color:#C8922A}
.sl_{font-size:12.5px;color:var(--ts);margin-top:4px}
.su{font-size:11.5px;color:var(--g);font-weight:600;margin-top:2px}

/* ── TICKER ── */
.ticker{background:var(--o);overflow:hidden;height:40px;display:flex;align-items:center}
.tk-lbl{background:var(--od);height:40px;padding:0 20px;font-size:11px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.1em;display:flex;align-items:center;gap:6px;flex-shrink:0}
.tk-track{display:flex;align-items:center;white-space:nowrap;animation:tickA 35s linear infinite}
@keyframes tickA{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.tk-item{padding:0 32px;font-size:13px;color:#fff;font-weight:500;display:inline-flex;align-items:center;gap:8px}
.tk-sep{color:rgba(255,255,255,.4);font-size:18px}

/* ── SECTION HELPERS ── */
.section{padding:88px 0}
.sec-sm{padding:56px 0}
.bg-w{background:var(--w)} .bg-ow{background:var(--ow)} .bg-bg{background:var(--bg)} .bg-n{background:var(--n)} .bg-o{background:var(--o)}
.s-tag{display:inline-flex;align-items:center;gap:10px;font-size:11.5px;font-weight:700;color:var(--o);text-transform:uppercase;letter-spacing:.12em;margin-bottom:12px;font-family:var(--fb)}
.s-tag::before{content:'';width:24px;height:2px;background:var(--o)}
.s-title{font-family:var(--fh);font-size:clamp(1.7rem,3vw,2.5rem);font-weight:800;color:var(--n);line-height:1.15;letter-spacing:-.02em;margin-bottom:12px}
.s-title.lgt{color:#fff}
.s-sub{font-size:16px;color:var(--ts);max-width:580px;line-height:1.75}
.s-sub.lgt{color:rgba(255,255,255,.55)}
.sh{margin-bottom:52px}
.sh-flex{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:52px;gap:20px;flex-wrap:wrap}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:7px;padding:11px 24px;border-radius:var(--r);font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all .2s;font-family:var(--fb);white-space:nowrap}
.btn-p{background:var(--o);color:#fff} .btn-p:hover{background:var(--od);transform:translateY(-1px)}
.btn-ol{background:transparent;border:2px solid var(--o);color:var(--o)} .btn-ol:hover{background:var(--o);color:#fff}
.btn-w{background:#fff;color:var(--n)} .btn-w:hover{background:var(--ol);color:var(--o)}
.btn-sm{padding:9px 20px;font-size:13px}

/* ══════════════════════════════════
   6 AXES AVEC IMAGES
══════════════════════════════════ */
.axes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.axe-card{background:var(--w);border:1px solid var(--b);border-radius:var(--rx);overflow:hidden;transition:box-shadow .3s,transform .3s;cursor:pointer}
.axe-card:hover{box-shadow:var(--sl);transform:translateY(-5px)}
.axe-img-wrap{position:relative;height:210px;overflow:hidden}
.axe-img{width:100%;height:100%;object-fit:cover;transition:transform .55s ease}
.axe-card:hover .axe-img{transform:scale(1.07)}
.axe-img-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,27,53,.75) 25%,transparent 75%)}
.axe-num{position:absolute;top:14px;left:14px;width:44px;height:44px;border-radius:var(--r);background:var(--w);display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:18px;font-weight:800;color:var(--o);box-shadow:var(--ss)}
.axe-num.g{color:var(--g)} .axe-num.d{color:var(--n)} .axe-num.gd{color:#C8922A}
.axe-img-title{position:absolute;bottom:14px;left:14px;right:14px;font-family:var(--fh);font-size:16px;font-weight:700;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.4)}
.axe-body{padding:20px 22px 22px}
.axe-sub{font-size:13px;color:var(--ts);margin-bottom:15px;font-weight:400;line-height:1.55}
.axe-prog-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.axe-prog-lbl{font-size:12px;color:var(--ts);white-space:nowrap}
.axe-prog-trk{flex:1;height:7px;background:var(--bg);border-radius:4px;overflow:hidden}
.axe-prog-bar{height:100%;border-radius:4px;background:var(--o);transition:width 1.2s cubic-bezier(.4,0,.2,1)}
.apb-g{background:var(--g)} .apb-n{background:var(--n)} .apb-gd{background:#C8922A}
.axe-pct{font-size:13px;font-weight:700;white-space:nowrap;min-width:34px;text-align:right}
.axe-foot{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--b)}
.axe-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:4px 12px;border-radius:20px;text-transform:uppercase;letter-spacing:.05em}
.ab-o{background:var(--ol);color:var(--o)} .ab-g{background:var(--gl);color:var(--g)} .ab-n{background:var(--nl);color:var(--n)} .ab-gd{background:#FDF4E3;color:#C8922A}
.axe-arrow{color:var(--o);font-size:22px;transition:transform .2s}
.axe-card:hover .axe-arrow{transform:translateX(5px)}

/* ══════════════════════════════════
   CHIFFRES CLÉS
══════════════════════════════════ */
.nums-grid{display:grid;grid-template-columns:repeat(5,1fr);border-radius:var(--rx);overflow:hidden;border:1px solid rgba(255,255,255,.1)}
.num-it{padding:42px 28px;text-align:center;border-right:1px solid rgba(255,255,255,.08)}
.num-it:last-child{border-right:none}
.num-val{font-family:var(--fh);font-size:3.2rem;font-weight:900;color:var(--o);line-height:1;margin-bottom:8px;letter-spacing:-.02em}
.num-val.g{color:var(--g)}
.num-lbl{font-size:13px;color:rgba(255,255,255,.48);line-height:1.5}
.num-up{font-size:12px;color:var(--g);font-weight:600;margin-top:6px}

/* ══════════════════════════════════
   NEWS CAROUSEL
══════════════════════════════════ */
.news-carousel{overflow:hidden;position:relative}
.news-track{display:flex;gap:24px;transition:transform .55s cubic-bezier(.16,1,.3,1)}
.news-slide{flex:0 0 calc((100% - 48px) / 3);min-width:0}
.news-card{background:var(--w);border:1px solid var(--b);border-radius:var(--rx);overflow:hidden;height:100%;display:flex;flex-direction:column;transition:box-shadow .25s,transform .25s}
.news-card:hover{box-shadow:var(--sm);transform:translateY(-3px)}
.nc-img-wrap{position:relative;height:205px;overflow:hidden;flex-shrink:0}
.nc-img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.news-card:hover .nc-img{transform:scale(1.06)}
.nc-cat{position:absolute;top:14px;left:14px;font-size:11px;font-weight:700;padding:5px 12px;border-radius:20px;text-transform:uppercase;letter-spacing:.05em;font-family:var(--fb)}
.cat-o{background:var(--o);color:#fff} .cat-g{background:var(--g);color:#fff} .cat-n{background:var(--n);color:#fff} .cat-gd{background:#C8922A;color:#fff}
.nc-body{padding:22px;flex:1;display:flex;flex-direction:column}
.nc-date{font-size:12.5px;color:var(--ts);margin-bottom:10px;font-weight:500}
.nc-title{font-family:var(--fh);font-size:1.05rem;font-weight:700;color:var(--n);line-height:1.42;margin-bottom:10px;flex:1}
.nc-text{font-size:13.5px;color:var(--ts);line-height:1.65}
.nc-link{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-size:13.5px;font-weight:700;color:var(--o);font-family:var(--fb);transition:gap .2s}
.news-card:hover .nc-link{gap:10px}
.car-controls{display:flex;align-items:center;gap:14px;margin-top:36px;justify-content:center}
.car-btn{width:48px;height:48px;border-radius:50%;border:2px solid var(--b);background:var(--w);color:var(--tm);display:flex;align-items:center;justify-content:center;font-size:20px;transition:all .2s;box-shadow:var(--ss)}
.car-btn:hover{border-color:var(--o);color:var(--o);background:var(--ol)}
.car-dots{display:flex;gap:8px;align-items:center}
.car-dot{width:8px;height:8px;border-radius:50%;background:var(--bm);border:none;cursor:pointer;transition:all .3s;padding:0}
.car-dot.active{background:var(--o);width:22px;border-radius:4px}

/* ══════════════════════════════════
   MAP + DOCS
══════════════════════════════════ */
.mdc-grid{display:grid;grid-template-columns:1fr 420px;gap:32px;align-items:start}
.map-box{border-radius:var(--rx);overflow:hidden;border:1px solid var(--b);box-shadow:var(--ss)}
.map-inner{background:linear-gradient(135deg,#D8EFE3,#C4D9EF 50%,#D0E4F4);height:380px;position:relative}
.map-legend{position:absolute;bottom:14px;left:14px;background:rgba(255,255,255,.95);border:1px solid var(--b);border-radius:var(--r);padding:12px 16px;display:flex;flex-direction:column;gap:7px;box-shadow:var(--ss)}
.ml-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--tm)}
.ml-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.map-footer{padding:16px 20px;background:var(--w);display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--b)}
.mf-title{font-family:var(--fh);font-size:15px;font-weight:700;color:var(--n)}
.mf-sub{font-size:12px;color:var(--ts)}
.doc-card{background:var(--w);border:1px solid var(--b);border-radius:var(--rx);overflow:hidden;box-shadow:var(--ss)}
.dc-hdr{background:var(--n);padding:18px 22px;display:flex;align-items:center;justify-content:space-between}
.dch-title{font-family:var(--fh);font-size:15px;font-weight:700;color:#fff}
.dch-link{font-size:13px;color:var(--o);font-weight:600}
.doc-item{display:flex;align-items:center;gap:14px;padding:14px 22px;border-bottom:1px solid var(--b);cursor:pointer;transition:background .15s}
.doc-item:last-child{border-bottom:none}
.doc-item:hover{background:var(--ow)}
.d-ico{width:42px;height:42px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.d-red{background:#FDE8E8} .d-grn{background:var(--gl)} .d-blu{background:#EBF1FB} .d-gld{background:#FDF4E3}
.d-nm{font-size:13px;font-weight:600;color:var(--n);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.d-mt{font-size:11.5px;color:var(--ts);margin-top:2px}
.d-dl{color:var(--ts);font-size:18px;flex-shrink:0;transition:color .2s;margin-left:auto}
.doc-item:hover .d-dl{color:var(--o)}

/* ── PARTNERS ── */
.part-row{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;align-items:center}
.part-chip{padding:11px 22px;border:1.5px solid var(--b);border-radius:30px;font-size:13px;font-weight:600;color:var(--tm);background:var(--w);transition:all .2s;cursor:pointer}
.part-chip:hover{border-color:var(--o);color:var(--o);transform:translateY(-2px);box-shadow:var(--ss)}

/* ── NEWSLETTER ── */
.nl-inner{display:flex;align-items:center;gap:40px;flex-wrap:wrap}
.nl-txt{flex:1}
.nl-h{font-family:var(--fh);font-size:1.6rem;font-weight:800;color:#fff;margin-bottom:8px;letter-spacing:-.01em}
.nl-s{font-size:15px;color:rgba(255,255,255,.68)}
.nl-form{display:flex;gap:10px;flex-shrink:0;min-width:320px}
.nl-inp{flex:1;border:none;border-radius:var(--r);padding:12px 18px;font-size:14px;font-family:var(--fb);background:rgba(255,255,255,.92);color:var(--n)}
.nl-inp:focus{outline:none}
.nl-inp::placeholder{color:#999}
.nl-btn{background:var(--n);color:#fff;border:none;padding:12px 24px;border-radius:var(--r);font-size:14px;font-weight:700;font-family:var(--fb);white-space:nowrap;transition:background .2s}
.nl-btn:hover{background:var(--nm)}

/* ── FOOTER ── */
.footer{background:var(--n);padding:64px 0 0}
.fg{display:grid;grid-template-columns:300px 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.07)}
.fb-desc{font-size:13.5px;color:rgba(255,255,255,.38);line-height:1.75;margin:16px 0 22px}
.f-flag{display:flex;height:5px;border-radius:3px;overflow:hidden;width:54px}
.f-flag span{flex:1}
.fc-t{font-family:var(--fh);font-size:12px;font-weight:700;color:rgba(255,255,255,.55);text-transform:uppercase;letter-spacing:.08em;margin-bottom:18px}
.fl{display:flex;flex-direction:column;gap:10px}
.fl a{font-size:13.5px;color:rgba(255,255,255,.38);transition:color .2s;cursor:pointer}
.fl a:hover{color:rgba(255,255,255,.82)}
.fb-bot{padding:18px 0;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.fb-copy{font-size:12px;color:rgba(255,255,255,.25)}
.fb-leg{display:flex;gap:20px}
.fb-leg a{font-size:12px;color:rgba(255,255,255,.25);cursor:pointer;transition:color .2s}
.fb-leg a:hover{color:rgba(255,255,255,.6)}

.back-top{position:fixed;bottom:28px;right:28px;width:48px;height:48px;border-radius:50%;background:var(--o);color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 4px 20px rgba(244,121,32,.4);border:none;opacity:0;pointer-events:none;transition:opacity .3s,transform .3s;z-index:999}
.back-top.show{opacity:1;pointer-events:all}
.back-top:hover{transform:translateY(-3px)}

::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--bm);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--o)}

@media(max-width:1100px){.axes-grid{grid-template-columns:repeat(2,1fr)}.news-slide{flex:0 0 calc((100% - 24px)/2)}.fg{grid-template-columns:1fr 1fr}}
@media(max-width:768px){.axes-grid,.mdc-grid{grid-template-columns:1fr}.sb-inner{grid-template-columns:repeat(2,1fr)}.hero-slider{height:520px}.nums-grid{grid-template-columns:repeat(2,1fr)}.main-nav{display:none}.s-thumbs{display:none}}

/* ── Logo placeholders partners ── */
.logo-slot{border:2px dashed var(--bm);border-radius:var(--rl);height:72px;display:flex;align-items:center;justify-content:center;background:var(--w);transition:border-color .2s,box-shadow .2s;cursor:pointer;overflow:hidden;position:relative}
.logo-slot:hover{border-color:var(--o);box-shadow:var(--ss)}
.logo-slot img{max-width:80%;max-height:52px;object-fit:contain;display:block}
.logo-slot span{font-size:11.5px;font-weight:600;color:var(--ts);text-align:center;padding:0 8px}

/* ── hp-pills for homepage map ── */
.hp-pill{padding:7px 16px;border-radius:20px;font-size:12px;font-weight:700;border:2px solid var(--b);background:var(--w);color:var(--tm);cursor:pointer;transition:all .2s;font-family:var(--fb);display:inline-flex;align-items:center;gap:5px}
.hp-pill.active{background:var(--o);border-color:var(--o);color:#fff}

/* ══════════════════════════════════════════════════
   DATA TABLE WRAPPER (horizontal scroll mobile)
══════════════════════════════════════════════════ */
.data-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: var(--rl);
  border: 1px solid var(--b);
}
.data-table-wrap .data-table {
  border: none;
  border-radius: 0;
}

/* ══════════════════════════════════════════════════
   PAGES — MOBILE FIXES
══════════════════════════════════════════════════ */
@media (max-width: 768px) {
  /* Breadcrumb */
  .breadcrumb { display:none; }

  /* Page hero */
  .page-hero { padding:28px 0; }
  .ph-inner { gap:16px; }
  .ph-tag { font-size:10.5px; }

  /* Layout sidebar */
  .layout-sb { grid-template-columns:1fr; gap:20px; }
  .sidebar { position:static !important; top:auto !important; }
  .sb-nav { margin-bottom:0; }

  /* KPI row on pages */
  .kpi-row { grid-template-columns:repeat(2,1fr); gap:10px; }
  .kpi-val { font-size:1.8rem; }

  /* Content card */
  .content-card { padding:20px; }

  /* Cards grids */
  .cards-grid-3 { grid-template-columns:1fr !important; }
  .cards-grid-2 { grid-template-columns:1fr !important; }

  /* Timeline horizontal */
  .timeline-h { flex-direction:column !important; border-radius:var(--rl) !important; }
  .th-step { border-right:none !important; border-bottom:1px solid var(--b); }
  .th-step:last-child { border-bottom:none; }

  /* Axe detail card */
  .axe-detail-header { grid-template-columns:1fr !important; }
  .axe-img-block { height:180px; }
  .axe-obj-grid { grid-template-columns:repeat(2,1fr) !important; }

  /* Map layout ci-developpe */
  .ci-layout { grid-template-columns:1fr !important; height:auto !important; }
  #ciLeaflet { height:320px !important; }
  .ci-sb { height:340px; }
  .pil-bar .pil-bar-inner { flex-wrap:wrap; }
  .pil-select { width:100%; min-width:auto !important; }
  .pill-row { overflow-x:auto; flex-wrap:nowrap; padding-bottom:6px; -webkit-overflow-scrolling:touch; }
  .qpill { flex-shrink:0; }

  /* Projets liste */
  .pcf-head { flex-wrap:wrap; gap:8px; }
  .pcf-budget { width:100%; }
  .pcf-detail-grid { grid-template-columns:1fr 1fr !important; }

  /* Financement page */
  .fin-source-grid { grid-template-columns:1fr !important; }
  .fin-ptf-grid { grid-template-columns:1fr !important; }
  .fin-opp-grid { grid-template-columns:1fr !important; }
  .timeline-fin { flex-direction:column !important; }
  .tf-step { border-right:none !important; border-bottom:1px solid var(--b); }
  .fin-cta { grid-template-columns:1fr !important; text-align:center; }
  .opport-card { border-radius:var(--rl); }

  /* Vision gouvernement */
  .vision-quote-big { font-size:1.2rem !important; }

  /* Acteurs */
  .actor-card { flex-direction:column; }
  .ptf-card { flex-direction:column; gap:8px; }

  /* Pédagogie pages */
  .pillar-full-hdr { grid-template-columns:1fr !important; }
  .pillar-num { display:flex; align-items:center; justify-content:center; height:60px; font-size:1.4rem; }

  /* Contact */
  .contact-grid { grid-template-columns:1fr !important; }
  .map-static { height:160px !important; }

  /* Indicateurs */
  .filter-bar { flex-direction:column; }
  .f-input { width:100%; }
  .f-select { width:100%; }

  /* Modal full-screen on mobile */
  .modal-mask, #rgModal, #hpModal {
    align-items:flex-end !important;
    padding:0 !important;
  }
  .modal-box, .modal-box.show > *, #rgModal .modal-box, #hpModal > div {
    border-radius:20px 20px 0 0 !important;
    max-height:92vh !important;
    width:100% !important;
    max-width:100% !important;
  }
  .modal-pi-row, #mPiRow { overflow-x:auto; flex-wrap:nowrap; -webkit-overflow-scrolling:touch; }
  .mpi-tab { flex-shrink:0; }

  /* sh-flex on pages */
  .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; }
}

@media (max-width: 480px) {
  /* KPI */
  .kpi-row { grid-template-columns:repeat(2,1fr) !important; }
  .kpi-val { font-size:1.6rem !important; }

  /* Axe obj grid */
  .axe-obj-grid { grid-template-columns:1fr !important; }

  /* Fin timeline */
  .timeline-fin { border-radius:var(--rl) !important; }

  /* Tables */
  .data-table { font-size:12px; }
  .data-table thead th { padding:10px 12px; font-size:11px; }
  .data-table tbody td { padding:10px 12px; }

  /* Peda grid */
  .peda-grid { grid-template-columns:1fr !important; }

  /* Projets liste detail */
  .pcf-detail-grid { grid-template-columns:1fr !important; }
}
