:root{--rouge:#C0392B;--rouge-vif:#E74C3C;--vert:#27AE60;--vert-clair:#2ECC71;--or:#F39C12;--or-clair:#F1C40F;--terre:#8B5E3C;--nuit:#0D0D0D;--nuit2:#1A1A1A;--creme:#FDF6EC;--creme2:#F9F0E0;--texte:#1C1007;--texte-soft:#6B5B45}
*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}
body{font-family:'Outfit',sans-serif;background:var(--creme);color:var(--texte);overflow-x:hidden}

nav{position:fixed;top:0;left:0;right:0;z-index:500;padding:1.2rem 5%;display:flex;justify-content:space-between;align-items:center;background:rgba(13,13,13,.93);backdrop-filter:blur(14px);border-bottom:1px solid rgba(240,180,60,.12)}
.nav-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none}
.nav-logo-text{font-family:'Playfair Display',serif;font-size:1.3rem;color:#fff;letter-spacing:.02em}
.nav-logo-text span{color:var(--or)}
.nav-menu{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-menu a{text-decoration:none;color:rgba(255,255,255,.6);font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;transition:color .25s}
.nav-menu a:hover{color:var(--or)}
.nav-don{background:var(--rouge)!important;color:white!important;padding:.55rem 1.4rem!important;border-radius:2rem!important;font-weight:600!important}
.nav-don:hover{background:var(--rouge-vif)!important}
.nav-president{color:var(--rouge-vif)!important;font-weight:600!important}
.nav-president:hover{color:var(--rouge)!important}
.nav-menu a.nav-active{color:white!important;border-bottom:2px solid var(--or)}
.nav-menu a.nav-president.nav-active{color:var(--rouge-vif)!important;border-bottom-color:var(--rouge-vif)}
#back-top{position:fixed;bottom:2rem;right:2rem;width:2.6rem;height:2.6rem;border-radius:50%;background:var(--rouge);color:white;border:none;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(192,57,43,.4);opacity:0;transform:translateY(10px);transition:opacity .3s,transform .3s;pointer-events:none;z-index:999}
#back-top.visible{opacity:1;transform:translateY(0);pointer-events:auto}
#back-top:hover{background:var(--rouge-vif)}

.hero{min-height:100vh;background:var(--nuit);display:grid;grid-template-columns:45% 55%;overflow:hidden;position:relative}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 70% 50%,rgba(39,174,96,.06),transparent 60%),radial-gradient(ellipse 60% 80% at 20% 80%,rgba(192,57,43,.08),transparent 50%),var(--nuit)}
.hero-left{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:flex-start;padding:6rem 5% 3rem 7%}
.hero-badge{display:inline-flex;align-items:center;gap:.6rem;background:rgba(243,156,18,.12);border:1px solid rgba(243,156,18,.3);color:var(--or-clair);padding:.4rem 1rem;border-radius:2rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;margin-bottom:1.2rem;width:fit-content;opacity:0;animation:fadeUp .7s .1s forwards}
.hero-title{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,3.5vw,4rem);font-weight:700;line-height:1.08;color:#fff;margin-bottom:1rem;opacity:0;animation:fadeUp .7s .3s forwards}
.hero-title .ar{color:var(--rouge-vif)}.hero-title .ao{color:var(--or);font-style:italic}
.hero-lead{font-size:1rem;line-height:1.65;color:rgba(255,255,255,.65);max-width:500px;margin-bottom:1.5rem;font-weight:300;opacity:0;animation:fadeUp .7s .5s forwards}
.hero-lead strong{color:rgba(255,255,255,.9);font-weight:500}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap;opacity:0;animation:fadeUp .7s .7s forwards}
.btn-rouge{background:var(--rouge);color:white;padding:.9rem 2.2rem;border:none;border-radius:2.5rem;font-family:'Outfit',sans-serif;font-size:.95rem;font-weight:600;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;transition:all .3s}
.btn-rouge:hover{background:var(--rouge-vif);transform:translateY(-2px);box-shadow:0 10px 35px rgba(192,57,43,.4)}
.btn-outline{background:transparent;color:rgba(255,255,255,.85);padding:.9rem 2.2rem;border:1.5px solid rgba(255,255,255,.25);border-radius:2.5rem;font-family:'Outfit',sans-serif;font-size:.95rem;font-weight:500;cursor:pointer;text-decoration:none;transition:all .3s}
.btn-outline:hover{border-color:var(--or);color:var(--or)}
.hero-urgence{margin-top:1.5rem;padding:1rem 1.5rem;background:rgba(192,57,43,.15);border:1px solid rgba(192,57,43,.3);border-left:4px solid var(--rouge-vif);border-radius:.75rem;opacity:0;animation:fadeUp .7s .9s forwards}
.hero-urgence p{color:rgba(255,255,255,.75);font-size:.88rem;line-height:1.6}
.hero-urgence strong{color:#ff8080;font-weight:600}
.hero-right{position:relative;z-index:2;display:flex;align-items:flex-start;justify-content:center;padding:9rem 1.5rem 3rem 0}
.hero-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:1.5rem;overflow:hidden;width:100%;max-width:none;opacity:0;animation:fadeUp .7s .5s forwards}
.hero-map{height:200px;background:linear-gradient(160deg,#1a3a2a,#0d2218,#0a1a10);position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-map svg{width:120px;opacity:.6;filter:drop-shadow(0 0 20px rgba(39,174,96,.5))}
.map-pin{position:absolute;width:14px;height:14px;background:var(--rouge-vif);border:2px solid white;border-radius:50%;animation:ping 2s ease-in-out infinite}
.map-label{position:absolute;bottom:1rem;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.7);color:white;font-size:.7rem;padding:.3rem .8rem;border-radius:2rem;white-space:nowrap;letter-spacing:.08em;text-transform:uppercase}
.hero-card-tagline{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.6rem}
.hero-card-tag{font-size:.82rem;color:rgba(255,255,255,.7);padding:.35rem .9rem;background:rgba(255,255,255,.06);border-radius:2rem;display:inline-block;width:fit-content;letter-spacing:.03em}
.hero-card-tag--rouge{color:#ff8080;background:rgba(192,57,43,.2)}
.hs-item{text-align:center;padding:1rem;background:rgba(255,255,255,.04);border-radius:.75rem;border:1px solid rgba(255,255,255,.07)}
.hs-num{font-family:'Playfair Display',serif;font-size:2rem;font-weight:700;color:var(--or);line-height:1;display:block}
.hs-lbl{font-size:.72rem;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.08em;margin-top:.3rem;display:block;line-height:1.3}

.urgence{background:var(--rouge);padding:5rem 7% 3rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;position:relative;overflow:hidden}
.urgence::before{content:'';position:absolute;width:600px;height:600px;border-radius:50%;background:rgba(0,0,0,.1);right:-200px;top:-200px;pointer-events:none}
.urgence-content{position:relative;z-index:1}
.eyebrow{font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;color:rgba(255,255,255,.65);display:block;margin-bottom:1rem}
.urgence-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,3vw,3.2rem);font-weight:700;color:white;line-height:1.15;margin-bottom:1.5rem}
.urgence-title em{font-style:italic;color:var(--or-clair)}
.urgence-text{font-size:1rem;line-height:1.75;color:rgba(255,255,255,.82);font-weight:300;margin-bottom:1.5rem}
.urgence-big{display:inline-flex;align-items:center;gap:1rem;background:rgba(0,0,0,.2);border-radius:1rem;padding:1.25rem 1.75rem;margin-top:.5rem}
.ub-num{font-family:'Playfair Display',serif;font-size:3.5rem;font-weight:700;color:var(--or-clair);line-height:1}
.ub-txt{font-size:.88rem;color:rgba(255,255,255,.75);line-height:1.5;max-width:200px}
.urgence-facts{position:relative;z-index:1;display:flex;flex-direction:column;gap:1.25rem}
.fact-card{background:rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.12);border-radius:1rem;padding:1.5rem;display:flex;gap:1.25rem;align-items:flex-start;transition:background .3s}
.fact-card:hover{background:rgba(0,0,0,.3)}
.fact-icon{font-size:2rem;flex-shrink:0}
.fact-text h4{font-size:.95rem;font-weight:600;color:white;margin-bottom:.4rem}
.fact-text p{font-size:.83rem;color:rgba(255,255,255,.65);line-height:1.5}

