/*
 * OXS Chat Widget — chat-widget.css
 * Light mode · Poppins · Accent #d62153
 * UX-first: warm cream palette, clear hierarchy, micro-interactions
 */

/* ── Variables ──────────────────────────────────────────────── */
#chat-widget {
  /* Wrapper sorti du flow (zéro impact layout sur le footer/body) :
     position fixed 0×0 + pointer-events disabled. Les enfants
     (chat-fab, chat-panel) ont chacun leur propre position:fixed
     calculée relativement au viewport, donc ils restent positionnés
     correctement et cliquables (chacun ré-active pointer-events). */
  position: fixed;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  pointer-events: none;
  z-index: 9000;
  /* UX mobile : pas de flash bleu/gris au tap, pas de menu contextuel inutile */
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;

  --chat-bg:           #ffffff;
  --chat-bg2:          #f7f5f2;
  --chat-bg3:          #ede9e4;
  --chat-border:       #e8e4de;
  --chat-accent:       #d62153;
  --chat-accent-h:     #b81944;
  --chat-accent-soft:  rgba(214,33,83,.08);
  --chat-accent-soft2: rgba(214,33,83,.14);
  --chat-text:         #1c1917;
  --chat-text-muted:   #79716b;
  --chat-text-faint:   #b0a89f;
  --chat-bubble-me:    #d62153;
  --chat-bubble-other: #ede9e4;
  --chat-radius:       16px;
  --chat-shadow:       0 16px 48px rgba(0,0,0,.10), 0 2px 8px rgba(0,0,0,.06);
  --chat-w:            370px;
  --chat-h:            540px;
  --chat-z:            9000;
  font-family: 'Poppins', sans-serif;
}

/* ── Bouton flottant ─────────────────────────────────────────── */
#chat-widget .chat-fab {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: var(--chat-z);
  pointer-events: auto; /* ré-active les clics (parent les bloque) */
  touch-action: manipulation; /* supprime le délai 300ms iOS, pas de zoom double-tap */
  -webkit-tap-highlight-color: transparent;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--chat-accent);
  color: #fff;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(214,33,83,.45), 0 1px 4px rgba(0,0,0,.1);
  transition: transform .18s ease, background .18s ease, box-shadow .18s ease;
}
#chat-widget .chat-fab:hover {
  background: var(--chat-accent-h);
  transform: scale(1.07);
  box-shadow: 0 8px 28px rgba(214,33,83,.55);
}
#chat-widget .chat-fab:active { transform: scale(.95); }
#chat-widget .chat-fab:focus-visible {
  outline: 2px solid var(--chat-accent);
  outline-offset: 3px;
}
/* Pulse quand messages non lus (classe ajoutée par JS) */
#chat-widget .chat-fab--pulse {
  animation: chat-fab-pulse 2.4s cubic-bezier(.4,0,.6,1) infinite;
}
@keyframes chat-fab-pulse {
  0%, 100% { box-shadow: 0 4px 20px rgba(214,33,83,.45), 0 0 0 0 rgba(214,33,83,0); }
  45%       { box-shadow: 0 6px 28px rgba(214,33,83,.6),  0 0 0 10px rgba(214,33,83,.08); }
  70%       { box-shadow: 0 6px 28px rgba(214,33,83,.55), 0 0 0 14px rgba(214,33,83,0); }
}

#chat-widget .chat-fab-badge {
  position: absolute;
  top: -3px;
  right: -3px;
  min-width: 20px;
  height: 20px;
  padding: 0 5px;
  border-radius: 10px;
  background: #fff;
  color: var(--chat-accent);
  font-size: 11px;
  font-weight: 700;
  line-height: 20px;
  text-align: center;
  box-shadow: 0 1px 4px rgba(0,0,0,.15);
  animation: chat-badge-pop .2s ease;
}
@keyframes chat-badge-pop {
  from { transform: scale(0); }
  to   { transform: scale(1); }
}

/* ── Panneau ─────────────────────────────────────────────────── */
#chat-widget .chat-panel {
  position: fixed;
  bottom: 90px;
  right: 24px;
  z-index: var(--chat-z);
  pointer-events: auto; /* ré-active (parent #chat-widget les bloque) */
  width: var(--chat-w);
  height: var(--chat-h);
  background: var(--chat-bg);
  border: 1px solid var(--chat-border);
  border-radius: var(--chat-radius);
  box-shadow: var(--chat-shadow);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transform-origin: bottom right;
  animation: chat-open .22s cubic-bezier(.34,1.15,.64,1);
}
@keyframes chat-open {
  from { opacity: 0; transform: scale(.88) translateY(12px); }
  to   { opacity: 1; transform: scale(1)  translateY(0); }
}
#chat-widget .chat-panel[hidden] { display: none !important; }
/* Bande d'accent en haut du panneau — identité visuelle immédiate */
#chat-widget .chat-panel::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--chat-accent) 0%, #f472b6 50%, var(--chat-accent) 100%);
  z-index: 2;
  pointer-events: none;
  border-radius: var(--chat-radius) var(--chat-radius) 0 0;
}

/* ── Header ──────────────────────────────────────────────────── */
#chat-widget .chat-panel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 14px 10px;
  background: var(--chat-bg);
  border-bottom: 1px solid var(--chat-border);
  box-shadow: 0 1px 4px rgba(0,0,0,.04);
  flex-shrink: 0;
  gap: 8px;
}
#chat-widget .chat-panel__title {
  font-weight: 700;
  font-size: 15px;
  color: var(--chat-text);
  display: flex;
  align-items: center;
  gap: 7px;
}
#chat-widget .chat-panel__title svg { color: var(--chat-accent); }
#chat-widget .chat-panel__actions { display: flex; gap: 2px; }
#chat-widget .chat-panel__btn {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--chat-text-muted);
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s, color .15s;
}
#chat-widget .chat-panel__btn:hover { background: var(--chat-bg2); color: var(--chat-text); }
#chat-widget .chat-panel__btn:focus-visible {
  outline: 2px solid var(--chat-accent);
  outline-offset: 2px;
}

