/* ============================================================================
   NEBULA AFFILIÉS — Système de design « Bureau Virtuel »
   Archétype : Ethereal Glass (OLED + orbes + verre vantablack + double-bezel)
   Tout piloté par --accent (personnalisable par chaque affilié).
   ============================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root{
  --bg:#060509; --bg-2:#0a0a12;
  --ink:#ECEAF6; --muted:#9d9db6; --faint:#6b6b86;
  --accent:#7b5cff; --accent-2:#22d3ee;
  --glass:rgba(255,255,255,.04); --glass-2:rgba(255,255,255,.06);
  --hair:rgba(255,255,255,.08); --hair-2:rgba(255,255,255,.15);
  --ok:#36f5a0; --warn:#f5b14c; --info:#4cc6ff; --bad:#ff5c7a; --gold:#e6c34c;
  --r:22px; --r-lg:30px; --r-sm:14px;
  --ease:cubic-bezier(.32,.72,0,1);
  --spring:cubic-bezier(.34,1.56,.64,1);
  --sh-soft:0 30px 80px -30px rgba(0,0,0,.8);
  --glow:0 0 0 1px color-mix(in srgb,var(--accent) 40%,transparent),0 16px 50px -12px color-mix(in srgb,var(--accent) 55%,transparent);
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  font-family:'Plus Jakarta Sans',system-ui,sans-serif;
  background:var(--bg); color:var(--ink); min-height:100dvh;
  font-weight:400; line-height:1.55; overflow-x:hidden;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{font-family:'Space Grotesk',sans-serif; font-weight:600; letter-spacing:-.02em; line-height:1.05}
.mono{font-family:'JetBrains Mono',monospace; font-variant-numeric:tabular-nums}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit}
::selection{background:color-mix(in srgb,var(--accent) 45%,transparent)}

/* ---- Décor : orbes + grain (fixes, pointer-events none) ---- */
.bg-orbs,.bg-grain{position:fixed;inset:0;pointer-events:none;z-index:0}
.bg-orbs{
  background:
    radial-gradient(38% 30% at 12% 8%, color-mix(in srgb,var(--accent) 30%,transparent), transparent 70%),
    radial-gradient(34% 28% at 88% 18%, rgba(34,211,238,.16), transparent 68%),
    radial-gradient(46% 38% at 70% 96%, color-mix(in srgb,var(--accent) 18%,transparent), transparent 72%),
    radial-gradient(40% 30% at 20% 88%, rgba(54,245,160,.08), transparent 70%);
  filter:saturate(1.1); animation:drift 26s var(--ease) infinite alternate;
}
@keyframes drift{from{transform:translate3d(-1.5%,-1%,0) scale(1)}to{transform:translate3d(1.5%,1.5%,0) scale(1.06)}}
.bg-grain{z-index:51;opacity:.035;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.stars{position:fixed;inset:0;z-index:0;pointer-events:none}

/* ---- Double-bezel (carte = plaque de verre dans une coque usinée) ---- */
.card{position:relative;background:var(--glass);border:1px solid var(--hair);
  border-radius:var(--r-lg);padding:7px;backdrop-filter:blur(2px)}
.card>.in{position:relative;background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.012));
  border:1px solid var(--hair);border-radius:calc(var(--r-lg) - 7px);padding:22px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08), var(--sh-soft)}
.card.glow>.in{box-shadow:inset 0 1px 0 rgba(255,255,255,.1), var(--glow)}

/* ---- Boutons (pill + button-in-button) ---- */
.btn{position:relative;display:inline-flex;align-items:center;gap:12px;
  padding:13px 16px 13px 22px;border-radius:999px;font-weight:600;font-size:.95rem;
  background:var(--glass-2);border:1px solid var(--hair-2);color:var(--ink);
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),background .3s var(--ease)}
.btn .ico{width:32px;height:32px;border-radius:999px;display:grid;place-items:center;
  background:rgba(255,255,255,.08);transition:transform .5s var(--spring),background .3s}
