/* ============================================================================
   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;
  animation:badgePop .45s var(--ease) both,badgePulse 2.4s ease-in-out infinite}
@keyframes badgePop{from{transform:scale(0)}60%{transform:scale(1.25)}to{transform:scale(1)}}
@keyframes badgePulse{0%,100%{box-shadow:0 0 0 0 color-mix(in srgb,var(--bad) 65%,transparent)}55%{box-shadow:0 0 0 7px transparent}}
.bell-ring{animation:bellShake .7s var(--ease)}
@keyframes bellShake{0%,100%{transform:none}15%{transform:rotate(-14deg)}30%{transform:rotate(11deg)}45%{transform:rotate(-8deg)}60%{transform:rotate(6deg)}75%{transform:rotate(-3deg)}}
/* pastille de type dans la fenêtre de notifications */
.ndot{width:9px;height:9px;border-radius:50%;flex:0 0 auto;margin-top:5px;box-shadow:0 0 8px currentColor}
.nhead{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--muted);margin-bottom:12px}
.nhead .pill{background:var(--bad);color:#fff;font-weight:700;border-radius:9px;padding:1px 8px;font-size:.78rem}

/* ---- 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)}}

/* ---- « Discuter avec NEBULA Agency » (assistant public) ---- */
.ag-fab{position:fixed;bottom:26px;z-index:60;display:inline-flex;align-items:center;gap:10px;
  padding:13px 18px;border-radius:40px;border:1px solid rgba(255,255,255,.22);cursor:pointer;font-family:inherit;
  background:linear-gradient(100deg,var(--accent),var(--accent-2));color:#07060e;font-weight:700;font-size:.84rem;
  box-shadow:0 12px 30px -10px color-mix(in srgb,var(--accent) 75%,transparent);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.ag-fab.right{right:26px}.ag-fab.left{left:26px}
.ag-fab.above{right:26px;bottom:100px}
.ag-fab:hover{transform:translateY(-3px);box-shadow:0 16px 38px -10px color-mix(in srgb,var(--accent) 85%,transparent)}
.ag-fab .ag-dot{width:9px;height:9px;border-radius:50%;background:#07060e;animation:blink 1.5s infinite;flex:0 0 auto}
.nova-panel.ag.left{right:auto;left:26px}
@media(max-width:680px){
  .ag-fab{font-size:.76rem;padding:11px 14px;bottom:16px}
  .ag-fab.right{right:12px}.ag-fab.left{left:12px}
  .ag-fab.above{right:12px;bottom:148px}
  .ag-fab .ag-lbl{max-width:42vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .nova-panel.ag{left:12px;right:12px;bottom:84px;width:auto}
}

/* ---- INSIGNES DE RANG : un médaillon unique par rang ---- */
.rk{position:relative;display:inline-grid;place-items:center;flex:0 0 auto;border-radius:50%;
  background:radial-gradient(120% 120% at 30% 25%,color-mix(in srgb,var(--c1) 92%,#fff 8%),var(--c2) 75%);
  box-shadow:inset 0 1px 2px rgba(255,255,255,.5),inset 0 -3px 8px color-mix(in srgb,var(--c2) 60%,#000 40%),
    0 6px 16px -6px color-mix(in srgb,var(--c2) 75%,transparent);isolation:isolate}
.rk.no-glow{box-shadow:inset 0 1px 2px rgba(255,255,255,.5),inset 0 -3px 8px color-mix(in srgb,var(--c2) 60%,#000 40%)}
.rk-xs{width:20px;height:20px}.rk-sm{width:30px;height:30px}.rk-md{width:46px;height:46px}.rk-lg{width:86px;height:86px}
.rk-xs .rk-core svg{width:11px;height:11px}.rk-xs .rk-ring{inset:-2px}
.rk-core{display:grid;place-items:center;z-index:2}
.rk-core svg{stroke:#fff;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.45))}
.rk-sm .rk-core svg{width:15px;height:15px}.rk-md .rk-core svg{width:23px;height:23px}.rk-lg .rk-core svg{width:42px;height:42px}
.rk-core::after{content:"";position:absolute;inset:14% 0 auto 0;height:34%;margin:0 16%;border-radius:50%;
  background:linear-gradient(rgba(255,255,255,.55),transparent);z-index:3;pointer-events:none}
/* Anneaux */
.rk-ring{position:absolute;inset:-5px;border-radius:50%;z-index:1;pointer-events:none}
.ring-solid .rk-ring{border:2px solid color-mix(in srgb,var(--c1) 70%,transparent)}
.ring-orbit .rk-ring{border:1.5px dashed color-mix(in srgb,var(--c1) 75%,transparent);animation:rkspin 9s linear infinite}
.ring-rays .rk-ring{background:conic-gradient(from 0deg,color-mix(in srgb,var(--c1) 85%,transparent) 0 3deg,transparent 3deg 30deg);
  -webkit-mask:radial-gradient(transparent 58%,#000 60%);mask:radial-gradient(transparent 58%,#000 60%);animation:rkspin 14s linear infinite}
.ring-burst .rk-ring{border:2px solid color-mix(in srgb,var(--c1) 70%,transparent);animation:rkpulse 2.4s ease-in-out infinite}
.ring-cosmic .rk-ring{inset:-4px;background:conic-gradient(from 0deg,#ffe9a8,#ff8ad4,#6d3bff,#67e8ff,#4df0a6,#ffe9a8);
  -webkit-mask:radial-gradient(transparent 60%,#000 62%);mask:radial-gradient(transparent 60%,#000 62%);animation:rkspin 6s linear infinite}
.ring-cosmic.rk{box-shadow:inset 0 1px 2px rgba(255,255,255,.6),inset 0 -3px 8px color-mix(in srgb,var(--c2) 55%,#000 45%),
    0 0 22px -2px color-mix(in srgb,var(--c1) 70%,transparent),0 8px 22px -6px color-mix(in srgb,var(--c2) 80%,transparent)}
@keyframes rkspin{to{transform:rotate(360deg)}}
@keyframes rkpulse{0%,100%{box-shadow:0 0 0 0 color-mix(in srgb,var(--c1) 55%,transparent)}55%{box-shadow:0 0 0 7px transparent}}
@media(prefers-reduced-motion:reduce){.rk-ring{animation:none!important}}
/* Nom du rang coloré assorti */
.rk-name{font-weight:700;background:linear-gradient(90deg,var(--c1),var(--c2));-webkit-background-clip:text;
  background-clip:text;color:transparent;letter-spacing:.01em}

/* ---- Échelle des rangs (modale) ---- */
.rl-card{width:min(460px,calc(100vw - 32px));max-height:88dvh;overflow-y:auto;background:var(--glass);border:1px solid var(--hair-2);border-radius:24px}
.rl-bar{height:8px;border-radius:6px;background:rgba(255,255,255,.07);overflow:hidden;margin:14px 0 18px}
.rl-bar span{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--accent),var(--accent-2));box-shadow:var(--glow)}
.rl-list{display:flex;flex-direction:column;gap:8px}
.rl-row{display:grid;grid-template-columns:auto 1fr auto;gap:13px;align-items:center;padding:10px 13px;border-radius:14px;border:1px solid var(--hair);background:rgba(255,255,255,.02);transition:all .25s var(--ease)}
.rl-row.cur{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 30%,transparent)}
.rl-row.lock{opacity:.5}
.rl-tx b{display:block;font-family:'Space Grotesk';font-size:.98rem;line-height:1.1}
.rl-tx small{font-size:.76rem;color:var(--muted)}
.rl-st svg{width:18px;height:18px}
.rl-ok{color:var(--ok)}.rl-lock{color:var(--faint)}
.rl-you{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#07060e;background:linear-gradient(100deg,var(--accent-2),var(--accent));padding:4px 10px;border-radius:20px}
.rl-paltitle{margin:20px 0 10px;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.rl-pals{display:flex;gap:9px}
.rl-pal{flex:1;text-align:center;padding:12px 8px;border-radius:13px;background:rgba(255,255,255,.03);border:1px solid var(--hair)}
.rl-pal b{display:block;font-family:'Space Grotesk';font-size:.84rem}
.rl-pal small{display:block;font-size:.68rem;color:var(--muted);margin:3px 0 6px}
.rl-pal em{font-style:normal;font-family:'Space Grotesk';font-weight:700;font-size:1.1rem;background:linear-gradient(100deg,var(--accent-2),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}
.rl-foot{margin-top:16px;font-size:.74rem;color:var(--muted);text-align:center;border-top:1px solid var(--hair);padding-top:12px}
.rank-click{cursor:pointer;transition:transform .2s var(--ease)}
.rank-click:hover{transform:translateY(-1px);filter:brightness(1.12)}
.clickable{cursor:pointer}
.card.clickable:hover{border-color:var(--hair-2)}
.tap-hint{font-size:.6rem;letter-spacing:.04em;text-transform:none;color:var(--accent);background:color-mix(in srgb,var(--accent) 15%,transparent);border:1px solid color-mix(in srgb,var(--accent) 32%,transparent);border-radius:20px;padding:2px 8px;margin-left:7px;font-weight:600;vertical-align:middle}

/* ---- Recherche + filtres du chat ---- */
.chat-search{position:sticky;top:0;z-index:3;background:var(--bg-2,rgba(12,12,20,.92));backdrop-filter:blur(8px);padding:12px 12px 8px;border-bottom:1px solid var(--hair)}
.chat-search .cs-box{display:flex;align-items:center;gap:9px;background:rgba(0,0,0,.3);border:1px solid var(--hair);border-radius:13px;padding:9px 12px}
.chat-search .cs-box:focus-within{border-color:color-mix(in srgb,var(--accent) 55%,transparent)}
.chat-search .cs-box svg{width:16px;height:16px;color:var(--muted);flex:0 0 auto}
.chat-search input{flex:1;background:none;border:none;outline:none;color:var(--ink);font-size:15px;min-width:0}
.chat-filters{display:flex;gap:6px;flex-wrap:wrap;margin-top:9px}
.chat-chip{font-size:.72rem;font-weight:600;letter-spacing:.02em;color:var(--muted);background:rgba(255,255,255,.04);border:1px solid var(--hair);border-radius:20px;padding:5px 11px;cursor:pointer;transition:all .2s var(--ease);white-space:nowrap}
.chat-chip:hover{color:var(--ink);border-color:var(--hair-2)}
.chat-chip.on{color:#07060e;background:linear-gradient(100deg,var(--accent-2),var(--accent));border-color:transparent}
.chat-empty-filter{padding:24px 16px;text-align:center;color:var(--muted);font-size:.86rem}
.chat-rankmeta{display:flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-rankmeta .rk{flex:0 0 auto}
.chat-sortrow{display:flex;align-items:center;gap:8px;margin-top:9px}
.chat-sortrow label{font-size:.7rem;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.chat-sort{flex:1;background:rgba(0,0,0,.3);border:1px solid var(--hair);border-radius:10px;padding:7px 10px;color:var(--ink);font-size:.82rem;font-family:inherit}
.chat-sort:focus{outline:none;border-color:color-mix(in srgb,var(--accent) 55%,transparent)}

/* ---- Fiche partenaire (stats) ---- */
.pstats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.pstat{padding:13px 12px;border-radius:14px;background:var(--glass);border:1px solid var(--hair);text-align:center}
.pstat-n{font-size:1.12rem;font-weight:700;color:var(--accent);line-height:1.1}
.pstat-l{font-size:.72rem;color:var(--muted);margin-top:4px;letter-spacing:.02em}
@media(max-width:560px){.pstats{grid-template-columns:repeat(2,1fr)}}

/* ---- Schéma d'équipe (parrain → toi → filleuls) + note anti-Ponzi ---- */
.anti-ponzi{display:flex;gap:13px;align-items:flex-start;padding:14px 16px;border-radius:14px;
  background:linear-gradient(135deg,color-mix(in srgb,var(--ok) 14%,transparent),transparent);
  border:1px solid color-mix(in srgb,var(--ok) 35%,transparent);font-size:.85rem;line-height:1.55;color:var(--muted)}
.anti-ponzi .ap-ico{flex:0 0 auto;width:34px;height:34px;border-radius:10px;display:grid;place-items:center;
  background:color-mix(in srgb,var(--ok) 20%,transparent);color:var(--ok)}
.anti-ponzi .ap-ico svg{width:18px;height:18px}
.anti-ponzi b{color:var(--ink);font-weight:600}
.pyr{display:flex;flex-direction:column;align-items:center;text-align:center;margin-top:22px}
.pyr-lvl{display:flex;justify-content:center;gap:14px}
.pyr-lvl.wrap{flex-wrap:wrap;align-items:flex-start}
.pyr-conn{width:2px;height:24px;background:linear-gradient(var(--hair-2),color-mix(in srgb,var(--hair-2) 20%,transparent))}
.pyr-team-lbl{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin:6px 0 14px}
.pyr-node{display:flex;align-items:center;gap:11px;padding:12px 16px;border-radius:15px;background:var(--glass);
  border:1px solid var(--hair);text-align:left;min-width:186px;transition:transform .3s var(--ease),border-color .3s var(--ease)}
.pyr-node:hover{border-color:var(--hair-2);transform:translateY(-2px)}
.pyr-av{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;flex:0 0 auto;overflow:hidden;
  background:var(--glass-2);border:1px solid var(--hair);font-weight:700;color:var(--accent)}
.pyr-av.sm{width:32px;height:32px;font-size:.78rem}
.pyr-av svg{width:20px;height:20px;color:var(--accent)}
.pyr-av .av-img{width:100%;height:100%;object-fit:cover}
.pyr-tx b{display:block;font-weight:600;font-size:.92rem;line-height:1.25}
.pyr-tx small{color:var(--muted);font-size:.74rem}
.pyr-node.me{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 13%,transparent);
  box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 30%,transparent),var(--glow);transform:scale(1.05)}
.pyr-node.me:hover{transform:scale(1.05) translateY(-2px)}
.pyr-node.par,.pyr-node.top{border-style:dashed;opacity:.9}
.pyr-branch{display:flex;flex-direction:column;align-items:center}
.pyr-subconn{width:2px;height:15px;background:var(--hair-2)}
.pyr-kids{display:flex;flex-direction:column;gap:7px}
.pyr-node.n2{min-width:158px;padding:8px 12px}
.pyr-empty{color:var(--muted);font-size:.86rem;max-width:380px}
@media(max-width:680px){
  .pyr-lvl.wrap{flex-direction:column;align-items:center}
  .pyr-node{min-width:0;width:100%;max-width:300px}
}

/* ---- 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:flex-start;
    padding:8px 8px;border-right:none;border-top:1px solid var(--hair);z-index:40;gap:4px;
    overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .dock::-webkit-scrollbar{display:none}
  .dock .nav-i{flex:0 0 auto}
  .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}
}
