/* ═══════════════════════════════════════════════
   ERAD — Ethics & Research for Africa Development
   Feuille de style partagée — Multi-pages
   ═══════════════════════════════════════════════ */

/* ─── Reset & Base ─── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;background:#fff;color:#1C2B3A;overflow-x:hidden;line-height:1.65;}
img{display:block;max-width:100%;}
a{text-decoration:none;color:inherit;}
h1,h2,h3,h4,h5{font-family:'Cormorant Garamond',serif;line-height:1.18;color:#0B1F3A;}
h1{font-size:clamp(1.5rem,2.8vw,2.2rem);font-weight:700;letter-spacing:-.02em;}
h2{font-size:clamp(1.5rem,2.4vw,2.25rem);font-weight:700;letter-spacing:-.02em;}
h3{font-size:1.05rem;font-weight:600;}
p{font-size:.9rem;line-height:1.82;color:#5e7080;}
ul{list-style:none;}

/* ─── CSS Variables ─── */
:root{
  --nv:#0B1F3A;--nv2:#162F52;
  --gr:#1A9E52;--gr2:#22C468;
  --gbg:rgba(26,158,82,.08);
  --sd:#F7F5F0;--bd:rgba(11,31,58,.1);
  --r:12px;--r2:20px;
  --s1:0 4px 20px rgba(11,31,58,.08);
  --s2:0 12px 40px rgba(11,31,58,.13);
  --s3:0 24px 64px rgba(11,31,58,.18);
  --NH:64px;
}

/* ─── Layout ─── */
.wrap{max-width:1160px;margin:0 auto;padding:0 5%;}
.section{padding:88px 5%;}

