/* ═══════════════════════════════════════════════════════════
   COMPONENTS — recalibrat cu noua paletă
   ═══════════════════════════════════════════════════════════ */

/* ── BUTTON ─────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; justify-content:center;
  gap:7px; padding:11px 22px;
  border-radius:var(--r-lg); font-size:14px; font-weight:600;
  cursor:pointer; border:none;
  transition:all var(--t-mid);
  white-space:nowrap; user-select:none;
  position:relative; overflow:hidden; letter-spacing:.01em;
}
.btn:active  { transform:scale(.97); }
.btn:disabled{ opacity:.35; cursor:not-allowed; pointer-events:none; }
.btn.loading>*:not(.spinner-wrap){opacity:0;}
.btn.loading::before{
  content:''; position:absolute;
  width:16px; height:16px;
  border:2px solid rgba(255,255,255,.25); border-top-color:#fff;
  border-radius:50%; animation:spin .7s linear infinite;
}

.btn-primary {
  background: var(--grad-brand); color:#fff;
  box-shadow: var(--glow-sm), 0 4px 16px rgba(124,58,237,.3);
}
.btn-primary:hover {
  box-shadow: var(--glow-md), 0 6px 24px rgba(124,58,237,.45);
  transform:translateY(-1px);
  filter:brightness(1.08);
}

.btn-secondary {
  background: var(--bg-3); color:var(--t1);
  border:1px solid var(--b2);
}
.btn-secondary:hover { background:var(--bg-4); border-color:var(--b3); }

.btn-ghost {
  background:transparent; color:var(--t2);
  border:1px solid var(--b2);
}
.btn-ghost:hover { background:var(--bg-3); color:var(--t1); border-color:var(--b3); }

.btn-danger {
  background:var(--red-soft); color:var(--red);
  border:1px solid rgba(248,113,113,0.3);
}
.btn-danger:hover { background:rgba(248,113,113,.2); box-shadow:0 0 16px rgba(248,113,113,.2); }

.btn-icon {
  width:36px; height:36px; padding:0;
  border-radius:var(--r-md); color:var(--t2); flex-shrink:0;
}
.btn-icon:hover { background:var(--bg-3); color:var(--t1); }
.btn-icon:active{ background:var(--bg-active); color:var(--accent-glow); }
.btn-icon-lg    { width:40px; height:40px; border-radius:var(--r-lg); font-size:17px; }

.btn-sm   { padding:7px 14px; font-size:13px; border-radius:var(--r-md); }
.btn-lg   { padding:14px 28px; font-size:16px; border-radius:var(--r-xl); }
.btn-full { width:100%; }

/* ── FIELD / INPUT ──────────────────────────────────────── */
.field { display:flex; flex-direction:column; gap:6px; }

.field-label {
  font-size:12px; font-weight:600;
  color:var(--t2); letter-spacing:.04em; text-transform:uppercase;
}

.field-wrap {
  display:flex; align-items:center;
  background:var(--bg-input);
  border:1.5px solid var(--b2);
  border-radius:var(--r-lg); overflow:hidden;
  transition:all var(--t-mid);
}
.field-wrap:focus-within {
  border-color:var(--bfocus);
  background:rgba(124,58,237,0.07);
  box-shadow:0 0 0 3px rgba(124,58,237,.12), var(--glow-xs);
}
.field-wrap.error                { border-color:var(--red-dim); }
.field-wrap.error:focus-within   { box-shadow:0 0 0 3px var(--red-soft); }

.field-input {
  flex:1; padding:12px 16px; font-size:15px;
  color:var(--t1); background:transparent;
  caret-color:var(--accent-glow);
}
.field-input::placeholder { color:var(--t3); }

.field-icon  { padding:0 12px 0 16px; color:var(--t3); font-size:15px; flex-shrink:0; }
.field-right { padding:0 14px; color:var(--t3); cursor:pointer; transition:color var(--t-fast); }
.field-right:hover { color:var(--t1); }
.field-error { font-size:12px; color:var(--red); font-weight:500; }
.field-hint  { font-size:12px; color:var(--t3); }
.field-textarea {
  resize:none; padding:12px 16px;
  min-height:90px; line-height:1.6;
}

