:root{--bg:#0b1220;--card:#0f172a;--fg:#e2e8f0;--muted:#94a3b8;--accent:#60a5fa}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font:16px/1.5 system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial,sans-serif}
.container{max-width:860px;margin:8vh auto;padding:24px}
.card{background:var(--card);border-radius:16px;padding:28px;box-shadow:0 10px 30px rgba(2,8,23,.25);margin-bottom:16px}
h1{margin:0 0 8px;font-size:clamp(24px,4vw,36px)} p{color:var(--muted);margin:0 0 12px}
label{display:block;margin:10px 0 6px}
input,textarea,select{width:100%;padding:10px 12px;border-radius:12px;border:1px solid #1e293b;background:#0b1120;color:var(--fg)}
button{cursor:pointer;border:0;border-radius:12px;padding:10px 14px;background:var(--accent);color:#020617;font-weight:600}
button.secondary{background:#1f2937;color:#e2e8f0}
.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.alert{margin-top:12px;padding:10px 12px;border-radius:10px;background:#0b1120;border:1px solid #1f2937}
.badge{display:inline-block;padding:4px 8px;border-radius:999px;background:#0b1120;border:1px solid #1f2937;color:#cbd5e1;font-size:12px}
small{color:#94a3b8}
a{color:#a5b4fc;text-decoration:none} a:hover{text-decoration:underline}
/* --- Chat layout --- */
.chat{
  display:grid;
  grid-template-columns: 320px 1fr; /* colonne de gauche / panneau de droite */
  gap:24px;
  align-items:start;
}

.chat-list{
  max-height: calc(100vh - 220px);
  overflow:auto;
  padding-right:8px;
}

/* élément d'une ligne de la liste */
.chat-item{
  display:grid;
  grid-template-columns: 48px 1fr;
  gap:12px;
  align-items:center;
  padding:8px 10px;
  border-radius:10px;
  cursor:pointer;
}
.chat-item:hover{ background: rgba(255,255,255,.05); }
.chat-item.active{ background: rgba(255,255,255,.08); }

/* avatar: taille fixe et rognage propre */
.avatar{
  width:48px;
  height:48px;
  border-radius:50%;
  object-fit:cover;
}

/* panneau de conversation */
.chat-panel{
  display:flex;
  flex-direction:column;
  height: calc(100vh - 220px);
}

/* liste des messages */
.messages{
  flex:1;
  overflow:auto;
  display:flex;
  flex-direction:column;
  gap:8px;
}

/* bulles */
.msg{
  max-width:72%;
  padding:10px 12px;
  border-radius:14px;
  word-wrap:break-word;
}
.msg.me{
  align-self:flex-end;
  background:#3b82f6;
  color:#fff;
  border-bottom-right-radius:4px;
}
.msg.them{
  align-self:flex-start;
  background:rgba(255,255,255,.08);
  border-bottom-left-radius:4px;
}

/* zone de saisie */
.composer{
  display:flex;
  gap:8px;
  margin-top:12px;
}
.composer input{ flex:1; }