.betafo{padding:8rem 7%;background:var(--creme2);position:relative;overflow:hidden}
.betafo::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(to right,var(--vert),var(--or),var(--rouge))}
/* Alignement titres : centré = sections émotionnelles (femmes, poème, témoignages, soutenir, connaître Betafo)
   à gauche = sections factuelles (urgence, projet, association, président) */
.section-eyebrow{font-size:.72rem;text-transform:uppercase;letter-spacing:.2em;color:var(--vert);font-weight:600;display:block;margin-bottom:1rem}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(1.55rem,2.2vw,2.5rem);font-weight:700;line-height:1.2;color:var(--texte)}
.section-title em{font-style:italic;color:var(--rouge)}
.betafo-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:4rem;align-items:start;max-width:1200px;margin:3rem auto 0}
.betafo-text h3{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700;color:var(--terre);margin-bottom:1.2rem}
.betafo-text p{font-size:.98rem;line-height:1.8;color:var(--texte-soft);margin-bottom:1rem;font-weight:300}
.betafo-text p strong{color:var(--texte);font-weight:500}
.betafo-hl{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}
.bh-item{display:flex;gap:1rem;align-items:flex-start;padding:1.1rem 1.3rem;background:white;border-radius:.75rem;border-left:3px solid var(--vert);transition:box-shadow .3s}
.bh-item:hover{box-shadow:0 6px 25px rgba(39,174,96,.1)}
.bh-icon{font-size:1.4rem;flex-shrink:0}
.bh-txt{font-size:.88rem;color:var(--texte-soft);line-height:1.5}
.bh-txt strong{color:var(--texte);font-weight:600;font-size:.92rem;display:block;margin-bottom:.2rem}
.landscape{position:relative}
.ls-main{background:linear-gradient(160deg,#1a4a2e,#2d6e40 25%,#4a8a5a 50%);border-radius:1.25rem;aspect-ratio:3/4;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;position:relative}
.ls-layers{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end}
.ls-sky{flex:1;background:linear-gradient(180deg,#0a1f2e,#1a3a4a 40%,#2d5a6e 70%,#4a7a8a);position:relative;overflow:hidden}
.ls-sky::before{content:'';position:absolute;width:150px;height:150px;background:radial-gradient(circle,rgba(255,220,80,.3),transparent 60%);top:15%;right:20%;border-radius:50%}
.ls-mtn{height:160px;background:linear-gradient(180deg,transparent,#1a3d20);position:relative;overflow:hidden}
.ls-mtn::before{content:'';position:absolute;bottom:0;left:0;right:0;height:100%;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 800 160' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolygon points='0,160 100,60 200,90 320,20 440,70 560,30 680,80 800,40 800,160' fill='%23234d2b'/%3E%3Cpolygon points='0,160 80,100 160,120 280,80 380,110 500,70 600,100 720,75 800,95 800,160' fill='%231a3d20'/%3E%3C/svg%3E") no-repeat bottom;background-size:cover}
.ls-fields{height:120px;background:linear-gradient(180deg,#1a3d20,#4a7a3a)}
.ls-caption{position:absolute;bottom:0;left:0;right:0;padding:1.5rem;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);color:white;z-index:1}
.ls-caption p{font-family:'Playfair Display',serif;font-style:italic;font-size:1rem;line-height:1.4}
.ls-caption cite{font-size:.7rem;opacity:.65;text-transform:uppercase;letter-spacing:.1em;margin-top:.4rem;display:block}

.femmes{background:var(--nuit);padding:1rem 7%;position:relative;overflow:hidden}
.femmes::before{content:'';position:absolute;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(192,57,43,.08),transparent);left:-200px;top:-200px;pointer-events:none}
.femmes-hdr{text-align:center;margin-bottom:1rem;position:relative;z-index:1}
.femmes-hdr .section-title{color:white}
.femmes-hdr .section-title em{color:var(--or-clair)}
.femmes-hdr .section-eyebrow{color:var(--rouge-vif)}
.femmes-hdr .sub{font-size:.9rem;color:rgba(255,255,255,.55);max-width:600px;margin:.4rem auto 0;font-weight:300;line-height:1.5}
.profils{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;max-width:1100px;margin:0 auto 1rem;position:relative;z-index:1}
.profil-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:1rem;overflow:hidden;transition:transform .4s,box-shadow .4s}
.profil-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.4)}
.profil-hdr{height:110px;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
.profil-card:nth-child(1) .profil-hdr{background:linear-gradient(145deg,#2d1b0e,#8B5E3C 50%,#c8963e)}
.profil-card:nth-child(2) .profil-hdr{background:linear-gradient(145deg,#0e2d1a,#27AE60 60%,#2ECC71)}
.profil-card:nth-child(3) .profil-hdr{background:linear-gradient(145deg,#1a0e0e,#C0392B 60%,#E74C3C)}
.profil-emoji{font-size:3.5rem;opacity:.6}
.profil-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.55;transition:opacity .4s}
.profil-card:hover .profil-img{opacity:.75}
.profil-age{position:absolute;top:1rem;right:1rem;background:rgba(0,0,0,.5);color:var(--or-clair);font-size:.7rem;font-weight:600;padding:.3rem .7rem;border-radius:2rem;text-transform:uppercase;letter-spacing:.1em}
.profil-body{padding:.7rem 1.1rem}
.profil-name{font-family:'Playfair Display',serif;font-size:1rem;font-weight:700;color:white;margin-bottom:.25rem}
.profil-lieu{font-size:.7rem;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.6rem}
.profil-story{font-size:.8rem;color:rgba(255,255,255,.65);line-height:1.55;font-weight:300}
.profil-story strong{color:rgba(255,255,255,.9);font-weight:500}
.stat-bar{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.06);border-radius:1rem;overflow:hidden;border:1px solid rgba(255,255,255,.06);position:relative;z-index:1}
.sb-item{background:rgba(255,255,255,.03);padding:1rem 1rem;text-align:center;transition:background .3s}
.sb-item:hover{background:rgba(255,255,255,.07)}
.sb-num{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:700;color:var(--rouge-vif);line-height:1;display:block;margin-bottom:.25rem}
.sb-lbl{font-size:.68rem;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.07em;line-height:1.35}

.projet{padding:1.5rem 7%;background:var(--creme)}
.projet-inner{max-width:1100px;margin:0 auto}
.projet-intro{font-size:1rem;line-height:1.85;color:var(--texte-soft);margin:1.25rem 0}
.projet-cols{display:grid;grid-template-columns:1.1fr 1fr;gap:3.5rem;align-items:start;margin-bottom:3rem}
.projet-foot-img{border-radius:1rem;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.12);width:75%}
.projet-foot-img img{width:100%;display:block;object-fit:cover}
.projet-historique{border-top:2px solid rgba(0,0,0,.08);padding-top:3rem;margin-top:1rem}
.projet-hist-eyebrow{font-size:.7rem;text-transform:uppercase;letter-spacing:.18em;color:var(--rouge);font-weight:600;display:block;margin-bottom:.6rem}
.projet-hist-title{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700;color:var(--texte);margin-bottom:1.25rem}
.projet-interview-img{border-radius:.75rem;overflow:hidden;margin:2rem 0;box-shadow:0 10px 40px rgba(0,0,0,.1)}
.projet-interview-img img{width:100%;display:block}
.projet-interview-caption{font-size:.75rem;color:var(--texte-soft);font-style:italic;text-align:center;margin-top:.5rem}
.projet-partenariat{margin-top:2.5rem;padding:1.25rem 1.5rem;background:rgba(192,57,43,.06);border-left:3px solid var(--rouge);border-radius:.5rem}
.projet-partenariat strong{color:var(--texte)}
.projet-steps{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}
.step{display:flex;gap:1.25rem;align-items:flex-start}
.step-num{width:36px;height:36px;background:var(--or);color:var(--nuit);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0}
.step-text h4{font-weight:600;font-size:.95rem;color:var(--texte);margin-bottom:.25rem}
.step-text p{font-size:.83rem;color:var(--texte-soft);line-height:1.5}
.collecte{background:white;border-radius:1.5rem;padding:2.5rem;box-shadow:0 15px 50px rgba(0,0,0,.06);border:1px solid rgba(0,0,0,.05)}
.collecte h3{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700;color:var(--texte);margin-bottom:.3rem}
.collecte-sub{font-size:.82rem;color:var(--texte-soft);margin-bottom:2rem}
.c-amount{font-family:'Playfair Display',serif;font-size:3.5rem;font-weight:700;color:var(--vert);line-height:1;margin-bottom:.25rem}
.c-goal{font-size:.88rem;color:var(--texte-soft);margin-bottom:1.5rem}
.progress-bar{height:10px;background:#EEE;border-radius:5px;overflow:hidden;margin-bottom:.75rem}
.progress-fill{height:100%;background:linear-gradient(to right,var(--vert),var(--vert-clair));border-radius:5px;width:0;transition:width 2s ease}
.progress-fill.go{width:67%}
.p-labels{display:flex;justify-content:space-between;font-size:.78rem;color:var(--texte-soft);margin-bottom:2rem}
.c-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem}
.cs-it{text-align:center;padding:1rem;background:var(--creme);border-radius:.75rem}
.cs-v{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700;color:var(--texte)}
.cs-k{font-size:.72rem;color:var(--texte-soft);text-transform:uppercase;letter-spacing:.08em}
.montants{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.5rem}
.m-btn{background:var(--creme);border:1.5px solid transparent;border-radius:.75rem;padding:.85rem .5rem;text-align:center;cursor:pointer;transition:all .3s;font-family:'Outfit',sans-serif}
.m-btn:hover,.m-btn.active{border-color:var(--rouge);background:rgba(192,57,43,.05)}
.m-euros{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700;color:var(--texte);display:block}
.m-impact{font-size:.65rem;color:var(--texte-soft);text-transform:uppercase;letter-spacing:.07em;margin-top:.2rem;display:block}
.btn-don{display:block;width:100%;padding:1.1rem;background:var(--rouge);color:white;border:none;border-radius:2.5rem;font-family:'Outfit',sans-serif;font-size:1rem;font-weight:600;cursor:pointer;text-align:center;text-decoration:none;transition:all .3s;letter-spacing:.04em;animation:glowPulse 2s ease-in-out infinite}
.btn-don:hover{background:var(--rouge-vif);transform:translateY(-2px);animation:none}
.c-trust{display:flex;justify-content:center;gap:1.5rem;margin-top:1rem;font-size:.72rem;color:var(--texte-soft)}
.c-trust span{display:flex;align-items:center;gap:.3rem}

.temoignages{background:var(--creme2);padding:1.5rem 7%}
.temo-hdr{text-align:center;margin-bottom:2.5rem}
.temo-hdr .section-title em{color:var(--vert)}
.temo-carousel-outer{position:relative;max-width:1200px;margin:0 auto}
.temo-carousel-wrap{overflow:hidden}
.temo-track{display:flex;gap:1.5rem;transition:transform .7s cubic-bezier(.4,0,.2,1)}
.temo-arrow{position:absolute;top:50%;transform:translateY(-50%);width:2.6rem;height:2.6rem;border-radius:50%;background:white;border:1px solid rgba(0,0,0,.1);box-shadow:0 4px 14px rgba(0,0,0,.1);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--texte);transition:all .25s;z-index:10}
.temo-arrow:hover{background:var(--rouge);color:white;border-color:var(--rouge);box-shadow:0 6px 20px rgba(192,57,43,.3)}
.temo-arrow-prev{left:-1.4rem}
.temo-arrow-next{right:-1.4rem}
.temo-card{background:white;border-radius:1.25rem;padding:2rem;box-shadow:0 4px 20px rgba(0,0,0,.04);border:1px solid rgba(0,0,0,.06);transition:box-shadow .3s;position:relative;flex-shrink:0;opacity:1!important;transform:none!important}
.temo-card:hover{box-shadow:0 15px 40px rgba(0,0,0,.1)}
.temo-card::before{content:'"';font-family:'Playfair Display',serif;font-size:8rem;position:absolute;top:-1.5rem;left:1.5rem;color:rgba(192,57,43,.1);line-height:1;pointer-events:none}
.temo-dots{display:flex;justify-content:center;gap:.6rem;margin-top:2rem}
.temo-dot{width:.55rem;height:.55rem;border-radius:50%;background:rgba(0,0,0,.15);border:none;cursor:pointer;padding:0;transition:background .3s,transform .3s}
.temo-dot.active{background:var(--rouge);transform:scale(1.3)}
.temo-stars{color:var(--or);font-size:.9rem;margin-bottom:1rem;letter-spacing:.1em}
.temo-text{font-size:.9rem;line-height:1.7;color:var(--texte-soft);font-style:italic;margin-bottom:1.5rem;position:relative;z-index:1}
.temo-author{display:flex;align-items:center;gap:.75rem}
.temo-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.temo-card:nth-child(1) .temo-avatar{background:linear-gradient(135deg,#8B5E3C,#c8963e)}
.temo-card:nth-child(2) .temo-avatar{background:linear-gradient(135deg,#1a3d20,#27AE60)}
.temo-card:nth-child(3) .temo-avatar{background:linear-gradient(135deg,#1a0e0e,#C0392B)}
.temo-card:nth-child(4) .temo-avatar{background:linear-gradient(135deg,#1a2a4a,#2980b9)}
.temo-card:nth-child(5) .temo-avatar{background:linear-gradient(135deg,#4a1a1a,#c0392b)}
.temo-card:nth-child(6) .temo-avatar{background:linear-gradient(135deg,#2c3e1a,#f39c12)}
.temo-name{font-weight:600;font-size:.88rem;color:var(--texte)}
.temo-role{font-size:.75rem;color:var(--texte-soft)}

.adhesion{background:var(--nuit);padding:8rem 7%}
.adh-hdr{text-align:center;margin-bottom:2.5rem}
.adh-hdr .section-title{color:white}
.adh-hdr .section-title em{color:var(--or-clair)}
.adh-hdr .section-eyebrow{color:var(--vert-clair)}
.adh-hdr p{color:rgba(255,255,255,.55);font-size:1rem;margin-top:.75rem;font-weight:300}
.adh-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;max-width:1100px;margin:0 auto}
.adh-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:1.25rem;padding:2rem 1.5rem;text-align:center;transition:all .4s;position:relative}
.adh-card:hover{background:rgba(255,255,255,.08);transform:translateY(-4px)}
.adh-card.featured{border-color:var(--or);background:rgba(243,156,18,.06)}
.adh-card.featured::before{content:'Recommandé';position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--or);color:var(--nuit);font-size:.65rem;font-weight:700;padding:.25rem .9rem;border-radius:2rem;text-transform:uppercase;letter-spacing:.1em;white-space:nowrap}
.adh-type{font-size:.72rem;text-transform:uppercase;letter-spacing:.15em;color:var(--or-clair);margin-bottom:.75rem;display:block}
.adh-prix{font-family:'Playfair Display',serif;font-size:2.5rem;font-weight:700;color:white;line-height:1;margin-bottom:.2rem}
.adh-prix sup{font-size:1.2rem}
.adh-prix .per{font-size:1rem;color:rgba(255,255,255,.4);font-weight:400}
.adh-desc{font-size:.82rem;color:rgba(255,255,255,.5);line-height:1.6;margin:1rem 0 1.5rem}
.adh-btn{display:block;padding:.7rem;background:rgba(255,255,255,.08);color:white;border:1px solid rgba(255,255,255,.15);border-radius:2rem;text-decoration:none;font-size:.82rem;font-weight:500;transition:all .3s;cursor:pointer}
.adh-card.featured .adh-btn{background:var(--or);border-color:var(--or);color:var(--nuit);font-weight:700}
.adh-btn:hover{background:var(--rouge);border-color:var(--rouge);color:white}

footer{background:#080808;padding:4rem 7% 2rem;border-top:1px solid rgba(243,156,18,.1)}
.ft-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:4rem;margin-bottom:3.5rem}
.ft-brand{font-family:'Playfair Display',serif;font-size:1.6rem;color:white;margin-bottom:.3rem}
.ft-brand span{color:var(--or)}
.ft-tag{font-size:.85rem;color:rgba(255,255,255,.4);line-height:1.7;margin-bottom:1.5rem}
.ft-mada{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.55);padding:.5rem 1rem;border-radius:2rem;font-size:.75rem}
.ft-col h4{font-size:.7rem;text-transform:uppercase;letter-spacing:.18em;color:var(--or);margin-bottom:1.25rem}
.ft-col ul{list-style:none;display:flex;flex-direction:column;gap:.65rem}
.ft-col a{text-decoration:none;color:rgba(255,255,255,.4);font-size:.85rem;transition:color .25s}
.ft-col a:hover{color:rgba(255,255,255,.8)}
.ft-bottom{border-top:1px solid rgba(255,255,255,.05);padding-top:1.75rem;display:flex;justify-content:space-between;align-items:center;font-size:.78rem;color:rgba(255,255,255,.25)}

.hero-photo-bg{display:none}
.hero-photo-img{width:100%;height:100%;object-fit:cover;object-position:center 40%}
.hero-photo-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,.82) 0%,rgba(0,0,0,.6) 50%,rgba(0,0,0,.35) 100%)}
.hero-card-photo{position:relative;height:180px;overflow:hidden;border-radius:.75rem .75rem 0 0}
.hero-card-img{width:100%;height:100%;object-fit:cover;object-position:center 55%}
.hero-card-photo-label{position:absolute;bottom:.75rem;left:.75rem;background:rgba(0,0,0,.65);color:white;font-size:.68rem;padding:.25rem .7rem;border-radius:2rem;letter-spacing:.08em;text-transform:uppercase}

/* PRÉSIDENT */
.president{padding:1.5rem 7%;background:var(--nuit);position:relative;overflow:hidden}
.president::before{content:'';position:absolute;inset:0;background:url("img-extracted-4.jpg") center/cover no-repeat;opacity:.08;pointer-events:none}
.president-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1.6fr;gap:3rem;align-items:center;position:relative;z-index:1}
.president-photo-wrap{position:relative}
.president-photo{width:100%;border-radius:1.25rem;overflow:hidden;aspect-ratio:3/2;position:relative}
.president-photo img{width:100%;height:100%;object-fit:cover;object-position:center 40%}
.president-photo-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 60%)}
.president-photo-caption{position:absolute;bottom:1.25rem;left:1.25rem;z-index:1}
.president-photo-caption .name{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;color:white}
.president-photo-caption .titre{font-size:.72rem;color:var(--or-clair);text-transform:uppercase;letter-spacing:.12em;margin-top:.15rem}
.president-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(243,156,18,.1);border:1px solid rgba(243,156,18,.25);color:var(--or-clair);padding:.35rem .9rem;border-radius:2rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;margin-top:1.25rem}
.president-content .section-eyebrow{color:var(--or)}
.president-content .section-title{color:white;margin:.4rem 0 .8rem}
.president-content .section-title em{color:var(--or-clair)}
.president-text{font-size:.85rem;line-height:1.65;color:rgba(255,255,255,.68);font-weight:300}
.president-text strong{color:rgba(255,255,255,.92);font-weight:500}
.president-text p{margin-bottom:.6rem}
.president-signature{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:1rem}
.president-sig-line{width:50px;height:2px;background:var(--or);border-radius:1px}
.president-sig-text{font-family:'Playfair Display',serif;font-style:italic;font-size:1rem;color:var(--or-clair)}

/* POÈME */
.poeme{padding:1.5rem 7%;background:var(--rouge);position:relative;overflow:hidden}
.poeme::before{content:'';position:absolute;width:700px;height:700px;border-radius:50%;background:rgba(0,0,0,.12);right:-200px;top:-100px;pointer-events:none}
.poeme::after{content:'"';font-family:'Playfair Display',serif;font-size:28rem;position:absolute;top:-8rem;left:-2rem;color:rgba(255,255,255,.04);line-height:1;pointer-events:none}
.poeme-inner{max-width:900px;margin:0 auto;position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;align-items:center}
.poeme-eyebrow{font-size:.72rem;text-transform:uppercase;letter-spacing:.22em;color:rgba(255,255,255,.55);display:block;margin-bottom:1rem}
.poeme-title{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,4vw,3.8rem);font-weight:700;color:white;line-height:1.1;margin-bottom:.4rem}
.poeme-subtitle{font-family:'Playfair Display',serif;font-style:italic;font-size:1.1rem;color:var(--or-clair);margin-bottom:3.5rem}
.poeme-strophes{display:flex;flex-direction:column;align-items:center;gap:2rem;margin-bottom:2.5rem}
.poeme-strophe{text-align:left;max-width:520px;width:100%}
.poeme-strophe h4{display:none}
.poeme-strophe p{font-size:.95rem;line-height:2;color:rgba(255,255,255,.85);font-style:italic;font-family:'Playfair Display',serif;white-space:pre-line;margin:0}
.poeme-refrain{margin-bottom:2.5rem;text-align:left;max-width:520px;width:100%;margin-left:auto;margin-right:auto}
.poeme-refrain h4{display:none}
.poeme-refrain p{font-size:.95rem;line-height:2;color:rgba(255,255,255,.85);font-family:'Playfair Display',serif;font-style:italic;white-space:pre-line;margin:0}
.poeme-author{display:flex;align-items:center;justify-content:center;gap:1rem}
.poeme-author-line{width:40px;height:1px;background:rgba(255,255,255,.3)}
.poeme-author-text{font-size:.82rem;color:rgba(255,255,255,.55);letter-spacing:.08em}
.ai-ph{background:linear-gradient(135deg,#0d0d0d,#1a1a1a);padding:1.25rem 1.5rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(243,156,18,.1)}
.ai-ph-info{display:flex;align-items:center;gap:.75rem}
.ai-avatar{width:38px;height:38px;background:linear-gradient(135deg,var(--rouge),var(--or));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem}
.ai-ph-name{font-family:'Playfair Display',serif;font-size:1rem;color:white;font-weight:700}
.ai-ph-status{font-size:.68rem;color:var(--vert-clair);display:flex;align-items:center;gap:.35rem}
.ai-ph-status::before{content:'';width:5px;height:5px;background:var(--vert-clair);border-radius:50%;display:inline-block;animation:ping 2s infinite}
.ai-close{background:rgba(255,255,255,.07);border:none;color:rgba(255,255,255,.6);width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:.9rem;transition:all .2s}
.ai-close:hover{background:rgba(255,255,255,.15);color:white}
.ai-msgs{flex:1;overflow-y:auto;padding:1.25rem;display:flex;flex-direction:column;gap:.85rem;max-height:380px;background:#141414}
.ai-msg{display:flex;gap:.6rem;animation:fadeUp .25s ease}
.ai-msg.user{flex-direction:row-reverse}
.ai-bubble{max-width:82%;padding:.8rem 1rem;border-radius:.9rem;font-size:.85rem;line-height:1.55}
.ai-msg.bot .ai-bubble{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.8);border-radius:.25rem .9rem .9rem .9rem}
.ai-msg.user .ai-bubble{background:var(--rouge);color:white;border-radius:.9rem .25rem .9rem .9rem}
.ai-input-row{padding:1rem 1.25rem;background:var(--nuit2);border-top:1px solid rgba(255,255,255,.05);display:flex;gap:.75rem;align-items:flex-end}
.ai-field{flex:1;padding:.65rem .95rem;background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.08);border-radius:1.5rem;font-family:'Outfit',sans-serif;font-size:.85rem;color:white;resize:none;outline:none;max-height:90px;transition:border-color .3s}
.ai-field::placeholder{color:rgba(255,255,255,.25)}
.ai-field:focus{border-color:var(--or)}
.ai-send{width:36px;height:36px;background:var(--rouge);border:none;border-radius:50%;color:white;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s}
.ai-send:hover{background:var(--rouge-vif);transform:scale(1.05)}
.ai-send:disabled{opacity:.4;cursor:not-allowed}
.dots{display:flex;gap:.3rem;align-items:center;padding:.3rem 0}
.dots span{width:5px;height:5px;background:var(--or);border-radius:50%;animation:bounce 1.2s ease-in-out infinite}
.dots span:nth-child(2){animation-delay:.2s}
.dots span:nth-child(3){animation-delay:.4s}

@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideUp{from{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}
@keyframes ping{0%,100%{box-shadow:0 0 0 0 rgba(39,174,96,.5)}50%{box-shadow:0 0 0 8px rgba(39,174,96,0)}}
@keyframes ripple{0%,100%{transform:scale(1);opacity:.2}50%{transform:scale(1.2);opacity:0}}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
@keyframes glowPulse{0%,100%{box-shadow:0 0 0 0 rgba(192,57,43,.4)}50%{box-shadow:0 0 25px 8px rgba(192,57,43,0)}}

.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

.hero,.urgence,.femmes,.projet,.temoignages,.association-section{min-height:100vh;scroll-margin-top:80px}
.urgence{align-content:start}
.femmes,.projet,.temoignages,.association-section{display:flex;flex-direction:column;justify-content:center}
@media(max-width:900px){.hero,.urgence,.femmes,.projet,.temoignages,.association-section{min-height:auto}}

@media(max-width:900px){
nav{padding:1rem 4%}.nav-menu{display:none}
.hero{grid-template-columns:1fr}.hero-right{padding:0 5% 3rem;justify-content:flex-start}.hero-left{padding:7rem 5% 2rem}
.urgence{grid-template-columns:1fr;padding:4rem 5%;gap:3rem}
.betafo{padding:5rem 5%}.betafo-grid{grid-template-columns:1fr}.landscape{display:none}
.femmes{padding:5rem 5%}.profils{grid-template-columns:1fr}.stat-bar{grid-template-columns:1fr 1fr}
.president{padding:5rem 5%}.president-inner{grid-template-columns:1fr;gap:3rem}
.poeme{padding:5rem 5%}.poeme-strophes{grid-template-columns:1fr}

.temoignages{padding:5rem 5%}.temo-grid{grid-template-columns:1fr}
.adhesion{padding:5rem 5%}.adh-cards{grid-template-columns:1fr 1fr}
footer{padding:3rem 5% 1.5rem}.ft-grid{grid-template-columns:1fr;gap:2rem}
.ft-bottom{flex-direction:column;gap:1rem;text-align:center}
.ai-panel{width:calc(100vw - 2rem);right:1rem}}
.budget-table{width:100%;border-collapse:collapse;margin:1.5rem 0}
.budget-table tr{border-bottom:1px solid rgba(0,0,0,.07)}
.budget-table td{padding:.65rem .4rem;font-size:.9rem;color:var(--texte)}
.budget-table td:last-child{text-align:right;font-weight:600;white-space:nowrap}
.budget-table tr.total-row{border-top:2px solid var(--rouge)}
.budget-table tr.total-row td{color:var(--rouge);font-size:1rem;font-weight:700;padding-top:.9rem}
.note-douane{font-size:.75rem;color:var(--texte-soft);font-style:italic;margin-top:.3rem}
.projet-don-cta{margin-top:2.5rem;padding:2rem;background:rgba(192,57,43,.06);border-top:3px solid var(--rouge);border-radius:.5rem}
.projet-don-cta>h3{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700;color:var(--rouge);margin:0 0 .4rem}
.projet-don-cta>h3 em{font-style:italic}
.projet-don-text{margin:0;font-size:.9rem;color:var(--texte-soft)}
.iban-block{background:rgba(0,0,0,.04);border-left:3px solid var(--or);border-radius:.5rem;padding:1rem 1.2rem;margin:1rem 0;font-size:.85rem;line-height:1.9}
.iban-num{font-family:monospace;font-size:.95rem;font-weight:700;letter-spacing:.04em;color:var(--texte)}
.don-section{margin-bottom:1.4rem}
.don-section-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.16em;color:var(--texte-soft);margin-bottom:.75rem;display:block}
.niveaux-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.55rem;margin:.5rem 0}
.niv-btn{border:1px solid rgba(0,0,0,.12);border-radius:.6rem;padding:.45rem .3rem;text-align:center;background:white;transition:all .25s;cursor:pointer}
.niv-btn:hover{border-color:var(--rouge);background:rgba(192,57,43,.04)}
.niv-label{font-size:.58rem;text-transform:uppercase;letter-spacing:.1em;color:var(--texte-soft);display:block;margin-bottom:.1rem}
.niv-montant{font-family:'Playfair Display',serif;font-size:.82rem;font-weight:700;color:var(--texte)}
.niv-btn.bronze .niv-label{color:#b87333}
.niv-btn.argent .niv-label{color:#888}
.niv-btn.or .niv-label{color:var(--or)}
.don-note{font-size:.75rem;color:var(--texte-soft);font-style:italic;text-align:center;margin-top:.75rem;line-height:1.55}
.soutenir-section{padding:1rem 7%;background:var(--nuit)}
.association-section{padding:1.5rem 7%;background:var(--creme)}
.assoc-inner{max-width:1100px;margin:0 auto}
.assoc-top{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;margin-bottom:2.5rem}
.assoc-intro{text-align:left}
.assoc-intro p{font-size:.9rem;color:var(--texte-soft);margin:.6rem 0 0;line-height:1.75}
.assoc-photo{border-radius:1.25rem;overflow:hidden;max-height:300px;position:relative;margin:0}
.assoc-photo img{width:100%;height:100%;object-fit:cover;display:block;transform:scaleX(-1)}
.assoc-photo-caption{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.6));color:white;font-size:.8rem;padding:1.5rem 1.5rem .9rem;letter-spacing:.05em}
.assoc-cols{display:grid;grid-template-columns:1fr 1fr;gap:3rem}
.assoc-cols>div:first-child{order:2}
.assoc-cols>div:last-child{order:1}
.assoc-col-title{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;color:var(--texte);margin-bottom:1.5rem;padding-bottom:.6rem;border-bottom:2px solid var(--rouge)}
.assoc-subgroup{margin-bottom:1.5rem}
.assoc-subgroup-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.18em;color:var(--texte-soft);display:block;margin-bottom:.7rem}
.member-card{padding:.6rem 0 .6rem .9rem;border-bottom:1px solid rgba(0,0,0,.05);border-left:2px solid var(--rouge)}
.member-card:last-child{border-bottom:none}
.member-role{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--rouge);font-weight:600;margin-bottom:.15rem}
.member-name{font-size:.9rem;color:var(--texte);font-weight:400}
.assoc-texte{margin-bottom:3rem;max-width:760px}
.assoc-texte-titre{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:var(--texte);margin-bottom:1.25rem}
.assoc-texte p{font-size:.95rem;color:var(--texte-soft);line-height:1.8;margin-bottom:.85rem}
.soutenir-inner{max-width:1100px;margin:0 auto;text-align:center}
.soutenir-inner .section-title{color:white;font-size:clamp(1.4rem,2vw,2rem);margin-bottom:.2rem}
.soutenir-inner .section-title em{color:var(--or-clair)}
.soutenir-inner .section-eyebrow{color:var(--vert-clair)}
.soutenir-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:1rem;text-align:left}
.soutenir-bloc{padding:0}
.soutenir-card-title{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:white;margin-bottom:1.25rem}
.soutenir-grid .iban-block{background:rgba(255,255,255,.06);border-left-color:var(--or-clair);color:rgba(255,255,255,.8)}
.soutenir-grid .iban-num{color:white}
.soutenir-grid .don-note{color:rgba(255,255,255,.45);text-align:left}
.soutenir-grid .niv-btn{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.15)}
.soutenir-grid .niv-btn:hover{border-color:var(--or);background:rgba(243,156,18,.08)}
.soutenir-grid .niv-label{color:rgba(255,255,255,.45)}
.soutenir-grid .niv-montant{color:white}
.projet-don-cta .soutenir-card-title{color:var(--texte)}
.projet-don-cta .soutenir-grid .niv-btn{background:white;border-color:rgba(0,0,0,.12)}
.projet-don-cta .soutenir-grid .niv-btn:hover{border-color:var(--rouge);background:rgba(192,57,43,.04)}
.projet-don-cta .soutenir-grid .niv-label{color:var(--texte-soft)}
.projet-don-cta .soutenir-grid .niv-montant{color:var(--texte)}
.projet-don-cta .soutenir-grid .iban-block{background:rgba(0,0,0,.04);border-left-color:var(--or);color:var(--texte)}
.projet-don-cta .soutenir-grid .iban-num{color:var(--texte)}
.projet-don-cta .soutenir-grid .don-note{color:var(--texte-soft);text-align:left}
.projet-don-cta .soutenir-grid .don-note a{color:var(--rouge)}
.contact-don{margin-top:1.25rem;background:rgba(0,0,0,.03);border-radius:.75rem;padding:1rem 1.2rem;font-size:.82rem;color:var(--texte-soft);line-height:1.7}
.contact-don a{color:var(--rouge);text-decoration:none}
.soutenir-subtitle{color:rgba(255,255,255,.6);font-size:.85rem;margin:.2rem auto .8rem;max-width:540px}
.soutenir-carte-icon{font-size:2rem;margin-bottom:.6rem}
.soutenir-card-desc{font-size:.82rem;color:rgba(255,255,255,.45);line-height:1.6;margin:.3rem 0 1rem}
.soutenir-grid .soutenir-bloc{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:1rem;padding:1.5rem}
.btn-soutenir-action{display:inline-block;margin-top:1.1rem;font-size:.78rem;color:var(--or-clair);text-decoration:none;letter-spacing:.06em;font-weight:500;transition:opacity .2s;text-transform:uppercase}
.btn-soutenir-action:hover{opacity:.65}
.btn-copier{display:block;width:100%;margin-top:.75rem;padding:.6rem 1rem;background:transparent;border:1px solid rgba(255,255,255,.18);border-radius:.5rem;color:rgba(255,255,255,.6);font-size:.8rem;cursor:pointer;transition:all .25s;font-family:'Outfit',sans-serif;box-sizing:border-box}
.btn-copier:hover,.btn-copier.copied{border-color:var(--or-clair);color:var(--or-clair)}
.twint-placeholder{margin-top:.6rem;padding:.55rem;background:rgba(255,255,255,.02);border-radius:.5rem;font-size:.75rem;color:rgba(255,255,255,.25);text-align:center;font-style:italic}
.form-don-wrap{margin-top:3rem;padding:1.25rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:1rem;max-width:700px;margin-left:auto;margin-right:auto;text-align:left}
.form-don-wrap>h3{font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:700;color:white;margin:0 0 .3rem}
.form-don-wrap>p{font-size:.82rem;color:rgba(255,255,255,.45);margin-bottom:1.25rem}
.form-don{display:flex;flex-direction:column;gap:.5rem}
.form-don .btn-rouge{padding:.55rem 1.6rem;font-size:.82rem;align-self:flex-start}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.form-don input,.form-don select,.form-don textarea{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:.5rem;padding:.55rem .9rem;font-family:'Outfit',sans-serif;font-size:.875rem;color:white;width:100%;box-sizing:border-box;transition:border-color .2s}
.form-don input::placeholder,.form-don textarea::placeholder{color:rgba(255,255,255,.3)}
.form-don input:focus,.form-don select:focus,.form-don textarea:focus{outline:none;border-color:var(--or-clair)}
.form-don select option{background:#1a1a2e;color:white}
.form-don textarea{resize:vertical;min-height:80px}
.form-note{font-size:.72rem;color:rgba(255,255,255,.25);font-style:italic;margin-top:.75rem;text-align:center;line-height:1.55}
.form-note a{color:rgba(255,255,255,.45)}
.budget-details{margin-top:3rem;border-top:1px solid rgba(255,255,255,.07);padding-top:1.5rem}
.budget-details summary{font-size:.75rem;color:rgba(255,255,255,.3);cursor:pointer;letter-spacing:.1em;text-transform:uppercase;list-style:none;text-align:center;user-select:none}
.budget-details summary::-webkit-details-marker{display:none}
.budget-details summary::after{content:' ↓'}
.budget-details[open] summary::after{content:' ↑'}
.budget-details .budget-table{margin-top:1rem;max-width:540px;margin-left:auto;margin-right:auto}
.budget-details .budget-table tr{border-bottom-color:rgba(255,255,255,.06)}
.budget-details .budget-table td{color:rgba(255,255,255,.55)}
.budget-details .budget-table tr.total-row{border-top-color:rgba(255,255,255,.2)}
.budget-details .budget-table tr.total-row td{color:var(--or-clair)}
.budget-details .note-douane{color:rgba(255,255,255,.25);text-align:center}
.soutenir-main-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}
.soutenir-choix-bloc{display:flex;align-items:flex-start;gap:0;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:1rem;padding:.9rem 1.25rem;margin-bottom:0;text-align:left}
.soutenir-choix-col{flex:1}
.soutenir-choix-col .soutenir-card-title{font-size:1.3rem;margin-bottom:.75rem;color:var(--rouge-vif)}
.soutenir-choix-sep{width:1px;background:rgba(255,255,255,.1);margin:0 1.5rem;align-self:stretch}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
#urgence,#femmes,#poeme,#projet,#soutenir,#association,#temoignages,#president{scroll-margin-top:68px}
.step-badge{display:inline-flex;align-items:center;justify-content:center;width:1.6rem;height:1.6rem;border-radius:50%;background:var(--rouge);color:#fff;font-family:'Outfit',sans-serif;font-size:.85rem;font-weight:700;flex-shrink:0;margin-right:.5rem}
.step-arrow{display:inline-flex;align-items:center;justify-content:center;background:var(--rouge);color:#fff;font-family:'Outfit',sans-serif;font-size:.85rem;font-weight:700;flex-shrink:0;margin-right:.6rem;padding:.3rem .7rem .3rem .55rem;border-radius:4px 20px 20px 4px;clip-path:polygon(0 0,70% 0,100% 50%,70% 100%,0 100%,0 0);min-width:2.2rem;min-height:1.6rem}
.soutenir-card-title-row{display:flex;align-items:center;margin-bottom:.5rem}
.soutenir-card-title-row h3{font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:700;margin:0 0 .3rem}
.soutenir-divider{border:none;border-top:1px solid rgba(255,255,255,.1);margin:1.5rem 0}
.soutenir-main-grid .form-don-wrap{margin:0;max-width:none;padding:1.25rem}
.soutenir-main-grid .soutenir-bloc{text-align:left;padding:1.25rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:1rem}
.paiement-section{margin-top:1.5rem;padding:1.5rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:1rem}
.paiement-title{font-family:'Playfair Display',serif;font-size:1rem;font-weight:700;color:white;margin:0 0 1rem;display:flex;align-items:center;gap:.5rem}
.paiement-inner{display:grid;grid-template-columns:1fr auto auto;gap:1rem;align-items:center}
.soutenir-main-grid .iban-block{background:rgba(255,255,255,.06);border-left-color:var(--or-clair);color:rgba(255,255,255,.8)}
.soutenir-main-grid .iban-num{color:white}
@media(max-width:768px){.form-row{grid-template-columns:1fr}.soutenir-main-grid{grid-template-columns:1fr}.paiement-inner{grid-template-columns:1fr}}
.projet-carousel{position:relative;width:100%;aspect-ratio:16/9;margin:0 0 2.5rem;border-radius:12px;overflow:hidden;box-shadow:0 12px 32px rgba(13,13,13,.18);background:var(--nuit)}
.projet-carousel-track{position:absolute;inset:0}
.projet-carousel-slide{position:absolute;inset:0;opacity:0;transition:opacity .8s ease-in-out}
.projet-carousel-slide.is-active{opacity:1}
.projet-carousel-slide img{width:100%;height:100%;object-fit:cover;display:block}
.projet-carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);width:2.6rem;height:2.6rem;border-radius:50%;border:1px solid rgba(255,255,255,.5);background:rgba(13,13,13,.35);color:white;font-size:1.2rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .25s,border-color .25s,transform .25s;z-index:2;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.projet-carousel-arrow:hover{background:rgba(192,57,43,.75);border-color:var(--or)}
.projet-carousel-arrow.prev{left:1rem}
.projet-carousel-arrow.next{right:1rem}
.projet-carousel-dots{position:absolute;left:50%;bottom:1rem;transform:translateX(-50%);display:flex;gap:.5rem;z-index:2}
.projet-carousel-dot{width:.6rem;height:.6rem;border-radius:50%;border:1px solid rgba(255,255,255,.7);background:rgba(255,255,255,.25);cursor:pointer;padding:0;transition:background .25s,transform .25s}
.projet-carousel-dot.is-active{background:var(--or);border-color:var(--or);transform:scale(1.2)}
.projet-carousel-dot:hover{background:rgba(243,156,18,.7)}
@media(max-width:600px){.projet-carousel-arrow{width:2.2rem;height:2.2rem;font-size:1rem}.projet-carousel-arrow.prev{left:.5rem}.projet-carousel-arrow.next{right:.5rem}}
.hero-carousel{position:relative;width:100%;aspect-ratio:16/9;max-height:550px;border-radius:12px;overflow:hidden;background:#0D0D0D;box-shadow:0 12px 32px rgba(0,0,0,.45)}
.hero-carousel-track{position:absolute;inset:0}
.hero-carousel-slide{position:absolute;inset:0;opacity:0;transition:opacity .4s ease-in-out;z-index:1}
.hero-carousel-slide.is-active{opacity:1;transition:opacity .4s ease-in-out .4s;z-index:2}
.hero-carousel-slide img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;background:#0D0D0D}
.hero-carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);width:2.75rem;height:2.75rem;border-radius:50%;border:1px solid rgba(255,255,255,.55);background:rgba(13,13,13,.35);color:white;font-size:1.15rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .25s,border-color .25s,transform .25s;z-index:4;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.hero-carousel-arrow:hover{background:rgba(192,57,43,.75);border-color:var(--or);transform:translateY(-50%) scale(1.1)}
.hero-carousel-arrow.prev{left:.75rem}
.hero-carousel-arrow.next{right:.75rem}
.hero-carousel-dots{position:absolute;left:50%;bottom:1rem;transform:translateX(-50%);display:flex;gap:.55rem;z-index:4}
.hero-carousel-dot{width:12px;height:12px;border-radius:50%;border:1px solid rgba(255,255,255,.85);background:rgba(255,255,255,.35);cursor:pointer;padding:0;transition:background .25s,transform .25s;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.hero-carousel-dot.is-active{background:var(--or);border-color:var(--or);transform:scale(1.2)}
.hero-carousel-dot:hover{background:rgba(243,156,18,.8)}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem;margin-top:1.5rem;opacity:0;animation:fadeUp .7s 1.1s forwards}
.hero-cta-bubble{margin-top:1.25rem;padding:1rem 1.25rem;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:1rem;box-shadow:0 8px 24px rgba(0,0,0,.25);display:flex;align-items:center;justify-content:center;gap:.85rem;width:fit-content;opacity:0;animation:fadeUp .7s 1.3s forwards;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.hero-cta-arrow{color:var(--or);font-size:1.4rem;line-height:1;animation:heroArrowBounce 1.6s ease-in-out infinite}
@keyframes heroArrowBounce{0%,100%{transform:translateY(0);opacity:.7}50%{transform:translateY(5px);opacity:1}}
.hero-stat{padding:.55rem .5rem;border-radius:.5rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);text-align:center}
.hero-stat-num{font-family:'Playfair Display',serif;font-size:clamp(.9rem,1.5vw,1.4rem);font-weight:700;line-height:1;letter-spacing:-.02em}
.hero-stat-num--or{color:var(--or)}
.hero-stat-num--rouge{color:var(--rouge-vif)}
.hero-stat-num-small{font-size:.5em;font-weight:600;color:rgba(255,255,255,.7);font-family:'Outfit',sans-serif}
.hero-stat-label{margin-top:.3rem;font-size:.55rem;color:rgba(255,255,255,.75);text-transform:uppercase;letter-spacing:.06em;line-height:1.3}
@media(max-width:600px){.hero-stats{grid-template-columns:1fr;gap:.4rem}.hero-stat{padding:.5rem}}
@media(max-width:1100px){.hero{grid-template-columns:1fr}.hero-left{padding:7rem 5% 2rem}.hero-right{padding:0 5% 3rem;justify-content:flex-start}.hero-carousel{max-height:none;aspect-ratio:16/9}}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:.5rem;width:2.6rem;height:2.6rem;flex-direction:column;justify-content:space-between}
.nav-toggle span{display:block;width:1.6rem;height:2px;background:var(--or);border-radius:2px;transition:transform .3s,opacity .3s}
.nav-toggle.is-open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle.is-open span:nth-child(2){opacity:0}
.nav-toggle.is-open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.nav-mobile{position:fixed;top:0;right:-100%;width:min(85vw,320px);height:100vh;background:var(--nuit);z-index:1000;padding:5rem 1.5rem 2rem;transition:right .35s ease;box-shadow:-12px 0 40px rgba(0,0,0,.5);overflow-y:auto}
.nav-mobile.is-open{right:0}
.nav-mobile ul{list-style:none;display:flex;flex-direction:column;gap:.4rem}
.nav-mobile a{display:block;padding:.85rem 1rem;color:rgba(255,255,255,.85);text-decoration:none;font-weight:500;border-radius:.5rem;transition:background .2s,color .2s}
.nav-mobile a:hover,.nav-mobile a:focus{background:rgba(255,255,255,.06);color:var(--or)}
.nav-mobile a.nav-don{background:var(--rouge);color:white;text-align:center;margin-top:.5rem}
.nav-mobile a.nav-don:hover{background:var(--rouge-vif);color:white}
.nav-mobile-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:999;opacity:0;transition:opacity .3s;pointer-events:none}
.nav-mobile-overlay.is-visible{opacity:1;pointer-events:auto}
@media(max-width:900px){
.nav-toggle{display:flex}
.hero-title{font-size:clamp(1.9rem,7vw,2.6rem)}
.hero-lead{font-size:.95rem;max-width:100%}
.hero-stat-num{font-size:clamp(1rem,4.5vw,1.4rem)}
.hero-stat-label{font-size:.6rem}
.hero-cta-bubble{width:100%;justify-content:center}
.section-title{font-size:clamp(1.6rem,5.5vw,2.4rem)!important}
section,section *{max-width:100%}
img,video,iframe{max-width:100%;height:auto}
table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
.budget-table{display:table}
}
@media(max-width:600px){
.hero-cta-bubble{padding:.85rem 1rem;gap:.5rem;width:100%}
.projet-cols{grid-template-columns:1fr!important;gap:2rem}
.hero-urgence{padding:.85rem 1rem}
.hero-urgence p{font-size:.82rem}
}

/* ═══ PAGE INTÉRIEURE — moyens-action.html ═══ */
.page-hero{padding:8rem 7% 3rem;background:var(--creme2);text-align:center}
.page-hero-inner{max-width:800px;margin:0 auto}
.page-hero-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,5vw,3.5rem);color:var(--texte);margin:.5rem 0 1rem;font-weight:700}
.page-hero-title em{color:var(--rouge);font-style:italic}
.page-hero-sub{font-size:1rem;color:var(--texte-soft);max-width:600px;margin:0 auto;line-height:1.6}
.ma-bloc{padding:3rem 7%;background:var(--creme)}
.ma-bloc-alt{background:var(--creme2)}
.ma-bloc-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1.3fr;gap:3rem;align-items:center}
.ma-bloc-alt .ma-bloc-inner{grid-template-columns:1.3fr 1fr}
.ma-bloc-alt .ma-bloc-photo{order:2}
.ma-bloc-alt .ma-bloc-text{order:1}
.ma-bloc-photo img{width:100%;border-radius:1rem;aspect-ratio:4/3;object-fit:cover;display:block}
.ma-bloc-alt .ma-bloc-photo img{aspect-ratio:auto;height:auto;object-fit:initial}
.ma-bloc-text h2{margin:.4rem 0 1rem}
.ma-bloc-text p{font-size:.95rem;line-height:1.7;color:var(--texte-soft);margin-bottom:1.25rem}
.ma-bloc-list{list-style:none;padding:0;margin:0 0 1.5rem}
.ma-bloc-list li{font-size:.95rem;line-height:1.7;color:var(--texte-soft);padding-left:1.25rem;position:relative;margin-bottom:.5rem}
.ma-bloc-list li::before{content:'→';position:absolute;left:0;color:var(--rouge);font-weight:600}
.ma-bloc-text .btn-primary{display:inline-block;background:var(--rouge);color:#fff;padding:.7rem 1.6rem;border-radius:2rem;text-decoration:none;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;transition:background .25s}
.ma-bloc-text .btn-primary:hover{background:var(--rouge-vif)}
@media(max-width:900px){
  .ma-bloc{padding:2rem 6%}
  .ma-bloc-inner,.ma-bloc-alt .ma-bloc-inner{grid-template-columns:1fr;gap:1.5rem}
  .ma-bloc-alt .ma-bloc-photo{order:1}
  .ma-bloc-alt .ma-bloc-text{order:2}
  .page-hero{padding:6rem 6% 2rem}
}

/* ═══ Carrousel affiches concerts ═══ */
.concerts{padding:4rem 7%;background:var(--creme)}
.concerts-hdr{text-align:center;margin-bottom:2.5rem}
.concerts-hdr h2{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,4vw,2.5rem);color:var(--texte);font-weight:700;margin-top:.4rem}
.concerts-hdr h2 em{color:var(--rouge);font-style:italic}
.aff-carousel{max-width:1100px;margin:0 auto;position:relative}
.aff-trio{display:grid;grid-template-columns:1fr 1.5fr 1fr;gap:1.5rem;align-items:center}
.aff-cell{display:flex;justify-content:center}
.aff-cell img{width:100%;height:auto;border-radius:.75rem;display:block;box-shadow:0 8px 20px rgba(0,0,0,.15);transition:transform .3s,box-shadow .3s}
.aff-cell.aff-feature img{box-shadow:0 16px 40px rgba(0,0,0,.28)}
.aff-arrow{position:absolute;top:50%;transform:translateY(-50%);background:var(--rouge);color:#fff;border:none;width:44px;height:44px;border-radius:50%;font-size:1.2rem;cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center;transition:background .25s}
.aff-arrow:hover{background:var(--rouge-vif)}
.aff-arrow.prev{left:-1.5rem}
.aff-arrow.next{right:-1.5rem}
.aff-dots{display:flex;justify-content:center;gap:.6rem;margin-top:1.75rem}
.aff-dot{width:10px;height:10px;border-radius:50%;background:rgba(0,0,0,.2);border:none;cursor:pointer;padding:0;transition:background .25s}
.aff-dot.active{background:var(--rouge)}
@media(max-width:700px){
  .concerts{padding:2.5rem 6%}
  .aff-trio{grid-template-columns:1fr;gap:1rem}
  .aff-arrow.prev{left:.5rem}
  .aff-arrow.next{right:.5rem}
}

/* ═══ Bloc Repas — image centrée sous titre, texte à sa gauche ═══ */
.ma-repas-grid{display:grid;grid-template-columns:1fr 450px 1fr;gap:2.5rem;align-items:start;max-width:100%}
.ma-repas-photo{width:450px}
.ma-repas-photo img{width:100%;height:auto;border-radius:1rem;display:block;box-shadow:0 8px 24px rgba(0,0,0,.15)}
.ma-repas-text{text-align:left;align-self:start}
.ma-repas-text p{font-size:.98rem;line-height:1.75;color:var(--texte-soft);margin-bottom:1rem}
.ma-repas-text p:last-child{margin-bottom:0;font-size:1.05rem;color:var(--rouge)}
.ma-repas-spacer{width:100%}
@media(max-width:900px){
  .ma-repas-grid{grid-template-columns:1fr;gap:1.5rem}
  .ma-repas-photo{width:100%;max-width:450px;margin:0 auto;order:-1}
  .ma-repas-spacer{display:none}
}

/* ═══ Drapeau Madagascar (SVG inline) ═══ */
.flag-mg{display:inline-block;width:1.6em;height:1.07em;vertical-align:-.18em;border-radius:2px;border:1px solid rgba(0,0,0,.25);margin-right:.3em;flex-shrink:0;background:#fff}
