/* ============================================================
   NeoGenesis Technologies — couche « Cyber » du réseau social
   S'appuie sur les tokens de style.css (--cyan, --violet, --grad…).
   Néon maîtrisé, glassmorphism, accents HUD. Zéro dépendance.
   ============================================================ */
:root{
  --neon:#22d3ee; --neon-2:#a855f7; --neon-g:#34d399; --neon-r:#fb7185; --neon-y:#fbbf24;
  --hud-line:rgba(34,211,238,.35);
  --glass:rgba(13,18,32,.72);
  --glow-cy:0 0 0 1px rgba(34,211,238,.35),0 0 18px -2px rgba(34,211,238,.45);
  --glow-vi:0 0 0 1px rgba(168,85,247,.35),0 0 18px -2px rgba(168,85,247,.45);
}

/* ---------- libellés HUD ---------- */
.ng-mono{font-family:"Courier New",ui-monospace,monospace;letter-spacing:.14em;text-transform:uppercase;font-size:.66rem;color:var(--neon);opacity:.85}
.ng-kicker{display:inline-flex;align-items:center;gap:.5rem;font-family:"Courier New",monospace;letter-spacing:.18em;text-transform:uppercase;font-size:.64rem;color:var(--neon)}
.ng-kicker::before{content:"";width:14px;height:1px;background:linear-gradient(90deg,transparent,var(--neon))}

/* ---------- carte cyber (cadre + coins HUD) ---------- */
.ng-card{position:relative;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));
  border:1px solid var(--line);border-radius:16px;padding:1.3rem;backdrop-filter:blur(10px);transition:.25s}
.ng-card:hover{border-color:rgba(34,211,238,.35);box-shadow:0 16px 40px -20px rgba(34,211,238,.35)}
.ng-card::before,.ng-card::after{content:"";position:absolute;width:12px;height:12px;pointer-events:none;opacity:.55;transition:.25s}
.ng-card::before{top:8px;left:8px;border-top:2px solid var(--neon);border-left:2px solid var(--neon)}
.ng-card::after{bottom:8px;right:8px;border-bottom:2px solid var(--neon-2);border-right:2px solid var(--neon-2)}
.ng-card:hover::before,.ng-card:hover::after{opacity:1;width:16px;height:16px}

/* ---------- avatars ---------- */
.ng-ava{border-radius:50%;display:flex;align-items:center;justify-content:center;color:#04121a;
  font-weight:800;flex:none;background-size:cover;background-position:center;position:relative}
.ng-ava.glow{box-shadow:0 0 0 2px rgba(6,8,15,1),0 0 0 3px var(--neon),0 0 16px -2px var(--neon)}
.ng-ava-xl{width:5.2rem;height:5.2rem;font-size:2rem}
.ng-ava-lg{width:3rem;height:3rem;font-size:1.2rem}
.ng-ava-sm{width:2.2rem;height:2.2rem;font-size:.9rem}

/* ---------- boutons d'action néon ---------- */
.ng-act{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;cursor:pointer;
  font:inherit;font-weight:700;font-size:.85rem;padding:.55rem 1rem;border-radius:10px;
  border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--text);transition:.18s;white-space:nowrap}
.ng-act:hover{transform:translateY(-1px)}
.ng-act:disabled{opacity:.55;cursor:default;transform:none}
.ng-act-primary{background:var(--grad);color:#04121a;border-color:transparent;box-shadow:0 8px 22px -10px rgba(34,211,238,.7)}
.ng-act-primary:hover{box-shadow:0 12px 28px -8px rgba(168,85,247,.7)}
.ng-act-neon{border-color:var(--hud-line);color:var(--neon);background:rgba(34,211,238,.06)}
.ng-act-neon:hover{box-shadow:var(--glow-cy);background:rgba(34,211,238,.12)}
.ng-act-ok{border-color:rgba(52,211,153,.45);color:var(--neon-g);background:rgba(52,211,153,.08)}
.ng-act-ok:hover{box-shadow:0 0 18px -2px rgba(52,211,153,.5)}
.ng-act-danger{border-color:rgba(251,113,133,.4);color:var(--neon-r);background:rgba(251,113,133,.07)}
.ng-act-danger:hover{box-shadow:0 0 18px -2px rgba(251,113,133,.5)}
.ng-act-ghost{color:var(--muted)}
.ng-act-ghost:hover{color:var(--text);border-color:var(--line)}
.ng-act-sm{padding:.38rem .7rem;font-size:.78rem;border-radius:8px}

/* ---------- badges ---------- */
.ng-badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.62rem;font-weight:800;letter-spacing:.08em;
  text-transform:uppercase;padding:.18rem .5rem;border-radius:999px;border:1px solid var(--line)}