/* ─── Shared Components ─── */
.lbl{display:inline-flex;align-items:center;gap:8px;font-size:.64rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--gr);margin-bottom:10px;}
.lbl::before{content:'';width:20px;height:2px;background:currentColor;border-radius:2px;display:block;}
.lbl.lt{color:var(--gr2);}
.tag{background:rgba(11,31,58,.06);color:var(--nv2);border-radius:4px;padding:3px 8px;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;}
.tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:12px;}
.ck{width:20px;height:20px;border-radius:50%;flex-shrink:0;background:var(--gbg);border:1.5px solid rgba(26,158,82,.25);display:flex;align-items:center;justify-content:center;color:var(--gr);font-size:.58rem;font-weight:700;margin-top:2px;}
.btn-p{display:inline-flex;align-items:center;gap:6px;background:var(--nv);color:#fff;padding:11px 22px;border-radius:7px;font-size:.86rem;font-weight:600;box-shadow:0 4px 16px rgba(11,31,58,.2);transition:background .2s,transform .2s;}
.btn-p:hover{background:var(--nv2);transform:translateY(-2px);}
.btn-l{display:inline-flex;align-items:center;gap:6px;color:var(--nv);border:2px solid rgba(11,31,58,.18);padding:10px 22px;border-radius:7px;font-size:.86rem;font-weight:600;transition:border-color .2s,transform .2s;}
.btn-l:hover{border-color:var(--nv);transform:translateY(-2px);}

/* ─── Animations ─── */
.rv{opacity:0;transform:translateY(20px);transition:opacity .58s,transform .58s;}
.rv.on{opacity:1;transform:none;}
.d1{transition-delay:.1s;}.d2{transition-delay:.22s;}

/* ─── Navigation ─── */
#nav{overflow:visible;position:fixed;top:0;left:0;right:0;z-index:900;height:var(--NH);display:flex;align-items:center;justify-content:space-between;padding:0 5%;background:rgba(255,255,255,.97);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--bd);transition:box-shadow .3s;}
#nav.up{box-shadow:var(--s2);}
.logo{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.logo img{height:36px;width:36px;object-fit:contain;flex-shrink:0;}
.logo b{display:block;font-family:'Cormorant Garamond',serif;font-size:1rem;font-weight:700;color:var(--nv);line-height:1.1;}
.logo small{display:block;font-size:.52rem;font-weight:700;color:var(--gr);text-transform:uppercase;letter-spacing:.06em;}
.nav-links{list-style:none;display:flex;align-items:center;gap:2px;margin-left:8px;}
.nav-links a{font-size:.72rem;font-weight:500;color:#5e7080;padding:5px 7px;border-bottom:2px solid transparent;transition:color .2s,border-color .2s;white-space:nowrap;}
.nav-links a:hover,.nav-links a.cur{color:var(--nv);border-bottom-color:var(--gr);}
.nav-links .ncta{background:var(--gr)!important;color:#fff!important;padding:7px 13px!important;border-radius:40px;border-bottom:none!important;font-weight:600!important;box-shadow:0 4px 12px rgba(26,158,82,.28);transition:background .2s,transform .2s!important;}
.nav-links .ncta:hover{background:var(--gr2)!important;transform:translateY(-1px)!important;}
.nav-links .ncta.cur{background:var(--gr2)!important;border-bottom:none!important;}

/* ─── Language Selector ─── */
.lsw{position:relative;margin-left:4px;flex-shrink:0;}
.lglobe{font-size:.85rem;opacity:.7;}
.lbtn{display:flex;align-items:center;gap:4px;background:none;border:1.5px solid var(--bd);border-radius:40px;padding:5px 9px;cursor:pointer;font:700 .72rem 'DM Sans',sans-serif;color:var(--nv);transition:border-color .2s,color .2s;white-space:nowrap;}
.lbtn:hover{border-color:var(--gr);color:var(--gr);}
.chev{font-size:.5rem;display:inline-block;transition:transform .2s;}
.lsw.open .chev{transform:rotate(180deg);}
.ldrop{position:absolute;top:calc(100% + 6px);right:0;z-index:999;background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 8px 28px rgba(11,31,58,.14);border:1px solid var(--bd);min-width:116px;opacity:0;transform:translateY(-5px);pointer-events:none;transition:opacity .18s,transform .18s;}
.lsw.open .ldrop{opacity:1;transform:translateY(0);pointer-events:auto;}
.lopt{display:flex;align-items:center;gap:8px;padding:9px 13px;font-size:.79rem;font-weight:600;color:var(--nv);cursor:pointer;transition:background .12s;}
.lopt:hover{background:var(--sd);}
.lopt.on{background:var(--gbg);color:var(--gr);}

/* ─── Mobile Menu ─── */
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:5px;flex-shrink:0;margin-left:4px;}
.burger span{display:block;width:22px;height:2px;background:var(--nv);border-radius:2px;transition:transform .28s,opacity .28s;}
.burger.x span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.burger.x span:nth-child(2){opacity:0;}
.burger.x span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}
.mob{position:fixed;inset:0;z-index:899;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);padding:20px;}
.mob.show{transform:none;}
.mob a{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:700;color:var(--nv);padding:11px 0;width:100%;max-width:280px;text-align:center;border-bottom:1px solid var(--bd);transition:color .2s;}
.mob a:last-of-type{border-bottom:none;}
.mob a:hover{color:var(--gr);}
.mob .mc{background:var(--gr);color:#fff!important;border-radius:40px;padding:11px 36px;border:none!important;font-size:.9rem;font-weight:600;margin-top:16px;}
.mob-lang{display:flex;gap:10px;margin-top:20px;}
.mob-lopt{display:flex;align-items:center;gap:6px;padding:9px 16px;border-radius:40px;font-size:.8rem;font-weight:600;color:var(--nv);cursor:pointer;border:1.5px solid var(--bd);transition:border-color .2s,background .2s,color .2s;}
.mob-lopt:hover{background:var(--sd);}
.mob-lopt.on{background:var(--gbg);border-color:var(--gr);color:var(--gr);}

/* ─── Page Hero (sous-pages) ─── */
.page-hero{padding-top:var(--NH);background:linear-gradient(148deg,var(--nv) 0%,var(--nv2) 55%,#0C2D18 100%);position:relative;overflow:hidden;}
.page-hero::before{content:'';position:absolute;right:-100px;top:-100px;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,rgba(26,158,82,.13),transparent 65%);pointer-events:none;}
.page-hero .ph-inner{max-width:1160px;margin:0 auto;padding:64px 5% 56px;}
.page-hero h1{color:#fff;margin-bottom:14px;}
.page-hero h1 em{color:var(--gr2);font-style:normal;}
.page-hero .h-sub{color:rgba(255,255,255,.65);border-left-color:rgba(255,255,255,.2);}
.page-hero .lbl{color:var(--gr2);}
.page-hero .lbl::before{background:var(--gr2);}
.page-hero .lbl.lt{color:var(--gr2);}

/* ─── Hero Landing ─── */
#hero{padding-top:var(--NH);min-height:100vh;display:flex;align-items:center;background:linear-gradient(148deg,#ECF1F9 0%,#E5F3EC 52%,#EEF3FA 100%);position:relative;overflow:hidden;}
.glow{position:absolute;border-radius:50%;pointer-events:none;}
.glow.a{width:460px;height:460px;right:-60px;top:0;background:radial-gradient(circle,rgba(26,158,82,.08),transparent 68%);}
.glow.b{width:240px;height:240px;left:3%;bottom:5%;background:radial-gradient(circle,rgba(11,31,58,.05),transparent 70%);}
.h-inner{display:grid;grid-template-columns:55fr 45fr;gap:52px;align-items:center;max-width:1160px;width:100%;margin:0 auto;padding:56px 5%;}
.chip{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid rgba(26,158,82,.22);border-radius:40px;padding:4px 14px 4px 8px;margin-bottom:18px;box-shadow:var(--s1);}
.chip .dot{width:7px;height:7px;border-radius:50%;background:var(--gr);flex-shrink:0;}
.chip span{font-size:.64rem;font-weight:700;color:var(--gr);text-transform:uppercase;letter-spacing:.08em;}
#hero h1{margin-bottom:12px;}
#hero h1 em{color:var(--gr);font-style:normal;}
.h-sub{border-left:3px solid var(--gr);padding-left:12px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:.92rem;color:var(--nv);opacity:.7;line-height:1.7;margin-bottom:13px;}
.h-desc{max-width:460px;margin-bottom:28px;font-size:.88rem;}
.btns{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:38px;}
.stats{display:flex;padding-top:24px;border-top:1px solid rgba(11,31,58,.1);}
.st{padding-right:22px;margin-right:22px;border-right:1px solid rgba(11,31,58,.1);}
.st:last-child{border-right:none;padding-right:0;margin-right:0;}
.stn{font-family:'Cormorant Garamond',serif;font-size:1.65rem;font-weight:700;color:var(--nv);line-height:1;}
.stn em{color:var(--gr);font-style:normal;}
.stl{font-size:.61rem;font-weight:700;color:#5e7080;text-transform:uppercase;letter-spacing:.07em;margin-top:4px;}

/* ─── Identity Card ─── */
.idc{background:#fff;border-radius:var(--r2);box-shadow:var(--s3);border:1px solid rgba(11,31,58,.05);overflow:hidden;}
.idc-top{background:var(--nv);padding:24px 22px 18px;display:flex;flex-direction:column;align-items:center;text-align:center;}
.idc-top img{width:96px;height:96px;object-fit:contain;margin-bottom:11px;}
.idc-top h3{color:#fff;font-size:.9rem;margin-bottom:3px;}
.idc-top p{color:rgba(255,255,255,.45);font-size:.68rem;line-height:1.5;}
.idc-row{display:flex;align-items:flex-start;gap:9px;padding:10px 18px;border-bottom:1px solid var(--bd);}
.idc-row:last-of-type{border-bottom:none;}
.idc-ico{width:26px;height:26px;border-radius:6px;flex-shrink:0;background:var(--gbg);display:flex;align-items:center;justify-content:center;font-size:.76rem;}
.idc-lb{font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#5e7080;margin-bottom:1px;}
.idc-v{font-size:.78rem;font-weight:600;color:#1C2B3A;}
.idc-v a{color:#1C2B3A;transition:color .2s;}
.idc-v a:hover{color:var(--gr);}
.idc-s{font-size:.67rem;color:#5e7080;margin-top:1px;}
.idc-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;object-position:center 15%;border:2px solid rgba(26,158,82,.25);flex-shrink:0;margin-top:2px;}
.eu-bar{display:flex;align-items:center;gap:9px;padding:9px 18px;background:var(--gbg);border-top:1px solid rgba(26,158,82,.12);}
.eu-bar .eu-l{font-size:.57rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--gr);}
.eu-bar .eu-v{font-size:.78rem;font-weight:600;color:var(--nv);}

/* ─── About ─── */
#about{background:#fff;}
.ab-g{display:grid;grid-template-columns:52fr 48fr;gap:72px;align-items:start;}
.ab-l h2{margin:4px 0 14px;}
.ab-l p{margin-bottom:12px;}
.vis{background:var(--nv);border-radius:var(--r);padding:22px 24px;margin-top:18px;}
.vis h4{font-size:.9rem;font-weight:600;color:#fff;margin-bottom:7px;}
.vis p{color:rgba(255,255,255,.6);font-size:.81rem;line-height:1.78;}
.pills{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.pill{background:var(--sd);border-radius:var(--r);padding:16px;border:1px solid var(--bd);transition:transform .2s,box-shadow .2s;}
.pill:hover{transform:translateY(-3px);box-shadow:var(--s2);}
.pill .pi{font-size:1.3rem;margin-bottom:7px;}
.pill h5{font-size:.76rem;font-weight:600;color:var(--nv);margin-bottom:3px;}
.pill p{font-size:.72rem;line-height:1.55;}
.pill.fp{grid-column:1/-1;display:flex;align-items:center;gap:12px;}
.pill.fp .pi{font-size:1.55rem;flex-shrink:0;margin-bottom:0;}

/* ─── EPP ─── */
#epp{background:linear-gradient(160deg,#F0F4FB 0%,#EBF5FF 100%);}
.epp-intro{display:grid;grid-template-columns:52fr 48fr;gap:72px;align-items:start;margin-bottom:52px;}
.epp-intro h2{margin:4px 0 14px;}
.epp-intro>div:first-child p{margin-bottom:12px;}
.epp-badge{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid rgba(26,158,82,.22);border-radius:40px;padding:6px 16px 6px 10px;margin-top:16px;box-shadow:var(--s1);font-size:.72rem;font-weight:700;color:var(--gr);text-transform:uppercase;letter-spacing:.07em;}
.epp-timeline{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:40px;}
.epp-tcard{background:#fff;border-radius:var(--r2);padding:22px 20px;border:1px solid var(--bd);position:relative;overflow:hidden;transition:transform .24s,box-shadow .24s;}
.epp-tcard:hover{transform:translateY(-4px);box-shadow:var(--s3);}
.epp-tcard::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;}
.epp-tcard.t1::before{background:linear-gradient(90deg,#4E9AF1,#6BB5FF);}
.epp-tcard.t2::before{background:linear-gradient(90deg,var(--gr),var(--gr2));}
.epp-tcard.t3::before{background:linear-gradient(90deg,var(--nv),#2A5298);}
.tc-tag{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;}
.epp-tcard.t1 .tc-tag{color:#4E9AF1;}
.epp-tcard.t2 .tc-tag{color:var(--gr);}
.epp-tcard.t3 .tc-tag{color:var(--nv);}
.epp-tcard h4{font-size:.96rem;font-weight:600;color:var(--nv);margin-bottom:6px;}
.epp-tcard p{font-size:.8rem;line-height:1.72;}
.epp-bottom{display:grid;grid-template-columns:48fr 52fr;gap:32px;align-items:start;}
.epp-cad{background:#fff;border-radius:var(--r2);padding:24px 22px;border:1px solid var(--bd);}
.epp-cad h3{font-size:1rem;color:var(--nv);margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid var(--gbg);}
.epp-crit{display:flex;align-items:flex-start;gap:11px;padding:10px 0;border-bottom:1px solid var(--bd);}
.epp-crit:last-child{border-bottom:none;padding-bottom:0;}
.epp-dot{width:34px;height:34px;border-radius:8px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1rem;}
.epp-crit-txt h5{font-size:.82rem;font-weight:600;color:var(--nv);margin-bottom:2px;}
.epp-crit-txt p{font-size:.75rem;line-height:1.6;margin:0;}
.epp-types{display:flex;flex-direction:column;gap:10px;}
.epp-type{background:#fff;border-radius:var(--r);padding:16px 18px;border:1px solid var(--bd);border-left:4px solid transparent;transition:transform .2s,box-shadow .2s;}
.epp-type:hover{transform:translateX(4px);box-shadow:var(--s2);}
.epp-type.qa{border-left-color:#4E9AF1;}
.epp-type.ql{border-left-color:var(--gr);}
.epp-type.mx{border-left-color:#F5A623;}
.epp-type.rt{border-left-color:var(--nv);}
.epp-type h4{font-size:.84rem;font-weight:600;color:var(--nv);margin-bottom:3px;}
.epp-type p{font-size:.76rem;line-height:1.6;margin:0;}

/* ─── Services ─── */
#services{background:var(--sd);}
.svc-hd{display:grid;grid-template-columns:50fr 50fr;gap:40px;align-items:end;margin-bottom:36px;}
.svc-hd h2{margin:4px 0 0;}
.sg{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.svc{background:#fff;border-radius:var(--r2);padding:24px 22px;border:1px solid var(--bd);display:flex;flex-direction:column;position:relative;overflow:hidden;transition:transform .26s,box-shadow .26s;}
.svc:hover{transform:translateY(-4px);box-shadow:var(--s3);}
.svc-bar{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--nv),var(--gr));transform:scaleX(0);transform-origin:left;transition:transform .3s;}
.svc:hover .svc-bar{transform:scaleX(1);}
.svc-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:11px;}
.sico{width:42px;height:42px;border-radius:10px;background:var(--gbg);display:flex;align-items:center;justify-content:center;font-size:1.2rem;}
.snum{font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:700;color:rgba(11,31,58,.05);line-height:1;}
.svc h3{margin-bottom:7px;font-size:.98rem;}
.svc>p{font-size:.82rem;flex:1;}

/* ─── Consultance ─── */
#consultance{background:#fff;}
.cons-g{display:grid;grid-template-columns:42fr 58fr;gap:64px;align-items:start;}
.cons-g h2{margin:4px 0 14px;}
.cons-g>div:first-child p{margin-bottom:12px;}
.cons-badge{display:inline-flex;align-items:center;gap:8px;background:var(--gbg);border:1px solid rgba(26,158,82,.2);border-radius:8px;padding:8px 14px;margin-top:14px;font-size:.76rem;font-weight:600;color:var(--gr);}
.cons-cards{display:flex;flex-direction:column;gap:11px;}
.cons-card{background:var(--sd);border-radius:var(--r);padding:18px 20px;border:1px solid var(--bd);display:flex;align-items:flex-start;gap:13px;transition:transform .22s,box-shadow .22s;position:relative;overflow:hidden;}
.cons-card:hover{transform:translateX(4px);box-shadow:var(--s2);}
.cc-ico{font-size:1.4rem;flex-shrink:0;width:40px;text-align:center;margin-top:2px;}
.cc-num{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#5e7080;margin-bottom:3px;}
.cons-card h4{font-size:.9rem;font-weight:600;color:var(--nv);margin-bottom:3px;}
.cons-card p{font-size:.78rem;line-height:1.72;margin:0;}

/* ─── Agriculture ─── */
#agri{background:linear-gradient(148deg,#EDF8F2 0%,#E6F5EC 60%,#F0F8F4 100%);position:relative;overflow:hidden;}
#agri::after{content:'';position:absolute;right:-100px;bottom:-100px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(26,158,82,.09),transparent 70%);pointer-events:none;}
.ag-g{display:grid;grid-template-columns:50fr 50fr;gap:52px;align-items:start;}
.ag-l h2{margin:4px 0 13px;}
.ag-l p{margin-bottom:11px;}
.cb{background:#fff;border-radius:var(--r);padding:18px 20px;border:1px solid rgba(26,158,82,.15);box-shadow:var(--s1);margin-top:14px;}
.cb h4{font-size:.9rem;font-weight:600;color:var(--nv);margin-bottom:10px;}
.ci{display:flex;align-items:flex-start;gap:9px;padding:8px 0;border-bottom:1px solid var(--bd);font-size:.81rem;color:#5e7080;line-height:1.7;}
.ci:last-child{border-bottom:none;padding-bottom:0;}
.ag-cards{display:flex;flex-direction:column;gap:10px;}
.agc{background:#fff;border-radius:var(--r);padding:14px 16px;border:1px solid rgba(26,158,82,.12);box-shadow:var(--s1);display:flex;align-items:flex-start;gap:11px;transition:transform .2s,box-shadow .2s;}
.agc:hover{transform:translateY(-2px);box-shadow:var(--s2);}
.agci{width:36px;height:36px;border-radius:8px;flex-shrink:0;background:var(--gbg);display:flex;align-items:center;justify-content:center;font-size:1.05rem;}
.agc h4{font-size:.92rem;font-weight:600;color:var(--nv);margin-bottom:2px;}
.agc p{font-size:.76rem;line-height:1.6;margin:0;}
.agc.dk{background:var(--nv);border-color:transparent;}
.agc.dk .agci{background:rgba(255,255,255,.1);}
.agc.dk h4{color:#fff;}
.agc.dk p{color:rgba(255,255,255,.5);}
.agc.ac{background:linear-gradient(135deg,var(--gr),var(--gr2));border-color:transparent;}
.agc.ac .agci{background:rgba(255,255,255,.2);}
.agc.ac h4{color:#fff;}
.agc.ac p{color:rgba(255,255,255,.85);}

/* ─── Immobilier ─── */
#immo{background:var(--sd);}
.im-hdr{display:grid;grid-template-columns:48fr 52fr;gap:52px;align-items:center;margin-bottom:34px;}
.im-hl h2{margin:4px 0 12px;}
.im-hl p{font-size:.88rem;}
.im-hr{background:var(--nv);border-radius:var(--r2);padding:24px 26px;}
.itag{display:inline-block;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--gr2);margin-bottom:8px;}
.im-hr h4{font-size:1rem;font-weight:600;color:#fff;margin-bottom:8px;line-height:1.3;}
.im-hr p{color:rgba(255,255,255,.56);font-size:.81rem;line-height:1.78;}
.im-r1{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:11px;}
.im-r2{display:grid;grid-template-columns:repeat(3,1fr);gap:11px;}
.imc{background:#fff;border-radius:var(--r);padding:15px 14px;border:1px solid var(--bd);display:flex;align-items:flex-start;gap:11px;transition:transform .2s,box-shadow .2s;}
.imc:hover{transform:translateY(-2px);box-shadow:var(--s2);}
.imci{width:32px;height:32px;border-radius:7px;flex-shrink:0;background:var(--gbg);display:flex;align-items:center;justify-content:center;font-size:.96rem;}
.imc h4{font-size:.9rem;font-weight:600;color:var(--nv);margin-bottom:2px;}
.imc p{font-size:.75rem;line-height:1.6;margin:0;}
.imc.nc{background:var(--nv);border-color:transparent;}
.imc.nc .imci{background:rgba(255,255,255,.1);}
.imc.nc h4{color:#fff;}
.imc.nc p{color:rgba(255,255,255,.5);}
.imc.gc{background:linear-gradient(135deg,var(--gr),var(--gr2));border-color:transparent;}
.imc.gc .imci{background:rgba(255,255,255,.2);}
.imc.gc h4{color:#fff;}
.imc.gc p{color:rgba(255,255,255,.88);}

/* ─── Approche ─── */
#approche{background:var(--nv);}
#approche h2{color:#fff;}
.ap-intro{color:rgba(255,255,255,.55);max-width:480px;margin:8px 0 40px;font-size:.88rem;}
.ap-g{display:grid;grid-template-columns:53fr 47fr;gap:72px;}
.ap-list{display:flex;flex-direction:column;}
.ap-item{display:flex;gap:12px;align-items:flex-start;padding:15px 0;border-bottom:1px solid rgba(255,255,255,.07);}
.ap-item:last-child{border-bottom:none;}
.ap-ico{width:36px;height:36px;border-radius:9px;flex-shrink:0;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:.98rem;}
.ap-item h4{font-size:.83rem;font-weight:600;color:#fff;margin-bottom:2px;}
.ap-item p{font-size:.75rem;color:rgba(255,255,255,.44);line-height:1.65;}
.ap-r{display:flex;flex-direction:column;gap:13px;}
.ap-q{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-left:4px solid var(--gr);border-radius:0 var(--r) var(--r) 0;padding:20px 22px;}
.ap-q p{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:.92rem;color:rgba(255,255,255,.78);line-height:1.78;}
.ap-kpis{display:grid;grid-template-columns:1fr 1fr;gap:9px;}
.ap-kpi{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);border-radius:var(--r);padding:16px 12px;text-align:center;}
.ap-kpi .kv{font-family:'Cormorant Garamond',serif;font-size:1.45rem;font-weight:700;color:var(--gr2);line-height:1;margin-bottom:4px;}
.ap-kpi .kl{font-size:.62rem;color:rgba(255,255,255,.36);line-height:1.5;}

/* ─── Impact ─── */
#impact{background:#fff;}
.ip-g{display:grid;grid-template-columns:54fr 46fr;gap:72px;align-items:center;}
.ip-l h2{margin:4px 0 12px;}
.ip-l>p{margin-bottom:20px;max-width:380px;}
.im-ul{list-style:none;}
.im-li{display:flex;align-items:flex-start;gap:10px;padding:11px 0;border-bottom:1px solid var(--bd);font-size:.84rem;color:#5e7080;line-height:1.72;}
.im-li:last-child{border-bottom:none;}
.kpis{display:grid;grid-template-columns:1fr 1fr;gap:11px;}
.kpi{border-radius:var(--r2);padding:20px 16px;text-align:center;display:flex;flex-direction:column;align-items:center;}
.kpi.sd{background:var(--sd);}
.kpi.nv{background:var(--nv);}
.kpi.gn{background:linear-gradient(135deg,var(--gr),var(--gr2));}
.kpi .kv{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:700;line-height:1;margin-bottom:6px;color:var(--nv);}
.kpi.nv .kv{color:var(--gr2);}
.kpi.gn .kv{color:#fff;}
.kpi p{font-size:.7rem;line-height:1.55;color:#5e7080;}
.kpi.nv p{color:rgba(255,255,255,.5);}
.kpi.gn p{color:rgba(255,255,255,.88);}

/* ─── Contact ─── */
#contact{background:linear-gradient(148deg,var(--nv) 0%,#102845 55%,#0C2D18 100%);}
#contact h2{color:#fff;}
.ct-g{display:grid;grid-template-columns:44fr 56fr;gap:48px;align-items:start;margin-top:34px;}
.ct-list{display:flex;flex-direction:column;}
.ct-row{display:flex;align-items:flex-start;gap:11px;padding:11px 0;border-bottom:1px solid rgba(255,255,255,.08);}
.ct-row:last-child{border-bottom:none;}
.ct-ico{width:32px;height:32px;border-radius:7px;flex-shrink:0;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:.84rem;}
.ct-lb{font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:rgba(255,255,255,.34);margin-bottom:1px;}
.ct-val{font-size:.81rem;font-weight:600;color:#fff;}
.ct-val a{color:#fff;transition:color .2s;}
.ct-val a:hover{color:var(--gr2);}
.ct-sub{font-size:.67rem;color:rgba(255,255,255,.34);margin-top:1px;}
.ct-sub a{color:rgba(255,255,255,.34);transition:color .2s;}
.ct-sub a:hover{color:rgba(255,255,255,.6);}
.frm{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.11);border-radius:var(--r2);padding:22px 20px;}
.frm h3{font-size:1.05rem;color:#fff;margin-bottom:15px;font-weight:600;}
.fr{margin-bottom:9px;}
.fr label{display:block;font-size:.59rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:rgba(255,255,255,.4);margin-bottom:3px;}
.fr input,.fr textarea,.fr select{width:100%;padding:8px 11px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);border-radius:7px;color:#fff;font:400 .81rem 'DM Sans',sans-serif;outline:none;transition:border-color .2s,background .2s;-webkit-appearance:none;appearance:none;}
.fr input::placeholder,.fr textarea::placeholder{color:rgba(255,255,255,.22);}
.fr input:focus,.fr textarea:focus,.fr select:focus{border-color:var(--gr2);background:rgba(255,255,255,.1);}
.fr select option{background:#102845;color:#fff;}
.fr textarea{min-height:80px;resize:vertical;}
.fr2{display:grid;grid-template-columns:1fr 1fr;gap:9px;}
.frbtn{width:100%;background:var(--gr);color:#fff;border:none;border-radius:7px;padding:11px;font:600 .86rem 'DM Sans',sans-serif;cursor:pointer;transition:background .2s,transform .15s;margin-top:3px;}
.frbtn:hover{background:var(--gr2);transform:translateY(-1px);}

/* ─── PDG / Président ─── */
#pdg{background:var(--nv);position:relative;overflow:hidden;}
#pdg::before{content:'';position:absolute;right:-120px;top:-120px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(26,158,82,.12),transparent 65%);pointer-events:none;}
.pdg-inner{display:grid;grid-template-columns:260px 1fr 1fr;gap:48px;align-items:start;}
.pdg-ql{font-family:'Cormorant Garamond',serif;font-size:8rem;line-height:.7;color:var(--gr);opacity:.35;margin-bottom:-20px;display:block;}
.pdg-quote blockquote{font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-style:italic;color:rgba(255,255,255,.88);line-height:1.85;margin-bottom:32px;}
.pdg-sig{display:flex;align-items:center;gap:16px;}
.pdg-sig-line{width:40px;height:2px;background:var(--gr);flex-shrink:0;}
.pdg-name{font-size:.88rem;font-weight:700;color:#fff;margin-bottom:3px;}
.pdg-title{font-size:.68rem;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.08em;}
.pdg-right{display:flex;flex-direction:column;gap:12px;}
.pdg-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r);padding:18px 20px;transition:background .2s,transform .2s;}
.pdg-card:hover{background:rgba(255,255,255,.09);transform:translateX(4px);}
.pdg-card.accent{background:rgba(26,158,82,.12);border-color:rgba(26,158,82,.25);}
.pdg-ico{font-size:1.3rem;margin-bottom:9px;}
.pdg-card h4{font-size:.86rem;font-weight:600;color:#fff;margin-bottom:5px;}
.pdg-card p{font-size:.78rem;color:rgba(255,255,255,.5);line-height:1.72;margin:0;}
.pdg-card.accent p{color:rgba(255,255,255,.65);}
.pdg-photo{position:relative;border-radius:var(--r2);overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.4);}
.pdg-photo img{width:100%;height:390px;object-fit:cover;object-position:center 15%;display:block;}
.pdg-photo-overlay{position:absolute;bottom:0;left:0;right:0;padding:24px 16px 18px;background:linear-gradient(0deg,rgba(6,15,28,.95) 0%,rgba(6,15,28,.25) 55%,transparent 100%);}
.pdg-photo-name{display:block;font-size:.84rem;font-weight:700;color:#fff;margin-bottom:3px;}
.pdg-photo-role{display:block;font-size:.56rem;font-weight:700;text-transform:uppercase;letter-spacing:.11em;color:var(--gr2);}

/* ─── Page Président (page dédiée) ─── */
.pres-hero{padding-top:var(--NH);background:var(--nv);position:relative;overflow:hidden;}
.pres-hero::before{content:'';position:absolute;right:-120px;top:-80px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(26,158,82,.14),transparent 65%);pointer-events:none;}
.pres-hero::after{content:'';position:absolute;left:-80px;bottom:-80px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(26,158,82,.07),transparent 70%);pointer-events:none;}
.pres-hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;max-width:1160px;margin:0 auto;padding:72px 5% 64px;}
.pres-photo{position:relative;}
.pres-photo img{width:100%;max-width:420px;border-radius:var(--r2);box-shadow:var(--s3);display:block;}
.pres-photo-frame{position:absolute;bottom:-16px;right:-16px;width:100%;max-width:420px;border:2px solid rgba(26,158,82,.3);border-radius:var(--r2);pointer-events:none;}
.pres-content .chip-dark{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.08);border:1px solid rgba(26,158,82,.35);border-radius:40px;padding:4px 14px 4px 8px;margin-bottom:20px;}
.pres-content .chip-dark .dot{width:7px;height:7px;border-radius:50%;background:var(--gr2);flex-shrink:0;}
.pres-content .chip-dark span{font-size:.64rem;font-weight:700;color:var(--gr2);text-transform:uppercase;letter-spacing:.08em;}
.pres-content h1{color:#fff;margin-bottom:8px;font-size:clamp(1.7rem,3vw,2.8rem);}
.pres-content .pres-role{font-size:.8rem;font-weight:700;color:var(--gr2);text-transform:uppercase;letter-spacing:.1em;margin-bottom:24px;}
.pres-content .pres-quote-block{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-left:4px solid var(--gr);border-radius:0 var(--r) var(--r) 0;padding:20px 22px;margin-bottom:24px;}
.pres-content .pres-quote-block blockquote{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:.98rem;color:rgba(255,255,255,.82);line-height:1.85;}
.pres-contact-links{display:flex;flex-wrap:wrap;gap:10px;}
.pres-contact-links a{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:7px;font-size:.8rem;font-weight:600;transition:background .2s,transform .2s;}
.pres-contact-links a.link-email{background:var(--gr);color:#fff;box-shadow:0 4px 12px rgba(26,158,82,.3);}
.pres-contact-links a.link-email:hover{background:var(--gr2);transform:translateY(-2px);}
.pres-contact-links a.link-tel{border:1.5px solid rgba(255,255,255,.25);color:rgba(255,255,255,.82);}
.pres-contact-links a.link-tel:hover{border-color:var(--gr2);color:#fff;transform:translateY(-2px);}
.pres-contact-links a.link-pdf{border:1.5px solid rgba(255,255,255,.25);color:rgba(255,255,255,.82);}
.pres-contact-links a.link-pdf:hover{border-color:#fff;color:#fff;transform:translateY(-2px);}

/* ─── Version simplifiée carte identité (pour page président) ─── */
.pres-vision{background:#fff;}
.pres-vision-inner{max-width:1160px;margin:0 auto;padding:80px 5%;}
.pres-vision-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:36px;}
.pres-vcard{background:var(--sd);border-radius:var(--r2);padding:28px 24px;border:1px solid var(--bd);transition:transform .22s,box-shadow .22s;}
.pres-vcard:hover{transform:translateY(-4px);box-shadow:var(--s2);}
.pres-vcard.accent{background:linear-gradient(135deg,var(--gr),var(--gr2));border-color:transparent;}
.pres-vcard .pico{font-size:1.6rem;margin-bottom:12px;}
.pres-vcard h4{font-size:.95rem;font-weight:600;color:var(--nv);margin-bottom:8px;}
.pres-vcard p{font-size:.82rem;line-height:1.72;color:#5e7080;}
.pres-vcard.accent h4{color:#fff;}
.pres-vcard.accent p{color:rgba(255,255,255,.82);}

/* ─── Activités Timeline ─── */
.act-section{background:#fff;}
.act-timeline{max-width:860px;margin:48px auto 0;position:relative;}
.act-timeline::before{content:'';position:absolute;left:24px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--gr),var(--nv));opacity:.2;border-radius:2px;}
.act-card{display:flex;gap:24px;margin-bottom:32px;position:relative;}
.act-dot{width:48px;height:48px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1.1rem;position:relative;z-index:1;}
.act-dot.conf{background:linear-gradient(135deg,#4E9AF1,#6BB5FF);box-shadow:0 4px 14px rgba(78,154,241,.3);}
.act-dot.pub{background:linear-gradient(135deg,var(--gr),var(--gr2));box-shadow:0 4px 14px rgba(26,158,82,.3);}
.act-dot.part{background:linear-gradient(135deg,var(--nv),#2A5298);box-shadow:0 4px 14px rgba(11,31,58,.3);}
.act-dot.form{background:linear-gradient(135deg,#F5A623,#F7C25E);box-shadow:0 4px 14px rgba(245,166,35,.3);}
.act-dot.award{background:linear-gradient(135deg,#9C27B0,#BA68C8);box-shadow:0 4px 14px rgba(156,39,176,.3);}
.act-body{flex:1;background:var(--sd);border-radius:var(--r2);padding:22px 24px;border:1px solid var(--bd);transition:box-shadow .22s,transform .22s;}
.act-body:hover{box-shadow:var(--s2);transform:translateX(4px);}
.act-meta{display:block;}
.act-date{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#5e7080;}
.act-badge{display:inline-flex;align-items:center;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:2px 9px;border-radius:40px;}
.act-badge.conf{background:rgba(78,154,241,.12);color:#3581d9;}
.act-badge.pub{background:var(--gbg);color:var(--gr);}
.act-badge.part{background:rgba(11,31,58,.07);color:var(--nv);}
.act-badge.form{background:rgba(245,166,35,.12);color:#c07a00;}
.act-badge.award{background:rgba(156,39,176,.1);color:#9C27B0;}
.act-body h4{font-size:1rem;font-weight:600;color:var(--nv);margin-bottom:6px;line-height:1.3;}
.act-body p{font-size:.82rem;line-height:1.75;color:#5e7080;margin:0;}
.act-body .act-link{display:inline-flex;align-items:center;gap:5px;margin-top:12px;font-size:.76rem;font-weight:600;color:var(--gr);transition:color .2s;}
.act-body .act-link:hover{color:var(--nv);}
.act-empty{text-align:center;padding:60px 20px;}
.act-empty .act-empty-ico{font-size:2.5rem;margin-bottom:12px;}
.act-empty p{font-size:.88rem;color:#5e7080;}

/* ─── Footer ─── */
footer{background:#060F1C;padding:56px 5% 0;}
.ft-top{display:grid;grid-template-columns:1.8fr 1fr 1.4fr 1fr;gap:36px;max-width:1160px;margin:0 auto;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.07);}
.ft-blogo{display:flex;align-items:center;gap:10px;margin-bottom:16px;}
.ft-blogo img{height:34px;width:34px;object-fit:contain;flex-shrink:0;}
.ft-blogo b{display:block;font-family:'Cormorant Garamond',serif;font-size:1.05rem;font-weight:700;color:rgba(255,255,255,.8);line-height:1.1;}
.ft-blogo small{display:block;font-size:.5rem;font-weight:700;color:var(--gr2);text-transform:uppercase;letter-spacing:.07em;}
.ft-blurb{font-size:.76rem;color:rgba(255,255,255,.32);line-height:1.78;margin-bottom:18px;}
.ft-badges{display:flex;flex-direction:column;gap:6px;}
.ft-badges span{font-size:.63rem;color:rgba(255,255,255,.2);font-weight:500;}
.ft-col h5{font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:rgba(255,255,255,.25);margin-bottom:18px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.06);}
.ft-col a{display:block;font-size:.76rem;color:rgba(255,255,255,.4);margin-bottom:10px;transition:color .2s;}
.ft-col a:hover{color:var(--gr2);padding-left:3px;}
.ft-col span{display:block;font-size:.74rem;color:rgba(255,255,255,.28);line-height:1.7;margin-bottom:6px;}
.ft-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;max-width:1160px;margin:0 auto;padding:18px 0 22px;}
.ft-copy{font-size:.68rem;color:rgba(255,255,255,.2);}
.ft-legal{font-size:.65rem;color:rgba(255,255,255,.15);}
.funding-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.08);}

/* ─── CTA Strip (landing) ─── */
.cta-strip{background:linear-gradient(135deg,var(--nv) 0%,#0D2E1A 100%);padding:64px 5%;}
.cta-strip-inner{max-width:780px;margin:0 auto;text-align:center;}
.cta-strip h2{color:#fff;margin-bottom:12px;font-size:clamp(1.4rem,2.2vw,2rem);}
.cta-strip p{color:rgba(255,255,255,.6);font-size:.9rem;margin-bottom:28px;}
.cta-strip .btns{justify-content:center;}
.cta-strip .btn-p{background:var(--gr);box-shadow:0 4px 16px rgba(26,158,82,.3);}
.cta-strip .btn-p:hover{background:var(--gr2);}
.cta-strip .btn-l{color:rgba(255,255,255,.8);border-color:rgba(255,255,255,.25);}
.cta-strip .btn-l:hover{border-color:#fff;color:#fff;}

/* ─── Services Grid (page services) ─── */
.services-bg{background:var(--sd);}

/* ─── Responsive ─── */
@media (max-width:1100px){
  .h-inner{gap:40px;}
  .ab-g,.epp-intro,.ap-g,.ip-g,.cons-g{gap:52px;}
  .pres-hero-inner{gap:52px;}
}
@media (max-width:960px){
  .pdg-inner{grid-template-columns:55fr 45fr;gap:36px;}
  .pdg-photo{display:none;}
  .section{padding:68px 5%;}
  .h-inner{grid-template-columns:1fr;gap:36px;padding:48px 5%;}
  .h-inner>div:last-child{display:flex;justify-content:center;}
  .idc{max-width:420px;width:100%;}
  .ab-g,.ag-g,.ap-g,.ip-g,.ct-g,.cons-g{grid-template-columns:1fr;gap:36px;}
  .epp-intro{grid-template-columns:1fr;gap:36px;margin-bottom:36px;}
  .epp-bottom{grid-template-columns:1fr;gap:24px;}
  .epp-timeline{grid-template-columns:repeat(3,1fr);}
  .im-hdr{grid-template-columns:1fr;gap:24px;}
  .svc-hd{grid-template-columns:1fr;gap:14px;margin-bottom:28px;}
  .pills{grid-template-columns:1fr 1fr;}
  .pill.fp{grid-column:1/-1;}
  .sg{grid-template-columns:1fr 1fr;}
  .im-r2{grid-template-columns:repeat(3,1fr);}
  .pres-hero-inner{grid-template-columns:1fr;gap:40px;padding:52px 5% 48px;}
  .pres-photo img{max-width:340px;margin:0 auto;}
  .pres-vision-grid{grid-template-columns:1fr 1fr;}
  .act-timeline::before{left:20px;}
  .act-dot{width:40px;height:40px;font-size:.95rem;}
  /* Section "Comment ERAD intervient" */
  [style*="grid-template-columns:repeat(3,1fr)"]{grid-template-columns:1fr!important;}
}
@media (max-width:768px){
  .section{padding:56px 4.5%;}
  #nav .nav-links{display:none;}
  .burger{display:flex;}
  .h-inner{padding:40px 4.5%;gap:28px;}
  .stats{flex-wrap:wrap;gap:14px;}
  .st{border-right:none;padding-right:0;margin-right:0;}
  .sg{grid-template-columns:1fr;}
  .pills{grid-template-columns:1fr 1fr;}
  .epp-timeline{grid-template-columns:1fr 1fr;}
  .im-r1{grid-template-columns:1fr 1fr;}
  .im-r2{grid-template-columns:1fr 1fr;}
  .kpis{grid-template-columns:1fr 1fr;}
  .ap-kpis{grid-template-columns:1fr 1fr;}
  .fr2{grid-template-columns:1fr 1fr;}
  .pdg-inner{grid-template-columns:1fr;}
  .ft-top{grid-template-columns:1fr 1fr;}
  .ft-brand-col{grid-column:1/-1;}
  .pres-vision-grid{grid-template-columns:1fr;}
  .act-timeline{margin-top:32px;}
  .act-body:hover{transform:none;}
}
@media (max-width:520px){
  .ft-top{grid-template-columns:1fr;}
  .pdg-ql{font-size:5rem;}
  .section{padding:46px 4%;}
  .h-inner{padding:32px 4%;gap:24px;}
  .idc{max-width:100%;}
  .btns{flex-direction:column;}
  .btn-p,.btn-l{width:100%;justify-content:center;}
  .pills{grid-template-columns:1fr;}
  .pill.fp{flex-direction:row;}
  .sg{grid-template-columns:1fr;}
  .epp-timeline{grid-template-columns:1fr;}
  .im-r1{grid-template-columns:1fr;}
  .im-r2{grid-template-columns:1fr 1fr;}
  .kpis{grid-template-columns:1fr 1fr;}
  .ap-kpis{grid-template-columns:1fr 1fr;}
  .fr2{grid-template-columns:1fr;}
  .svc{padding:18px 16px;}
  .pres-hero-inner{padding:40px 4% 36px;}
  .pres-contact-links{flex-direction:column;}
  .pres-contact-links a{justify-content:center;}
  .act-timeline::before{display:none;}
  .act-card{flex-direction:column;gap:12px;}
  .act-dot{width:36px;height:36px;}
}
@media (max-width:380px){
  .im-r2{grid-template-columns:1fr;}
  .kpis{grid-template-columns:1fr;}
  .ap-kpis{grid-template-columns:1fr;}
}