/* ── AVATAR ─────────────────────────────────────────────── */
.avatar {
  border-radius:50%; overflow:hidden; flex-shrink:0;
  background:var(--bg-3);
  border:1px solid var(--b2);
  display:flex; align-items:center; justify-content:center;
  font-weight:700; color:var(--t-accent); position:relative;
}
.avatar img { width:100%; height:100%; object-fit:cover; }
.av-28 { width:28px; height:28px; font-size:11px; }
.av-32 { width:32px; height:32px; font-size:12px; }
.av-40 { width:40px; height:40px; font-size:15px; }
.av-48 { width:48px; height:48px; font-size:18px; }
.av-64 { width:64px; height:64px; font-size:24px; }
.av-96 { width:96px; height:96px; font-size:36px; }
.av-group { border-radius:var(--r-lg); }

.online-dot {
  position:absolute; bottom:1px; right:1px;
  width:10px; height:10px; border-radius:50%;
  border:2px solid var(--bg-1);
}
.online-dot.on  { background:var(--green); box-shadow:var(--green-glow); }
.online-dot.off { background:var(--t3); }

/* ── BADGE ──────────────────────────────────────────────── */
.badge {
  min-width:18px; height:18px; padding:0 5px;
  border-radius:var(--r-full);
  background:var(--grad-h); color:#fff;
  font-size:11px; font-weight:700;
  display:inline-flex; align-items:center; justify-content:center;
  box-shadow:var(--glow-xs);
}

/* ── MODAL ──────────────────────────────────────────────── */
.modal-overlay {
  position:fixed; inset:0;
  background:rgba(8,8,26,.88);
  backdrop-filter:blur(20px) saturate(0.7);
  z-index:var(--z4);
  display:flex; align-items:center; justify-content:center;
  padding:var(--s4);
  animation:fadeIn .2s ease;
}
.modal {
  background:var(--bg-2);
  border:1px solid var(--b2);
  border-radius:var(--r-2xl);
  padding:var(--s5); width:min(480px,100%);
  box-shadow:var(--shadow-xl), var(--glow-xs);
  animation:scaleIn .25s var(--t-bounce);
  position:relative; overflow:hidden;
}
.modal::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, var(--accent-glow), transparent);
  opacity:.4;
}
.modal-header {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:var(--s4);
}
.modal-title  { font-size:20px; font-weight:800; letter-spacing:-.3px; }
.modal-body   { margin-bottom:var(--s4); }
.modal-footer { display:flex; gap:var(--s2); justify-content:flex-end; }

/* ── TOAST ──────────────────────────────────────────────── */
.toast-root {
  position:fixed; bottom:var(--s5); left:50%;
  transform:translateX(-50%); z-index:var(--z5);
  display:flex; flex-direction:column; gap:var(--s2);
  pointer-events:none; align-items:center;
}
.toast {
  display:flex; align-items:center; gap:10px;
  padding:12px 18px;
  border-radius:var(--r-xl);
  background:var(--bg-3);
  border:1px solid var(--b2);
  box-shadow:var(--shadow-lg);
  font-size:14px; font-weight:500; color:var(--t1);
  pointer-events:all; cursor:pointer;
  animation:toastIn .25s var(--t-spring) both;
  backdrop-filter:blur(20px);
  white-space:nowrap; max-width:380px;
}
.toast.out { animation:toastOut .2s ease both; }
.toast-icon { font-size:16px; flex-shrink:0; }
.toast-success { border-color:rgba(34,197,94,.3);  }
.toast-success .toast-icon { color:var(--green); }
.toast-error   { border-color:rgba(248,113,113,.3); }
.toast-error   .toast-icon { color:var(--red); }
.toast-warning { border-color:rgba(251,191,36,.3);  }
.toast-warning .toast-icon { color:var(--yellow); }
.toast-info    { border-color:var(--b-accent);      }
.toast-info    .toast-icon { color:var(--t-accent); }

/* ── CONTEXT MENU ───────────────────────────────────────── */
.ctx-menu {
  position:fixed;
  background:var(--bg-3);
  border:1px solid var(--b2);
  border-radius:var(--r-xl);
  padding:var(--s1); min-width:190px;
  box-shadow:var(--shadow-lg);
  z-index:var(--z5);
  animation:scaleIn .14s ease;
  backdrop-filter:blur(20px);
}
.ctx-item {
  display:flex; align-items:center; gap:var(--s2);
  padding:10px 14px; border-radius:var(--r-lg);
  font-size:14px; font-weight:500; color:var(--t2);
  cursor:pointer; transition:all var(--t-fast);
}
.ctx-item:hover { background:var(--bg-4); color:var(--t1); }
.ctx-item.danger       { color:var(--red); }
.ctx-item.danger:hover { background:var(--red-soft); }
.ctx-icon { width:22px; text-align:center; font-size:14px; }
.ctx-sep  { height:1px; background:var(--b1); margin:4px 6px; }

