/* ===========================================================
   DONDOU JEUNESSE ET MOUVEMENT
   École : afro-contemporain géométrique — blocs, motifs, énergie
   =========================================================== */
:root{
  --indigo:#1B2A6B;
  --indigo-d:#121e4d;
  --terra:#C44119;
  --terra-d:#9c3214;
  --sun:#F2B705;
  --green:#1E8A5A;
  --sand:#F6ECDA;
  --sand-2:#FBF5E8;
  --ink:#1c1408;
  --cream-line:#e6d9bf;
  --muted:#6f6450;
  --maxw:1180px;
  --disp:"Bricolage Grotesque",system-ui,sans-serif;
  --body:"Mulish",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--sand);color:var(--ink);line-height:1.7;font-size:17px;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--disp);font-weight:800;line-height:.98;letter-spacing:-.02em}
h1{font-size:clamp(2.8rem,7vw,5.6rem)}
h2{font-size:clamp(2rem,4.5vw,3.3rem)}
h3{font-size:1.4rem}
p{margin-bottom:1rem}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.lead{font-size:1.2rem}
.muted{color:var(--muted)}
section{padding:84px 0}
.tag{display:inline-block;font-family:var(--disp);font-weight:800;text-transform:uppercase;letter-spacing:.06em;font-size:.8rem;background:var(--sun);color:var(--indigo);padding:6px 14px;border-radius:999px}

/* pattern band (motif géométrique répété) */
.band{height:26px;background:
  repeating-linear-gradient(45deg,var(--terra) 0 14px,var(--sun) 14px 28px,var(--green) 28px 42px,var(--indigo) 42px 56px)}
.band.thin{height:14px}
.zig{height:34px;background:linear-gradient(135deg,var(--sun) 25%,transparent 25%) -34px 0,
  linear-gradient(225deg,var(--sun) 25%,transparent 25%) -34px 0,
  linear-gradient(315deg,var(--terra) 25%,transparent 25%),
  linear-gradient(45deg,var(--terra) 25%,transparent 25%);
  background-size:34px 34px;background-color:var(--indigo)}

