:root{
  --bg:#F7F5F0; --surface:#FFFFFF; --ink:#14201C; --muted:#5C6B63;
  --line:#E7E3DA; --teal:#0B5D4E; --teal-d:#094A3F; --teal-soft:#E3F0EB; --coral:#FF6B2C;
  --orange:#FF6B2C; --orange-d:#E85A1E;
  --wa:#1F8A4C; --wa-d:#156336;
  --a:#0B5D4E; --a-bg:#E3F0EB; --b:#8A5A0B; --b-bg:#FAEEDA; --c:#A32D2D; --c-bg:#FCEBEB;
  --r:12px;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--teal)}
.skip{position:absolute;left:-999px}
.skip:focus{left:8px;top:8px;background:#fff;padding:8px;border-radius:8px;z-index:99}

/* top nav */
.nav{background:var(--ink);color:#EAF0ED;padding:13px 22px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.nav .brand{display:inline-flex;align-items:center;gap:9px;text-decoration:none}
.nav .brand-mark{width:26px;height:29px;display:block;flex:0 0 auto}
.nav .brand-word{font-size:19px;font-weight:800;letter-spacing:-.4px;line-height:1}
.nav .brand-word .w-ink{color:#F7F5F0}
.nav .brand-word .w-teal{color:#39B58C}
.nav .brand-word .w-orange{color:var(--orange)}
.nav .tag{font-size:11.5px;color:#9DB3AB;border:1px solid #2E433B;border-radius:999px;padding:2px 10px}
.nav .spacer{flex:1}
.nav a.link{color:#C7D6D0;text-decoration:none;font-size:13.5px;font-weight:600}
.nav a.link:hover{color:#fff}
.nav a.link.active{color:#6FD7B6}

.container{max-width:1180px;margin:0 auto;padding:20px}

/* hero / presentation */
.hero{max-width:1180px;margin:0 auto;padding:34px 20px 8px}
.hero .eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:1.6px;color:var(--teal);font-weight:700;margin:0 0 8px}
.hero h1{font-size:40px;line-height:1.06;margin:0 0 8px;font-weight:700;letter-spacing:-.5px}
.hero .subtitle{font-size:18px;color:var(--ink);font-weight:600;margin:0 0 14px;opacity:.85}
.hero .presentation{font-size:16px;color:var(--muted);max-width:760px;margin:0 0 18px;line-height:1.6}
.hl{display:flex;flex-wrap:wrap;gap:9px;margin:0 0 22px}
.hl span{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--teal);background:var(--teal-soft);border:1px solid #CFE7DF;border-radius:999px;padding:6px 13px;font-weight:600}
.hl span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--orange)}
.cta-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.btn{font-family:inherit;cursor:pointer;border:none;border-radius:10px;font-size:15px;font-weight:600;padding:12px 22px;text-decoration:none;display:inline-flex;align-items:center;gap:9px;transition:.14s}
.btn-primary{background:var(--teal);color:#fff}
.btn-primary:hover{background:var(--teal-d)}
.btn-ghost{background:#fff;border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--muted)}
.hero-rule{max-width:1180px;margin:26px auto 0;padding:0 20px}
.hero-rule hr{border:none;border-top:1px solid var(--line);margin:0}

/* tool layout */
.tool-head{max-width:1180px;margin:0 auto;padding:26px 20px 0}
.tool-head .eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:1.4px;color:var(--teal);font-weight:700;margin:0 0 4px}
.tool-head h2{font-size:22px;margin:0 0 4px;font-weight:700}
.tool-head .sub{font-size:14px;color:var(--muted)}
.wrap{max-width:1180px;margin:0 auto;padding:18px 20px 40px;display:grid;grid-template-columns:340px 1fr;gap:20px;align-items:start}
@media(max-width:840px){.wrap{grid-template-columns:1fr}}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:18px}
.panel.sticky{position:sticky;top:16px}
@media(max-width:840px){.panel.sticky{position:static}}
.eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:1.4px;color:var(--teal);font-weight:700;margin:0 0 4px}
h3.block{font-size:15px;margin:0 0 14px;font-weight:600}
label.fld{display:block;font-size:12px;font-weight:600;color:var(--muted);margin:14px 0 5px}
select{width:100%;padding:9px 10px;border:1px solid var(--line);border-radius:9px;background:#fff;font-size:14px;color:var(--ink)}
select:focus,button:focus-visible,a:focus-visible,.chip input:focus-visible+span,summary:focus-visible{outline:2px solid var(--teal);outline-offset:1px}
.chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:5px}
.chip{position:relative;cursor:pointer;user-select:none}
.chip input{position:absolute;opacity:0;inset:0;cursor:pointer}
.chip span{display:inline-block;padding:6px 11px;border:1px solid var(--line);border-radius:999px;font-size:12.5px;background:#fff;color:var(--muted);transition:.12s}
.chip input:checked+span{background:var(--teal-soft);border-color:var(--teal);color:var(--teal);font-weight:600}
.actions{display:flex;gap:8px;margin-top:18px}
button{font-family:inherit;cursor:pointer;border:none;border-radius:9px;font-size:13.5px;font-weight:600;padding:10px 14px}
.btn-reset{background:#fff;border:1px solid var(--line);color:var(--muted)}
.btn-reset:hover{border-color:var(--muted)}
.results-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:10px;flex-wrap:wrap}
.results-head .sub{font-size:12.5px;color:var(--muted)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:15px 16px;margin-bottom:11px}
.card.top{border-color:var(--orange);box-shadow:0 0 0 1px var(--orange) inset}
.card .row1{display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.card h4{font-size:15px;margin:0;font-weight:600}
.card .type{font-size:11.5px;color:var(--muted)}
.badge{font-size:10.5px;font-weight:700;border-radius:999px;padding:2px 8px;letter-spacing:.3px}
.badge.A{background:var(--a-bg);color:var(--a)} .badge.B{background:var(--b-bg);color:var(--b)} .badge.C{background:var(--c-bg);color:var(--c)}
.pill{font-size:10.5px;font-weight:600;border-radius:999px;padding:2px 8px;background:#EFEAE2;color:#7A5B1E}
.pill.free{background:var(--a-bg);color:var(--a)} .pill.nd{background:#E7EEFB;color:#1B4F8A}
.card .apport{font-size:13.5px;margin:8px 0 6px;color:#26342E}
.card .why{font-size:12px;color:var(--muted)}
.card .why b{color:var(--teal);font-weight:600}
.card .foot{margin-top:8px;font-size:12.5px}
.empty{padding:30px;text-align:center;color:var(--muted);font-size:14px}
.wa{margin-top:18px}
.wa textarea{width:100%;min-height:150px;border:1px solid var(--line);border-radius:10px;padding:12px;font-size:13px;font-family:ui-monospace,Menlo,Consolas,monospace;color:var(--ink);background:#FBFCFB;resize:vertical}
.wa-actions{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.btn-copy{background:var(--teal);color:#fff} .btn-copy:hover{background:var(--teal-d)}
.btn-wa{background:var(--wa);color:#fff;text-decoration:none;display:inline-flex;align-items:center;gap:7px;border-radius:9px;padding:10px 14px;font-size:13.5px;font-weight:600}
.btn-wa:hover{background:var(--wa-d)}
.copied{font-size:12.5px;color:var(--a);align-self:center;opacity:0;transition:.2s}
.copied.show{opacity:1}
.note{font-size:11.5px;color:var(--muted);margin-top:8px}

/* about page */
.about-intro{max-width:820px;margin:6px 0 26px;font-size:16px;color:var(--muted);line-height:1.65}
.about-intro p{margin:0 0 12px}
.about-intro .mission{color:var(--ink);font-weight:600;border-left:3px solid var(--teal);padding-left:14px;border-radius:0}
.acc-title{font-size:14px;text-transform:uppercase;letter-spacing:1.2px;color:var(--teal);font-weight:700;margin:30px 0 12px}
.accordion{max-width:820px}
.acc-item{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);margin-bottom:10px;overflow:hidden}
.acc-head{width:100%;background:#fff;border:none;text-align:left;padding:15px 16px;display:flex;align-items:center;gap:12px;cursor:pointer}
.acc-head:hover{background:#FAFBFA}
.acc-avatar{width:38px;height:38px;border-radius:50%;background:var(--teal-soft);color:var(--teal);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;flex:0 0 auto}
.acc-meta{flex:1;min-width:0}
.acc-name{font-size:15px;font-weight:600;color:var(--ink);margin:0}
.acc-role{font-size:12.5px;color:var(--muted);margin:1px 0 0}
.acc-chev{transition:transform .2s;color:var(--muted);flex:0 0 auto;font-size:18px;line-height:1}
.acc-item.open .acc-chev{transform:rotate(180deg)}
.acc-panel{max-height:0;overflow:hidden;transition:max-height .25s ease}
.acc-body{padding:0 16px 16px 66px;font-size:14px;color:var(--muted);line-height:1.6}

footer.foot{border-top:1px solid var(--line);margin-top:10px}
footer.foot .inner{max-width:1180px;margin:0 auto;padding:18px 20px;font-size:12.5px;color:var(--muted);display:flex;gap:10px;flex-wrap:wrap;align-items:center}
footer.foot .inner .spacer{flex:1}

/* ============ ÉQUIPE ============ */
.avatar{position:relative;border-radius:50%;overflow:hidden;background:var(--teal-soft);color:var(--teal);
  display:flex;align-items:center;justify-content:center;font-weight:700;flex:0 0 auto}
.avatar img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.avatar.sm{width:42px;height:42px;font-size:15px}
.avatar.md{width:60px;height:60px;font-size:20px}
.avatar.lg{width:84px;height:84px;font-size:28px}

/* teaser accueil */
.team-teaser{max-width:1180px;margin:0 auto;padding:30px 20px 8px}
.team-teaser .head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.team-teaser h2{font-size:22px;margin:0;font-weight:700}
.team-teaser .lead{font-size:14px;color:var(--muted);max-width:640px;margin:4px 0 0}
.team-teaser a.seeall{font-size:13.5px;font-weight:600;text-decoration:none;color:var(--teal);white-space:nowrap}
.avatars{display:flex;flex-wrap:wrap;gap:12px}
.mini{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:6px 16px 6px 6px;text-decoration:none}
.mini:hover{border-color:var(--teal)}
.mini .mname{font-size:13px;font-weight:600;line-height:1.15;color:var(--ink)}
.mini .mrole{font-size:11px;color:var(--muted)}

/* grille équipe */
.group-title{font-size:13px;text-transform:uppercase;letter-spacing:1.2px;color:var(--teal);font-weight:700;margin:28px 0 12px}
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.member-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:18px;cursor:pointer;
  transition:.14s;display:flex;flex-direction:column;text-align:left;font:inherit;color:inherit}
.member-card:hover{border-color:var(--teal);box-shadow:0 4px 18px rgba(15,110,86,.08);transform:translateY(-1px)}
.member-card .top{display:flex;gap:13px;align-items:center;margin-bottom:12px}
.member-card .mname{font-size:16px;font-weight:700;margin:0;line-height:1.2}
.member-card .mrole{font-size:12px;color:var(--teal);font-weight:600;margin:2px 0 0}
.member-card .mtag{font-size:13px;color:var(--muted);font-style:italic;margin:0 0 12px;line-height:1.45}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}
.tag-x{font-size:11px;background:var(--teal-soft);color:var(--teal);border-radius:999px;padding:3px 9px;font-weight:600}
.tag-v{font-size:11px;background:#EFEAE2;color:#7A5B1E;border-radius:999px;padding:3px 9px;font-weight:600}
.member-card .more{font-size:12.5px;color:var(--teal);font-weight:700;margin-top:13px}
.member-card.is-placeholder{opacity:.72}

/* modale profil */
.modal{position:fixed;inset:0;background:rgba(20,36,31,.55);display:none;align-items:flex-start;justify-content:center;padding:24px;z-index:100;overflow:auto}
.modal.open{display:flex}
body.modal-open{overflow:hidden}
.modal-card{background:#fff;border-radius:16px;max-width:680px;width:100%;padding:26px;position:relative;margin:auto}
.modal-close{position:absolute;top:14px;right:14px;background:#fff;border:1px solid var(--line);border-radius:8px;width:34px;height:34px;font-size:18px;cursor:pointer;color:var(--muted);line-height:1}
.modal-close:hover{border-color:var(--muted)}
.modal-head{display:flex;gap:16px;align-items:center;margin-bottom:14px;padding-right:30px}
.modal-head .mname{font-size:21px;font-weight:700;margin:0;line-height:1.15}
.modal-head .mrole{font-size:13.5px;color:var(--teal);font-weight:600;margin:3px 0 0}
.modal-tag{font-style:italic;color:var(--muted);margin:0 0 16px}
.modal-bio{font-size:14.5px;color:#26342E;line-height:1.65;margin:0 0 18px}
.modal-bio p{margin:0 0 10px}
.modal-sec{margin:0 0 16px}
.modal-sec h4{font-size:11.5px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin:0 0 8px}
.hl-list{margin:0;padding-left:18px;font-size:13.5px;color:#26342E;line-height:1.5}
.hl-list li{margin-bottom:5px}
.modal-links{display:flex;gap:8px;flex-wrap:wrap}
.modal-links a{font-size:13px;font-weight:600;text-decoration:none;border:1px solid var(--line);border-radius:8px;padding:7px 12px;color:var(--ink)}
.modal-links a:hover{border-color:var(--teal);color:var(--teal)}

/* photo prominente (fiche profil) + agrandissement */
.avatar.xl{width:118px;height:118px;font-size:40px;border-radius:16px}
.avatar.xl img{border-radius:16px}
.member-card .avatar.md{width:64px;height:64px}
button.avatar{padding:0;border:none;cursor:default}
button.avatar.photo-zoomable{cursor:zoom-in}
button.avatar.photo-zoomable::after{content:"⤢";position:absolute;right:4px;bottom:4px;width:22px;height:22px;
  display:flex;align-items:center;justify-content:center;font-size:13px;background:rgba(21,36,31,.72);color:#fff;border-radius:7px}
.modal-head{align-items:flex-start}

.lightbox{position:fixed;inset:0;background:rgba(10,18,15,.86);display:none;align-items:center;justify-content:center;padding:24px;z-index:200}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:14px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lightbox-close{position:fixed;top:18px;right:18px;width:42px;height:42px;border-radius:10px;border:none;
  background:rgba(255,255,255,.14);color:#fff;font-size:20px;cursor:pointer}
.lightbox-close:hover{background:rgba(255,255,255,.26)}

/* ============ CONTRIBUER ============ */
/* compteur */
.stats-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:20px;margin-bottom:18px}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:620px){.stats-grid{grid-template-columns:1fr;gap:10px;text-align:left}}
.stat{display:flex;flex-direction:column;gap:2px;padding:10px 14px;background:var(--teal-soft);border:1px solid #CFE7DF;border-radius:10px}
.stat-num{font-size:32px;font-weight:700;line-height:1;color:var(--teal);letter-spacing:-.5px}
.stat-lbl{font-size:12px;color:var(--muted);font-weight:600}
.stat-momentum{background:#fff;border-color:var(--line)}
.stat-mom{font-size:15px;font-weight:700;color:var(--ink);line-height:1.2}
.progress-wrap{margin-top:16px}
.progress-top{display:flex;justify-content:space-between;font-size:12.5px;color:var(--muted);font-weight:600;margin-bottom:6px}
.progress-bar{height:10px;background:#E9EFEC;border-radius:999px;overflow:hidden}
.progress-bar span{display:block;height:100%;width:0;background:var(--teal);border-radius:999px;transition:width .4s}
.stats-quote{margin:16px 0 0;padding:12px 16px;border-left:3px solid var(--teal);background:#FAFBFA;border-radius:0 8px 8px 0;
  font-size:14.5px;font-style:italic;color:#26342E;line-height:1.55}

/* CTA paiement */
.cta-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:20px;margin-bottom:18px}
.cta-card-head{margin-bottom:14px}
.cta-title{font-size:19px;margin:0;font-weight:700}
.pay-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media(max-width:620px){.pay-row{grid-template-columns:1fr}}
.pay-btn{display:flex;flex-direction:column;align-items:flex-start;gap:2px;text-decoration:none;cursor:pointer;
  border:1px solid var(--line);border-radius:11px;padding:13px 15px;background:#fff;font-family:inherit;text-align:left;transition:.14s}
.pay-btn:hover{border-color:var(--teal);box-shadow:0 4px 14px rgba(15,110,86,.08);transform:translateY(-1px)}
.pay-name{font-size:15px;font-weight:700;color:var(--ink)}
.pay-sub{font-size:12.5px;color:var(--muted);font-weight:600}
.pay-wave{border-left:4px solid #1DC8FF}
.pay-om{border-left:4px solid #FF7900}
.pay-momo{border-left:4px solid #FFCC00}
.pay-note{font-size:12.5px;color:var(--b);background:var(--b-bg);border-radius:9px;padding:10px 12px;margin:4px 0 0}
.share-row{display:flex;align-items:center;gap:10px;margin-top:14px;flex-wrap:wrap}

/* derniers soutiens */
.recent{margin:0 0 22px}
.recent-chips{display:flex;flex-wrap:wrap;gap:9px}
.recent-chip{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);
  border-radius:999px;padding:5px 14px 5px 5px}
.recent-chip .rc-name{font-size:12.5px;font-weight:600;color:var(--ink)}

/* liste */
.list-head{display:flex;align-items:flex-end;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.list-title{font-size:20px;margin:0;font-weight:700}
.list-count{font-size:12.5px;color:var(--muted);font-weight:600}
.filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.filter{background:#fff;border:1px solid var(--line);color:var(--muted);border-radius:999px;padding:7px 13px;
  font-size:13px;font-weight:600;cursor:pointer;transition:.12s}
.filter:hover{border-color:var(--muted)}
.filter.is-active{background:var(--teal-soft);border-color:var(--teal);color:var(--teal)}
.filter-n{display:inline-block;font-size:11px;opacity:.75;margin-left:2px}

.contrib-row{display:flex;gap:13px;align-items:flex-start;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r);padding:14px 16px;margin-bottom:10px}
.contrib-body{flex:1;min-width:0}
.contrib-top{display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.contrib-name{font-size:15px;font-weight:700;color:var(--ink);text-decoration:none}
a.contrib-name:hover{color:var(--teal);text-decoration:underline}
.contrib-what{font-size:13.5px;color:#26342E;margin-top:3px}
.contrib-msg{font-size:13px;color:var(--muted);font-style:italic;margin:6px 0 0;line-height:1.5}
.contrib-meta{display:inline-block;font-size:12px;color:var(--muted);margin-top:6px}
.ctag{font-size:11px;font-weight:700;border-radius:999px;padding:2px 9px;letter-spacing:.2px}
.ctag.t-fin{background:var(--a-bg);color:var(--a)}
.ctag.t-nat{background:#EFEAE2;color:#7A5B1E}
.ctag.t-men{background:#E7EEFB;color:#1B4F8A}
.ctag.t-rel{background:#F3E8F7;color:#7A2E8A}
.ctag.t-def{background:#EEF1EF;color:var(--muted)}

/* initiales dans avatars (page contribuer/teaser) */
.avatar .ini{position:relative;z-index:1}

/* carrousel de citations */
.quote-carousel{margin-top:16px;border-left:3px solid var(--teal);background:#FAFBFA;border-radius:0 10px 10px 0;padding:15px 18px}
.qc-stage{transition:opacity .2s ease}
.qc-stage.qc-fade{opacity:0}
.qc-theme{display:inline-block;font-size:10px;text-transform:uppercase;letter-spacing:.9px;font-weight:700;
  color:var(--teal);background:var(--teal-soft);border:1px solid #CFE7DF;border-radius:999px;padding:2px 9px;margin-bottom:8px}
.qc-text{margin:0;font-size:15.5px;font-style:italic;color:#26342E;line-height:1.6}
.qc-author{font-size:13px;color:var(--muted);font-weight:600;margin-top:8px}
.qc-controls{display:flex;align-items:center;gap:12px;margin-top:12px}
.qc-nav{width:32px;height:32px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--ink);
  font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}
.qc-nav:hover{border-color:var(--teal);color:var(--teal)}
.qc-count{font-size:12px;color:var(--muted);font-weight:600;font-variant-numeric:tabular-nums}

/* ============ FAQ ============ */
.faq-toc{display:flex;flex-wrap:wrap;gap:8px;margin:4px 0 24px}
.faq-toc-link{font-size:13px;font-weight:600;text-decoration:none;color:var(--teal);background:var(--teal-soft);
  border:1px solid #CFE7DF;border-radius:999px;padding:6px 13px}
.faq-toc-link:hover{background:#d3ebe2}
.faq-section{margin:0 0 26px;max-width:820px}
.faq-section-title{font-size:13px;text-transform:uppercase;letter-spacing:1.2px;color:var(--teal);font-weight:700;margin:0 0 12px}
.faq-head{width:100%;background:#fff;border:none;text-align:left;padding:15px 16px;display:flex;align-items:center;
  gap:12px;cursor:pointer;font:inherit}
.faq-head:hover{background:#FAFBFA}
.faq-q{flex:1;font-size:15px;font-weight:600;color:var(--ink);line-height:1.35}
.faq-body{padding:0 16px 16px;font-size:14px;color:var(--muted);line-height:1.65}
.faq-body p{margin:0 0 10px}
.faq-body p:last-child{margin-bottom:0}
.faq-scores{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.fs-row{display:flex;gap:10px;align-items:flex-start;font-size:13.5px;color:#26342E}
.fs-row .badge{flex:0 0 auto;margin-top:1px}
.faq-cta{font-size:14px;color:var(--muted)}

/* ===== Bloc « Son projet » (fiche profil) ===== */
.proj-card{background:var(--teal-soft);border:1px solid #CFE7DF;border-radius:12px;padding:16px 16px 18px;margin:0 0 18px}
.proj-card.is-placeholder{background:var(--bg);border:1px dashed var(--line)}
.proj-eyebrow{display:block;font-size:10.5px;text-transform:uppercase;letter-spacing:1.2px;color:var(--teal);font-weight:700;margin:0 0 5px}
.proj-name{font-size:18px;font-weight:700;margin:0 0 6px;letter-spacing:-.2px;color:var(--ink)}
.proj-syn{font-size:13.5px;color:#26342E;line-height:1.55;margin:0 0 14px}
.proj-btn{font-size:14px;padding:10px 18px}

/* ===== Landing page projet (projet.html) ===== */
.lp-hero{max-width:900px;margin:0 auto;padding:38px 20px 6px}
.lp-hero .eyebrow{margin-bottom:10px}
.lp-hero h1{font-size:38px;line-height:1.07;margin:0 0 10px;font-weight:700;letter-spacing:-.5px}
.lp-hero .tagline{font-size:18px;color:var(--muted);max-width:680px;margin:0 0 18px;line-height:1.5}
.lp-meta{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 18px}
.lp-meta .chip-meta{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:999px;padding:5px 12px;font-weight:600}
.lp-meta .chip-meta strong{color:var(--ink);font-weight:700}
.lp-cta{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:0 0 6px}
.lp-body{max-width:900px;margin:0 auto;padding:14px 20px 10px}
.lp-rule{max-width:900px;margin:22px auto 0;padding:0 20px}
.lp-rule hr{border:none;border-top:1px solid var(--line);margin:0}
.lp-desc{font-size:16px;color:#26342E;line-height:1.7;max-width:720px}
.lp-desc p{margin:0 0 14px}
.lp-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:22px 0 6px}
@media(max-width:680px){.lp-grid{grid-template-columns:1fr}}
.lp-block{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:18px}
.lp-block h3{font-size:11.5px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin:0 0 10px}
.lp-block p{margin:0;font-size:14.5px;color:#26342E;line-height:1.55}
.lp-block .hl-list{font-size:14px}
.lp-founder{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:16px;margin:22px 0 6px;flex-wrap:wrap}
.lp-founder .who{flex:1;min-width:180px}
.lp-founder .who .lbl{font-size:10.5px;text-transform:uppercase;letter-spacing:1px;color:var(--teal);font-weight:700;margin:0 0 3px}
.lp-founder .who .nm{font-size:16px;font-weight:700;margin:0;color:var(--ink)}
.lp-founder .who .rl{font-size:12.5px;color:var(--muted);margin:2px 0 0}
.lp-confirm{font-size:12px;color:var(--b);background:var(--b-bg);border:1px solid #EAD8B4;border-radius:8px;padding:8px 12px;margin:18px 0 0;max-width:720px}
.lp-placeholder{font-size:13.5px;color:var(--muted);background:var(--bg);border:1px dashed var(--line);border-radius:10px;padding:16px;max-width:720px}

/* ===== Avatars : silhouette neutre (plus d'initiales) ===== */
.avatar .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:0}
.avatar .ph-ico{width:62%;height:62%;fill:var(--teal);opacity:.42}
.avatar img{z-index:1}

/* ===== Résultats du moteur : cartes cliquables ===== */
.card.clickable{cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .05s}
.card.clickable:hover{border-color:var(--teal);box-shadow:0 6px 18px rgba(2,108,84,.09)}
.card.clickable:active{transform:translateY(1px)}
.card.clickable:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
.card .foot{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.card-detail{font-weight:700;color:var(--teal)}
.card-detail:hover{text-decoration:underline}

/* ===== Fiche détaillée acteur (acteur.html) ===== */
.ac-badges{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:0 0 14px}
.ac-sec{max-width:760px;margin:0 0 22px}
.ac-sec h3{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin:0 0 8px}
.ac-sec p{font-size:15.5px;line-height:1.7;color:#26342E;margin:0}
.lp-grid-3{grid-template-columns:1fr 1fr 1fr}
@media(max-width:780px){.lp-grid-3{grid-template-columns:1fr}}
.tagrow{display:flex;flex-wrap:wrap;gap:6px}
.ac-useful{background:var(--teal-soft);border:1px solid #CFE7DF;border-radius:12px;padding:16px 18px;max-width:760px;margin:0 0 22px}
.ac-useful-lbl{display:block;font-size:10.5px;text-transform:uppercase;letter-spacing:1.2px;color:var(--teal);font-weight:700;margin:0 0 6px}
.ac-useful p{margin:0;font-size:15px;line-height:1.65;color:#1d2b25}
.ac-trust{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;max-width:760px;margin:18px 0 6px}
.ac-trust-head{display:flex;align-items:center;gap:10px;font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);font-weight:700;margin:0 0 8px}
.ac-trust-main{font-size:14.5px;color:#26342E;margin:0 0 8px;line-height:1.55}
.ac-trust-line{font-size:13px;color:var(--muted);margin:4px 0;line-height:1.5}
.ac-src{font-size:12px}

/* ===== Panneau d'étape (formulaire moteur) ===== */
.phase-info{background:var(--teal-soft);border:1px solid #CFE7DF;border-radius:10px;padding:11px 13px;margin:4px 0 2px;font-size:13px}
.phase-info .pi-stade{margin:0 0 5px;font-weight:700;color:var(--teal);font-size:13px}
.phase-info .pi-num{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--teal);color:#fff;font-size:11px;margin-right:5px;font-weight:800}
.phase-info .pi-tag{font-weight:600;color:#2a463d}
.phase-info .pi-desc{margin:0 0 7px;color:#26342E;line-height:1.5}
.phase-info .pi-needs{margin:0 0 8px;color:var(--muted);font-size:12px;display:flex;flex-wrap:wrap;gap:5px;align-items:center}
.phase-info .pi-need{background:#fff;border:1px solid #CFE7DF;border-radius:999px;padding:2px 8px;color:var(--teal);font-weight:600}
.phase-info .pi-link{font-size:12.5px;font-weight:700;color:var(--teal)}
.pill.step{background:#FFE6D8;color:#C24E16}

/* ===== Page Parcours (parcours.html) ===== */
.pc-intro{max-width:820px;font-size:16px;color:#26342E;line-height:1.65}
.pc-stade{margin:32px 0 0;scroll-margin-top:80px}
.pc-stade-head{display:flex;align-items:center;gap:12px;margin:0 0 3px}
.pc-stade-num{width:34px;height:34px;border-radius:10px;background:var(--teal);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;flex:0 0 auto}
.pc-stade-head h2{font-size:24px;margin:0;letter-spacing:-.4px}
.pc-stade-tag{color:var(--muted);font-size:14px;margin:0 0 12px;padding-left:46px}
.pc-sous{border:1px solid var(--line);border-radius:14px;background:var(--surface);padding:16px 18px;margin:12px 0}
.pc-sous-h{display:flex;align-items:baseline;gap:8px;margin:0 0 4px;flex-wrap:wrap}
.pc-sous-id{font-size:12px;font-weight:800;color:var(--orange)}
.pc-sous-h h3{font-size:16px;margin:0}
.pc-sous-desc{color:#26342E;font-size:14px;margin:0 0 12px;line-height:1.55}
.pc-comp{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:680px){.pc-comp{grid-template-columns:1fr}}
.pc-comp-item{background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:12px 13px}
.pc-comp-item h4{margin:0 0 5px;font-size:13.5px;color:var(--teal)}
.pc-comp-item p{margin:0;font-size:12.8px;color:#3a4a43;line-height:1.5}
.pc-needs{margin:11px 0 0;display:flex;flex-wrap:wrap;gap:5px;align-items:center}
.pc-needs .nlbl{font-size:11.5px;color:var(--muted);margin-right:2px}
.pc-support{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin:14px 0 4px}
@media(max-width:760px){.pc-support{grid-template-columns:1fr}}
.pc-final{background:var(--teal-soft);border:1px solid #CFE7DF;border-radius:14px;padding:18px 20px;margin:14px 0;max-width:820px}
.pc-final h3{margin:0 0 8px;color:var(--teal);font-size:16px}
.pc-final p{margin:0;font-size:14.5px;color:#26342E;line-height:1.6}
.pc-anchor-nav{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 4px}
.pc-anchor-nav a{font-size:13px;font-weight:600;color:var(--teal);background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:6px 13px;text-decoration:none}
.pc-anchor-nav a:hover{border-color:var(--teal)}
.pc-src{font-size:12px;color:var(--muted);margin:20px 0 0;max-width:820px}
