/* ============================================================
   FONDATION RZB v6 — éditorial premium (light, multicolore)
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--text);font-size:var(--t-base);line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;font-family:var(--display);font-weight:700;line-height:.98;letter-spacing:-.02em}
p{margin:0}
:focus-visible{outline:3px solid var(--navy);outline-offset:3px}
.skip-link{position:absolute;left:-999px;background:var(--navy);color:#fff;padding:.7rem 1.2rem;z-index:300}
.skip-link:focus{left:0}
.todo{color:var(--red);font-style:italic;font-size:.72em;font-family:var(--mono);opacity:.9}
.accent{color:var(--red)}
.italic{font-style:italic}

/* Curseur custom (desktop fin) */
.cursor{position:fixed;top:0;left:0;z-index:400;pointer-events:none;mix-blend-mode:multiply;display:none}
@media (hover:hover) and (pointer:fine){.cursor{display:block}body{cursor:none}a,button{cursor:none}}
.cursor-dot{position:absolute;width:7px;height:7px;border-radius:50%;background:var(--red);transform:translate(-50%,-50%)}
.cursor-ring{position:absolute;width:38px;height:38px;border:1.5px solid var(--navy);border-radius:50%;transform:translate(-50%,-50%);transition:width .3s var(--ease),height .3s var(--ease),background .3s,opacity .3s}
.cursor.is-hover .cursor-ring{width:64px;height:64px;background:rgba(0,24,120,.06)}
.cursor.is-give .cursor-ring{width:74px;height:74px;border-color:var(--red);background:rgba(216,0,30,.08)}