.btn .ico svg{width:16px;height:16px}
.btn:hover{transform:translateY(-2px);box-shadow:0 14px 34px -14px rgba(0,0,0,.7)}
.btn:hover .ico{transform:translate(3px,-1px) scale(1.08)}
.btn:active{transform:scale(.97)}
.btn.primary{background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 92%,white),var(--accent) 60%,color-mix(in srgb,var(--accent) 70%,black));
  color:#0a0712;border-color:rgba(255,255,255,.3);box-shadow:var(--glow)}
.btn.primary .ico{background:rgba(0,0,0,.18)}
.btn.ghost{background:transparent}
.btn.sm{padding:9px 12px 9px 16px;font-size:.85rem}
.btn.sm .ico{width:26px;height:26px}.btn.sm .ico svg{width:13px;height:13px}
.btn.block{width:100%;justify-content:center}

/* ---- Eyebrow / tags ---- */
.eyebrow{display:inline-flex;align-items:center;gap:8px;border-radius:999px;
  padding:6px 13px;font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  background:var(--glass-2);border:1px solid var(--hair);color:var(--muted)}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent)}

/* ---- Champs ---- */
.field{display:block;margin-bottom:16px}
.field label{display:block;font-size:.78rem;color:var(--muted);margin-bottom:8px;letter-spacing:.02em}
.field .wrap{background:var(--glass);border:1px solid var(--hair);border-radius:var(--r-sm);padding:3px}
.field input,.field select,.field textarea{width:100%;background:rgba(0,0,0,.25);border:1px solid var(--hair);
  border-radius:calc(var(--r-sm) - 3px);padding:14px 15px;color:var(--ink);font-size:16px;
  transition:border-color .4s var(--ease),box-shadow .4s var(--ease)}
.field textarea{resize:vertical;min-height:90px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;
  border-color:color-mix(in srgb,var(--accent) 60%,transparent);
  box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 16%,transparent)}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239d9db6' stroke-width='1.4' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center}

/* ---- App shell : dock + workspace ---- */
.app{position:relative;z-index:1;display:grid;grid-template-columns:88px 1fr;min-height:100dvh}
.dock{position:sticky;top:0;height:100dvh;display:flex;flex-direction:column;align-items:center;
  gap:8px;padding:20px 0;background:linear-gradient(180deg,rgba(12,12,20,.6),rgba(8,8,14,.4));
  border-right:1px solid var(--hair);backdrop-filter:blur(20px)}
.dock .logo{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;margin-bottom:14px;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#07060e;font-weight:700;
  font-family:'Space Grotesk';box-shadow:var(--glow)}
.nav-i{position:relative;width:50px;height:50px;border-radius:15px;display:grid;place-items:center;color:var(--muted);
  transition:color .4s var(--ease),background .4s var(--ease),transform .5s var(--spring)}
.nav-i svg{width:21px;height:21px}
.nav-i:hover{color:var(--ink);background:var(--glass-2);transform:translateY(-2px)}
.nav-i.on{color:var(--ink);background:color-mix(in srgb,var(--accent) 16%,transparent)}
.nav-i.on::before{content:"";position:absolute;left:-20px;top:50%;transform:translateY(-50%);
  width:4px;height:24px;border-radius:4px;background:var(--accent);box-shadow:0 0 14px var(--accent)}