/* ── UX 2026 : tous les boutons/liens du widget — pas de flash tactile,
     pas de délai 300ms, focus visible mais propre, transitions douces ── */
#chat-widget button,
#chat-widget a,
#chat-widget [role="tab"],
#chat-widget [role="button"],
#chat-widget .chat-online-item,
#chat-widget .chat-dm-item {
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}
/* Focus visible UNIQUEMENT au clavier (pas au tap/clic souris) */
#chat-widget button:focus,
#chat-widget a:focus,
#chat-widget [role="tab"]:focus,
#chat-widget [role="button"]:focus { outline: none; }
#chat-widget button:focus-visible,
#chat-widget a:focus-visible,
#chat-widget [role="tab"]:focus-visible,
#chat-widget [role="button"]:focus-visible {
  outline: 2px solid var(--chat-accent);
  outline-offset: 2px;
}
/* Respect du paramètre OS "réduire les animations" */
@media (prefers-reduced-motion: reduce) {
  #chat-widget *, #chat-widget *::before, #chat-widget *::after {
    animation-duration: .01ms !important;
    transition-duration: .01ms !important;
  }
}

/* ── Onglets (pills toujours visibles, wrap si nécessaire) ────── */
#chat-widget .chat-tabs {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  background: var(--chat-bg2);
  border-bottom: 1px solid var(--chat-border);
  flex-shrink: 0;
  padding: 6px 8px;
  gap: 4px;
}

/* ── Design pill : pas de border-bottom, pas de saut de layout ── */
#chat-widget .chat-tab {
  flex-shrink: 0;
  padding: 5px 10px;
  font-size: 12px;
  font-weight: 500;       /* ne change PAS à l'activation → zéro saut */
  color: var(--chat-text-muted);
  background: none;
  border: none;
  border-radius: 20px;    /* pill */
  cursor: pointer;
  white-space: nowrap;
  transition: color .15s, background .18s, box-shadow .18s, transform .1s;
  display: flex;
  align-items: center;
  gap: 5px;
  user-select: none;
  line-height: 1.4;
}
#chat-widget .chat-tab:hover {
  color: var(--chat-text);
  background: rgba(0,0,0,.06);
}
#chat-widget .chat-tab:active { transform: scale(.93); }
/* Onglet actif : pill plein accent — aucune propriété de layout ne change */
#chat-widget .chat-tab[aria-selected="true"] {
  color: #fff;
  background: var(--chat-accent);
  font-weight: 600;
  box-shadow: 0 2px 8px rgba(214,33,83,.3);
}
#chat-widget .chat-tab[aria-selected="true"]:hover {
  background: var(--chat-accent-h);
}

/* Badge dans les onglets */
#chat-widget .chat-tab__badge {
  background: var(--chat-accent);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  min-width: 16px;
  height: 16px;
  border-radius: 8px;
  padding: 0 4px;
  line-height: 16px;
  text-align: center;
}
/* Badge visible sur onglet actif (fond blanc semi-transparent) */
#chat-widget .chat-tab[aria-selected="true"] .chat-tab__badge {
  background: rgba(255,255,255,.28);
  color: #fff;
}
#chat-widget .chat-tab__badge[hidden] { display: none; }
#chat-widget .chat-tab__badge--green { background: #10b981; }

/* Icônes salon */
#chat-widget .chat-tab__icon {
  width: 13px;
  height: 13px;
  flex-shrink: 0;
  opacity: .6;
}
#chat-widget .chat-tab[aria-selected="true"] .chat-tab__icon { opacity: 1; }

/* (Dropdown salons retiré — pills affichées directement dans .chat-tabs) */

/* ── Corps ───────────────────────────────────────────────────── */
#chat-widget .chat-panel__body {
  flex: 1;
  overflow: hidden;
  position: relative;
}

/* ── Panneaux (un seul visible à la fois) ───────────────────── */
#chat-widget .chat-pane {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
#chat-widget .chat-pane[hidden] { display: none !important; }

/* ── Zone messages ───────────────────────────────────────────── */
#chat-widget .chat-messages {
  flex: 1;
  overflow-y: auto;
  padding: 14px 12px 8px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  scroll-behavior: smooth;
  scrollbar-width: thin;
  scrollbar-color: var(--chat-border) transparent;
  background: var(--chat-bg);
}
#chat-widget .chat-messages::-webkit-scrollbar { width: 4px; }
#chat-widget .chat-messages::-webkit-scrollbar-track { background: transparent; }
#chat-widget .chat-messages::-webkit-scrollbar-thumb { background: var(--chat-border); border-radius: 2px; }

/* Message row */
#chat-widget .chat-msg {
  display: flex;
  gap: 8px;
  align-items: flex-end;
  animation: chat-msg-in .16s ease;
}
@keyframes chat-msg-in {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}
#chat-widget .chat-msg--mine { flex-direction: row-reverse; }

/* Avatar */
#chat-widget .chat-msg__avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--chat-accent);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  text-transform: uppercase;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(0,0,0,.1);
}
#chat-widget .chat-msg__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  display: block;
}
#chat-widget .chat-msg--mine .chat-msg__avatar { background: var(--chat-bg3); color: var(--chat-text-muted); }
/* Avatar cliquable → profil */
#chat-widget a.chat-msg__avatar {
  text-decoration: none;
  cursor: pointer;
  transition: opacity .15s, transform .12s;
}
#chat-widget a.chat-msg__avatar:hover {
  opacity: .85;
  transform: scale(1.08);
}
#chat-widget a.chat-msg__avatar:focus-visible {
  outline: 2px solid var(--chat-accent);
  outline-offset: 2px;
}