.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--disp);font-weight:800;font-size:1rem;padding:15px 30px;border-radius:999px;border:3px solid var(--ink);cursor:pointer;transition:.16s;box-shadow:5px 5px 0 var(--ink)}
.btn:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--ink)}
.btn-terra{background:var(--terra);color:#fff}
.btn-sun{background:var(--sun);color:var(--indigo)}
.btn-ind{background:var(--indigo);color:#fff}
.btn-line{background:var(--sand);color:var(--ink)}

/* header */
.hdr{position:sticky;top:0;z-index:60;background:var(--indigo);color:#fff}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--disp);font-weight:800;font-size:1.18rem;color:#fff;line-height:1}
.brand img{width:42px;height:42px}
.brand small{display:block;font-size:.62rem;letter-spacing:.18em;color:var(--sun);font-family:var(--body);font-weight:700}
.nav-links{display:flex;gap:4px;list-style:none;align-items:center}
.nav-links a{padding:9px 14px;font-family:var(--disp);font-weight:700;font-size:.95rem;color:#fff;border-radius:999px;transition:.15s}
.nav-links a:hover,.nav-links a.active{background:var(--sun);color:var(--indigo)}
.nav-links .cta{background:var(--terra);color:#fff;border:2px solid #fff}
.burger{display:none;width:46px;height:44px;border:2px solid #fff;background:transparent;border-radius:10px;cursor:pointer}
.burger span{display:block;width:20px;height:2px;background:#fff;margin:4px auto}

/* hero */
.hero{background:var(--indigo);color:#fff;position:relative;overflow:hidden;padding:70px 0 90px}
.hero .blob{position:absolute;border-radius:50%;opacity:.9}
.hero .b1{width:300px;height:300px;background:var(--terra);top:-80px;right:-60px}
.hero .b2{width:180px;height:180px;background:var(--green);bottom:-50px;left:8%}
.hero .b3{width:90px;height:90px;background:var(--sun);top:40px;left:42%}
.hero .wrap{position:relative;z-index:2}
.hero h1{color:#fff}
.hero h1 .u{color:var(--sun)}
.hero h1 .o{-webkit-text-stroke:2px var(--sun);color:transparent}
.hero p{max-width:48ch;margin-top:18px;font-size:1.25rem;color:#f3eede}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;margin-top:30px}
.hero-photo{margin-top:50px;border:4px solid #fff;border-radius:24px;overflow:hidden;transform:rotate(-1.2deg);box-shadow:12px 12px 0 var(--terra)}
.hero-photo img{width:100%;height:clamp(240px,40vh,420px);object-fit:cover}

/* marquee valeurs */
.marq{background:var(--terra);color:#fff;overflow:hidden;border-top:4px solid var(--ink);border-bottom:4px solid var(--ink)}
.marq .track{display:flex;gap:40px;white-space:nowrap;animation:scroll 24s linear infinite;padding:14px 0;font-family:var(--disp);font-weight:800;text-transform:uppercase;font-size:1.15rem;letter-spacing:.04em}
.marq .track span{display:inline-flex;gap:40px}
.marq .track span::after{content:"★";color:var(--sun)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* mission */
.mission .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center}
.mission .ph{border:4px solid var(--ink);border-radius:20px;overflow:hidden;box-shadow:10px 10px 0 var(--green)}
.mission .ph img{width:100%;height:100%;object-fit:cover;min-height:300px}

/* piliers (3 actions) */
.piliers{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pilier{border:3px solid var(--ink);border-radius:22px;padding:30px;background:var(--sand-2);box-shadow:7px 7px 0 var(--ink);transition:.18s}
.pilier:hover{transform:translate(-3px,-3px);box-shadow:10px 10px 0 var(--ink)}
.pilier:nth-child(1){background:var(--sun)}
.pilier:nth-child(2){background:#fff}
.pilier:nth-child(3){background:var(--green);color:#fff}
.pilier .ic{width:60px;height:60px;border:3px solid var(--ink);border-radius:16px;display:grid;place-items:center;font-family:var(--disp);font-weight:800;font-size:1.6rem;margin-bottom:16px;background:#fff;color:var(--ink)}
.pilier h3{margin-bottom:8px}.pilier p{margin:0}

/* stat blocks */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:4px solid var(--ink);border-radius:22px;overflow:hidden}
.stats .s{padding:30px 22px;border-right:3px solid var(--ink)}
.stats .s:last-child{border-right:0}
.stats .s:nth-child(1){background:var(--indigo);color:#fff}
.stats .s:nth-child(2){background:var(--terra);color:#fff}
.stats .s:nth-child(3){background:var(--sun);color:var(--indigo)}
.stats .s:nth-child(4){background:var(--green);color:#fff}
.stats .n{font-family:var(--disp);font-weight:800;font-size:2.6rem;line-height:1}
.stats .l{font-weight:700;margin-top:6px;font-size:.92rem}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.step{position:relative;padding:26px;border:3px dashed var(--terra);border-radius:20px;background:var(--sand-2)}
.step .n{font-family:var(--disp);font-weight:800;font-size:2.2rem;color:var(--terra);line-height:1}
.step h3{margin:8px 0 6px}.step p{margin:0;color:var(--muted)}

/* CTA big */
.cta{background:var(--sun);border-top:4px solid var(--ink);border-bottom:4px solid var(--ink);text-align:center}
.cta h2{color:var(--indigo)}
.cta p{max-width:46ch;margin:14px auto 26px;font-weight:600;color:var(--indigo-d)}

/* partners */
.logos{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.logos .p{background:#fff;border:3px solid var(--ink);border-radius:14px;padding:14px 24px;font-family:var(--disp);font-weight:800;box-shadow:4px 4px 0 var(--ink)}

/* page hero */
.page-hero{background:var(--indigo);color:#fff;padding:60px 0;position:relative;overflow:hidden}
.page-hero .wrap{position:relative;z-index:2}
.page-hero h1{color:#fff}.page-hero h1 .u{color:var(--sun)}
.page-hero p{color:#f0ead9;max-width:60ch;margin-top:12px;font-size:1.15rem}
.page-hero .b{position:absolute;border-radius:50%}
.page-hero .pb1{width:200px;height:200px;background:var(--terra);top:-60px;right:-40px}
.page-hero .pb2{width:90px;height:90px;background:var(--green);bottom:-30px;left:10%}

/* generic */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split.rev .m{order:2}
.split .m{border:4px solid var(--ink);border-radius:20px;overflow:hidden;box-shadow:9px 9px 0 var(--sun)}
.split .m img{width:100%;height:100%;object-fit:cover;min-height:280px}
.checks{list-style:none;display:grid;gap:12px;margin-top:16px}
.checks li{display:flex;gap:12px;font-weight:700}
.checks .t{flex:0 0 auto;width:28px;height:28px;border-radius:50%;background:var(--green);color:#fff;display:grid;place-items:center;font-weight:900}
.prose{max-width:760px}
.prose h2{margin:28px 0 10px}
.prose p,.prose li{color:#3a3220}
.prose ul{padding-left:20px;margin:8px 0;display:grid;gap:6px}

/* contact / legal */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start}
.info{background:#fff;border:3px solid var(--ink);border-radius:18px;padding:20px;margin-bottom:16px;box-shadow:5px 5px 0 var(--ink)}
.info h3{margin-bottom:4px}.info p,.info a{margin:0;color:var(--muted)}.info a{color:var(--terra-d);font-weight:800}
.legal{background:var(--indigo);color:#fff;border:3px solid var(--ink);border-radius:18px;padding:24px;box-shadow:5px 5px 0 var(--terra)}
.legal h3{color:var(--sun);margin-bottom:10px}
.legal .row{display:flex;justify-content:space-between;gap:14px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.18);font-size:.92rem}
.legal .row:last-child{border:0}.legal .row span:first-child{color:#cfd5ea;font-weight:700}.legal .row span:last-child{font-weight:800;text-align:right}
.form-card{background:var(--sand-2);border:3px solid var(--ink);border-radius:20px;padding:28px;box-shadow:7px 7px 0 var(--green)}
.field{margin-bottom:15px}.field label{display:block;font-family:var(--disp);font-weight:800;font-size:.86rem;margin-bottom:6px}
.field input,.field textarea,.field select{width:100%;padding:13px 15px;border:2.5px solid var(--ink);border-radius:12px;font:inherit;background:#fff}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--terra)}
.field textarea{min-height:130px;resize:vertical}
.consent{display:flex;gap:9px;font-size:.84rem;color:var(--muted)}.consent input{width:auto;margin-top:4px}
.map{border:3px solid var(--ink);border-radius:16px;width:100%;height:280px;margin-top:16px}

/* footer */
.ftr{background:var(--indigo-d);color:#cfd5ea;padding:60px 0 26px}
.ftr-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1.2fr;gap:32px}
.ftr .brand{color:#fff;margin-bottom:12px}
.ftr h4{color:var(--sun);font-family:var(--disp);font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
.ftr ul{list-style:none;display:grid;gap:9px}.ftr a,.ftr li{color:#cfd5ea;font-size:.92rem}.ftr a:hover{color:var(--sun)}
.ftr-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-top:40px;padding-top:18px;border-top:1px solid rgba(255,255,255,.16);font-size:.84rem;color:#9aa2c4}
.ftr-bottom a{color:#cfd5ea}

.reveal{opacity:0;transform:translateY(20px);transition:.55s}.reveal.in{opacity:1;transform:none}

@media(max-width:920px){
  .mission .wrap,.split,.contact-grid{grid-template-columns:1fr}
  .split.rev .m{order:0}
  .piliers,.steps,.stats{grid-template-columns:1fr 1fr}
  .stats .s:nth-child(2){border-right:0}
  .stats .s{border-bottom:3px solid var(--ink)}
  .ftr-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .nav-links{position:fixed;inset:74px 0 auto 0;background:var(--indigo);flex-direction:column;align-items:stretch;padding:14px;gap:6px;transform:translateY(-130%);transition:.3s}
  .nav-links.open{transform:none}.burger{display:block}
  .piliers,.steps,.stats,.ftr-grid{grid-template-columns:1fr}
  .stats .s{border-right:0}
  section{padding:58px 0}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}.marq .track{animation:none}}