.nav-i .badge{position:absolute;top:6px;right:6px;min-width:17px;height:17px;padding:0 4px;border-radius:9px;
  background:var(--bad);color:#fff;font-size:10px;font-weight:700;display:grid;place-items:center}
.nav-sp{flex:1}

.work{padding:26px clamp(18px,3.4vw,42px) 120px;max-width:1280px;width:100%;margin:0 auto}
.topbar{display:flex;align-items:center;gap:16px;justify-content:space-between;margin-bottom:30px;flex-wrap:wrap}
.topbar .who{display:flex;align-items:center;gap:14px}
.chip{display:inline-flex;align-items:center;gap:9px;padding:8px 14px;border-radius:999px;
  background:var(--glass-2);border:1px solid var(--hair);font-size:.82rem;color:var(--muted)}
.chip b{color:var(--ink)}
.icon-btn{width:42px;height:42px;border-radius:13px;display:grid;place-items:center;color:var(--muted);
  background:var(--glass-2);border:1px solid var(--hair);transition:all .4s var(--ease);position:relative}
.icon-btn:hover{color:var(--ink);transform:translateY(-2px)}
.icon-btn svg{width:19px;height:19px}
.icon-btn .badge{position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;
  background:var(--bad);color:#fff;font-size:10px;font-weight:700;display:grid;place-items:center}

/* ---- Vues (transitions « changement de pièce ») ---- */
.view{display:none}
.view.on{display:block;animation:roomIn .6s var(--ease) both}
@keyframes roomIn{from{opacity:0;transform:translateY(18px) scale(.99);filter:blur(8px)}to{opacity:1;transform:none;filter:blur(0)}}

/* ---- Grilles bento ---- */
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}
.col-3{grid-column:span 3}.col-4{grid-column:span 4}.col-5{grid-column:span 5}
.col-6{grid-column:span 6}.col-7{grid-column:span 7}.col-8{grid-column:span 8}.col-12{grid-column:span 12}

/* ---- Stat tiles ---- */
.stat .lbl{font-size:.74rem;text-transform:uppercase;letter-spacing:.14em;color:var(--faint);margin-bottom:10px}
.stat .num{font-family:'JetBrains Mono';font-size:2.4rem;font-weight:700;line-height:1;letter-spacing:-.02em}
.stat .sub{font-size:.82rem;color:var(--muted);margin-top:8px}
.stat .num.accent{color:var(--accent)}

/* ---- Barre d'XP ---- */
.xp{margin-top:14px}
.xp .track{height:12px;border-radius:999px;background:rgba(0,0,0,.4);border:1px solid var(--hair);overflow:hidden;position:relative}
.xp .fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--accent-2));
  box-shadow:0 0 18px color-mix(in srgb,var(--accent) 70%,transparent);width:0;transition:width 1.2s var(--ease);position:relative}
.xp .fill::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);
  transform:translateX(-100%);animation:shimmer 2.4s var(--ease) infinite}
@keyframes shimmer{to{transform:translateX(120%)}}
.xp .meta{display:flex;justify-content:space-between;margin-top:9px;font-size:.78rem;color:var(--muted)}

/* ---- Emblème de rang ---- */
.rank{display:flex;align-items:center;gap:18px}
.rank .emblem{position:relative;width:84px;height:84px;border-radius:24px;display:grid;place-items:center;
  font-size:2.4rem;background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.12),transparent 60%),var(--glass-2);
  border:1px solid var(--hair-2)}
.rank .emblem::before{content:"";position:absolute;inset:-2px;border-radius:26px;padding:2px;
  background:conic-gradient(from 0deg,var(--accent),var(--accent-2),var(--gold),var(--accent));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;
  animation:spin 7s linear infinite;opacity:.9}
@keyframes spin{to{transform:rotate(360deg)}}
.rank .r-name{font-family:'Space Grotesk';font-size:1.5rem;font-weight:700}
.rank .r-sub{font-size:.82rem;color:var(--muted)}

/* ---- Statut pills + point de paiement ---- */
.pill{display:inline-flex;align-items:center;gap:7px;padding:6px 13px;border-radius:999px;font-size:.78rem;font-weight:600;
  border:1px solid;background:color-mix(in srgb,var(--c) 14%,transparent);border-color:color-mix(in srgb,var(--c) 35%,transparent);color:var(--c)}