/* Inner wrapper */
#chat-widget .chat-msg__inner {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  max-width: 72%;
}
#chat-widget .chat-msg--mine .chat-msg__inner { align-items: flex-end; }

/* Enveloppe bulle */
#chat-widget .chat-msg__bubble-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
}

/* Bouton supprimer */
#chat-widget .chat-msg__delete {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: calc(100% + 5px);
  width: 26px;
  height: 26px;
  border-radius: 7px;
  background: var(--chat-bg);
  border: 1px solid var(--chat-border);
  color: var(--chat-text-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity .15s, color .15s, background .15s;
  z-index: 2;
  box-shadow: 0 1px 4px rgba(0,0,0,.08);
}
#chat-widget .chat-msg:hover .chat-msg__delete { opacity: 1; pointer-events: auto; }
#chat-widget .chat-msg__delete:hover { color: #e74c3c; background: #fef2f2; border-color: rgba(231,76,60,.25); }

/* Bulle */
#chat-widget .chat-msg__bubble {
  padding: 9px 13px;
  border-radius: 18px 18px 18px 4px;
  background: var(--chat-bubble-other);
  color: var(--chat-text);
  font-size: 13px;
  line-height: 1.5;
  word-break: break-word;
  white-space: pre-wrap;
  box-shadow: 0 1px 2px rgba(0,0,0,.05);
}
#chat-widget .chat-msg--mine .chat-msg__bubble {
  background: var(--chat-bubble-me);
  color: #fff;
  border-radius: 18px 18px 4px 18px;
  box-shadow: 0 2px 8px rgba(214,33,83,.25);
}
#chat-widget .chat-msg--deleted .chat-msg__bubble {
  color: var(--chat-text-faint);
  font-style: italic;
  background: transparent;
  border: 1px solid var(--chat-border);
  box-shadow: none;
}
#chat-widget .chat-msg--deleted .chat-msg__delete { display: none !important; }

/* ── Groupage WhatsApp ───────────────────────────────────────── */
/* Réduction du gap entre messages consécutifs du même expéditeur */
#chat-widget .chat-msg--grouped { margin-top: -4px; }
/* Cache avatar (invisible mais conserve l'alignement horizontal) */
#chat-widget .chat-msg--grouped .chat-msg__avatar { visibility: hidden; }
/* Cache nom — on garde le timestamp */
#chat-widget .chat-msg--grouped .chat-msg__nick { display: none; }
/* Coins connectés : angle supérieur du côté expéditeur arrondi à 4px */
#chat-widget .chat-msg--grouped .chat-msg__bubble         { border-top-left-radius:  4px; }
#chat-widget .chat-msg--grouped.chat-msg--mine .chat-msg__bubble { border-top-right-radius: 4px; }
/* Premier d'un groupe : coin inférieur fermé pour connecter au suivant */
#chat-widget .chat-msg--group-start .chat-msg__bubble         { border-bottom-left-radius:  4px; }
#chat-widget .chat-msg--group-start.chat-msg--mine .chat-msg__bubble { border-bottom-right-radius: 4px; }

/* Nom + heure */
#chat-widget .chat-msg__meta {
  font-size: 10px;
  color: var(--chat-text-faint);
  margin-bottom: 3px;
  display: flex;
  gap: 5px;
  align-items: center;
}
#chat-widget .chat-msg--mine .chat-msg__meta { flex-direction: row-reverse; }
#chat-widget .chat-msg__nick { font-weight: 600; color: var(--chat-text-muted); text-decoration: none; }
#chat-widget a.chat-msg__nick { cursor: pointer; transition: color .12s; }
#chat-widget a.chat-msg__nick:hover { color: var(--chat-accent); text-decoration: underline; }
#chat-widget .chat-msg--mine .chat-msg__nick { display: none; }
#chat-widget .chat-msg__time { font-size: 10px; color: var(--chat-text-faint); cursor: default; }

/* Séparateur de date */
#chat-widget .chat-date-sep {
  text-align: center;
  font-size: 11px;
  color: var(--chat-text-faint);
  margin: 8px 0 4px;
  display: flex;
  align-items: center;
  gap: 8px;
}
#chat-widget .chat-date-sep::before,
#chat-widget .chat-date-sep::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--chat-border);
}

/* Load more */
#chat-widget .chat-load-more { text-align: center; margin-bottom: 8px; }
#chat-widget .chat-load-more-btn {
  font-size: 11px;
  color: var(--chat-text-muted);
  background: none;
  border: 1px solid var(--chat-border);
  border-radius: 12px;
  padding: 4px 14px;
  cursor: pointer;
  transition: border-color .15s, color .15s, background .15s;
}
#chat-widget .chat-load-more-btn:hover { border-color: var(--chat-accent); color: var(--chat-accent); background: var(--chat-accent-soft); }

/* Spinner */
#chat-widget .chat-loading {
  display: flex;
  justify-content: center;
  align-items: center;
  flex: 1;
  padding: 24px;
}
#chat-widget .chat-spinner {
  width: 22px;
  height: 22px;
  border: 2px solid var(--chat-border);
  border-top-color: var(--chat-accent);
  border-radius: 50%;
  animation: chat-spin .7s linear infinite;
}
@keyframes chat-spin { to { transform: rotate(360deg); } }

/* Empty state simple (inline) */
#chat-widget .chat-empty {
  color: var(--chat-text-muted);
  font-size: 13px;
  text-align: center;
  padding: 32px 20px;
  line-height: 1.6;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