/* ── TYPING ─────────────────────────────────────────────── */
.typing-dots { display:flex; align-items:center; gap:4px; padding:10px 16px; }
.typing-dots span {
  width:7px; height:7px; border-radius:50%;
  background:var(--accent-3);
  animation:typingDot 1.2s ease infinite;
}
.typing-dots span:nth-child(2) { animation-delay:.2s; }
.typing-dots span:nth-child(3) { animation-delay:.4s; }

/* ── SEARCH ─────────────────────────────────────────────── */
.search-wrap {
  display:flex; align-items:center; gap:var(--s2);
  background:var(--bg-3);
  border:1.5px solid var(--b2);
  border-radius:var(--r-xl);
  padding:9px 14px;
  transition:all var(--t-mid);
}
.search-wrap:focus-within {
  border-color:var(--bfocus);
  background:rgba(124,58,237,.07);
  box-shadow:var(--glow-xs);
}
.search-wrap input {
  flex:1; font-size:14px; background:none; outline:none;
  color:var(--t1); caret-color:var(--accent-glow);
}
.search-wrap input::placeholder { color:var(--t3); }
.search-icon { color:var(--t3); font-size:14px; flex-shrink:0; }

/* ── SPINNER / EMPTY ────────────────────────────────────── */
.spinner {
  width:20px; height:20px; border-radius:50%;
  border:2px solid var(--b2); border-top-color:var(--accent-glow);
  animation:spin .75s linear infinite; display:inline-block;
}
.empty {
  flex:1; display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  gap:var(--s3); padding:var(--s6);
  color:var(--t2); text-align:center;
}
.empty-icon  { font-size:52px; opacity:.35; }
.empty-title { font-size:19px; font-weight:700; color:var(--t1); letter-spacing:-.3px; }
.empty-sub   { font-size:14px; color:var(--t2); line-height:1.65; max-width:260px; }

/* ── TOGGLE ─────────────────────────────────────────────── */
.toggle { position:relative; width:44px; height:24px; cursor:pointer; }
.toggle input { opacity:0; width:0; height:0; position:absolute; }
.toggle-track {
  position:absolute; inset:0; border-radius:var(--r-full);
  background:var(--bg-4); border:1.5px solid var(--b2);
  transition:all var(--t-mid);
}
.toggle input:checked + .toggle-track {
  background:var(--grad-h); border-color:var(--accent);
  box-shadow:var(--glow-xs);
}
.toggle-thumb {
  position:absolute; top:3px; left:3px;
  width:16px; height:16px; border-radius:50%;
  background:var(--t3);
  transition:all var(--t-spring); pointer-events:none;
}
.toggle input:checked ~ .toggle-thumb {
  background:#fff; transform:translateX(20px);
  box-shadow:0 2px 6px rgba(0,0,0,.3);
}

/* ── DIVIDER ────────────────────────────────────────────── */
.divider { height:1px; background:var(--b1); width:100%; }
.divider-text {
  display:flex; align-items:center; gap:var(--s2);
  color:var(--t3); font-size:12px; font-weight:500;
}
.divider-text::before,
.divider-text::after { content:''; flex:1; height:1px; background:var(--b1); }

/* ── GLASS CARD ─────────────────────────────────────────── */
.glass-card {
  background:var(--bg-glass);
  border:1px solid var(--b2);
  border-radius:var(--r-xl);
  backdrop-filter:blur(16px);
  position:relative; overflow:hidden;
}
.glass-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.1), transparent);
}

/* ── PERSON ITEM ────────────────────────────────────────── */
.person-item {
  display:flex; align-items:center; gap:var(--s3);
  padding:12px var(--s4); cursor:pointer;
  transition:background var(--t-fast);
  border-bottom:1px solid var(--b1);
}
.person-item:hover { background:var(--bg-hover); }
.person-item:last-child { border-bottom:none; }
.person-item-info { flex:1; overflow:hidden; }
.person-item-name { font-size:14px; font-weight:600; color:var(--t1); }
.person-item-sub  { font-size:13px; color:var(--t2); margin-top:2px; }
.person-item-actions { display:flex; gap:4px; }