.pill .d{width:7px;height:7px;border-radius:50%;background:var(--c);box-shadow:0 0 8px var(--c)}
.pay{display:inline-flex;align-items:center;gap:8px;font-size:.8rem;font-weight:600}
.pay .dot{width:13px;height:13px;border-radius:50%;background:#3a3a48;border:1px solid var(--hair-2);transition:all .5s var(--spring)}
.pay.ok .dot{background:var(--ok);border-color:var(--ok);box-shadow:0 0 14px var(--ok),0 0 30px color-mix(in srgb,var(--ok) 50%,transparent);animation:payPulse 2s var(--ease) infinite}
.pay.ok{color:var(--ok)}
@keyframes payPulse{0%,100%{box-shadow:0 0 14px var(--ok)}50%{box-shadow:0 0 22px var(--ok),0 0 44px color-mix(in srgb,var(--ok) 60%,transparent)}}

/* ---- Tableaux / listes ---- */
.row{display:grid;align-items:center;gap:14px;padding:16px;border-radius:18px;background:var(--glass);
  border:1px solid var(--hair);margin-bottom:11px;transition:transform .4s var(--ease),border-color .4s,background .4s}
.row:hover{transform:translateY(-2px);border-color:var(--hair-2);background:var(--glass-2)}
.row .ttl{font-weight:600}.row .meta{font-size:.8rem;color:var(--muted)}
.avatar{width:42px;height:42px;border-radius:13px;display:grid;place-items:center;font-weight:700;font-family:'Space Grotesk';
  background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 80%,transparent),color-mix(in srgb,var(--accent-2) 70%,transparent));color:#07060e}

/* ---- Segmented (sélecteur de statut) ---- */
.seg{display:inline-flex;gap:4px;padding:4px;border-radius:999px;background:rgba(0,0,0,.3);border:1px solid var(--hair);flex-wrap:wrap}
.seg button{padding:7px 13px;border-radius:999px;font-size:.78rem;font-weight:600;color:var(--muted);transition:all .35s var(--ease)}
.seg button.on{background:color-mix(in srgb,var(--c,var(--accent)) 22%,transparent);color:var(--c,var(--ink))}

/* ---- NOVA (cerveau) ---- */
.nova-fab{position:fixed;right:26px;bottom:26px;z-index:60;width:64px;height:64px;border-radius:22px;display:grid;place-items:center;
  background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.25),transparent 55%),linear-gradient(135deg,var(--accent),var(--accent-2));
  box-shadow:var(--glow);transition:transform .5s var(--spring)}
.nova-fab:hover{transform:scale(1.08) rotate(-4deg)}
.nova-fab .pulse{position:absolute;inset:0;border-radius:22px;box-shadow:0 0 0 0 color-mix(in srgb,var(--accent) 60%,transparent);animation:ring 2.6s var(--ease) infinite}
@keyframes ring{to{box-shadow:0 0 0 26px transparent}}
.nova-panel{position:fixed;right:26px;bottom:104px;z-index:60;width:min(420px,calc(100vw - 36px));height:min(620px,70dvh);
  display:none;flex-direction:column;overflow:hidden;border-radius:26px;background:rgba(10,10,17,.86);
  border:1px solid var(--hair-2);backdrop-filter:blur(26px);box-shadow:var(--sh-soft)}