#chat-widget .chat-empty::before {
  content: '💬';
  font-size: 30px;
  opacity: .25;
  display: block;
}
/* Empty state riche (avec CTA) */
#chat-widget .chat-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 36px 24px;
  text-align: center;
  flex: 1;
}
#chat-widget .chat-empty-state__icon {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--chat-bg2);
  border: 1.5px solid var(--chat-border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--chat-text-faint);
  margin-bottom: 4px;
}
#chat-widget .chat-empty-state__title {
  font-size: 14px;
  font-weight: 700;
  color: var(--chat-text);
}
#chat-widget .chat-empty-state__hint {
  font-size: 12px;
  color: var(--chat-text-muted);
  line-height: 1.5;
  max-width: 240px;
}
#chat-widget .chat-empty-state__cta {
  margin-top: 4px;
  padding: 7px 16px;
  background: var(--chat-accent);
  color: #fff;
  border: none;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s, transform .1s;
  font-family: inherit;
}
#chat-widget .chat-empty-state__cta:hover { background: var(--chat-accent-h); transform: scale(1.03); }

/* ── Typing indicator ────────────────────────────────────────── */
#chat-widget .chat-typing {
  padding: 3px 14px 3px;
  font-size: 11px;
  color: var(--chat-text-muted);
  flex-shrink: 0;
  min-height: 20px;
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--chat-bg);
}
#chat-widget .chat-typing[hidden] { display: none !important; }
#chat-widget .chat-typing-dots { display: inline-flex; align-items: center; gap: 4px; }
#chat-widget .chat-typing-dots span {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--chat-accent);
  opacity: .35;
  animation: chat-dot-bounce 1.2s cubic-bezier(.4,0,.2,1) infinite;
}
#chat-widget .chat-typing-dots span:nth-child(2) { animation-delay: .22s; }
#chat-widget .chat-typing-dots span:nth-child(3) { animation-delay: .44s; }
@keyframes chat-dot-bounce {
  0%, 55%, 100% { transform: translateY(0) scale(1);   opacity: .35; }
  27%            { transform: translateY(-5px) scale(1.1); opacity: .9; }
}

/* ── Formulaire d'envoi ──────────────────────────────────────── */
#chat-widget .chat-form {
  display: flex;
  align-items: flex-end;
  gap: 8px;
  padding: 8px 12px 10px;
  /* Séparateur doux à la place d'une bordure dure */
  border-top: none;
  box-shadow: 0 -1px 0 0 var(--chat-border), 0 -4px 14px rgba(0,0,0,.04);
  background: var(--chat-bg);
  flex-shrink: 0;
}
#chat-widget .chat-form-wrap {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  position: relative;
  /* La wrap devient le conteneur visuel (pill) */
  background: var(--chat-bg2);
  border: 1.5px solid var(--chat-border);
  border-radius: 22px;
  transition: border-color .15s, box-shadow .15s, background .15s;
}
/* Focus-within : le pill entier s'allume quand l'utilisateur tape */
#chat-widget .chat-form-wrap:focus-within {
  border-color: var(--chat-accent);
  background: #fff;
  box-shadow: 0 0 0 3px var(--chat-accent-soft);
}
#chat-widget .chat-input {
  width: 100%;
  min-height: 38px;
  box-sizing: border-box;
  /* Fond transparent — hérite du form-wrap */
  background: transparent;
  border: none;
  border-radius: 22px;
  padding: 9px 14px;
  color: var(--chat-text);
  font-size: 16px;
  font-family: inherit;
  line-height: 1.4;
  resize: none;
  max-height: 100px;
  overflow-y: auto;
  transition: none;
  /* ── Scrollbar fine et discrète ── */
  scrollbar-width: thin;
  scrollbar-color: var(--chat-border) transparent;
}
#chat-widget .chat-input::-webkit-scrollbar { width: 3px; }
#chat-widget .chat-input::-webkit-scrollbar-track { background: transparent; }
#chat-widget .chat-input::-webkit-scrollbar-thumb {
  background: var(--chat-border);
  border-radius: 2px;
}
#chat-widget .chat-input:focus { outline: none; }
#chat-widget .chat-input::placeholder { color: var(--chat-text-faint); }
#chat-widget .chat-send {
  flex-shrink: 0;
  /* Légèrement plus petit pour un ensemble équilibré avec le pill */
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--chat-accent);
  color: #fff;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s, transform .15s, box-shadow .15s;
  box-shadow: 0 2px 10px rgba(214,33,83,.35);
}
#chat-widget .chat-send:hover { background: var(--chat-accent-h); box-shadow: 0 4px 18px rgba(214,33,83,.55); transform: scale(1.08); }
#chat-widget .chat-send:active { transform: scale(.88); box-shadow: 0 1px 4px rgba(214,33,83,.25); }
#chat-widget .chat-send:disabled { background: var(--chat-bg3); box-shadow: none; cursor: not-allowed; }
#chat-widget .chat-send:focus-visible { outline: 2px solid var(--chat-accent); outline-offset: 3px; }
#chat-widget .chat-send.empty { background: var(--chat-bg3); box-shadow: none; cursor: not-allowed; transform: none; }
#chat-widget .chat-send.loading {
  background: var(--chat-bg3);
  cursor: not-allowed;
  pointer-events: none;
}
#chat-widget .chat-send.loading svg { display: none; }
#chat-widget .chat-send.loading::after {
  content: '';
  width: 14px;
  height: 14px;
  border: 2px solid rgba(0,0,0,.2);
  border-top-color: var(--chat-text-muted);
  border-radius: 50%;
  animation: chat-spin .6s linear infinite;
  display: block;
}
#chat-widget .chat-send:not(.loading) { transition: background .15s, transform .1s, box-shadow .15s; }

/* ── Compteur de caractères ──────────────────────────────────── */
#chat-widget .chat-char-counter {
  font-size: 10px;
  color: var(--chat-text-faint);
  text-align: right;
  padding: 0 10px 5px;
  line-height: 1;
}
#chat-widget .chat-char-counter.warn  { color: #f59e0b; }
#chat-widget .chat-char-counter.limit { color: #ef4444; font-weight: 700; }
#chat-widget .chat-char-counter[hidden] { display: none; }