/* Grain */
.grain{position:fixed;inset:0;z-index:350;pointer-events:none;opacity:.04;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* Loader */
.loader{position:fixed;inset:0;z-index:500;background:var(--paper);display:grid;place-items:center}
.loader-radiant{width:min(46vw,360px);position:absolute;opacity:.9}
.loader-count{font-family:var(--display);font-weight:700;font-size:clamp(3rem,12vw,8rem);color:var(--navy);display:flex;align-items:baseline;gap:.1em}
.loader-count i{font-family:var(--mono);font-size:.2em;font-style:normal;color:var(--red)}
.loader-word{position:absolute;bottom:14%;font-family:var(--mono);font-size:var(--t-sm);letter-spacing:.3em;text-transform:uppercase;color:var(--ink-soft)}
.loaded .loader{display:none}

/* ===== Header ===== */
.hdr{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;gap:1.5rem;padding:1.1rem var(--pad);transition:padding .4s var(--ease),background .4s}
.hdr.shrink{padding:.6rem var(--pad);background:rgba(251,250,247,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.hdr-brand{display:flex;align-items:center;gap:.6rem;font-family:var(--display);font-weight:700;color:var(--navy)}
.hdr-brand img{width:46px;height:46px;object-fit:contain;transition:width .4s}
.hdr.shrink .hdr-brand img{width:38px;height:38px}
.hdr-nav{display:flex;gap:1.6rem;margin-left:auto;font-size:var(--t-sm)}
.hdr-nav a{position:relative;font-weight:500;padding:.2rem 0}
.hdr-nav a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--red);transition:width .4s var(--ease)}
.hdr-nav a:hover::after{width:100%}
.btn-give{display:inline-flex;align-items:center;gap:.5em;background:var(--red);color:#fff;font-family:var(--display);font-weight:600;padding:.7em 1.3em;border-radius:50px;border:0;font-size:var(--t-sm);transition:background .3s,transform .3s var(--ease)}
.btn-give:hover{background:#b00018}
.btn-give svg path{stroke:currentColor}
.btn-lg{font-size:var(--t-base);padding:.95em 1.7em}
.btn-block{width:100%;justify-content:center}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;margin-left:auto}
.burger span{width:26px;height:2px;background:var(--navy);display:block}

/* ===== HERO éditorial ===== */
.hero{position:relative;min-height:100svh;padding:clamp(6rem,12vh,9rem) var(--pad) var(--sp-5);display:grid;grid-template-columns:1.45fr .55fr;grid-template-rows:auto 1fr;gap:1rem 3rem;align-content:start}
.hero-meta{grid-column:1/-1;display:flex;gap:2rem;flex-wrap:wrap;font-family:var(--mono);font-size:var(--t-sm);letter-spacing:.05em;text-transform:uppercase;color:var(--ink-soft)}
.hero-meta span{position:relative;padding-left:1.1rem}
.hero-meta span::before{content:"";position:absolute;left:0;top:50%;width:7px;height:7px;border-radius:50%;background:var(--red);transform:translateY(-50%)}
.hero-title{grid-column:1;font-size:var(--t-mega);margin-top:.1em;align-self:end}
.hero-title .l{display:block;overflow:hidden}
.hero-title .l>span{display:block;will-change:transform}
.hero-title .accent>span{color:var(--red)}
.hero-aside{grid-column:2;grid-row:2;align-self:end;display:flex;flex-direction:column;gap:1.4rem}
.hero-fig{margin:0;border-radius:2px;overflow:hidden;aspect-ratio:4/5;clip-path:polygon(0 0,100% 4%,100% 100%,0 96%)}
.hero-fig img{width:100%;height:100%;object-fit:cover}
.hero-lead{font-size:var(--t-md);line-height:1.25;color:var(--ink)}
.kenburns{animation:kb 18s ease-in-out infinite alternate}
@keyframes kb{from{transform:scale(1.02) translate(0,0)}to{transform:scale(1.14) translate(-2%,-2%)}}
.hero-radiant{position:absolute;right:-6%;top:6%;width:min(42vw,520px);z-index:-1;opacity:.85;mix-blend-mode:multiply}
.hero-scroll{position:absolute;left:var(--pad);bottom:1.4rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-soft)}
.hero-scroll::after{content:"";display:block;width:1px;height:32px;background:var(--navy);margin-top:.4rem;animation:drop 1.8s var(--ease) infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ===== Marquee ===== */
.marquee{border-block:1.5px solid var(--ink);padding:.6rem 0;overflow:hidden;white-space:nowrap;background:var(--paper)}
.marquee-track{display:inline-flex;align-items:center;gap:2rem;font-family:var(--display);font-weight:700;font-size:clamp(1.6rem,4vw,3rem);will-change:transform}
.marquee-track span{color:var(--c,var(--ink));text-transform:uppercase;letter-spacing:-.01em}
.marquee-track i{color:var(--ink-soft);font-style:normal;font-size:.5em}

/* ===== Manifeste ===== */
.manifesto{padding:var(--sp-7) var(--pad);max-width:1100px}
.manif{font-family:var(--display);font-weight:300;font-size:var(--t-lg);line-height:1.18;letter-spacing:-.02em}
.manif em{font-style:normal;color:var(--c);font-weight:700}
.reveal-words .word{display:inline-block;opacity:.12;transition:opacity .5s}

/* ===== Section heads ===== */
.sec-head{padding:0 var(--pad);margin-bottom:var(--sp-4)}
.sec-kicker{font-family:var(--mono);font-size:var(--t-sm);letter-spacing:.15em;text-transform:uppercase;color:var(--red);display:inline-block;margin-bottom:1rem}
.sec-title{font-size:var(--t-xl)}

/* ===== Approche (rangées asymétriques) ===== */
.approach{padding:var(--sp-6) 0}
.rows{display:flex;flex-direction:column;gap:0;border-top:1.5px solid var(--ink)}
.row{position:relative;padding:clamp(1.8rem,4vw,3.2rem) var(--pad);border-bottom:1.5px solid var(--line);display:grid;grid-template-columns:auto 1fr;gap:1rem 3rem;align-items:baseline;transition:background .5s,color .5s}
.row.offset{padding-left:clamp(3rem,12vw,14rem)}
.row-num{font-family:var(--mono);font-size:var(--t-sm);color:var(--red)}
.row h3{font-size:var(--t-lg)}
.row p{grid-column:2;max-width:46ch;color:var(--ink-soft);font-size:var(--t-md)}
.row:hover{background:var(--navy);color:#fff}
.row:hover p{color:rgba(255,255,255,.8)}
.row:hover .row-num{color:#fff}

/* ===== Journey (scroll horizontal épinglé) ===== */
.journey{position:relative}
.journey-pin{height:100svh;overflow:hidden;display:flex;align-items:center}
.journey-track{display:flex;align-items:stretch;gap:0;height:78svh;padding-inline:var(--pad);will-change:transform}
.panel{flex:0 0 auto;height:100%}
.jintro{width:min(80vw,520px);display:flex;flex-direction:column;justify-content:center;padding-right:4rem}
.jintro-title{font-size:var(--t-xl);margin:.4rem 0 1rem}
.jintro p{color:var(--ink-soft);font-family:var(--mono);font-size:var(--t-sm)}
.commune{width:min(86vw,560px);margin-right:clamp(1.5rem,3vw,3rem);display:grid;grid-template-rows:1fr auto;border:1.5px solid var(--ink);background:var(--paper);overflow:hidden}
.commune-img{position:relative;overflow:hidden}
.commune-img::after{content:"";position:absolute;inset:0;background:var(--c);mix-blend-mode:multiply;opacity:.22;transition:opacity .6s}
.commune-img img{width:100%;height:100%;object-fit:cover}
.commune:hover .commune-img::after{opacity:.05}
.commune-txt{padding:clamp(1.2rem,2.4vw,2rem);position:relative}
.commune-txt::before{content:"";position:absolute;top:0;left:clamp(1.2rem,2.4vw,2rem);right:clamp(1.2rem,2.4vw,2rem);height:5px;background:var(--c)}
.commune-n{font-family:var(--mono);font-size:var(--t-sm);color:var(--c);filter:brightness(.8)}
.commune-place{display:block;font-family:var(--mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);margin:.3rem 0 .5rem}
.commune h3{font-size:var(--t-md)}
.commune p{margin:.6rem 0;color:var(--ink-soft)}

/* ===== Impact ===== */
.impact{padding:var(--sp-7) 0}
.bigstats{display:flex;flex-wrap:wrap;gap:clamp(2rem,6vw,6rem);padding:0 var(--pad);align-items:end}
.bigstat{flex:1 1 240px}
.bigstat.alt{flex:1.4 1 300px}
.bs-num{display:block;font-family:var(--display);font-weight:800;font-size:clamp(4rem,13vw,11rem);line-height:.85;letter-spacing:-.04em;color:var(--navy)}
.bigstat:nth-child(1) .bs-num{color:var(--abobo)}
.bigstat:nth-child(2) .bs-num{color:var(--bouake)}
.bigstat:nth-child(3) .bs-num{color:var(--root)}
.bs-lab{display:block;margin-top:.6rem;font-size:var(--t-md);color:var(--ink-soft);max-width:18ch}
.impact-note{padding:var(--sp-4) var(--pad) 0;font-family:var(--mono);font-size:var(--t-sm);color:var(--ink-soft);max-width:60ch}

/* ===== Cercle / Don ===== */
.cercle{padding:var(--sp-6) var(--pad);display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(2rem,5vw,5rem);align-items:start}
.cercle-head h2{margin:.4rem 0 1rem}
.cercle-head p{color:var(--ink-soft);font-size:var(--t-md)}
.give{background:#fff;border:1.5px solid var(--ink);padding:clamp(1.4rem,3vw,2.4rem)}
.give-freq{display:inline-flex;border:1.5px solid var(--line);border-radius:50px;padding:3px;margin-bottom:1.6rem}
.gf{border:0;background:none;font-family:var(--display);font-weight:600;padding:.55em 1.3em;border-radius:50px;color:var(--ink-soft)}
.gf.is-active{background:var(--navy);color:#fff}
.tiers{display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem;margin-bottom:1.4rem}
.tier{text-align:left;border:1.5px solid var(--line);background:#fff;padding:.9rem 1rem;display:flex;flex-direction:column;gap:.15rem;transition:border-color .25s,transform .25s var(--ease)}
.tier:hover{transform:translateY(-3px)}
.tier.is-active{border-color:var(--red);box-shadow:0 0 0 4px rgba(216,0,30,.1)}
.tier.wide{grid-column:1/-1}
.tier b{font-family:var(--display);font-size:var(--t-md);display:flex;align-items:baseline;gap:.3em}
.tier b i{font-family:var(--mono);font-size:.5em;font-style:normal;color:var(--ink-soft)}
.tier span{font-size:.82rem;color:var(--ink-soft)}
.give-sum{margin:0 0 1.2rem;text-align:center}
.give-sum p{font-size:var(--t-md)}
.give-sum strong{color:var(--red);font-family:var(--display)}
.give-imp{color:var(--root);font-weight:700;font-size:var(--t-base)!important}
.pays{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;justify-content:center;margin-top:1.4rem;font-family:var(--mono);font-size:.75rem;color:var(--ink-soft)}
.pays ul{display:flex;flex-wrap:wrap;gap:.4rem;list-style:none;padding:0;margin:0}
.pays li{background:var(--paper-2);border-radius:50px;padding:.25rem .7rem;font-weight:700;color:var(--navy)}
.give-note{text-align:center;font-family:var(--mono);font-size:.72rem;color:var(--ink-soft);margin-top:.9rem}
.todo-i{font-size:.7em}

/* ===== Transparence ===== */
.transp{padding:var(--sp-6) var(--pad);display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center;background:var(--paper-2)}
.transp-l h2{margin:.4rem 0 1rem}
.transp-l>p{color:var(--ink-soft);font-size:var(--t-md);max-width:42ch}
.transp-list{list-style:none;padding:0;margin:1.6rem 0 0;display:grid;gap:.7rem}
.transp-list li{display:flex;align-items:center;gap:.7rem;font-weight:500}
.transp-list i{width:11px;height:11px;border-radius:50%;background:var(--c);flex:none}
.alloc{display:grid;gap:1rem}
.alloc-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:.6rem;position:relative;padding:.9rem 1.1rem;border:1.5px solid var(--ink);overflow:hidden}
.alloc-row::before{content:"";position:absolute;inset:0 auto 0 0;width:calc(var(--p)*1%);background:var(--c);opacity:.16;transform-origin:left;transform:scaleX(0)}
.alloc-row.in::before{transform:scaleX(1);transition:transform 1.1s var(--ease)}
.alloc-row span{font-weight:500}
.alloc-row b{font-family:var(--display)}

/* ===== Footer ===== */
.ftr{background:var(--navy);color:#fff;padding:var(--sp-6) var(--pad) var(--sp-3);overflow:hidden}
.ftr-cta{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;padding-bottom:var(--sp-5);border-bottom:1px solid rgba(255,255,255,.18)}
.ftr-h{font-size:var(--t-xl);color:#fff}
.ftr-h .accent{color:var(--abobo)}
.ftr-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;padding:var(--sp-4) 0}
.ftr-cols h4{font-family:var(--display);font-size:var(--t-base);margin-bottom:.9rem}
.ftr-cols a,.ftr-cols p{display:block;color:rgba(255,255,255,.72);font-size:var(--t-sm);margin-bottom:.5rem}
.ftr-cols a:hover{color:#fff}
.ftr .todo{color:#ffb3bd}
.ftr-mark{font-family:var(--display);font-weight:800;font-size:clamp(8rem,34vw,28rem);line-height:.8;color:rgba(255,255,255,.07);letter-spacing:-.04em;margin:var(--sp-3) 0 0;text-align:center}
.ftr-bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-family:var(--mono);font-size:.72rem;color:rgba(255,255,255,.5);padding-top:var(--sp-3)}

/* ===== reveal ===== */
.reveal,.reveal-line>*{opacity:0}
.no-js .reveal,.no-js .reveal-line>*,.no-js .reveal-words .word{opacity:1!important;transform:none!important}

/* ===== Mobile nav ===== */
.mnav{position:fixed;inset:0;background:var(--navy);z-index:190;display:flex;flex-direction:column;justify-content:center;gap:1.2rem;padding:var(--pad);opacity:0;pointer-events:none;transition:opacity .4s}
.mnav.open{opacity:1;pointer-events:auto}
.mnav a{color:#fff;font-family:var(--display);font-size:var(--t-lg)}

/* ===== Responsive ===== */
@media (max-width:900px){
  .hdr-nav,.hdr .btn-give{display:none}
  .burger{display:flex}
  .hero{grid-template-columns:1fr;gap:1.5rem}
  .hero-title{grid-column:1}
  .hero-aside{grid-column:1;grid-row:auto}
  .hero-fig{aspect-ratio:16/10;max-height:42vh}
  .hero-radiant{width:70vw;opacity:.5}
  .cercle,.transp{grid-template-columns:1fr}
  .row.offset{padding-left:var(--pad)}
  .ftr-cols{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .tiers{grid-template-columns:1fr 1fr}
  .ftr-cols{grid-template-columns:1fr}
  .hero-meta{gap:1rem}
  .commune{width:84vw}
}
/* le scroll horizontal épinglé est désactivé en tactile/reduced (fallback empilé) */
@media (max-width:760px),(prefers-reduced-motion:reduce){
  .journey-pin{height:auto;overflow:visible;display:block}
  .journey-track{flex-direction:column;height:auto;gap:1.5rem;padding-block:var(--sp-5)}
  .commune,.jintro{width:100%}
  .commune-img{aspect-ratio:4/3}
  .kenburns{animation:none}
}