.nova-panel.on{display:flex;animation:roomIn .5s var(--ease) both}
.nova-head{display:flex;align-items:center;gap:12px;padding:18px;border-bottom:1px solid var(--hair)}
.nova-head .orb{width:38px;height:38px;border-radius:13px;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:var(--glow)}
.nova-log{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:14px}
.nova-msg{max-width:85%;padding:13px 15px;border-radius:17px;font-size:.9rem;line-height:1.5;white-space:pre-wrap}
.nova-msg.u{align-self:flex-end;background:color-mix(in srgb,var(--accent) 22%,transparent);border:1px solid color-mix(in srgb,var(--accent) 35%,transparent)}
.nova-msg.n{align-self:flex-start;background:var(--glass-2);border:1px solid var(--hair)}
.nova-foot{padding:14px;border-top:1px solid var(--hair);display:flex;gap:9px}
.nova-foot input{flex:1;background:rgba(0,0,0,.3);border:1px solid var(--hair);border-radius:14px;padding:13px 14px;color:var(--ink);font-size:16px}
.nova-foot input:focus{outline:none;border-color:color-mix(in srgb,var(--accent) 55%,transparent)}
.nova-send{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#07060e}
.typing{display:inline-flex;gap:4px}.typing i{width:7px;height:7px;border-radius:50%;background:var(--muted);animation:blink 1.2s infinite}
.typing i:nth-child(2){animation-delay:.2s}.typing i:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,60%,100%{opacity:.25;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}

/* ---- Toast ---- */
.toasts{position:fixed;top:20px;left:50%;transform:translateX(-50%);z-index:80;display:flex;flex-direction:column;gap:10px;align-items:center}
.toast{padding:13px 20px;border-radius:15px;background:rgba(12,12,20,.92);border:1px solid var(--hair-2);
  box-shadow:var(--sh-soft);font-size:.9rem;font-weight:500;animation:toastIn .5s var(--spring) both;display:flex;align-items:center;gap:10px}
.toast .bar{width:4px;height:22px;border-radius:4px;background:var(--accent)}
.toast.ok .bar{background:var(--ok)}.toast.bad .bar{background:var(--bad)}
@keyframes toastIn{from{opacity:0;transform:translateY(-14px) scale(.96)}to{opacity:1;transform:none}}

/* ---- Modal ---- */
.scrim{position:fixed;inset:0;z-index:70;background:rgba(4,4,8,.7);backdrop-filter:blur(10px);display:none;place-items:center;padding:20px}
.scrim.on{display:grid;animation:roomIn .4s var(--ease) both}
.modal{width:min(460px,100%);max-height:88dvh;overflow-y:auto}

/* ---- Reveal au scroll ---- */
.rv{opacity:0;transform:translateY(26px);filter:blur(6px);transition:opacity .8s var(--ease),transform .8s var(--ease),filter .8s var(--ease)}
.rv.in{opacity:1;transform:none;filter:blur(0)}

/* ---- Login / portail ---- */
.gate{min-height:100dvh;display:grid;place-items:center;padding:24px;position:relative;z-index:1}
.gate .box{width:min(440px,100%)}
.portal-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:26px}
.portal-card{cursor:pointer;transition:transform .6s var(--spring)}
.portal-card:hover{transform:translateY(-6px)}
.swatches{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}
.sw{width:34px;height:34px;border-radius:11px;cursor:pointer;border:2px solid transparent;transition:transform .4s var(--spring)}
.sw:hover{transform:scale(1.12)}.sw.on{border-color:#fff}

.muted{color:var(--muted)}.faint{color:var(--faint)}.center{text-align:center}
.flex{display:flex;align-items:center;gap:12px}.between{justify-content:space-between}.wrap{flex-wrap:wrap}
.gap8{gap:8px}.mt8{margin-top:8px}.mt16{margin-top:16px}.mt24{margin-top:24px}.mb8{margin-bottom:8px}.mb16{margin-bottom:16px}.mb24{margin-bottom:24px}
.grow{flex:1}.hide{display:none!important}
.big{font-size:clamp(2rem,5vw,3.2rem);line-height:1.02}
.lead{font-size:1.05rem;color:var(--muted)}
.divider{height:1px;background:var(--hair);margin:22px 0}

/* ---- Confetti ---- */
.confetti{position:fixed;inset:0;z-index:75;pointer-events:none}
/* ---- icône de rang (SVG pro) + badge de palier ---- */
.emblem svg{width:42px;height:42px;stroke:var(--accent);fill:none;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round}
.emblem.king svg{stroke:var(--gold)}
.pal-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:100px;font-family:'Space Grotesk';font-weight:700;font-size:.8rem;letter-spacing:.1em;
  background:color-mix(in srgb,var(--c) 15%,transparent);border:1px solid color-mix(in srgb,var(--c) 45%,transparent);color:var(--c)}
.pal-badge::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--c);box-shadow:0 0 10px var(--c)}
/* ---- arbre réseau (arborescence des filleuls) ---- */
.ntree{display:flex;flex-direction:column;gap:14px}
.nroot{display:inline-flex;align-items:center;gap:11px;padding:11px 18px;border-radius:14px;align-self:flex-start;font-family:'Space Grotesk';font-weight:700;
  background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 22%,transparent),transparent);border:1px solid color-mix(in srgb,var(--accent) 45%,transparent)}