.ng-badge-admin{color:var(--neon-y);border-color:rgba(251,191,36,.4);background:rgba(251,191,36,.08)}
.ng-badge-ami{color:var(--neon);border-color:var(--hud-line);background:rgba(34,211,238,.08)}
.ng-badge-part{color:var(--neon-2);border-color:rgba(168,85,247,.4);background:rgba(168,85,247,.08)}
.ng-badge-on{color:var(--neon-g);border-color:rgba(52,211,153,.4);background:rgba(52,211,153,.08)}

/* ---------- vue profil public ---------- */
.ngpv{max-width:680px;margin:2rem auto;padding:0 1rem}
.ngpv-hero{position:relative;overflow:hidden;border-radius:18px;padding:1.6rem;border:1px solid var(--line);
  background:linear-gradient(135deg,rgba(34,211,238,.10),rgba(168,85,247,.10)),var(--bg-3)}
.ngpv-hero::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:radial-gradient(60% 80% at 100% 0,rgba(168,85,247,.25),transparent 60%)}
.ngpv-row{display:flex;gap:1.2rem;align-items:center;position:relative;z-index:1;flex-wrap:wrap}
.ngpv-id{flex:1;min-width:180px}
.ngpv-name{font-size:1.5rem;font-weight:800;margin:0;display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.ngpv-title{color:var(--cyan);font-size:.95rem;margin-top:.15rem}
.ngpv-meta{color:var(--muted);font-size:.85rem;margin-top:.5rem;display:flex;gap:1rem;flex-wrap:wrap}
.ngpv-meta a{color:var(--cyan)}
.ngpv-stats{display:flex;gap:1.4rem;margin-top:1rem}
.ngpv-stat b{font-size:1.15rem;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.ngpv-stat span{display:block;font-size:.68rem;color:var(--dim);text-transform:uppercase;letter-spacing:.1em}
.ngpv-bio{margin-top:1.2rem;color:var(--text);line-height:1.6;white-space:pre-wrap}
.ngpv-actions{display:flex;gap:.6rem;margin-top:1.3rem;flex-wrap:wrap}
.ngpv-back{display:inline-flex;align-items:center;gap:.4rem;color:var(--muted);font-size:.85rem;margin-bottom:1rem}
.ngpv-back:hover{color:var(--cyan)}

/* ---------- panneau « Mes relations » ---------- */
.ngrel{margin-top:1.4rem}
.ngrel-tabs{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1rem}
.ngrel-tab{cursor:pointer;font:inherit;font-size:.8rem;font-weight:700;padding:.45rem .85rem;border-radius:999px;
  border:1px solid var(--line);background:transparent;color:var(--muted);transition:.18s;display:inline-flex;gap:.4rem;align-items:center}
.ngrel-tab:hover{color:var(--text);border-color:var(--hud-line)}
.ngrel-tab.on{color:#04121a;background:var(--grad);border-color:transparent;font-weight:800}
.ngrel-count{font-size:.66rem;background:rgba(0,0,0,.25);border-radius:999px;padding:.05rem .4rem;min-width:1.1rem;text-align:center}
.ngrel-tab.on .ngrel-count{background:rgba(0,0,0,.25)}
.ngrel-search{display:flex;gap:.5rem;margin-bottom:.9rem}
.ngrel-search input{flex:1;background:rgba(0,0,0,.28);border:1px solid var(--line);border-radius:10px;padding:.55rem .8rem;color:var(--text);font:inherit}
.ngrel-search input:focus{outline:none;border-color:var(--cyan)}
.ngrel-list{display:flex;flex-direction:column;gap:.6rem}
.ngrel-empty{color:var(--dim);font-size:.9rem;text-align:center;padding:1.4rem;border:1px dashed var(--line);border-radius:12px}

/* ligne de relation / membre */
.ngconn{display:flex;align-items:center;gap:.8rem;padding:.7rem .8rem;border:1px solid var(--line);border-radius:12px;
  background:rgba(255,255,255,.025);transition:.18s}
.ngconn:hover{border-color:var(--hud-line);background:rgba(34,211,238,.04)}
.ngconn-id{flex:1;min-width:0}
.ngconn-name{font-weight:700;font-size:.95rem;display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}
.ngconn-name a{color:inherit}.ngconn-name a:hover{color:var(--cyan)}
.ngconn-sub{color:var(--dim);font-size:.76rem;margin-top:.1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ngconn-actions{display:flex;gap:.4rem;flex:none}

/* ---------- message d'état ---------- */
.ng-msg{min-height:1.2em;font-size:.88rem;margin-top:.6rem}
.ng-msg.ok{color:var(--neon-g)}.ng-msg.err{color:var(--neon-r)}
.ng-spin{display:inline-block;width:1rem;height:1rem;border:2px solid rgba(255,255,255,.2);border-top-color:var(--cyan);border-radius:50%;animation:ngspin .7s linear infinite;vertical-align:-2px}
@keyframes ngspin{to{transform:rotate(360deg)}}

@media(max-width:560px){
  .ngpv-actions{width:100%}
  .ngconn-actions .ng-act span{display:none}
}
@media(prefers-reduced-motion:reduce){.ng-spin{animation:none}}

/* ============================================================
   Phase 2 — murs (toile), réactions, commentaires
   ============================================================ */
.ngw{margin-top:1.5rem}
.ngw-compose{border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.025);padding:.8rem;margin-bottom:1rem}
.ngw-compose textarea{width:100%;resize:vertical;min-height:2.7rem;max-height:12rem;background:rgba(0,0,0,.28);border:1px solid var(--line);border-radius:10px;padding:.6rem .8rem;color:var(--text);font:inherit}
.ngw-compose textarea:focus{outline:none;border-color:var(--cyan)}
.ngw-crow{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;flex-wrap:wrap}
.ngw-vis{background:rgba(0,0,0,.28);border:1px solid var(--line);border-radius:8px;color:var(--muted);font:inherit;font-size:.78rem;padding:.35rem .5rem}
.ngw-file{display:inline-flex;align-items:center;gap:.3rem;border:1px solid var(--line);border-radius:8px;padding:.35rem .6rem;cursor:pointer;font-size:.8rem;color:var(--muted)}
.ngw-file:hover{border-color:var(--cyan);color:var(--text)}
.ngw-prev{margin-top:.5rem;max-width:280px}.ngw-prev img,.ngw-prev video{max-width:100%;max-height:160px;border-radius:8px;display:block}
.ngw-list{display:flex;flex-direction:column;gap:.9rem}
.ngw-post{border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.025);overflow:hidden}
.ngw-post:hover{border-color:rgba(34,211,238,.22)}
.ngw-head{display:flex;align-items:center;gap:.6rem;padding:.7rem .85rem}
.ngw-name{font-weight:700;font-size:.92rem}.ngw-name a{color:inherit}.ngw-name a:hover{color:var(--cyan)}
.ngw-time{color:var(--dim);font-size:.72rem}
.ngw-del{margin-left:auto;background:transparent;border:none;color:var(--neon-r);opacity:.55;cursor:pointer;font-size:1rem}
.ngw-del:hover{opacity:1}
.ngw-text{padding:0 .85rem .6rem;white-space:pre-wrap;word-break:break-word;font-size:.94rem;line-height:1.5}
.ngw-media img,.ngw-media video{width:100%;max-height:460px;object-fit:contain;background:#000;display:block}
.ngw-vis-tag{font-size:.58rem;text-transform:uppercase;letter-spacing:.08em;color:var(--dim);border:1px solid var(--line);border-radius:999px;padding:.05rem .45rem}

/* réactions */
.ng-react{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap;padding:.5rem .85rem;border-top:1px solid var(--line)}
.ng-react-chip{display:inline-flex;align-items:center;gap:.25rem;cursor:pointer;font:inherit;font-size:.85rem;border:1px solid var(--line);background:rgba(255,255,255,.03);border-radius:999px;padding:.16rem .55rem;transition:.15s}
.ng-react-chip:hover{border-color:var(--hud-line)}
.ng-react-chip.mine{border-color:var(--cyan);background:rgba(34,211,238,.14);box-shadow:0 0 10px -3px rgba(34,211,238,.6)}
.ng-react-chip b{font-weight:700;font-size:.74rem;opacity:.85}
.ng-react-add{cursor:pointer;font:inherit;border:1px dashed var(--line);background:transparent;color:var(--muted);border-radius:999px;padding:.16rem .55rem;font-size:.9rem;line-height:1}
.ng-react-add:hover{color:var(--cyan);border-color:var(--hud-line)}
.ng-react-pick{display:inline-flex;gap:.1rem;flex-wrap:wrap;background:#0b1220;border:1px solid var(--hud-line);border-radius:999px;padding:.15rem .3rem}
.ng-react-pick button{background:transparent;border:none;cursor:pointer;font-size:1.05rem;padding:.1rem .2rem;border-radius:6px}
.ng-react-pick button:hover{background:rgba(255,255,255,.1)}

/* commentaires */
.ng-cmts{border-top:1px solid var(--line)}
.ng-cmts-toggle{cursor:pointer;font:inherit;background:transparent;border:none;color:var(--muted);font-size:.82rem;padding:.5rem .85rem;display:flex;align-items:center;gap:.4rem;width:100%;text-align:left}
.ng-cmts-toggle:hover{color:var(--cyan)}
.ng-cmts-body{padding:.2rem .85rem .7rem;display:flex;flex-direction:column;gap:.55rem}
.ng-cmt{display:flex;gap:.5rem;align-items:flex-start}
.ng-cmt-ava{width:1.8rem;height:1.8rem;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;color:#04121a;font-weight:800;font-size:.72rem;background-size:cover;background-position:center}
.ng-cmt-b{flex:1;min-width:0;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:10px;padding:.4rem .6rem}
.ng-cmt-n{font-weight:700;font-size:.8rem}.ng-cmt-n a{color:inherit}.ng-cmt-n a:hover{color:var(--cyan)}
.ng-cmt-tx{font-size:.86rem;line-height:1.4;white-space:pre-wrap;word-break:break-word;margin-top:.1rem}
.ng-cmt-del{background:transparent;border:none;color:var(--neon-r);opacity:.5;cursor:pointer;font-size:.85rem;flex:none}
.ng-cmt-del:hover{opacity:1}
.ng-cmt-form{display:flex;gap:.4rem;margin-top:.2rem}
.ng-cmt-form input{flex:1;background:rgba(0,0,0,.28);border:1px solid var(--line);border-radius:999px;padding:.4rem .8rem;color:var(--text);font:inherit;font-size:.86rem}
.ng-cmt-form input:focus{outline:none;border-color:var(--cyan)}

/* ============================================================
   Phase 3 — groupes
   ============================================================ */
.grwrap{max-width:820px;margin:2rem auto;padding:0 1rem}
.gr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.9rem}
.gr-card{position:relative;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.025);padding:1rem;display:flex;flex-direction:column;gap:.5rem;transition:.2s}
.gr-card:hover{border-color:var(--hud-line);box-shadow:0 14px 34px -22px rgba(34,211,238,.5);transform:translateY(-2px)}
.gr-card-top{display:flex;align-items:center;gap:.6rem}
.gr-ico{width:2.6rem;height:2.6rem;border-radius:12px;flex:none;display:flex;align-items:center;justify-content:center;font-size:1.2rem;background:var(--grad-soft);border:1px solid var(--line)}
.gr-card-name{font-weight:800;font-size:1rem;line-height:1.2}
.gr-card-desc{color:var(--muted);font-size:.85rem;line-height:1.45;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.gr-card-foot{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-top:.2rem}
.gr-meta{color:var(--dim);font-size:.74rem;display:flex;align-items:center;gap:.4rem}
.gr-hero{position:relative;overflow:hidden;border-radius:18px;padding:1.5rem;border:1px solid var(--line);background:linear-gradient(135deg,rgba(34,211,238,.10),rgba(168,85,247,.10)),var(--bg-3);margin-bottom:1.2rem}
.gr-hero::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;background:radial-gradient(60% 80% at 100% 0,rgba(168,85,247,.22),transparent 60%)}
.gr-hero-top{display:flex;gap:1rem;align-items:flex-start;flex-wrap:wrap;position:relative;z-index:1}
.gr-hero .gr-ico{width:3.4rem;height:3.4rem;font-size:1.6rem}
.gr-hname{font-size:1.4rem;font-weight:800;margin:0;display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}
.gr-hdesc{color:var(--text);opacity:.92;margin-top:.5rem;white-space:pre-wrap;line-height:1.55}
.gr-hact{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap;position:relative;z-index:1}
.gr-layout{display:grid;grid-template-columns:1fr 250px;gap:1.2rem;align-items:start}
.gr-aside{border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.025);padding:.9rem}
.gr-aside h3{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:.2rem 0 .6rem}
.gr-mem{display:flex;align-items:center;gap:.5rem;padding:.35rem 0}
.gr-mem .ng-ava{width:1.9rem;height:1.9rem;font-size:.78rem}
.gr-mem-n{font-size:.85rem;font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gr-mem-n a{color:inherit}.gr-mem-n a:hover{color:var(--cyan)}
.gr-create{border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.025);padding:1rem;margin-bottom:1.2rem}
.gr-create input,.gr-create textarea,.gr-create select{width:100%;background:rgba(0,0,0,.28);border:1px solid var(--line);border-radius:10px;padding:.6rem .8rem;color:var(--text);font:inherit;margin-bottom:.55rem}
.gr-create input:focus,.gr-create textarea:focus{outline:none;border-color:var(--cyan)}
@media(max-width:720px){.gr-layout{grid-template-columns:1fr}}

/* ============================================================
   Phase 4A — contenu enrichi (markdown léger, code, @mentions)
   ============================================================ */
.ngf-cb{background:#070b14;border:1px solid var(--line);border-left:2px solid var(--cyan);border-radius:10px;padding:.7rem .85rem;margin:.5rem 0;overflow-x:auto;font-family:"Courier New",ui-monospace,monospace;font-size:.85rem;line-height:1.5}
.ngf-cb code{font-family:inherit;white-space:pre;color:#cfe8ff;background:none;border:none;padding:0}
.ngf-ic{font-family:"Courier New",ui-monospace,monospace;font-size:.88em;background:rgba(34,211,238,.1);border:1px solid var(--line);border-radius:5px;padding:.05rem .35rem;color:#7ef0d6}
.ngf-kw{color:#c084fc;font-weight:600}
.ngf-str{color:#34d399}
.ngf-com{color:#64748b;font-style:italic}
.ngf-num{color:#fbbf24}
.ngf-link{color:var(--cyan);text-decoration:none;border-bottom:1px solid rgba(34,211,238,.4);word-break:break-all}
.ngf-link:hover{border-bottom-color:var(--cyan)}
.ngf-mention{color:var(--cyan);background:rgba(34,211,238,.1);border-radius:4px;padding:0 .2rem;font-weight:600}

/* ============================================================
   Phase 4B — forum Q&R
   ============================================================ */
.qa-wrap{max-width:800px;margin:2rem auto;padding:0 1rem}
.qa-search{display:flex;gap:.5rem;margin-bottom:1rem}
.qa-search input{flex:1;background:rgba(0,0,0,.28);border:1px solid var(--line);border-radius:10px;padding:.6rem .85rem;color:var(--text);font:inherit}
.qa-search input:focus{outline:none;border-color:var(--cyan)}
.qa-ask{border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.025);padding:1rem;margin-bottom:1.2rem}
.qa-ask input,.qa-ask textarea{width:100%;background:rgba(0,0,0,.28);border:1px solid var(--line);border-radius:10px;padding:.6rem .8rem;color:var(--text);font:inherit;margin-bottom:.55rem}
.qa-ask input:focus,.qa-ask textarea:focus{outline:none;border-color:var(--cyan)}
.qa-list{display:flex;flex-direction:column;gap:.7rem}
.qa-card{display:flex;gap:.9rem;border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.025);padding:.85rem 1rem;cursor:pointer;transition:.18s}
.qa-card:hover{border-color:var(--hud-line);background:rgba(34,211,238,.04)}
.qa-stat{flex:none;width:3.4rem;text-align:center}
.qa-stat b{display:block;font-size:1.15rem;color:var(--text)}
.qa-stat span{font-size:.6rem;color:var(--dim);text-transform:uppercase;letter-spacing:.06em}
.qa-stat.solved b{color:var(--neon-g)}
.qa-cmain{flex:1;min-width:0}
.qa-ctitle{font-weight:700;font-size:1rem;line-height:1.3}
.qa-ctitle .qa-solved{color:var(--neon-g);margin-right:.3rem}
.qa-cmeta{color:var(--dim);font-size:.76rem;display:flex;gap:.6rem;flex-wrap:wrap;align-items:center;margin-top:.4rem}
.qa-tag{display:inline-block;font-size:.66rem;color:var(--neon);background:rgba(34,211,238,.08);border:1px solid var(--hud-line);border-radius:6px;padding:.05rem .4rem}
.qa-q{border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));padding:1.2rem;margin-bottom:1rem}
.qa-q h1{font-size:1.4rem;margin:0 0 .6rem;line-height:1.25}
.qa-qbody,.qa-abody{line-height:1.6}
.qa-byline{display:flex;align-items:center;gap:.5rem;margin-top:.9rem;color:var(--dim);font-size:.8rem;flex-wrap:wrap}
.qa-byline a{color:inherit}.qa-byline a:hover{color:var(--cyan)}
.qa-ans-h{font-family:"Courier New",monospace;letter-spacing:.12em;text-transform:uppercase;font-size:.7rem;color:var(--muted);margin:1.3rem 0 .7rem}
.qa-ans{border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.025);padding:1rem;margin-bottom:.8rem}
.qa-ans.accepted{border-color:rgba(52,211,153,.5);box-shadow:0 0 18px -6px rgba(52,211,153,.45)}
.qa-accepted-badge{display:inline-flex;align-items:center;gap:.3rem;color:var(--neon-g);font-size:.72rem;font-weight:800;margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.06em}

/* ============================================================
   Phase 5 — réputation, badges, annuaire, aperçu public
   ============================================================ */
.ng-level{display:inline-flex;align-items:center;gap:.35rem;font-size:.64rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:.18rem .55rem;border-radius:999px;border:1px solid var(--hud-line);color:var(--neon);background:rgba(34,211,238,.08)}
.ng-level.lv4{color:var(--neon-2);border-color:rgba(168,85,247,.4);background:rgba(168,85,247,.08)}
.ng-level.lv5{color:var(--neon-y);border-color:rgba(251,191,36,.4);background:rgba(251,191,36,.08)}
.ng-level.lv6{color:#04121a;background:linear-gradient(120deg,#22d3ee,#a855f7);border-color:transparent}
.ng-pts{font-weight:800;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.ng-badges{display:flex;gap:.35rem;flex-wrap:wrap;margin-top:.6rem}
.ng-badge2{display:inline-flex;align-items:center;gap:.3rem;font-size:.7rem;border:1px solid var(--line);border-radius:8px;padding:.15rem .5rem;background:rgba(255,255,255,.03)}
.ng-badge2 i{font-style:normal}
.dir-tabs{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1rem}
.dir-list{display:flex;flex-direction:column;gap:.6rem}
.dir-row{display:flex;align-items:center;gap:.9rem;padding:.7rem .85rem;border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.025);transition:.18s}
.dir-row:hover{border-color:var(--hud-line);background:rgba(34,211,238,.04)}
.dir-rank{flex:none;width:1.8rem;text-align:center;font-weight:800;color:var(--dim)}
.dir-row.top1 .dir-rank{color:var(--neon-y)}.dir-row.top2 .dir-rank{color:#cbd5e1}.dir-row.top3 .dir-rank{color:#d6a06a}
.dir-id{flex:1;min-width:0}
.dir-name{font-weight:700;font-size:.95rem;display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}
.dir-name a{color:inherit}.dir-name a:hover{color:var(--cyan)}
.dir-sub{color:var(--dim);font-size:.74rem;margin-top:.2rem;display:flex;gap:.4rem;flex-wrap:wrap;align-items:center}
.dir-pts{flex:none;text-align:right}
.dir-pts b{display:block;font-size:1.05rem;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.dir-pts span{font-size:.58rem;color:var(--dim);text-transform:uppercase;letter-spacing:.08em}
.ngprev{margin:1.6rem auto 0;max-width:520px;border:1px solid var(--line);border-radius:16px;background:linear-gradient(180deg,rgba(34,211,238,.06),rgba(168,85,247,.05));padding:1.2rem;backdrop-filter:blur(6px)}
.ngprev h3{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--neon);margin-bottom:.8rem;text-align:center}
.ngprev-stats{display:flex;justify-content:center;gap:1.3rem;flex-wrap:wrap;margin-bottom:1rem}
.ngprev-stat{text-align:center}
.ngprev-stat b{display:block;font-size:1.4rem;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:800}
.ngprev-stat span{font-size:.64rem;color:var(--dim);text-transform:uppercase;letter-spacing:.06em}
.ngprev-q{display:flex;flex-direction:column;gap:.4rem}
.ngprev-qi{font-size:.85rem;color:var(--muted);padding:.4rem .6rem;border:1px solid var(--line);border-radius:8px;display:flex;justify-content:space-between;gap:.6rem}
.ngprev-qi span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ngprev-qi b{color:var(--neon);flex:none}

/* noms de membres cliquables (chat + feed) → profil */
.msg-name a,.cm-fcard-name a{color:inherit;text-decoration:none;cursor:pointer}
.msg-name a:hover,.cm-fcard-name a:hover{text-decoration:underline}

/* ===== Bonus (Phase 6) : infolettre, parrainage ===== */
.ng-bonus{background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.09);border-radius:18px;padding:1.5rem;margin-top:1.4rem;backdrop-filter:blur(10px)}
.ng-bonus-spin{display:flex;justify-content:center;padding:1.4rem}
.ng-bonus-h{display:flex;align-items:center;gap:.8rem;margin-bottom:1.1rem}
.ng-bonus-h .ic{font-size:1.5rem;flex:none}
.ng-bonus-h b{font-size:1.1rem}
.ng-bonus-sub{font-size:.8rem;color:var(--muted,#94a3b8)}
.ng-switch{display:flex;align-items:center;gap:.6rem;font-size:.92rem;cursor:pointer;margin-bottom:1rem}
.ng-switch input{width:1.1rem;height:1.1rem;accent-color:#22d3ee;flex:none}
.ng-bonus-row{display:flex;align-items:center;gap:.7rem;margin-bottom:1rem;flex-wrap:wrap}
.ng-bonus-row label{font-size:.85rem;color:var(--muted,#94a3b8)}
.ng-bonus-row select,.ng-bonus-row input[type=text]{flex:1;min-width:8rem;padding:.55rem .7rem;border-radius:10px;border:1px solid rgba(255,255,255,.16);background:rgba(0,0,0,.28);color:inherit;font:inherit}
.ng-bonus-row select:focus,.ng-bonus-row input:focus{outline:none;border-color:#22d3ee}
.ng-bonus-topics{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}
.ng-chip2{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:.35rem .7rem;cursor:pointer}
.ng-chip2 input{accent-color:#22d3ee}
.ng-bonus-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.8rem}
.ng-soon-note{font-size:.8rem;color:#fbbf24;background:rgba(251,191,36,.08);border:1px solid rgba(251,191,36,.22);border-radius:10px;padding:.6rem .8rem;line-height:1.45}
.ng-inv-stats{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1rem}
.ng-inv-stat{flex:1;min-width:4.6rem;text-align:center;background:rgba(34,211,238,.06);border:1px solid rgba(34,211,238,.16);border-radius:12px;padding:.8rem .4rem}
.ng-inv-stat b{display:block;font-size:1.5rem;color:#22d3ee}
.ng-inv-stat span{font-size:.72rem;color:var(--muted,#94a3b8)}
.ng-digest{margin-top:1rem;border-top:1px solid rgba(255,255,255,.08);padding-top:1rem}
.ng-digest-h{font-weight:800;margin-bottom:.7rem}
.ng-digest-pulse{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.9rem}
.ng-digest-pulse span{flex:1;min-width:6rem;text-align:center;background:rgba(255,255,255,.05);border-radius:10px;padding:.5rem .3rem;font-size:.72rem;color:var(--muted,#94a3b8)}
.ng-digest-pulse b{display:block;font-size:1.15rem;color:#e5e7eb;margin-bottom:.15rem}
.ng-digest-sec{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:#22d3ee;margin:.8rem 0 .4rem}
.ng-digest-item{font-size:.85rem;color:#cbd5e1;padding:.35rem 0;border-bottom:1px solid rgba(255,255,255,.05);line-height:1.4}

/* ===== Magazine / revue (Phase 7) ===== */
.magwrap{max-width:760px;margin:2rem auto;padding:0 1rem}
.mag-head{text-align:center;margin-bottom:1.4rem}
.mag-h1{font-size:1.8rem;margin:.3rem 0 .4rem}
.mag-sub{color:var(--muted,#94a3b8);font-size:.92rem;max-width:34rem;margin:0 auto}
.mag-admin-bar{display:flex;justify-content:center;margin-bottom:1.2rem}
.mag-hero{background:linear-gradient(135deg,rgba(34,211,238,.1),rgba(168,85,247,.1));border:1px solid rgba(34,211,238,.25);border-radius:18px;padding:1.6rem;cursor:pointer;transition:.18s;margin-bottom:1.6rem}
.mag-hero:hover{border-color:rgba(34,211,238,.55);transform:translateY(-2px)}
.mag-hero-tag{font-size:.66rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:#22d3ee;margin-bottom:.5rem}
.mag-hero h2{font-size:1.5rem;margin:0 0 .4rem}
.mag-hero-sub{color:#cbd5e1;margin:0 0 .3rem}
.mag-meta{font-size:.78rem;color:var(--muted,#94a3b8)}
.mag-arch-h{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:#22d3ee;margin:1.4rem 0 .7rem}
.mag-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.9rem}
.mag-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:14px;padding:1.1rem;cursor:pointer;transition:.18s}
.mag-card:hover{border-color:rgba(34,211,238,.4);transform:translateY(-2px)}
.mag-card h3{font-size:1.05rem;margin:0 0 .35rem}
.mag-card p{font-size:.85rem;color:#cbd5e1;margin:0 0 .5rem}
.mag-back{background:none;border:none;color:#22d3ee;cursor:pointer;font:inherit;font-size:.9rem;padding:.3rem 0;margin-bottom:.8rem}
.mag-issue-head{margin-bottom:1.4rem;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:1.1rem}
.mag-issue-head h1{font-size:1.7rem;margin:.2rem 0 .4rem}
.mag-issue-sub{color:#cbd5e1;font-size:1.05rem;margin:0 0 .4rem}
.mag-intro{margin-top:.9rem;color:#e5e7eb;line-height:1.6;background:rgba(255,255,255,.03);border-left:3px solid #22d3ee;border-radius:0 10px 10px 0;padding:.8rem 1rem}
.mag-draft{font-size:.62rem;font-weight:800;letter-spacing:.12em;color:#fbbf24;border:1px solid rgba(251,191,36,.4);border-radius:999px;padding:.15rem .55rem;vertical-align:middle}
.mag-sec{margin-bottom:1.8rem}
.mag-sec-h{font-size:1.15rem;font-weight:800;margin-bottom:.8rem;padding-bottom:.4rem;border-bottom:1px solid rgba(255,255,255,.08)}
.mag-item{display:flex;gap:.9rem;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:1rem;margin-bottom:.8rem}
.mag-item-img{width:5.5rem;height:5.5rem;flex:none;border-radius:10px;background-size:cover;background-position:center}
.mag-item-body{flex:1;min-width:0}
.mag-item-body h4{font-size:1.05rem;margin:0 0 .25rem;line-height:1.3}
.mag-item-body h4 a{color:inherit;text-decoration:none}.mag-item-body h4 a:hover{color:#22d3ee}
.mag-item-src{font-size:.72rem;color:#22d3ee;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.35rem}
.mag-item-body p{font-size:.9rem;color:#cbd5e1;margin:0;line-height:1.5}
.mag-pulse-note{font-size:.75rem;color:var(--muted,#94a3b8);margin:-.3rem 0 .7rem}
.mag-adm-row{display:flex;align-items:center;gap:.7rem;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:.7rem .9rem;margin-bottom:.6rem}
.mag-adm-info{flex:1;min-width:0}
.mag-adm-acts{display:flex;gap:.4rem;flex:none}
.mag-adm-badge{font-size:.62rem;font-weight:800;letter-spacing:.08em;border-radius:999px;padding:.1rem .5rem}
.mag-adm-badge.pub{color:#34d399;border:1px solid rgba(52,211,153,.4)}
.mag-adm-badge.dft{color:#fbbf24;border:1px solid rgba(251,191,36,.4)}
.mag-rub-tag{font-size:.72rem;color:#a855f7}
/* ===== Affiliation (Phase 7) ===== */
.ng-inv-pts b{color:#a855f7!important}
.ng-inv-rank{text-align:center;font-size:.95rem;background:rgba(168,85,247,.08);border:1px solid rgba(168,85,247,.22);border-radius:10px;padding:.55rem;margin-bottom:1rem}
.ng-lead-row{display:flex;align-items:center;gap:.6rem;padding:.45rem 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:.88rem}
.ng-lead-rk{width:1.8rem;text-align:center;font-weight:800;flex:none}
.ng-lead-av{width:1.7rem;height:1.7rem;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;color:#04121a;font-weight:800;font-size:.78rem}
.ng-lead-dn{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ng-lead-pts{flex:none;color:#a855f7;font-weight:700}
.ng-aff-row{display:flex;align-items:center;gap:.6rem;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.05)}
.ng-aff-dn{flex:1;min-width:0;display:flex;flex-direction:column;font-size:.9rem}
.ng-aff-sub{font-size:.72rem;color:var(--muted,#94a3b8)}
.ng-mag-feat{font-size:.88rem;background:rgba(34,211,238,.07);border:1px solid rgba(34,211,238,.18);border-radius:10px;padding:.6rem .8rem;margin-bottom:.8rem}
.ng-mag-feat a{color:#22d3ee;font-weight:700}