/* ── Bouton scroll-to-bottom ─────────────────────────────────── */
#chat-widget .chat-scroll-btn {
  position: absolute;
  bottom: 72px;
  right: 10px;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: #fff;
  border: 1.5px solid var(--chat-border);
  color: var(--chat-text-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s, background .15s, transform .1s;
  z-index: 5;
  box-shadow: 0 2px 10px rgba(0,0,0,.1);
}
#chat-widget .chat-scroll-btn.visible { opacity: 1; pointer-events: auto; transform: translateY(0); }
#chat-widget .chat-scroll-btn:hover {
  background: var(--chat-accent);
  color: #fff;
  border-color: var(--chat-accent);
  box-shadow: 0 4px 16px rgba(214,33,83,.35);
}
#chat-widget .chat-scroll-btn:active { transform: scale(.90); }
/* Badge non-lus sur le bouton scroll */
#chat-widget .chat-scroll-btn__badge {
  position: absolute;
  top: -4px;
  right: -4px;
  min-width: 17px;
  height: 17px;
  border-radius: 9px;
  padding: 0 4px;
  background: var(--chat-accent);
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  line-height: 17px;
  text-align: center;
  pointer-events: none;
  animation: chat-badge-pop .2s ease;
}

/* ── Liste DM ────────────────────────────────────────────────── */
#chat-widget #chat-dm-list {
  flex: 1;
  overflow-y: auto;
  padding: 6px 0;
  background: var(--chat-bg);
}
#chat-widget #chat-dm-list[hidden] { display: none !important; }
#chat-widget .chat-dm-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 16px;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  transition: background .15s;
  color: var(--chat-text);
}
#chat-widget .chat-dm-item:hover { background: var(--chat-bg2); }
#chat-widget .chat-dm-item__avatar {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--chat-accent);
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  text-transform: uppercase;
  box-shadow: 0 1px 4px rgba(0,0,0,.1);
  overflow: hidden;
}
#chat-widget .chat-dm-item__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  display: block;
}
#chat-widget .chat-dm-item__info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
#chat-widget .chat-dm-item__name {
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--chat-text);
}
#chat-widget .chat-dm-item__preview {
  font-size: 11px;
  color: var(--chat-text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
#chat-widget .chat-dm-item__unread {
  background: var(--chat-accent);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  min-width: 18px;
  height: 18px;
  border-radius: 9px;
  padding: 0 5px;
  line-height: 18px;
  text-align: center;
  flex-shrink: 0;
}

/* ── DM actif ────────────────────────────────────────────────── */
#chat-widget #chat-dm-active {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  overflow: hidden;
  position: relative;
  animation: chat-dm-slide-in .18s cubic-bezier(.25,.8,.25,1);
}
@keyframes chat-dm-slide-in {
  from { opacity: 0; transform: translateX(12px); }
  to   { opacity: 1; transform: translateX(0); }
}
#chat-widget #chat-dm-active[hidden] { display: none !important; }
#chat-widget .chat-dm-active__header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-bottom: 1px solid var(--chat-border);
  flex-shrink: 0;
  background: var(--chat-bg);
}
#chat-widget .chat-dm-back {
  background: none;
  border: none;
  color: var(--chat-text-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  padding: 4px 6px;
  border-radius: 6px;
  transition: color .15s, background .15s;
}
#chat-widget .chat-dm-back:hover { color: var(--chat-text); background: var(--chat-bg2); }
#chat-widget .chat-dm-back:focus-visible { outline: 2px solid var(--chat-accent); outline-offset: 2px; }
#chat-widget .chat-dm-active__title {
  font-size: 13px;
  font-weight: 600;
  color: var(--chat-text);
}

/* ── Réponse message (reply) ─────────────────────────────────── */
#chat-widget .chat-msg__reply-preview {
  font-size: 11px;
  color: var(--chat-text-muted);
  border-left: 2px solid var(--chat-accent);
  padding-left: 6px;
  margin-bottom: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
#chat-widget .chat-msg__reply-nick {
  font-weight: 700;
  font-size: 10px;
  color: var(--chat-accent);
  display: block;
  margin-bottom: 1px;
}
#chat-widget .chat-msg__reply-text {
  font-size: 11px;
  color: var(--chat-text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: block;
  max-width: 200px;
}

/* ── Highlight ───────────────────────────────────────────────── */
#chat-widget .chat-msg--highlight .chat-msg__bubble {
  animation: chat-highlight .3s ease 2;
}
@keyframes chat-highlight {
  0%, 100% { box-shadow: none; }
  50%       { box-shadow: 0 0 0 2px var(--chat-accent); }
}

/* ── Toasts ──────────────────────────────────────────────────── */
#chat-widget .chat-error-toast,
#chat-widget .chat-success-toast {
  position: absolute;
  bottom: 70px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 12px;
  padding: 7px 16px;
  border-radius: 20px;
  white-space: nowrap;
  animation: chat-toast-in .2s ease, chat-toast-out .3s ease 2.7s forwards;
  pointer-events: none;
  z-index: 20;
  font-weight: 500;
}
#chat-widget .chat-error-toast {
  background: #ef4444;
  color: #fff;
  box-shadow: 0 4px 16px rgba(239,68,68,.3);
}
#chat-widget .chat-success-toast {
  background: #10b981;
  color: #fff;
  box-shadow: 0 4px 16px rgba(16,185,129,.3);
}
@keyframes chat-toast-in {
  from { opacity: 0; transform: translateX(-50%) translateY(6px); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}
@keyframes chat-toast-out { from { opacity: 1; } to { opacity: 0; } }

/* ── Confirmation suppression ────────────────────────────────── */
#chat-widget .chat-confirm {
  position: absolute;
  bottom: 6px;
  left: 50%;
  transform: translateX(-50%);
  background: #fff;
  border: 1px solid var(--chat-border);
  border-radius: 12px;
  padding: 10px 14px;
  font-size: 12px;
  color: var(--chat-text);
  display: flex;
  align-items: center;
  gap: 8px;
  z-index: 10;
  white-space: nowrap;
  box-shadow: 0 4px 20px rgba(0,0,0,.12);
  animation: chat-open .15s ease;
}
#chat-widget .chat-confirm__yes {
  background: #ef4444; color: #fff; border: none; border-radius: 7px;
  padding: 4px 12px; font-size: 12px; cursor: pointer; font-weight: 600;
}
#chat-widget .chat-confirm__yes:hover { background: #dc2626; }
#chat-widget .chat-confirm__no {
  background: none; color: var(--chat-text-muted);
  border: 1px solid var(--chat-border); border-radius: 7px;
  padding: 4px 12px; font-size: 12px; cursor: pointer;
}
#chat-widget .chat-confirm__no:hover { background: var(--chat-bg2); }