.nroot svg{width:20px;height:20px;stroke:var(--accent);fill:none;stroke-width:1.5}
.nl1{padding:16px 18px}
.nl1 .nhead{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.nbadge{font-family:'Space Grotesk';font-weight:700;font-size:.66rem;letter-spacing:.08em;padding:3px 9px;border-radius:100px;
  background:color-mix(in srgb,var(--accent) 16%,transparent);border:1px solid color-mix(in srgb,var(--accent) 35%,transparent);color:var(--accent)}
.nbadge.n2{background:var(--glass2);border-color:var(--hair);color:var(--muted)}
.nkids{margin-top:12px;padding-top:12px;border-top:1px dashed var(--hair);display:flex;flex-direction:column;gap:8px}
.nkid{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 13px 9px 16px;border-radius:11px;flex-wrap:wrap;
  background:rgba(255,255,255,.02);border-left:2px solid color-mix(in srgb,var(--accent) 30%,transparent)}
.nkids .nl1{margin:0;background:rgba(255,255,255,.02)}
/* ---- didacticiel / guide ---- */
.tour-scrim .tour-card{width:min(540px,100%)}
.tour-ic{width:64px;height:64px;border-radius:18px;display:grid;place-items:center;
  background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 22%,transparent),transparent);border:1px solid color-mix(in srgb,var(--accent) 40%,transparent)}
.tour-ic svg{width:30px;height:30px;stroke:var(--accent);fill:none;stroke-width:1.5}
.tour-dot{width:7px;height:7px;border-radius:50%;background:var(--line2);transition:all .3s var(--ease)}
.tour-dot.on{background:var(--accent);box-shadow:0 0 8px var(--accent);width:18px;border-radius:4px}

/* ---- Mobile ---- */
@media(max-width:860px){
  .app{grid-template-columns:1fr}
  .dock{position:fixed;bottom:0;top:auto;left:0;right:0;height:auto;flex-direction:row;justify-content:space-around;
    padding:8px 10px;border-right:none;border-top:1px solid var(--hair);z-index:40;gap:4px}
  .dock .logo,.nav-sp{display:none}
  .nav-i.on::before{left:50%;top:-8px;transform:translateX(-50%);width:24px;height:4px}
  .work{padding:18px 16px 110px}
  .col-3,.col-4,.col-5,.col-6,.col-7,.col-8{grid-column:span 12}
  .portal-grid{grid-template-columns:1fr}
  .nova-panel{right:12px;left:12px;bottom:92px;width:auto}
  .nova-fab{right:16px;bottom:78px}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition-duration:.01ms!important}}

/* ---- Documentation · Publication · CGU (onglets pro) ---- */
.cgu-box{max-height:46vh;overflow-y:auto;padding:18px 20px;border:1px solid var(--hair);border-radius:18px;background:rgba(0,0,0,.25)}
.cgu-box h3{font-family:'Space Grotesk';font-size:1.05rem;margin:0 0 6px;color:var(--ink)}
.cgu-box h4{font-family:'Space Grotesk';font-size:.92rem;color:var(--ink);margin:15px 0 4px}
.cgu-box p{font-size:.85rem;line-height:1.6;color:var(--muted);margin:0 0 6px}
.cgu-box ul{margin:4px 0 8px;padding-left:18px}
.cgu-box li{font-size:.85rem;line-height:1.55;color:var(--muted);margin:2px 0}
.cgu-box::-webkit-scrollbar{width:8px}.cgu-box::-webkit-scrollbar-thumb{background:var(--hair-2);border-radius:8px}
.accept-row{display:flex;gap:12px;align-items:flex-start;margin-top:16px;padding:14px 16px;border:1px solid var(--hair);border-radius:14px;cursor:pointer;font-size:.9rem;line-height:1.5;color:var(--muted);transition:border-color .3s,background .3s;user-select:none}
.accept-row:hover{border-color:var(--hair-2);background:rgba(255,255,255,.02)}
.cbx{flex:0 0 22px;width:22px;height:22px;border-radius:7px;border:1.6px solid var(--hair-2);display:grid;place-items:center;transition:all .3s var(--ease);margin-top:1px}
.cbx.on{background:linear-gradient(135deg,var(--accent),var(--accent-2));border-color:transparent}
.cbx.on::after{content:'';width:11px;height:6px;border-left:2px solid #07060e;border-bottom:2px solid #07060e;transform:rotate(-45deg) translateY(-1px)}
.cat-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.cat-tab{padding:7px 14px;border-radius:999px;font-size:.8rem;font-weight:600;color:var(--muted);background:rgba(255,255,255,.03);border:1px solid var(--hair);cursor:pointer;transition:all .3s var(--ease)}
.cat-tab.on{color:#07060e;background:linear-gradient(135deg,var(--accent),var(--accent-2));border-color:transparent}
.pub-body{white-space:pre-wrap;font-size:.9rem;line-height:1.6;color:var(--ink);background:rgba(0,0,0,.22);border:1px solid var(--hair);border-radius:14px;padding:14px 16px;margin-top:12px}
.plat-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;font-size:.72rem;font-weight:600;color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,transparent);border:1px solid color-mix(in srgb,var(--accent) 30%,transparent)}
.new-badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:999px;font-size:.66rem;font-weight:700;letter-spacing:.05em;color:#07060e;background:linear-gradient(135deg,var(--ok),var(--accent-2))}
.upzone{border:1.5px dashed var(--hair-2);border-radius:14px;padding:18px;text-align:center;color:var(--muted);font-size:.85rem;cursor:pointer;transition:all .3s}
.upzone:hover{border-color:var(--accent);color:var(--ink)}
.doc-read{max-height:62vh;overflow-y:auto;padding:4px 2px}
.doc-read h4{font-family:'Space Grotesk';color:var(--ink);margin:16px 0 5px;font-size:1rem}
.doc-read p{color:var(--muted);line-height:1.65;margin:0 0 8px;font-size:.92rem}
.doc-read ul{padding-left:18px;margin:4px 0 10px}.doc-read li{color:var(--muted);line-height:1.6;margin:3px 0;font-size:.92rem}
.doc-read b{color:var(--ink)}
.dico{flex:0 0 44px;width:44px;height:44px;border-radius:13px;display:grid;place-items:center;background:rgba(255,255,255,.04);border:1px solid var(--hair)}
.dico svg{width:21px;height:21px;stroke:var(--accent);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}