/* ── Bouton signaler ─────────────────────────────────────────── */
#chat-widget .chat-msg__report {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: calc(100% + 5px);
  width: 24px;
  height: 24px;
  border-radius: 6px;
  background: var(--chat-bg);
  border: 1px solid var(--chat-border);
  color: var(--chat-text-faint);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity .15s, color .15s, background .15s;
  z-index: 2;
  box-shadow: 0 1px 4px rgba(0,0,0,.08);
}
#chat-widget .chat-msg:hover .chat-msg__report { opacity: 1; pointer-events: auto; }
#chat-widget .chat-msg__report:hover { color: #f59e0b; background: #fffbeb; border-color: rgba(245,158,11,.3); }

/* ── Réactions ───────────────────────────────────────────────── */
#chat-widget .chat-reactions {
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
  margin-top: 4px;
  align-items: center;
  position: relative;
}
#chat-widget .chat-reaction {
  background: var(--chat-bg2);
  border: 1px solid var(--chat-border);
  border-radius: 12px;
  padding: 2px 7px;
  font-size: 12px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 3px;
  transition: background .15s, transform .1s;
  color: var(--chat-text);
  line-height: 1;
}
#chat-widget .chat-reaction:hover { background: var(--chat-bg3); transform: scale(1.06); }
#chat-widget .chat-reaction.mine { background: var(--chat-accent-soft); border-color: rgba(214,33,83,.3); }
#chat-widget .chat-reaction__count { font-size: 10px; font-weight: 700; color: var(--chat-text-muted); }
#chat-widget .chat-reaction.mine .chat-reaction__count { color: var(--chat-accent); }
#chat-widget .chat-react-add {
  background: none;
  border: 1px dashed var(--chat-border);
  border-radius: 12px;
  padding: 1px 7px;
  font-size: 13px;
  color: var(--chat-text-faint);
  cursor: pointer;
  opacity: 0;
  transition: opacity .15s, background .15s;
  line-height: 1.6;
}
#chat-widget .chat-msg:hover .chat-react-add { opacity: 1; }
#chat-widget .chat-react-add:hover { background: var(--chat-bg2); color: var(--chat-text-muted); }

/* ── Picker emoji ────────────────────────────────────────────── */
#chat-widget .chat-emoji-picker {
  position: absolute;
  bottom: calc(100% + 6px);
  left: 0;
  background: #fff;
  border: 1px solid var(--chat-border);
  border-radius: 12px;
  padding: 6px;
  display: flex;
  gap: 4px;
  box-shadow: 0 8px 24px rgba(0,0,0,.12);
  z-index: 20;
  animation: chat-open .15s ease;
}
#chat-widget .chat-emoji-picker button {
  background: none;
  border: none;
  font-size: 18px;
  cursor: pointer;
  border-radius: 6px;
  padding: 3px 4px;
  transition: background .12s, transform .1s;
  line-height: 1;
}
#chat-widget .chat-emoji-picker button:hover { background: var(--chat-bg2); transform: scale(1.2); }

/* ── Modal signalement ───────────────────────────────────────── */
#chat-widget .chat-report-modal {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.3);
  backdrop-filter: blur(2px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 30;
  padding: 16px;
  animation: chat-open .15s ease;
}
#chat-widget .chat-report-modal__box {
  background: #fff;
  border: 1px solid var(--chat-border);
  border-radius: 14px;
  padding: 18px;
  width: 100%;
  max-width: 300px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  box-shadow: 0 8px 32px rgba(0,0,0,.12);
}
#chat-widget .chat-report-modal__title { font-size: 14px; font-weight: 700; color: var(--chat-text); }
#chat-widget .chat-report-modal__select,
#chat-widget .chat-report-modal__detail {
  background: var(--chat-bg2);
  border: 1.5px solid var(--chat-border);
  border-radius: 9px;
  color: var(--chat-text);
  font-size: 13px;
  font-family: inherit;
  padding: 8px 10px;
  resize: none;
  width: 100%;
  box-sizing: border-box;
}
#chat-widget .chat-report-modal__select:focus,
#chat-widget .chat-report-modal__detail:focus { outline: none; border-color: var(--chat-accent); }
#chat-widget .chat-report-modal__actions { display: flex; gap: 8px; justify-content: flex-end; }
#chat-widget .chat-report-modal__cancel {
  background: none; border: 1px solid var(--chat-border); border-radius: 8px;
  color: var(--chat-text-muted); font-size: 12px; padding: 6px 14px; cursor: pointer;
}
#chat-widget .chat-report-modal__cancel:hover { background: var(--chat-bg2); }
#chat-widget .chat-report-modal__submit {
  background: var(--chat-accent); border: none; border-radius: 8px;
  color: #fff; font-size: 12px; font-weight: 600; padding: 6px 16px; cursor: pointer;
}
#chat-widget .chat-report-modal__submit:hover { background: var(--chat-accent-h); }