/* ---- Photo de profil ---- */
.pfp{border-radius:50%;object-fit:cover;background:rgba(255,255,255,.05);border:1px solid var(--hair-2);display:block}
.pfp-wrap{position:relative;width:max-content}
.pfp-edit{position:absolute;right:-2px;bottom:-2px;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),var(--accent-2,#22d3ee));cursor:pointer;border:2px solid var(--bg,#0b0b12)}
.pfp-edit svg{width:16px;height:16px;stroke:#07060e;fill:none}
.av-img{width:100%;height:100%;object-fit:cover;border-radius:inherit}

/* ---- Logo NEBULA (marque) + filigrane de fond ---- */
.logo img,.brandmark{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}
.bg-orbs::after{content:"";position:fixed;inset:0;background:url(/static/nebula-logo.png) no-repeat center 20% / min(500px,68vw) auto;opacity:.05;pointer-events:none}

/* ---- Classement ---- */
.lb-row{display:grid;grid-template-columns:38px 48px 1fr auto;gap:14px;align-items:center;padding:13px 16px;border:1px solid var(--hair);border-radius:16px;background:rgba(255,255,255,.02);margin-bottom:10px;transition:border-color .3s,transform .35s var(--ease)}
.lb-row.me{border-color:color-mix(in srgb,var(--accent) 50%,transparent);background:color-mix(in srgb,var(--accent) 9%,transparent)}
.lb-row:hover{border-color:var(--hair-2);transform:translateX(3px)}
.lb-pos{font-family:'JetBrains Mono',monospace;font-weight:700;font-size:1.05rem;color:var(--muted);text-align:center}
.lb-pos.top{color:var(--gold)}
.lb-ava{width:46px;height:46px;border-radius:14px;background:rgba(255,255,255,.05);border:1px solid var(--hair-2);display:grid;place-items:center;font-weight:700;font-family:'Space Grotesk';overflow:hidden}

/* ---- Messagerie ---- */
.chat-wrap{position:relative;display:grid;grid-template-columns:300px 1fr;border:1px solid var(--hair);border-radius:22px;overflow:hidden;height:min(72vh,620px);background:rgba(0,0,0,.18)}
.chat-side{border-right:1px solid var(--hair);overflow-y:auto;background:rgba(255,255,255,.015)}
.chat-sechead{font-family:'JetBrains Mono',monospace;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);padding:14px 14px 6px}
.chat-contact{display:grid;grid-template-columns:44px 1fr auto;gap:11px;align-items:center;padding:12px 14px;cursor:pointer;border-bottom:1px solid var(--hair);transition:background .25s}
.chat-contact:hover{background:rgba(255,255,255,.035)}
.chat-contact.on{background:color-mix(in srgb,var(--accent) 13%,transparent)}
.chat-ava{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid var(--hair-2);display:grid;place-items:center;font-weight:700;overflow:hidden;flex-shrink:0}
.chat-ava.grp{background:linear-gradient(135deg,var(--accent),var(--accent-2,#22d3ee))}
.chat-ava.grp svg{width:22px;height:22px;stroke:#07060e;fill:none}
.chat-cdot{min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:linear-gradient(135deg,var(--accent),var(--accent-2,#22d3ee));color:#07060e;font-size:.7rem;font-weight:800;display:grid;place-items:center}
.chat-conv{display:flex;flex-direction:column;min-width:0}
.chat-head{display:flex;align-items:center;gap:11px;padding:12px 16px;border-bottom:1px solid var(--hair);background:rgba(255,255,255,.02)}
.chat-back{display:none}
.chat-msgs{flex:1;overflow-y:auto;padding:18px 16px;display:flex;flex-direction:column;gap:12px}
.msg{display:flex;gap:9px;max-width:80%;align-items:flex-end}
.msg.me{align-self:flex-end;flex-direction:row-reverse}
.msg-ava{width:30px;height:30px;border-radius:50%;flex-shrink:0;background:rgba(255,255,255,.06);display:grid;place-items:center;font-size:.7rem;font-weight:700;overflow:hidden}
.msg-col{min-width:0}
.msg-bub{padding:10px 14px;border-radius:16px;background:rgba(255,255,255,.05);border:1px solid var(--hair);font-size:.9rem;line-height:1.45;word-break:break-word;white-space:pre-wrap}
.msg.me .msg-bub{background:color-mix(in srgb,var(--accent) 20%,transparent);border-color:color-mix(in srgb,var(--accent) 35%,transparent)}
.msg-name{font-size:.72rem;color:var(--muted);margin-bottom:3px;font-weight:600}
.msg-time{font-size:.64rem;color:var(--faint);margin-top:3px}
.chat-foot{display:flex;gap:9px;padding:12px;border-top:1px solid var(--hair);background:rgba(255,255,255,.02)}
.chat-foot input{flex:1;background:rgba(0,0,0,.3);border:1px solid var(--hair);border-radius:999px;padding:11px 16px;color:var(--ink);font-family:inherit;font-size:.9rem;outline:none}
.chat-foot input:focus{border-color:var(--accent)}
.chat-sendbtn{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),var(--accent-2,#22d3ee));cursor:pointer;flex-shrink:0;border:none}
.chat-sendbtn svg{width:20px;height:20px;stroke:#07060e;fill:none}
.chat-empty{flex:1;display:grid;place-items:center;color:var(--muted);text-align:center;padding:30px}
@media(max-width:860px){
  .chat-wrap{grid-template-columns:1fr;height:min(74vh,620px)}
  .chat-side{position:absolute;inset:0;z-index:2;border-right:none}
  .chat-wrap.conv-open .chat-side{display:none}
  .chat-conv{display:none}
  .chat-wrap.conv-open .chat-conv{display:flex}
  .chat-back{display:grid;place-items:center;width:34px;height:34px;border-radius:10px;background:rgba(255,255,255,.05);cursor:pointer;flex-shrink:0}
  .chat-back svg{width:18px;height:18px;stroke:var(--ink);fill:none}
  .lb-row{grid-template-columns:30px 42px 1fr auto;gap:10px;padding:11px 12px}
}