/* ── Responsive mobile ───────────────────────────────────────── */
@media (max-width: 480px) {
  #chat-widget .chat-panel {
    position: fixed;
    inset: 0;
    width: 100%;
    height: 100%;
    padding-bottom: env(safe-area-inset-bottom, 0px);
    bottom: 0; right: 0;
    border-radius: 0;
    border: none;
    animation: none;
  }
  #chat-widget .chat-fab {
    bottom: calc(16px + env(safe-area-inset-bottom, 0px));
    right: 16px;
  }
  #chat-widget .chat-form {
    padding: 8px 12px calc(10px + env(safe-area-inset-bottom, 0px));
  }
  #chat-widget .chat-msg__inner { max-width: 82%; }
}
@media (max-width: 600px) and (min-width: 481px) {
  #chat-widget { --chat-w: 330px; --chat-h: 480px; }
}

/* ── Header — indicateur en ligne ────────────────────────────── */
#chat-widget .chat-header-online {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(16,185,129,.08);
  border: 1px solid rgba(16,185,129,.2);
  border-radius: 10px;
  padding: 2px 8px 2px 5px;
  margin-left: 6px;
}
#chat-widget .chat-header-online[hidden] { display: none !important; }
#chat-widget .chat-header-online__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #10b981;
  flex-shrink: 0;
  animation: chat-online-pulse 2s ease infinite;
}
@keyframes chat-online-pulse { 0%, 100% { opacity: 1; } 50% { opacity: .35; } }
#chat-widget #chat-header-online-count {
  font-size: 11px;
  font-weight: 700;
  color: #10b981;
  font-variant-numeric: tabular-nums;
}

/* ── Onglet En ligne ──────────────────────────────────────────── */
#chat-widget .chat-tab--online .chat-tab__online-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #10b981;
  flex-shrink: 0;
  animation: chat-online-pulse 2s ease infinite;
}
/* Quand l'onglet est actif (fond pink), le dot devient blanc */
#chat-widget .chat-tab--online[aria-selected="true"] .chat-tab__online-dot {
  background: rgba(255,255,255,.85);
  animation: none;
}

/* ── Panneau En ligne ────────────────────────────────────────── */
#chat-widget .chat-online-list {
  flex: 1;
  overflow-y: auto;
  padding: 0 0 12px;
  scrollbar-width: thin;
  scrollbar-color: var(--chat-border) transparent;
  display: flex;
  flex-direction: column;
  background: var(--chat-bg);
}
#chat-widget .chat-online-list::-webkit-scrollbar { width: 4px; }
#chat-widget .chat-online-list::-webkit-scrollbar-thumb { background: var(--chat-border); border-radius: 2px; }

/* Sections */
#chat-widget .chat-online-section { margin-bottom: 2px; }
#chat-widget .chat-online-section--admin {
  background: linear-gradient(to bottom, rgba(59,130,246,.05), rgba(59,130,246,.01));
  border-bottom: 1px solid rgba(59,130,246,.12);
  margin-bottom: 8px;
  padding-bottom: 4px;
}
#chat-widget .chat-online-section--admin .chat-online-item {
  border-left-color: rgba(59,130,246,.25);
}
#chat-widget .chat-online-section--admin .chat-online-item:hover {
  background: rgba(59,130,246,.05);
  border-left-color: #3b82f6;
}
#chat-widget .chat-online-section--admin .chat-online-item__name {
  font-weight: 600;
}
#chat-widget .chat-online-section--admin .chat-online-section__header {
  color: #3b82f6;
}
/* (Badge "Disponible" — désormais via .chat-online-item__role--admin) */
#chat-widget .chat-online-section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px 5px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--chat-text-muted);
}
#chat-widget .chat-online-section__count {
  background: var(--chat-bg2);
  border: 1px solid var(--chat-border);
  border-radius: 8px;
  padding: 1px 7px;
  font-size: 10px;
  font-weight: 700;
  color: var(--chat-text-muted);
}

/* Ligne utilisateur */
#chat-widget .chat-online-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px 8px 14px;
  transition: background .14s, border-color .14s;
  cursor: pointer;
  position: relative;
  border-left: 2.5px solid transparent;
  animation: chat-item-in .22s ease both;
}
@keyframes chat-item-in {
  from { opacity: 0; transform: translateX(-6px); }
  to   { opacity: 1; transform: translateX(0); }
}
#chat-widget .chat-online-item:hover {
  background: var(--chat-bg2);
  border-left-color: var(--chat-accent);
}
#chat-widget .chat-online-item[role="button"]:focus-visible {
  outline: 2px solid var(--chat-accent);
  outline-offset: -2px;
}
/* (Bouton DM rapide retiré — toute la ligne ouvre le dropdown) */

/* Avatar */
#chat-widget .chat-online-item__avatar {
  position: relative;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--chat-accent);
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  text-transform: uppercase;
  overflow: visible;
  box-shadow: 0 1px 4px rgba(0,0,0,.1);
}
#chat-widget .chat-online-item__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  display: block;
}
#chat-widget .chat-online-item__dot {
  position: absolute;
  bottom: 1px;
  right: 1px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #10b981;
  border: 2px solid var(--chat-bg);
  z-index: 1;
}

/* Admin avatar */
#chat-widget .chat-online-item__avatar--admin {
  background: linear-gradient(135deg, #1e40af, #3b82f6);
  box-shadow: 0 2px 8px rgba(59,130,246,.35);
}
/* Point de présence bleu (admin) */
#chat-widget .chat-online-item__dot--blue {
  background: #3b82f6 !important;
  animation: chat-admin-dot 2.5s ease infinite;
}
@keyframes chat-admin-dot {
  0%, 100% { box-shadow: 0 0 0 0 rgba(59,130,246,.5); }
  50%       { box-shadow: 0 0 0 4px rgba(59,130,246,.0); }
  25%       { box-shadow: 0 0 0 3px rgba(59,130,246,.2); }
}

/* Info */
#chat-widget .chat-online-item__info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
#chat-widget .chat-online-item__name {
  font-size: 13px;
  font-weight: 500;
  color: var(--chat-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: block;
}
#chat-widget .chat-online-item__role {
  font-size: 10px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 3px;
}
#chat-widget .chat-online-item__role--escort { color: var(--chat-accent); }
#chat-widget .chat-online-item__role--admin  { color: #3b82f6; }
#chat-widget .chat-online-item__role--member { color: var(--chat-text-faint); }
#chat-widget .chat-online-item__role--self   { color: #16a34a; font-weight: 600; }
#chat-widget .chat-online-item--self { background: linear-gradient(0deg, rgba(22,163,74,.04), transparent); border-left: 2.5px solid rgba(22,163,74,.4); }
#chat-widget .chat-online-item--self:hover { background: rgba(22,163,74,.06); border-left-color: #16a34a; }

/* Chevron — toujours visible (tactile-friendly), accentué au hover */
#chat-widget .chat-online-item__chevron {
  width: 14px;
  height: 14px;
  color: var(--chat-text-faint);
  flex-shrink: 0;
  opacity: .5;
  transition: opacity .15s, transform .15s;
}
#chat-widget .chat-online-item:hover .chat-online-item__chevron,
#chat-widget .chat-online-item:focus-visible .chat-online-item__chevron {
  opacity: 1;
  transform: translateX(2px);
  color: var(--chat-accent);
}

/* ── Dropdown utilisateur ───────────────────────────────────────── */
/* IMPORTANT : ce dropdown est appendé au <body> via JS pour échapper aux
   overflow internes ; les sélecteurs ne doivent donc PAS être préfixés
   par #chat-widget (sinon les couleurs/variables CSS ne s'appliquent plus
   et on hérite du thème de la page → texte blanc sur fond blanc, etc.). */
.chat-user-dropdown {
  position: fixed;
  z-index: 99999;
  min-width: 200px;
  background: #ffffff;
  border: 1px solid #e8e4de;
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(0,0,0,.14), 0 2px 6px rgba(0,0,0,.06);
  padding: 5px;
  font-family: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: 13.5px;
  color: #1c1917;
  animation: chat-dropdown-in .15s cubic-bezier(.34,1.2,.64,1);
}
@keyframes chat-dropdown-in {
  from { opacity: 0; transform: scale(.94) translateY(-4px); }
  to   { opacity: 1; transform: scale(1)   translateY(0); }
}
.chat-user-dropdown__item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  box-sizing: border-box;
  padding: 10px 12px;
  border: none;
  background: none;
  border-radius: 9px;
  font-size: 13.5px;
  font-weight: 500;
  color: #1c1917;
  cursor: pointer;
  text-align: left;
  text-decoration: none;
  font-family: inherit;
  line-height: 1.3;
  transition: background .12s, color .12s;
}
.chat-user-dropdown__item:hover,
.chat-user-dropdown__item:focus-visible {
  background: #f7f5f2;
  color: #1c1917;
  outline: none;
}
.chat-user-dropdown__item svg { flex-shrink: 0; }
.chat-user-dropdown__item--dm svg      { color: #d62153; }
.chat-user-dropdown__item--profile svg { color: #3b82f6; }
.chat-user-dropdown__item--block       { color: #ef4444; }
.chat-user-dropdown__item--block:hover { background: #fef2f2; color: #dc2626; }
.chat-user-dropdown__item--block svg   { color: #ef4444; }
.chat-user-dropdown__sep {
  height: 1px;
  background: #e8e4de;
  margin: 4px 8px;
}

/* (Bannière de réassurance retirée — bruit visuel inutile) */

/* ── CTA invité (mode non connecté) — barre compacte single-row ───── */
#chat-widget .chat-guest-cta {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  background: var(--chat-bg);
  border-top: 1px solid var(--chat-border);
  /* Fine ombre interne pour souligner la séparation messages / CTA */
  box-shadow: inset 0 1px 0 rgba(255,255,255,.6);
}
#chat-widget .chat-guest-cta__primary {
  flex: 1;
  padding: 9px 12px;
  border-radius: 20px;
  font-size: 12.5px;
  font-weight: 600;
  text-decoration: none;
  text-align: center;
  background: var(--chat-accent);
  color: #fff;
  box-shadow: 0 2px 8px rgba(214,33,83,.28);
  transition: background .15s, transform .1s, box-shadow .15s;
  white-space: nowrap;
}
#chat-widget .chat-guest-cta__primary:hover {
  background: var(--chat-accent-h);
  box-shadow: 0 4px 14px rgba(214,33,83,.38);
}
#chat-widget .chat-guest-cta__primary:active { transform: scale(.98); }
#chat-widget .chat-guest-cta__secondary {
  flex-shrink: 0;
  padding: 9px 12px;
  font-size: 12px;
  font-weight: 500;
  color: var(--chat-text-muted);
  text-decoration: none;
  border-radius: 20px;
  transition: color .15s, background .15s;
}
#chat-widget .chat-guest-cta__secondary:hover {
  color: var(--chat-accent);
  background: var(--chat-accent-soft);
}

/* ── Toast de bienvenue ──────────────────────────────────────── */
#chat-widget .chat-welcome-toast {
  position: absolute;
  top: 54px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--chat-accent);
  color: #fff;
  font-size: 12px;
  font-weight: 500;
  padding: 8px 18px;
  border-radius: 20px;
  white-space: nowrap;
  z-index: 50;
  box-shadow: 0 4px 16px rgba(214,33,83,.35);
  animation: chat-toast-in .25s ease, chat-toast-out .4s ease 4s forwards;
  pointer-events: none;
}
#chat-widget .chat-welcome-toast strong { font-weight: 700; }

/* ── Pages profil: FAB remonte au-dessus du CTA "Me contacter" ── */
@media (max-width: 767px) {
  body.has-profile-cta #chat-widget .chat-fab {
    bottom: calc(64px + env(safe-area-inset-bottom, 0px));
  }
}
