* { box-sizing: border-box; margin: 0; padding: 0; }

/* ============================================================
   Theme-Variablen — Default = Dark
   Light-Theme via [data-theme="light"] auf <html>
   Workspace-Branding setzt --accent zur Laufzeit
   ============================================================ */
:root {
  --accent: #6264a7;
  --accent-soft: #525497;
  --accent-fg: #ffffff;
  --link: #9caaff;

  --bg: #1f1f23;
  --bg-elev: #2c2f3a;
  --bg-elev-2: #25272f;
  --bg-input: #1f2128;
  --bg-hover: #2c2f38;
  --bg-active: #3a3e4d;
  --bg-chip: #1f2128;

  --fg: #e2e2e6;
  --fg-dim: #c0c0c8;
  --fg-muted: #8a8a92;
  --fg-very-muted: #6a6a72;

  --border: #3a3d4a;
  --border-soft: #2c2f3a;
  --divider: #1a1c23;

  --ok: #4caf50;
  --warn: #f5a524;
  --err: #ff7474;
  --danger: #c62828;

  --message-bg: #2a2d36;
  --message-own: #4a4d8c;
  --code-bg: #1f2128;
  --code-fg: #ffd479;

  /* Density: skaliert die Innenabstände in Listen + Chat */
  --pad-row: 8px;
  --pad-msg: 8px 12px;
  --gap-msgs: 10px;
}

html[data-theme="light"] {
  --accent: #4f51a4;
  --accent-soft: #6264a7;
  --accent-fg: #ffffff;
  --link: #4a55cc;

  --bg: #f6f6f9;
  --bg-elev: #ffffff;
  --bg-elev-2: #eef0f5;
  --bg-input: #ffffff;
  --bg-hover: #eef0f5;
  --bg-active: #d6d9e6;
  --bg-chip: #eef0f5;

  --fg: #1f1f23;
  --fg-dim: #44464f;
  --fg-muted: #6a6a72;
  --fg-very-muted: #8a8a92;

  --border: #d4d6df;
  --border-soft: #e2e4ec;
  --divider: #e2e4ec;

  --message-bg: #eef0f5;
  --message-own: #dcdef0;
  --code-bg: #f0f1f5;
  --code-fg: #b06600;
}

html.density-compact {
  --pad-row: 4px;
  --pad-msg: 5px 10px;
  --gap-msgs: 4px;
}

html, body {
  height: 100%;
  font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
  background: var(--bg);
  color: var(--fg);
  overflow: hidden;
  font-size: 14px;
}

.hidden { display: none !important; }
.muted { color: var(--fg-muted); font-weight: normal; font-size: 12px; }

button { font-family: inherit; }

/* ---------- Login ---------- */
.login-screen {
  position: fixed; inset: 0;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #2a2d3a, #16181f);
}
.login-box {
  background: var(--bg-elev);
  padding: 36px 32px;
  border-radius: 12px;
  width: 380px;
  max-width: calc(100vw - 24px);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}
.login-box h1 { color: var(--accent); margin: 0 0 14px; font-size: 28px; }
.login-box p { margin-bottom: 18px; color: #a0a0a8; }
.login-workspace { margin-bottom: 18px; }
.workspace-tag {
  font-size: 10px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--fg-muted);
  font-weight: 700;
  margin-bottom: 4px;
}
.login-info { color: #9be7a7; font-size: 13px; margin-top: 10px; min-height: 0; }
.login-info:not(:empty) { padding-top: 4px; }
.resend-link {
  display: block;
  width: 100%;
  margin-top: 12px;
  background: transparent;
  color: var(--link);
  border: 1px solid var(--border);
  padding: 8px;
  font-size: 12px;
  cursor: pointer;
  border-radius: 6px;
}
.resend-link:hover { background: var(--bg-input); color: #fff; }

.auth-tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 18px;
  border-bottom: 1px solid var(--border);
}
.auth-tab {
  flex: 1;
  padding: 10px;
  background: transparent;
  color: #a0a0a8;
  border: none;
  border-bottom: 2px solid transparent;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  margin-bottom: -1px;
}
.auth-tab:hover { color: #fff; }
.auth-tab.active {
  color: #fff;
  border-bottom-color: var(--accent);
}
.login-box label {
  display: block;
  margin-bottom: 12px;
  font-size: 12px;
  color: #b0b0b8;
}
.login-box input {
  display: block;
  width: 100%;
  padding: 10px 12px;
  margin-top: 4px;
  background: var(--bg-input);
  color: #fff;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 14px;
}
.login-box input:focus { border-color: var(--accent); outline: none; }
.login-box button {
  width: 100%;
  padding: 12px;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  margin-top: 6px;
}
.login-box button:hover { background: var(--accent-soft); }
.login-error { color: var(--err); font-size: 12px; margin-top: 10px; min-height: 16px; }
.auth-mode-toggle {
  text-align: center;
  margin-top: 12px;
  font-size: 13px;
  color: #a0a0a8;
}
.auth-mode-toggle a {
  color: var(--link);
  text-decoration: none;
  cursor: pointer;
}
.auth-mode-toggle a:hover { text-decoration: underline; }

.auth-customer-link {
  text-align: center;
  margin-top: 8px;
  font-size: 12px;
  color: var(--fg-muted);
}
.auth-customer-link a {
  color: var(--link);
  text-decoration: none;
  cursor: pointer;
  margin-left: 4px;
}
.auth-customer-link a:hover { text-decoration: underline; }

.lang-switcher {
  margin-top: 16px;
  text-align: center;
  font-size: 11px;
  color: var(--fg-very-muted);
}
/* Globaler Link-Look (z. B. Settings-Modal): beide Optionen wirken wie Links */
.lang-btn {
  background: transparent;
  color: var(--link);
  border: none;
  cursor: pointer;
  font-family: inherit;
  font-size: 12px;
  padding: 2px 6px;
  letter-spacing: 0.5px;
  text-decoration: none;
  font-weight: normal;
}
.lang-btn:hover { text-decoration: underline; }
.lang-btn.active { text-decoration: underline; cursor: default; }
.lang-btn.active:hover { text-decoration: underline; }
.lang-sep { color: var(--border); }

/* Im Login-Screen sollen die Sprachoptionen wie zwei kleine Text-Links unter
   dem „Noch keinen Account? Registrieren"-Link wirken — gleiche Farbe wie
   der Mode-Link, aktiv nur durch einen Unterstrich gekennzeichnet. */
.login-screen .lang-btn {
  color: var(--link);
  font-size: 13px;
  letter-spacing: 0;
  padding: 2px 4px;
}

/* ---------- App layout ---------- */
.app {
  display: grid;
  grid-template-columns:
    var(--sidebar-w, 240px)
    6px
    var(--users-w, 280px)
    6px
    minmax(320px, 1fr);
  height: 100vh;
}

.resize-handle {
  background: transparent;
  cursor: col-resize;
  position: relative;
  z-index: 10;
  transition: background 120ms ease;
}
.resize-handle::before {
  content: '';
  position: absolute;
  inset: 0 2px;
  background: var(--divider);
}
.resize-handle:hover::before,
.resize-handle.dragging::before {
  background: var(--accent);
}
body.resizing { cursor: col-resize !important; user-select: none; }

.mobile-nav { display: none; }

/* ---------- Sidebar (rooms) ---------- */
.sidebar {
  background: var(--bg-elev);
  border-right: 1px solid var(--divider);
  display: flex;
  flex-direction: column;
}
.sidebar-header {
  padding: 16px;
  border-bottom: 1px solid var(--divider);
}
.logo { font-size: 18px; font-weight: 700; color: var(--accent); }

.sidebar-section { flex: 1; overflow-y: auto; padding: 10px 0; }

.section-title {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 16px 6px;
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  color: var(--fg-muted); letter-spacing: 0.6px;
}
.section-title button {
  background: transparent; color: var(--fg-muted); border: none;
  font-size: 18px; cursor: pointer; line-height: 1; padding: 0 4px;
}
.section-title button:hover { color: #fff; }

.rooms-tree { list-style: none; }
.room-item {
  padding: 7px 16px;
  cursor: pointer;
  display: flex; align-items: center; gap: 8px;
  font-size: 14px; color: #ccc;
  border-left: 3px solid transparent;
  user-select: none;
}
.room-item:hover { background: #353946; }
.room-item.active {
  background: var(--bg-active);
  border-left-color: var(--accent);
  color: #fff;
}
.room-icon { color: var(--fg-muted); font-weight: 600; }
.room-count {
  margin-left: auto;
  font-size: 11px;
  color: var(--fg-muted);
  background: var(--bg-input);
  padding: 1px 7px;
  border-radius: 9px;
}
.room-actions {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 2px;
}
.room-delete, .room-settings-btn {
  background: transparent;
  color: var(--fg-muted);
  border: none;
  cursor: pointer;
  padding: 0 4px;
  font-size: 14px;
  line-height: 1;
  visibility: hidden;
  border-radius: 3px;
}
.room-delete { font-size: 18px; }
.room-item:hover .room-delete,
.room-item:hover .room-settings-btn { visibility: visible; }
.room-delete:hover { color: var(--err); background: var(--bg-elev); }
.room-settings-btn:hover { color: #fff; background: var(--bg-elev); }

/* ---------- Avatar-Bilder (mit Fallback auf Initialen) ---------- */
.avatar.avatar-img { padding: 0; overflow: hidden; }
.avatar.avatar-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}

/* ---------- Cmd+K Command-Palette ---------- */
.cmdk-box {
  width: 560px; max-width: 92vw;
  max-height: 70vh;
  margin-top: 10vh;
  background: var(--bg-elev);
  border-radius: 10px;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.5);
  display: flex; flex-direction: column;
  overflow: hidden;
}
#cmdk-input {
  width: 100%;
  padding: 14px 16px;
  background: transparent;
  color: var(--fg);
  border: none;
  border-bottom: 1px solid var(--border-soft);
  font-size: 16px;
  font-family: inherit;
  outline: none;
}
.cmdk-list {
  list-style: none;
  flex: 1;
  overflow-y: auto;
  padding: 4px;
  margin: 0;
}
.cmdk-list li {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px;
  border-radius: 6px;
  cursor: pointer;
}
.cmdk-list li.active { background: var(--bg-active); }
.cmdk-list li:hover { background: var(--bg-hover); }
.cmdk-list .cmdk-icon { width: 22px; text-align: center; }
.cmdk-list .cmdk-label { flex: 1; }
.cmdk-list .cmdk-meta { color: var(--fg-muted); font-size: 12px; }
.cmdk-foot {
  padding: 6px 12px;
  font-size: 11px;
  color: var(--fg-very-muted);
  border-top: 1px solid var(--border-soft);
}

/* ---------- Tastatur-Shortcuts-Modal ---------- */
.kbd-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
}
.kbd-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 6px 8px;
  border-bottom: 1px solid var(--border-soft);
  font-size: 13px;
}
.kbd-row span:first-child { color: var(--fg-dim); }
kbd {
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-bottom-width: 2px;
  border-radius: 4px;
  padding: 1px 6px;
  font-family: 'Consolas', monospace;
  font-size: 11px;
  color: var(--fg);
  min-width: 22px;
  display: inline-block;
  text-align: center;
}

/* ---------- Onboarding-Tour ---------- */
.onboarding-overlay {
  position: fixed; inset: 0;
  background: rgba(0, 0, 0, 0.55);
  z-index: 300;
}
.onboarding-card {
  position: absolute;
  background: var(--bg-elev);
  padding: 16px 18px;
  border-radius: 10px;
  width: 320px;
  max-width: 92vw;
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.5);
  border: 1px solid var(--accent);
}
.onboarding-card h3 { margin: 0 0 6px; color: var(--accent); font-size: 14px; }
.onboarding-card p { margin: 0 0 12px; color: var(--fg-dim); font-size: 13px; line-height: 1.4; }
.onboarding-actions { display: flex; gap: 8px; justify-content: flex-end; }

/* ---------- Skeleton-Loader ---------- */
.skel {
  background: linear-gradient(90deg, var(--bg-input) 0%, var(--bg-hover) 50%, var(--bg-input) 100%);
  background-size: 200% 100%;
  animation: skel-shimmer 1.4s infinite linear;
  border-radius: 4px;
  display: inline-block;
}
.skel-line { height: 12px; width: 100%; margin: 4px 0; }
.skel-row { display: flex; align-items: center; gap: 10px; padding: 8px 12px; }
.skel-circle { width: 32px; height: 32px; border-radius: 50%; flex-shrink: 0; }
.skel-grow { flex: 1; }
@keyframes skel-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ---------- Bessere Empty-States ---------- */
.empty-list-rich {
  padding: 24px 16px;
  text-align: center;
  color: var(--fg-muted);
  font-size: 13px;
}
.empty-list-rich .empty-icon { font-size: 32px; margin-bottom: 8px; }
.empty-list-rich .empty-hint { font-size: 12px; color: var(--fg-very-muted); margin-top: 4px; }

/* ---------- Settings-Modal ---------- */
.settings-avatar-row {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 12px;
}
.settings-avatar-row .avatar {
  width: 56px; height: 56px;
  font-size: 18px;
  flex-shrink: 0;
}
.settings-avatar-actions {
  display: flex; flex-direction: column; gap: 4px;
}
.settings-avatar-actions .btn-save,
.settings-avatar-actions .btn-cancel { padding: 6px 10px; font-size: 12px; }

.settings-radios {
  display: flex; flex-wrap: wrap; gap: 12px;
}

.settings-box { width: 560px; max-width: 92vw; }
.settings-body {
  padding: 14px 18px 18px;
  overflow: auto;
}
.settings-pane.hidden { display: none; }
.settings-section {
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--bg-elev);
}
.settings-section:last-child { border-bottom: none; }
.settings-section h3 {
  font-size: 12px;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--fg-muted);
  margin: 0 0 10px;
  font-weight: 700;
}
.settings-section label {
  display: block;
  margin-bottom: 8px;
  font-size: 12px;
  color: #b0b0b8;
}
.settings-section label span { display: inline-block; margin-bottom: 3px; }
.settings-section input[type="text"],
.settings-section input[type="password"],
.settings-section input:not([type]),
.settings-section select {
  width: 100%;
  padding: 8px 10px;
  background: var(--bg-input);
  color: #fff;
  border: 1px solid var(--border);
  border-radius: 4px;
  font-size: 13px;
  font-family: inherit;
}
.settings-section input:focus,
.settings-section select:focus { outline: none; border-color: var(--accent); }
.settings-section input:disabled { opacity: 0.6; cursor: not-allowed; }
.settings-radio {
  display: flex !important;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}
.settings-radio input[type="radio"] { accent-color: var(--accent); }
.settings-radio select {
  flex: 1;
  width: auto !important;
}
.settings-lang {
  display: flex; align-items: center; gap: 6px;
}
.settings-section.danger h3 { color: var(--err); }
.settings-warning { color: var(--err); font-size: 12px; margin: 0 0 10px; }
.settings-section .btn-save,
.settings-section .btn-reject {
  margin-top: 6px;
}
.settings-section input[type="range"] {
  width: 100%;
  margin-top: 4px;
  accent-color: var(--accent);
}
.settings-hint {
  color: var(--fg-muted);
  font-size: 11px;
  margin: 6px 0 0;
}
.settings-notify-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 8px;
}
.settings-notify-row .muted { font-size: 13px; flex: 1; }

/* Live-Mic-Test-Pegel im Settings-Modal */
.vu-test {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 4px 0 8px;
}
.vu-test-bar {
  flex: 1;
  height: 6px;
  background: var(--divider);
  border-radius: 3px;
  overflow: hidden;
}
.vu-test-fill {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--ok) 0%, #ffc107 70%, #ff5252 100%);
  transition: width 60ms linear;
}
.vu-test-hint {
  color: var(--fg-muted);
  font-size: 11px;
}

/* VU-Meter auf User-Tile (sichtbar nur während aktivem Anruf) */
.user-item .vu-bar {
  display: none;
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 2px;
  background: transparent;
  pointer-events: none;
}
.user-item .vu-bar-fill {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--ok), #9be7a7);
  transition: width 60ms linear;
}
.user-item.in-call { position: relative; }
.user-item.in-call .vu-bar { display: block; }
.user-item.in-call.speaking { box-shadow: inset 0 0 0 1px var(--ok); }

.room-settings-body {
  padding: 16px 18px;
  overflow: auto;
}
.room-lock-toggle {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  padding: 10px;
  background: var(--bg-elev-2);
  border: 1px solid var(--divider);
  border-radius: 6px;
  user-select: none;
}
.room-lock-toggle input { margin-top: 4px; accent-color: var(--accent); }
.room-lock-toggle small { display: block; color: var(--fg-muted); margin-top: 2px; font-size: 12px; }

.room-settings-section { margin-top: 18px; }
.room-settings-section h3 {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--fg-muted);
  margin: 0 0 8px;
}

.room-members-list, .room-ban-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 4px;
  max-height: 220px;
  overflow-y: auto;
}
.room-member-row, .room-ban-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 10px;
  background: var(--bg-elev-2);
  border: 1px solid var(--divider);
  border-radius: 4px;
}
.room-member-row .name, .room-ban-row .name { flex: 1; font-size: 13px; color: var(--fg); }
.room-member-row.muted .name { color: var(--fg-muted); }
.btn-kick {
  background: var(--danger);
  color: #fff;
  border: none;
  padding: 4px 10px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 12px;
}
.btn-kick:hover { background: var(--danger); }
.btn-kick:disabled { opacity: 0.4; cursor: not-allowed; }

.ban-toggle { display: flex; align-items: center; gap: 6px; font-size: 12px; cursor: pointer; }
.ban-toggle input { accent-color: var(--danger); }

/* Per-Mitglied Aktionsleiste in den Raum-Einstellungen */
.member-actions { display: flex; gap: 4px; align-items: center; }
.member-toggle {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--fg-muted);
  width: 28px; height: 24px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 13px;
  line-height: 1;
}
.member-toggle:hover { background: var(--bg-hover); color: #fff; }
.member-toggle.on { background: var(--accent); border-color: var(--accent); color: #fff; }
.room-member-row.hand .name,
.room-member-row.admin .name { color: #fff; }
.btn-grant-floor {
  background: #2e7d32;
  color: #fff;
  border: none;
  padding: 4px 10px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 12px;
}
.btn-grant-floor:hover { background: #256528; }
.btn-demote-admin {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--fg-muted);
  width: 24px; height: 24px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
}
.btn-demote-admin:hover { background: var(--danger); color: #fff; border-color: var(--danger); }

.room-ban-search {
  width: 100%;
  background: var(--bg-input);
  color: #fff;
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 6px 10px;
  font-size: 13px;
  margin-bottom: 8px;
  font-family: inherit;
}
.room-ban-search:focus { outline: none; border-color: var(--accent); }

.room-user {
  list-style: none;
  display: flex; align-items: center; gap: 6px;
  padding: 4px 16px 4px 38px;
  font-size: 13px;
  color: var(--fg-dim);
  cursor: pointer;
  user-select: none;
}
.room-user:hover { background: var(--bg-hover); }
.room-user.self { color: #fff; cursor: default; }
.room-user.self:hover { background: transparent; }
.room-user-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Sidebar-Kategorie-Header (collapsible) */
.room-category-header {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 16px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--fg-muted);
  cursor: pointer;
  user-select: none;
  margin-top: 6px;
}
.room-category-header:hover { color: #fff; }
.room-category-caret {
  display: inline-block;
  width: 12px;
  font-size: 10px;
  transition: transform 120ms;
}
.room-category-header.collapsed .room-category-caret { transform: rotate(-90deg); }
.room-category-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.room-category-count { color: var(--fg-very-muted); font-size: 10px; }

.room-category-row .room-category-input {
  display: flex;
  gap: 6px;
}
.room-category-row .room-category-input input {
  flex: 1;
  background: var(--bg-input);
  color: #fff;
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 6px 10px;
  font-size: 13px;
}
.room-category-row .room-category-input input:focus { outline: none; border-color: var(--accent); }

.room-automute-row {
  display: flex;
  gap: 8px;
  align-items: center;
  margin: 4px 0;
}
.room-automute-row input[type="number"] {
  width: 90px;
  background: var(--bg-input);
  color: #fff;
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 6px 10px;
  font-size: 13px;
}
.room-automute-row input[type="number"]:focus { outline: none; border-color: var(--accent); }
.room-user-badge {
  font-size: 11px;
  margin-left: 2px;
  cursor: help;
  user-select: none;
}

/* Inline-Admin-Aktionen direkt am Raum-User (nur für Raum-Admins sichtbar) */
.room-user-actions {
  display: inline-flex;
  gap: 2px;
  margin-left: 4px;
}
.room-user-toggle, .room-user-kick {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--fg-muted);
  width: 20px; height: 20px;
  padding: 0;
  border-radius: 3px;
  cursor: pointer;
  font-size: 11px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.room-user-toggle:hover, .room-user-kick:hover { background: var(--bg-hover); color: #fff; }
.room-user-toggle.on { background: var(--accent); border-color: var(--accent); color: #fff; }
.room-user-kick:hover { background: var(--danger); color: #fff; border-color: var(--danger); }
.room-user-badge.admin   { color: var(--link); }
.room-user-badge.muted   { color: #ff9d6c; }
.room-user-badge.chatban { color: var(--err); }
.room-user-badge.hand    { color: #ffd54f; animation: hand-wave 1.6s ease-in-out infinite; transform-origin: 70% 80%; }
@keyframes hand-wave {
  0%, 80%, 100% { transform: rotate(0deg); }
  88% { transform: rotate(-15deg); }
  94% { transform: rotate(12deg); }
}

.room-hand-badge {
  background: rgba(255, 213, 79, 0.18);
  color: #ffd54f;
  font-size: 11px;
  padding: 1px 6px;
  border-radius: 8px;
  margin-left: 4px;
}
.room-mention-badge {
  background: var(--danger);
  color: #fff;
  font-size: 11px;
  padding: 1px 6px;
  border-radius: 8px;
  margin-left: 4px;
  font-weight: 600;
}
.room-voice-badge {
  background: rgba(76, 175, 80, 0.20);
  color: #66bb6a;
  font-size: 11px;
  padding: 1px 6px;
  border-radius: 8px;
  margin-left: 4px;
  display: inline-flex;
  align-items: center;
  gap: 3px;
}
.room-item.in-voice .room-voice-badge {
  background: #2e7d32;
  color: #fff;
  font-weight: 600;
}

/* Persistent Voice-Channel-Strip (oberhalb der Nachrichten) */
.voice-strip {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  background: rgba(76, 175, 80, 0.08);
  border-bottom: 1px solid rgba(76, 175, 80, 0.25);
  flex-wrap: wrap;
}
.voice-strip.hidden { display: none; }
.voice-strip-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: #66bb6a;
  font-weight: 600;
}
.voice-strip-participants {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  flex: 1;
  min-width: 0;
}
.voice-strip-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(0, 0, 0, 0.25);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 14px;
  padding: 2px 10px 2px 4px;
  font-size: 12px;
}
.voice-strip-pill.speaking {
  border-color: #66bb6a;
  box-shadow: 0 0 0 2px rgba(102, 187, 106, 0.25);
}
.voice-strip-pill.sharing {
  border-color: #7e57c2;
}
.voice-strip-pill .voice-pill-avatar {
  width: 22px; height: 22px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 600;
  color: #fff;
}
.voice-strip-pill .voice-pill-name { color: #ddd; }
.voice-strip-pill .voice-pill-icon { font-size: 11px; opacity: 0.85; }
.voice-strip-action {
  background: #2e7d32;
  color: #fff;
  border: none;
  border-radius: 14px;
  padding: 4px 12px;
  font-size: 12px;
  cursor: pointer;
  font-weight: 600;
}
.voice-strip-action:hover { background: #388e3c; }
.voice-strip-action.leave { background: var(--danger); }
.voice-strip-action.leave:hover { background: #d32f2f; }

/* Smart-Reply-Vorschläge unter dem Composer (nur DMs) */
.smart-replies {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 16px;
  background: rgba(124, 77, 255, 0.06);
  border-top: 1px solid rgba(124, 77, 255, 0.18);
  flex-wrap: wrap;
}
.smart-replies.hidden { display: none; }
.smart-replies-label {
  font-size: 11px;
  color: #b39ddb;
  font-weight: 600;
  white-space: nowrap;
}
.smart-replies-chips {
  display: flex;
  gap: 6px;
  flex: 1;
  flex-wrap: wrap;
  min-width: 0;
}
.smart-replies-chip {
  background: rgba(124, 77, 255, 0.18);
  color: #ddd;
  border: 1px solid rgba(124, 77, 255, 0.4);
  border-radius: 14px;
  padding: 4px 12px;
  font-size: 12px;
  cursor: pointer;
  max-width: 320px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  transition: background 0.12s ease;
}
.smart-replies-chip:hover {
  background: rgba(124, 77, 255, 0.32);
}
.smart-replies-chip.loading {
  background: transparent;
  border-style: dashed;
  cursor: default;
  font-style: italic;
  opacity: 0.6;
}
.smart-replies-chip.loading:hover {
  background: transparent;
}
.smart-replies-dismiss {
  background: transparent;
  border: none;
  color: var(--fg-muted);
  font-size: 16px;
  cursor: pointer;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
}
.smart-replies-dismiss:hover {
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
}

/* Kanban / Tasks */
.tasks-box { width: min(1100px, 96vw); max-height: 90vh; }
.kanban {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 12px;
  padding: 16px;
}
.kanban-col {
  background: var(--bg);
  border: 1px solid #2c2e36;
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  min-height: 200px;
  max-height: 70vh;
}
.kanban-col-header {
  font-weight: 600;
  padding: 10px 12px;
  border-bottom: 1px solid #2c2e36;
  font-size: 13px;
}
.kanban-col-list {
  flex: 1;
  overflow-y: auto;
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.kanban-col-list.drag-over {
  background: rgba(98, 100, 167, 0.08);
}
.kanban-card {
  background: #2c2e36;
  border: 1px solid #44454f;
  border-radius: 6px;
  padding: 8px 10px;
  font-size: 12px;
  cursor: grab;
  position: relative;
}
.kanban-card.dragging { opacity: 0.5; }
.kanban-card-title { font-weight: 600; color: #ddd; margin-bottom: 4px; word-break: break-word; }
.kanban-card-meta { color: var(--fg-muted); font-size: 11px; display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.kanban-card-actions {
  display: flex;
  gap: 4px;
  margin-top: 6px;
}
.kanban-card-actions button {
  background: transparent;
  border: 1px solid #44454f;
  color: var(--fg-muted);
  border-radius: 4px;
  font-size: 10px;
  padding: 2px 6px;
  cursor: pointer;
}
.kanban-card-actions button:hover { background: #383a44; color: #fff; }
.kanban-card-actions button.danger:hover { background: var(--danger); color: #fff; border-color: var(--danger); }
.kanban-card-source {
  background: rgba(98, 100, 167, 0.15);
  border-left: 2px solid var(--accent);
  padding: 4px 6px;
  font-size: 11px;
  color: var(--fg-muted);
  margin-top: 4px;
  border-radius: 2px;
  cursor: pointer;
}
.kanban-card-source:hover { background: rgba(98, 100, 167, 0.25); }

.switch-label { display: inline-flex; align-items: center; }

/* Sidebar-Tools (Whiteboard / Docs) */
.sidebar-tools {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 0 8px 8px;
}
.sidebar-tool-btn {
  background: transparent;
  border: 1px solid #2c2e36;
  color: #ccc;
  padding: 6px 10px;
  border-radius: 4px;
  cursor: pointer;
  text-align: left;
  font-size: 13px;
}
.sidebar-tool-btn:hover { background: #2c2e36; color: #fff; }

/* Whiteboard */
.whiteboard-box { width: min(1700px, 96vw); height: min(960px, 92vh); display: flex; flex-direction: column; }
.whiteboard-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border-bottom: 1px solid #2c2e36;
  background: var(--bg);
}
.whiteboard-toolbar .wb-tool {
  background: transparent;
  border: 1px solid #44454f;
  color: #ccc;
  padding: 4px 8px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 14px;
}
.whiteboard-toolbar .wb-tool.active { background: var(--accent); color: #fff; border-color: var(--accent); }
.whiteboard-toolbar .wb-spacer { flex: 1; }
.whiteboard-toolbar input[type="color"] {
  width: 36px; height: 28px; border: none; background: transparent; cursor: pointer;
}
.whiteboard-toolbar input[type="range"] { width: 100px; }
.wb-status { margin-left: auto; font-size: 11px; }
.wb-status.live { color: var(--ok); }
.whiteboard-stage {
  flex: 1;
  overflow: auto;
  background: #15151a;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  padding: 8px;
}
#whiteboard-canvas {
  background: #1a1a20;
  border: 1px solid #2c2e36;
  cursor: crosshair;
}

/* ===========================================================
   Wissensdatenbank / Wiki — neues 3-Pane-Layout
   =========================================================== */
/* Wiki ist Vollbild — überspringt das übliche admin-modal-box-Cap. */
#docs-modal { padding: 0; }
.docs-box {
  width: 100vw;
  height: 100vh;
  max-width: 100vw;
  max-height: 100vh;
  border-radius: 0;
  display: flex;
  flex-direction: column;
}
.docs-layout {
  flex: 1;
  display: grid;
  grid-template-columns: 280px 1fr 280px;
  min-height: 0;
}

/* ----- Linke Spalte ----- */
.docs-sidebar {
  border-right: 1px solid var(--divider, #2c2e36);
  padding: 12px 10px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 10px;
  background: var(--bg-elev, rgba(0,0,0,.05));
}
.docs-sidebar-actions { display: flex; flex-direction: column; gap: 6px; }
.docs-new-wrap { position: relative; display: flex; gap: 0; }
.docs-new-btn {
  flex: 1;
  background: var(--accent, #6264a7);
  color: #fff;
  border: none;
  border-top-left-radius: 6px;
  border-bottom-left-radius: 6px;
  padding: 8px 12px;
  cursor: pointer;
  font-weight: 600;
  font-size: 13px;
}
.docs-new-btn:hover { filter: brightness(1.1); }
.docs-new-template-btn {
  background: var(--accent, #6264a7);
  color: #fff;
  border: none;
  border-left: 1px solid rgba(255,255,255,.15);
  border-top-right-radius: 6px;
  border-bottom-right-radius: 6px;
  padding: 8px 10px;
  cursor: pointer;
  font-weight: 700;
}
.docs-new-template-btn:hover { filter: brightness(1.1); }
.docs-template-menu {
  position: absolute;
  top: calc(100% + 4px); left: 0; right: 0;
  background: var(--bg-elev2, #2c2f3a);
  border: 1px solid var(--divider, #3a3d4a);
  border-radius: 6px;
  box-shadow: 0 12px 40px rgba(0,0,0,.4);
  z-index: 20;
  display: flex; flex-direction: column;
  padding: 4px;
}
.docs-template-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px;
  background: transparent;
  border: none;
  color: var(--fg, #e2e2e6);
  font: inherit;
  cursor: pointer;
  border-radius: 4px;
  text-align: left;
}
.docs-template-item:hover { background: rgba(98,100,167,.18); }
.docs-template-icon { font-size: 18px; flex: 0 0 auto; }

.docs-search { display: flex; }
.docs-search input {
  flex: 1; padding: 7px 10px;
  background: var(--bg, #1f2128);
  border: 1px solid var(--divider, #3a3d4a);
  color: var(--fg, #e2e2e6);
  border-radius: 6px;
  font-size: 13px;
}
.docs-filter-row { display: flex; gap: 6px; }
.docs-filter-select {
  flex: 1;
  background: var(--bg, #1f2128);
  border: 1px solid var(--divider, #3a3d4a);
  color: var(--fg, #e2e2e6);
  border-radius: 6px;
  padding: 6px 8px;
  font-size: 12px;
}
.docs-tags-btn {
  background: var(--bg, #1f2128);
  border: 1px solid var(--divider, #3a3d4a);
  color: var(--fg, #e2e2e6);
  border-radius: 6px;
  padding: 6px 10px;
  font-weight: 600;
  cursor: pointer;
}
.docs-tags-btn:hover { border-color: var(--accent, #6264a7); }
.docs-tags-panel {
  display: flex; flex-wrap: wrap; gap: 4px;
  padding: 6px 0;
  max-height: 140px; overflow-y: auto;
}
.docs-tag-chip {
  background: rgba(98,100,167,.10);
  border: 1px solid var(--divider, #3a3d4a);
  color: var(--fg, #e2e2e6);
  border-radius: 12px;
  padding: 3px 9px;
  font-size: 11px;
  cursor: pointer;
}
.docs-tag-chip:hover { border-color: var(--accent, #6264a7); }
.docs-tag-chip.active { background: var(--accent, #6264a7); color: #fff; border-color: var(--accent, #6264a7); }

.docs-section-h {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text-muted, #c0c0c8);
  margin: 8px 4px 4px;
}
.docs-section { display: flex; flex-direction: column; gap: 2px; }

/* Tree */
.docs-tree { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 1px; }
.docs-tree-item { padding: 0; cursor: pointer; }
.docs-tree-row {
  display: flex; align-items: center; gap: 6px;
  padding: 4px 6px;
  border-radius: 4px;
  color: var(--fg, #ccc);
  font-size: 13px;
}
.docs-tree-row:hover { background: rgba(98,100,167,.10); color: var(--fg, #fff); }
.docs-tree-item.active > .docs-tree-row { background: var(--accent, #6264a7); color: #fff; }
.docs-tree-caret {
  flex: 0 0 14px;
  font-size: 10px;
  color: var(--text-muted, #999);
  text-align: center;
  user-select: none;
}
.docs-tree-caret.empty { color: rgba(255,255,255,.15); }
.docs-tree-icon { flex: 0 0 18px; font-size: 14px; }
.docs-tree-title { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.docs-tree-status {
  flex: 0 0 auto;
  font-size: 10px;
  opacity: .7;
}
.docs-tree-empty { padding: 6px 8px; font-size: 12px; }

/* ----- Mitte ----- */
.docs-main {
  display: flex; flex-direction: column; min-height: 0;
  overflow: hidden;
}
.docs-empty { padding: 60px; text-align: center; color: var(--text-muted, #c0c0c8); font-size: 14px; }
.docs-doc {
  flex: 1;
  display: flex; flex-direction: column;
  min-height: 0;
  padding: 16px 24px;
  overflow-y: auto;
}
.docs-topbar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; min-height: 32px; }
.docs-breadcrumbs { flex: 1; display: flex; flex-wrap: wrap; align-items: center; gap: 4px; min-width: 0; }
.docs-breadcrumb { color: var(--text-muted, #c0c0c8); text-decoration: none; font-size: 12px; }
.docs-breadcrumb:hover { color: var(--accent, #6264a7); text-decoration: underline; }
.docs-breadcrumb-sep { color: var(--text-muted, #888); margin: 0 4px; font-size: 12px; }

.docs-topbar-right { display: flex; align-items: center; gap: 6px; }
.docs-status-badge {
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 10px;
  text-transform: uppercase;
  letter-spacing: .3px;
}
.docs-status-badge.status-draft     { background: rgba(255,200,80,.15); color: #ffc850; border: 1px solid #ffc85033; }
.docs-status-badge.status-published { background: rgba(155,231,167,.15); color: #9be7a7; border: 1px solid #9be7a733; }
.docs-status-badge.status-archived  { background: rgba(160,160,160,.15); color: #b0b0b0; border: 1px solid #b0b0b033; }

.docs-icon-btn, .docs-mode-btn {
  background: transparent;
  border: 1px solid var(--divider, #3a3d4a);
  color: var(--fg, #e2e2e6);
  border-radius: 4px;
  padding: 4px 10px;
  cursor: pointer;
  font-size: 12px;
}
.docs-icon-btn:hover, .docs-mode-btn:hover { border-color: var(--accent, #6264a7); }
.docs-icon-btn.danger { border-color: rgba(255,116,116,.4); color: #ff7474; }
.docs-icon-btn.danger:hover { background: rgba(255,116,116,.12); }
.docs-mode-btn.active { background: var(--accent, #6264a7); border-color: var(--accent, #6264a7); color: #fff; }
.docs-fav-btn { font-size: 14px; }
.docs-fav-btn.active { color: #ffc850; border-color: #ffc850; }

.docs-title-row { display: flex; align-items: center; gap: 8px; margin-top: 12px; }
.docs-icon-pick {
  background: transparent;
  border: 1px solid transparent;
  font-size: 28px;
  cursor: pointer;
  padding: 0 6px;
  border-radius: 4px;
}
.docs-icon-pick:hover { border-color: var(--divider, #3a3d4a); }
.docs-title {
  flex: 1;
  background: transparent;
  border: none;
  color: var(--fg, #fff);
  font-size: 28px;
  font-weight: 700;
  padding: 4px 0;
  outline: none;
  border-bottom: 1px solid transparent;
}
.docs-title:focus { border-bottom-color: var(--accent, #6264a7); }
.docs-title-display {
  flex: 1;
  font-size: 28px;
  font-weight: 700;
  margin: 0;
  color: var(--fg, #fff);
  word-wrap: break-word;
}

.docs-meta-row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin: 8px 0 12px; min-height: 22px; }
.docs-tags-display { display: flex; gap: 4px; flex-wrap: wrap; }
.docs-tag-chip-inline {
  background: rgba(98,100,167,.18);
  color: var(--accent, #b3b5e8);
  border-radius: 10px;
  padding: 2px 8px;
  font-size: 11px;
}
.docs-meta-sep { color: var(--text-muted, #666); }
.docs-meta-info { font-size: 12px; }

/* Edit-Toolbar */
.docs-edit-toolbar {
  display: flex; flex-wrap: wrap; align-items: center; gap: 4px;
  padding: 6px 8px;
  background: var(--bg-elev, rgba(255,255,255,.04));
  border: 1px solid var(--divider, #3a3d4a);
  border-radius: 6px;
  margin-bottom: 10px;
}
.docs-edit-toolbar button[data-md] {
  background: transparent;
  border: 1px solid transparent;
  color: var(--fg, #e2e2e6);
  border-radius: 4px;
  padding: 4px 8px;
  cursor: pointer;
  font-size: 12px;
  min-width: 28px;
}
.docs-edit-toolbar button[data-md]:hover {
  background: rgba(98,100,167,.18);
  border-color: var(--accent, #6264a7);
}
.docs-toolbar-sep { width: 1px; height: 18px; background: var(--divider, #3a3d4a); margin: 0 4px; }
.docs-status-indicator { margin-left: auto; font-size: 11px; }

/* Editor + Reader */
.docs-content {
  flex: 1; min-height: 300px;
  background: var(--bg, #1f2128);
  border: 1px solid var(--divider, #3a3d4a);
  color: var(--fg, #ddd);
  font-family: ui-monospace, 'Cascadia Code', Consolas, monospace;
  font-size: 13px;
  line-height: 1.55;
  padding: 14px;
  resize: none;
  outline: none;
  border-radius: 6px;
}
.docs-content:focus { border-color: var(--accent, #6264a7); }

.docs-reader {
  flex: 1;
  font-size: 14px;
  line-height: 1.65;
  color: var(--fg, #e2e2e6);
  padding: 0 4px;
}
.docs-reader h1, .docs-reader h2, .docs-reader h3, .docs-reader h4 {
  color: var(--fg, #fff);
  margin: 1.4em 0 .5em;
  font-weight: 700;
  scroll-margin-top: 80px;
}
.docs-reader h1 { font-size: 26px; border-bottom: 1px solid var(--divider, #3a3d4a); padding-bottom: 6px; }
.docs-reader h2 { font-size: 22px; border-bottom: 1px solid var(--divider, #3a3d4a); padding-bottom: 4px; }
.docs-reader h3 { font-size: 18px; }
.docs-reader h4 { font-size: 15px; }
.docs-reader p { margin: .6em 0; }
.docs-reader ul, .docs-reader ol { margin: .6em 0; padding-left: 1.6em; }
.docs-reader li { margin: 2px 0; }
.docs-reader a { color: var(--accent, #8a8cd4); }
.docs-reader a:hover { text-decoration: underline; }
.docs-reader code {
  background: rgba(255,255,255,.07);
  padding: 1px 6px;
  border-radius: 3px;
  font-family: ui-monospace, Consolas, monospace;
  font-size: 12.5px;
}
.docs-reader pre {
  background: var(--bg, #161821);
  border: 1px solid var(--divider, #3a3d4a);
  border-radius: 6px;
  padding: 12px 14px;
  overflow-x: auto;
  margin: 1em 0;
}
.docs-reader pre code {
  background: transparent;
  padding: 0;
  font-size: 12.5px;
  line-height: 1.5;
}
.docs-reader blockquote {
  border-left: 3px solid var(--accent, #6264a7);
  padding: 4px 14px;
  margin: 1em 0;
  color: var(--text-muted, #c0c0c8);
  background: rgba(98,100,167,.05);
  border-radius: 0 4px 4px 0;
}
.docs-reader table { border-collapse: collapse; margin: 1em 0; width: auto; }
.docs-reader th, .docs-reader td {
  border: 1px solid var(--divider, #3a3d4a);
  padding: 6px 10px;
  text-align: left;
}
.docs-reader th { background: rgba(98,100,167,.10); font-weight: 600; }
.docs-reader hr { border: 0; border-top: 1px solid var(--divider, #3a3d4a); margin: 1.5em 0; }
.docs-reader img { max-width: 100%; border-radius: 4px; }
.docs-reader input[type="checkbox"] { margin-right: 6px; }

.docs-md-fallback {
  white-space: pre-wrap;
  background: rgba(0,0,0,.2);
  padding: 12px;
  border-radius: 4px;
  color: var(--text-muted, #c0c0c8);
}

/* ----- Rechte Spalte ----- */
.docs-rail {
  border-left: 1px solid var(--divider, #2c2e36);
  padding: 14px 12px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 18px;
  background: var(--bg-elev, rgba(0,0,0,.05));
  font-size: 12px;
}
.docs-rail-section { display: flex; flex-direction: column; gap: 8px; }
.docs-rail-h {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text-muted, #c0c0c8);
  font-weight: 600;
}
.docs-rail-field { display: flex; flex-direction: column; gap: 4px; font-size: 12px; }
.docs-rail-field > span { color: var(--text-muted, #c0c0c8); font-size: 11px; }
.docs-rail-field input,
.docs-rail-field select,
.docs-rail-field textarea {
  background: var(--bg, #1f2128);
  border: 1px solid var(--divider, #3a3d4a);
  color: var(--fg, #e2e2e6);
  border-radius: 4px;
  padding: 5px 8px;
  font-size: 12px;
  font-family: inherit;
  resize: vertical;
}
.docs-rail-field input:focus,
.docs-rail-field select:focus,
.docs-rail-field textarea:focus { border-color: var(--accent, #6264a7); outline: none; }

.docs-toc { display: flex; flex-direction: column; gap: 2px; max-height: 320px; overflow-y: auto; }
.docs-toc-item {
  display: block;
  padding: 3px 6px;
  color: var(--text-muted, #c0c0c8);
  text-decoration: none;
  font-size: 12px;
  border-radius: 3px;
  border-left: 2px solid transparent;
}
.docs-toc-item:hover { color: var(--fg, #fff); border-left-color: var(--accent, #6264a7); background: rgba(98,100,167,.08); }
.docs-toc-item.lvl-1 { padding-left: 6px; font-weight: 600; }
.docs-toc-item.lvl-2 { padding-left: 16px; }
.docs-toc-item.lvl-3 { padding-left: 26px; }
.docs-toc-item.lvl-4 { padding-left: 36px; }
.docs-rail-info { font-size: 11px; line-height: 1.6; }
.docs-rail-info code { font-size: 10px; }

/* Mobile: rechte Spalte ausblenden, linke wird zu Toggle */
@media (max-width: 1024px) {
  .docs-layout { grid-template-columns: 260px 1fr; }
  .docs-rail { display: none; }
}
@media (max-width: 768px) {
  .docs-layout { grid-template-columns: 1fr; }
  .docs-sidebar { display: none; }
  .docs-doc { padding: 12px; }
  .docs-title-display, .docs-title { font-size: 22px; }
}

/* SSO-Button auf Login-Screen */
.sso-btn {
  margin-top: 8px;
  background: #1a73e8;
  border: 1px solid #1a73e8;
  color: #fff;
  border-radius: 4px;
  padding: 10px 14px;
  cursor: pointer;
  font-weight: 600;
}
.sso-btn:hover { background: #1565c0; }
.sso-btn.hidden { display: none; }

/* Hand-heben-Button im chat-header (active = Hand oben) */
#raise-hand-btn.active {
  background: #ffd54f;
  border-color: #ffd54f;
  color: var(--bg);
}

.user-card {
  padding: 12px 16px;
  border-top: 1px solid var(--divider);
  display: flex; align-items: center; gap: 10px;
}
.avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 600; color: #fff;
  background: var(--accent);
  font-size: 13px;
  flex-shrink: 0;
}
.avatar.small { width: 32px; height: 32px; font-size: 12px; }
.user-card-meta { min-width: 0; }
.user-card-name { font-weight: 600; font-size: 14px; }
.user-card-status { font-size: 11px; color: var(--ok); }

.presence-btn {
  display: inline-flex; align-items: center; gap: 6px;
  background: transparent;
  color: var(--fg-dim);
  border: 1px solid transparent;
  border-radius: 4px;
  padding: 2px 6px;
  font-size: 11px;
  cursor: pointer;
  font-family: inherit;
  margin-top: 1px;
}
.presence-btn:hover { background: var(--border); color: #fff; }
.presence-caret { font-size: 10px; opacity: 0.7; }

.presence-menu {
  position: absolute;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 6px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.45);
  padding: 4px;
  z-index: 50;
  min-width: 240px;
}
.presence-menu button {
  display: flex; align-items: center; gap: 8px;
  width: 100%;
  background: transparent;
  color: var(--fg);
  border: none;
  text-align: left;
  padding: 6px 10px;
  font-size: 13px;
  cursor: pointer;
  font-family: inherit;
  border-radius: 4px;
}
.presence-menu button:hover { background: var(--border); }
/* Input + Save-Button für den Status-Text. Vertikales Layout (Input oben,
   Button rechts darunter), damit beides ausreichend Platz hat — die
   .presence-menu button - Regel oben würde den Save-Button sonst auf 100%
   strecken. */
.presence-text-row {
  display: flex;
  flex-direction: column;
  gap: 6px;
  border-top: 1px solid var(--divider);
  padding: 8px 8px 6px;
  margin-top: 4px;
}
.presence-text-row input {
  display: block;
  width: 100%;
  box-sizing: border-box;
  background: var(--divider);
  color: var(--fg);
  border: 1px solid #44454f;
  border-radius: 4px;
  padding: 6px 8px;
  font-size: 12px;
  font-family: inherit;
}
.presence-text-row input:focus { outline: none; border-color: var(--accent); }
/* Override der .presence-menu button { width: 100% } - Regel: Save-Button
   ist auto-breit, an die rechte Seite gepinnt. */
.presence-menu button.presence-text-save {
  display: inline-block;
  width: auto;
  align-self: flex-end;
  background: var(--accent);
  color: #fff;
  font-size: 12px;
  padding: 4px 12px;
  white-space: nowrap;
  border-radius: 4px;
}
.presence-menu button.presence-text-save:hover { background: var(--accent-soft); }

/* Voice-Recording-Status (im Toolbar-Bereich) */
.chat-voice-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-left: 8px;
  background: var(--danger);
  color: #fff;
  border-radius: 4px;
  padding: 2px 8px;
  font-size: 12px;
}
.chat-voice-status.hidden { display: none; }
.chat-voice-dot {
  width: 8px; height: 8px;
  background: #fff;
  border-radius: 50%;
  animation: voice-pulse 1.2s ease-in-out infinite;
}
@keyframes voice-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}
.chat-voice-stop, .chat-voice-cancel {
  background: rgba(255,255,255,0.15);
  border: 0;
  color: #fff;
  width: 22px; height: 22px;
  border-radius: 3px;
  cursor: pointer;
  font-size: 12px;
}
.chat-voice-stop:hover, .chat-voice-cancel:hover { background: rgba(255,255,255,0.3); }
#chat-voice-btn.on { background: var(--danger); color: #fff; }

audio.voice-message {
  display: block;
  max-width: 320px;
  margin: 4px 0;
}

/* Live-Polls in Chat-Nachrichten */
.chat-poll {
  margin-top: 8px;
  background: var(--bg);
  border: 1px solid var(--bg-elev);
  border-radius: 6px;
  padding: 8px 10px;
}
.chat-poll-question {
  font-weight: 600;
  font-size: 13px;
  margin-bottom: 6px;
  color: #fff;
}
.chat-poll-option {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  color: var(--fg);
  border-radius: 4px;
  padding: 6px 10px;
  font-size: 13px;
  cursor: pointer;
  margin: 3px 0;
  text-align: left;
  overflow: hidden;
}
.chat-poll-option:hover { border-color: var(--accent); }
.chat-poll-option.mine {
  border-color: var(--accent);
  background: rgba(98, 100, 167, 0.15);
}
.chat-poll-fill {
  position: absolute;
  top: 0; bottom: 0; left: 0;
  background: rgba(98, 100, 167, 0.25);
  transition: width 200ms ease;
  z-index: 0;
}
.chat-poll-label, .chat-poll-count {
  position: relative;
  z-index: 1;
}
.chat-poll-label { flex: 1; }
.chat-poll-count {
  font-variant-numeric: tabular-nums;
  color: var(--fg-dim);
  margin-left: 8px;
}
.chat-poll-total {
  font-size: 11px;
  margin-top: 6px;
}

/* Q&A-Modal */
.qa-ask-row {
  display: flex;
  gap: 8px;
  padding: 12px 18px 6px;
  border-bottom: 1px solid var(--bg-elev);
}
.qa-ask-row input {
  flex: 1;
  background: var(--bg-input);
  color: #fff;
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 6px 10px;
  font-size: 13px;
  font-family: inherit;
}
.qa-ask-row input:focus { outline: none; border-color: var(--accent); }
.qa-row {
  display: flex;
  gap: 10px;
  align-items: center;
}
.qa-vote {
  display: flex;
  flex-direction: column;
  align-items: center;
  background: var(--bg-elev);
  border: 1px solid #44454f;
  color: var(--fg-dim);
  width: 44px;
  border-radius: 6px;
  padding: 4px 0;
  cursor: pointer;
}
.qa-vote:hover { background: var(--border); color: #fff; }
.qa-vote.mine { background: var(--accent); border-color: var(--accent); color: #fff; }
.qa-vote-arrow { font-size: 12px; line-height: 1; }
.qa-vote-count { font-variant-numeric: tabular-nums; font-weight: 600; font-size: 13px; }
.qa-content { flex: 1; min-width: 0; }
.qa-text { color: var(--fg); font-size: 13px; word-break: break-word; }
.qa-meta { font-size: 11px; margin-top: 4px; }
.qa-actions { display: flex; gap: 4px; }

/* Kontextmenü auf User-Tiles (Rechtsklick) */
.context-menu {
  position: fixed;
  z-index: 250;
  background: var(--bg-elev);
  border: 1px solid #44454f;
  border-radius: 6px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.5);
  padding: 4px;
  min-width: 220px;
  display: flex;
  flex-direction: column;
}
.context-menu.hidden { display: none; }
.context-menu button {
  background: transparent;
  border: 0;
  color: var(--fg);
  text-align: left;
  padding: 8px 12px;
  font-size: 13px;
  cursor: pointer;
  border-radius: 4px;
  font-family: inherit;
}
.context-menu button:hover { background: var(--border); }

/* Group-Chat-Tile in der User-Liste */
.user-item.gc-item .gc-avatar {
  background: var(--accent);
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Group-Chat-Erstellen-Modal */
.gc-create-box { width: 480px; max-width: 92vw; max-height: 80vh; display: flex; flex-direction: column; }
.gc-create-body { padding: 14px 18px 18px; overflow-y: auto; flex: 1; min-height: 0; }
.gc-create-body label { display: block; margin: 8px 0 4px; font-size: 13px; color: var(--fg-dim); }
.gc-create-body input[type="text"] {
  width: 100%;
  background: var(--bg);
  color: var(--fg);
  border: 1px solid #44454f;
  border-radius: 4px;
  padding: 8px 10px;
  font-size: 13px;
  box-sizing: border-box;
  font-family: inherit;
}
.gc-create-body input[type="text"]:focus { outline: none; border-color: var(--accent); }
.gc-create-userlist {
  list-style: none;
  margin: 8px 0 12px;
  padding: 0;
  max-height: 240px;
  overflow-y: auto;
  border: 1px solid var(--bg-elev);
  border-radius: 4px;
}
.gc-create-user {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 10px;
  cursor: pointer;
  border-bottom: 1px solid var(--divider);
}
.gc-create-user:last-child { border-bottom: 0; }
.gc-create-user:hover { background: var(--bg-elev-2); }
.gc-create-user.selected { background: rgba(98, 100, 167, 0.18); }
.gc-create-user .gc-create-name { flex: 1; font-size: 13px; color: var(--fg); }
.gc-create-user input[type="checkbox"] { accent-color: var(--accent); }
#gc-create-submit { width: 100%; margin-top: 10px; padding: 10px; }
#gc-create-submit:disabled { opacity: 0.6; cursor: not-allowed; }

/* Doku-Artikel (User-Help-Tab + Admin-Doku-Tab) */
.docs-article {
  padding: 18px 22px;
  font-size: 13px;
  line-height: 1.55;
  color: #d8d8de;
  max-width: 760px;
}
.docs-article h1 {
  font-size: 22px;
  margin: 0 0 12px;
  color: #fff;
}
.docs-article h2 {
  font-size: 16px;
  margin: 22px 0 8px;
  color: var(--link);
  border-bottom: 1px solid var(--bg-elev);
  padding-bottom: 4px;
}
.docs-article h3 {
  font-size: 14px;
  margin: 14px 0 6px;
  color: #fff;
}
.docs-article p { margin: 6px 0 10px; }
.docs-article ul, .docs-article ol { padding-left: 22px; margin: 6px 0 10px; }
.docs-article li { margin: 3px 0; }
.docs-article code {
  background: var(--bg-elev);
  padding: 1px 5px;
  border-radius: 3px;
  font-size: 12px;
  font-family: ui-monospace, SFMono-Regular, Consolas, monospace;
}
.docs-article kbd {
  background: var(--divider);
  border: 1px solid #44454f;
  border-bottom-width: 2px;
  border-radius: 3px;
  padding: 1px 5px;
  font-size: 11px;
  font-family: inherit;
}
.docs-article .docs-callout {
  background: rgba(98, 100, 167, 0.12);
  border-left: 3px solid var(--accent);
  padding: 8px 12px;
  border-radius: 0 4px 4px 0;
  margin: 10px 0;
}
.docs-article .docs-callout.warn {
  background: rgba(255, 213, 79, 0.10);
  border-color: #ffd54f;
}
.docs-article .docs-callout.danger {
  background: rgba(198, 40, 40, 0.12);
  border-color: var(--danger);
}
.docs-article .docs-callout strong { color: #fff; }
.docs-article details {
  background: var(--bg-elev-2);
  border: 1px solid var(--bg-elev);
  border-radius: 4px;
  padding: 6px 12px;
  margin: 8px 0;
}
.docs-article details summary {
  cursor: pointer;
  user-select: none;
  font-weight: 600;
  color: #fff;
}
.docs-article details[open] summary { margin-bottom: 6px; }
.docs-article a { color: var(--link); }

/* Schedule-Modal */
.schedule-box { width: 460px; max-width: 92vw; }
.schedule-body { padding: 16px 18px; }
.schedule-body label { display: block; margin: 12px 0 4px; font-size: 13px; color: var(--fg-dim); }
.schedule-body input[type="datetime-local"] {
  width: 100%;
  background: var(--bg);
  color: var(--fg);
  border: 1px solid #44454f;
  border-radius: 4px;
  padding: 8px 10px;
  font-size: 14px;
  font-family: inherit;
  box-sizing: border-box;
}
.schedule-body input[type="datetime-local"]:focus { outline: none; border-color: var(--accent); }
.schedule-quick {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 12px 0;
}
.schedule-quick .quick-btn {
  background: var(--bg-elev);
  color: var(--fg-dim);
  border: 1px solid #44454f;
  border-radius: 14px;
  padding: 4px 10px;
  font-size: 12px;
  cursor: pointer;
}
.schedule-quick .quick-btn:hover { background: var(--border); color: #fff; }
.schedule-body .btn-save { width: 100%; margin-top: 12px; padding: 10px; }

/* AI-Settings + WebLLM-Progress */
.settings-ai-local-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 8px;
}
.ai-progress-wrap {
  height: 6px;
  background: var(--divider);
  border-radius: 3px;
  overflow: hidden;
  margin-top: 6px;
}
.ai-progress-wrap.hidden { display: none; }
.ai-progress-fill {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--accent), var(--link));
  transition: width 200ms linear;
}
#settings-ai-status, #settings-ai-local-status {
  display: block;
  margin-top: 6px;
  font-size: 12px;
  word-break: break-word;
}

/* Catch-up-Modal */
.catchup-box {
  width: 720px;
  max-width: 92vw;
  max-height: 80vh;
  display: flex;
  flex-direction: column;
}
.catchup-body {
  padding: 14px 18px 18px;
  overflow-y: auto;
  flex: 1;
  min-height: 0;
}
.catchup-stats {
  font-size: 13px;
  margin-bottom: 12px;
}
.catchup-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-bottom: 14px;
  flex-wrap: wrap;
}
.catchup-actions .btn-save { padding: 6px 14px; font-size: 13px; }
.catchup-actions .muted { flex: 1; font-size: 12px; }
.catchup-summary {
  background: var(--bg);
  border: 1px solid var(--bg-elev);
  border-radius: 6px;
  padding: 12px 14px;
  font-size: 13px;
  line-height: 1.5;
  color: var(--fg);
  min-height: 60px;
}
.catchup-summary h1, .catchup-summary h2, .catchup-summary h3 { margin-top: 12px; margin-bottom: 6px; color: #fff; }
.catchup-summary h1 { font-size: 18px; }
.catchup-summary h2 { font-size: 16px; color: var(--link); }
.catchup-summary h3 { font-size: 14px; color: var(--fg-dim); }
.catchup-summary ul { padding-left: 18px; margin: 4px 0; }
.catchup-summary p { margin: 4px 0; }
.catchup-summary code.inline-code {
  background: var(--bg-elev);
  padding: 0 4px;
  border-radius: 3px;
  font-size: 12px;
}
.catchup-summary pre.code-block {
  background: #14151a;
  padding: 8px;
  border-radius: 4px;
  overflow-x: auto;
  font-size: 12px;
}
.catchup-raw {
  margin-top: 12px;
  font-size: 12px;
  color: var(--fg-muted);
}
.catchup-raw summary { cursor: pointer; user-select: none; }
.catchup-raw pre {
  background: #14151a;
  border-radius: 4px;
  padding: 8px;
  max-height: 200px;
  overflow: auto;
  font-size: 11px;
}

.read-receipt {
  font-size: 11px;
  color: var(--fg-muted);
  margin-top: 2px;
  text-align: right;
}
.read-receipt.seen { color: #9be7a7; }

/* ---------- Users panel ---------- */
.users-panel {
  background: var(--bg-elev-2);
  border-right: 1px solid var(--divider);
  display: flex; flex-direction: column;
}
.panel-header {
  padding: 16px;
  font-weight: 600;
  border-bottom: 1px solid var(--divider);
  font-size: 14px;
  display: flex; align-items: center; gap: 8px;
}
.users-filter {
  display: flex; gap: 6px;
  padding: 8px 12px;
  border-bottom: 1px solid var(--divider);
}
.users-filter input,
.users-filter select {
  flex: 1; min-width: 0;
  background: var(--bg-input);
  color: #fff;
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 6px 8px;
  font-size: 12px;
  font-family: inherit;
}
.users-filter input:focus,
.users-filter select:focus { outline: none; border-color: var(--accent); }
.users-filter select { flex: 0 0 110px; cursor: pointer; }

.users-list { list-style: none; flex: 1; overflow-y: auto; padding: 6px 0; }
.user-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px;
  position: relative;
  cursor: pointer;
}
.user-item.offline .avatar { opacity: 0.55; }
.user-item.offline .user-item-name { color: var(--fg-muted); }
.user-item.active { background: var(--bg-active); }
.user-item:hover { background: var(--bg-hover); }
.user-item.active:hover { background: var(--bg-active); }
.self-badge {
  font-size: 9px;
  font-weight: 700;
  background: var(--accent);
  color: #fff;
  padding: 1px 6px;
  border-radius: 8px;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  margin-left: 4px;
}
.user-meta { flex: 1; min-width: 0; }
.user-item-name {
  font-size: 14px; color: #eee;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  display: flex; align-items: center; gap: 6px;
}
.user-item-room { font-size: 11px; color: var(--fg-muted); }
.user-msg-preview {
  font-size: 12px;
  color: var(--fg-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}
.user-item.unread .user-msg-preview { color: #d0d0d8; font-weight: 500; }
.user-msg-time {
  font-size: 11px;
  color: var(--fg-muted);
  flex-shrink: 0;
  align-self: center;
  margin-left: 4px;
  white-space: nowrap;
}
.presence-dot {
  display: inline-block; width: 8px; height: 8px;
  border-radius: 50%;
  background: #555;
  flex-shrink: 0;
}
.presence-dot.online   { background: var(--ok); box-shadow: 0 0 0 2px rgba(76, 175, 80, 0.2); }
.presence-dot.away     { background: #f5a524; box-shadow: 0 0 0 2px rgba(245, 165, 36, 0.2); }
.presence-dot.busy     { background: var(--danger); box-shadow: 0 0 0 2px rgba(198, 40, 40, 0.25); }
.presence-dot.meeting  { background: var(--danger); box-shadow: 0 0 0 2px rgba(198, 40, 40, 0.25); }
.presence-dot.out      { background: var(--fg-muted); box-shadow: 0 0 0 2px rgba(138, 138, 146, 0.2); }
.presence-dot.offline  { background: #555; }
.user-group-tag {
  font-size: 10px; color: #b0b0b8;
  background: var(--border); padding: 1px 6px; border-radius: 8px;
  margin-left: auto;
}
.unread-badge {
  display: inline-block;
  background: var(--danger);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 10px;
  margin-left: 4px;
  min-width: 18px;
  text-align: center;
}
.btn-call {
  background: #2d5e3a; border: none; color: #fff;
  padding: 6px 10px; border-radius: 4px; cursor: pointer;
  font-size: 13px;
}
.btn-call:hover { background: #3d7e4a; }
.btn-call:disabled { opacity: 0.4; cursor: not-allowed; }
.empty-list { color: var(--fg-very-muted); padding: 12px 16px; font-size: 13px; }

/* ---------- Chat ---------- */
.chat-panel { display: flex; flex-direction: column; background: #1c1e25; min-width: 0; }
.chat-header {
  padding: 14px 18px;
  border-bottom: 1px solid var(--bg-elev);
  display: flex; justify-content: space-between; align-items: center;
  min-height: 56px;
}
#chat-room-name { font-weight: 600; font-size: 16px; }
.chat-actions { display: flex; align-items: center; gap: 12px; }
.header-action-btn {
  background: transparent;
  border: 1px solid #44454f;
  color: var(--fg-dim);
  width: 28px; height: 28px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
}
.header-action-btn:hover { background: var(--bg-elev); color: #fff; }
.header-action-btn.active { background: var(--accent); border-color: var(--accent); color: #fff; }
.groupcall-count {
  background: #2e7d32;
  color: #fff;
  font-size: 9px;
  border-radius: 7px;
  padding: 0 4px;
  position: absolute;
  margin-left: 14px;
  margin-top: -10px;
  min-width: 14px;
  text-align: center;
}
#groupcall-btn { position: relative; }

/* ---------- Group-Call-Panel ---------- */
.groupcall-panel {
  position: fixed;
  right: 18px;
  bottom: 18px;
  width: 380px;
  max-height: 70vh;
  background: var(--bg-elev-2);
  border: 1px solid #44454f;
  border-radius: 10px;
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.6);
  display: flex;
  flex-direction: column;
  z-index: 150;
  overflow: hidden;
}
.groupcall-panel.hidden { display: none; }
.groupcall-panel.collapsed {
  height: 44px;
  width: 220px;
  cursor: pointer;
}
.groupcall-panel.collapsed .groupcall-tiles,
.groupcall-panel.collapsed .groupcall-screen,
.groupcall-panel.collapsed .groupcall-controls { display: none; }
.groupcall-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 8px 12px;
  background: var(--bg-elev);
  border-bottom: 1px solid var(--divider);
  font-size: 13px;
  color: var(--fg);
}
.groupcall-title { font-weight: 600; }
.groupcall-tiles {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
  gap: 6px;
  padding: 10px;
  max-height: 200px;
  overflow-y: auto;
}
.groupcall-tile {
  background: var(--bg);
  border: 1px solid var(--divider);
  border-radius: 6px;
  padding: 8px 6px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.groupcall-tile { position: relative; }
.groupcall-tile.speaking { box-shadow: 0 0 0 2px var(--ok); }
.groupcall-tile.pinned { box-shadow: 0 0 0 2px #ffb300; }
.groupcall-tile.speaking.pinned { box-shadow: 0 0 0 2px var(--ok), 0 0 0 4px #ffb300; }
.groupcall-tile-pin {
  position: absolute;
  top: 4px;
  right: 4px;
  width: 22px; height: 22px;
  background: rgba(0,0,0,0.55);
  border: none;
  border-radius: 4px;
  color: rgba(255,255,255,0.55);
  cursor: pointer;
  font-size: 11px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.15s ease;
}
.groupcall-tile:hover .groupcall-tile-pin,
.groupcall-tile-pin.on { opacity: 1; }
.groupcall-tile-pin.on {
  background: #ffb300;
  color: var(--bg);
}
.groupcall-tile-video {
  width: 100%;
  height: 90px;
  object-fit: cover;
  background: #000;
  border-radius: 4px;
  display: block;
}
.groupcall-tile-video.hidden { display: none; }
.groupcall-tile.has-video .groupcall-avatar { display: none; }
#groupcall-camera-btn.on { background: var(--accent); border-color: var(--accent); color: #fff; }

/* 1:1-Call-Floating-Panel */
.onecall-panel {
  position: fixed;
  right: 18px;
  bottom: 18px;
  width: 360px;
  background: var(--bg-elev-2);
  border: 1px solid #44454f;
  border-radius: 10px;
  box-shadow: 0 16px 48px rgba(0,0,0,.6);
  z-index: 160;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.onecall-panel.hidden { display: none; }
.onecall-panel.collapsed { height: 44px; width: 240px; cursor: pointer; }
.onecall-panel.collapsed .onecall-stage,
.onecall-panel.collapsed .onecall-controls { display: none; }
.onecall-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 8px 12px;
  background: var(--bg-elev);
  border-bottom: 1px solid var(--divider);
  font-size: 13px;
  color: var(--fg);
}
.onecall-title { font-weight: 600; }
.onecall-stage {
  position: relative;
  background: #000;
  width: 100%;
  height: 240px;
  display: flex;
  align-items: center;
  justify-content: center;
}
#onecall-remote-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#onecall-remote-video.hidden { display: none; }
.onecall-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  color: var(--fg-dim);
  font-size: 14px;
}
.onecall-placeholder.hidden { display: none; }
.onecall-placeholder .avatar {
  width: 64px; height: 64px;
  border-radius: 50%;
  font-size: 22px;
}
.onecall-self-view {
  position: absolute;
  right: 8px; bottom: 8px;
  width: 100px; height: 75px;
  object-fit: cover;
  border: 1px solid #fff;
  border-radius: 4px;
  background: #000;
}
.onecall-self-view.hidden { display: none; }
.onecall-controls {
  display: flex;
  gap: 6px;
  justify-content: center;
  padding: 8px;
  background: var(--bg-elev);
  border-top: 1px solid var(--divider);
}
#onecall-camera-btn.on { background: var(--accent); border-color: var(--accent); color: #fff; }

/* Video-Vorschau in Settings (Audio-Tab) */
.video-preview-wrap {
  width: 100%;
  max-width: 320px;
  aspect-ratio: 16 / 9;
  background: #000;
  border-radius: 6px;
  margin: 8px 0;
  overflow: hidden;
}
.video-preview-wrap.hidden { display: none; }
#settings-video-preview {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.groupcall-avatar {
  width: 38px; height: 38px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  color: #fff;
  font-size: 13px;
}
.groupcall-tile-name {
  font-size: 11px;
  color: var(--fg);
  word-break: break-word;
  line-height: 1.2;
}
.groupcall-tile-status {
  display: flex;
  gap: 3px;
  font-size: 10px;
}
.groupcall-vu {
  width: 100%;
  height: 3px;
  background: var(--divider);
  border-radius: 2px;
  overflow: hidden;
}
.groupcall-vu-fill {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--ok), #9be7a7);
  transition: width 60ms linear;
}
.groupcall-screen {
  position: relative;
  background: #000;
  padding: 4px;
}
.groupcall-screen video {
  width: 100%;
  display: block;
  max-height: 240px;
  object-fit: contain;
  background: #000;
}
.groupcall-screen-author {
  position: absolute;
  top: 8px; left: 8px;
  background: rgba(0,0,0,0.6);
  color: #fff;
  font-size: 11px;
  padding: 2px 6px;
  border-radius: 3px;
}
.groupcall-controls {
  display: flex;
  gap: 6px;
  justify-content: center;
  padding: 8px;
  background: var(--bg-elev);
  border-top: 1px solid var(--divider);
}
.groupcall-ctrl {
  background: var(--bg);
  border: 1px solid #44454f;
  color: var(--fg);
  width: 36px; height: 36px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.groupcall-ctrl:hover { background: var(--bg-hover); }
.groupcall-ctrl.on { background: var(--accent); border-color: var(--accent); color: #fff; }
.groupcall-ctrl.danger { background: var(--danger); border-color: var(--danger); color: #fff; }
.groupcall-ctrl.danger:hover { background: var(--danger); }
#groupcall-record-btn.on {
  background: var(--danger);
  border-color: var(--danger);
  color: #fff;
  animation: rec-pulse 1.4s ease-in-out infinite;
}
@keyframes rec-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.55; }
}

/* Aufnahmen-Modal */
.recordings-box { width: 720px; max-width: 92vw; max-height: 80vh; display: flex; flex-direction: column; }
.recordings-list { overflow-y: auto; flex: 1; min-height: 0; padding: 8px 18px 18px; }
.recording-item {
  background: var(--bg-elev-2);
  border: 1px solid var(--divider);
  border-radius: 6px;
  padding: 10px 12px;
  margin-bottom: 8px;
}
.recording-item audio { width: 100%; margin: 8px 0; }
.recording-item .rec-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  font-size: 13px;
  color: var(--fg);
}
.recording-item .rec-meta .muted { color: var(--fg-muted); font-size: 12px; }
.rec-actions { margin-left: auto; display: flex; gap: 4px; }
.rec-transcribe {
  background: var(--accent);
  color: #fff;
  border: 0;
  width: 28px; height: 28px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 13px;
}
.rec-transcribe:hover { background: var(--accent-soft); }
.rec-status {
  font-size: 11px;
  padding: 2px 6px;
  border-radius: 8px;
  font-weight: 600;
}
.rec-status-ready { background: var(--bg-elev); color: var(--fg-dim); }
.rec-status-transcribing { background: rgba(98,100,167,.3); color: #cbd1ff; animation: rec-pulse 1.4s ease-in-out infinite; }
.rec-status-transcribed { background: rgba(76,175,80,.2); color: #9be7a7; }
.rec-status-failed { background: rgba(198,40,40,.25); color: var(--err); }
.rec-transcript {
  margin-top: 6px;
  background: var(--bg);
  border: 1px solid var(--bg-elev);
  border-radius: 4px;
  padding: 6px 10px;
  font-size: 12px;
}
.rec-transcript summary { cursor: pointer; color: var(--fg-dim); user-select: none; }
.rec-transcript pre {
  white-space: pre-wrap;
  font-family: inherit;
  margin: 6px 0 0;
  color: var(--fg);
  font-size: 12px;
  max-height: 280px;
  overflow-y: auto;
}
.rec-error {
  margin-top: 6px;
  font-size: 11px;
  color: var(--err);
  background: rgba(198,40,40,.15);
  padding: 4px 8px;
  border-radius: 3px;
}

/* ---------- Search-Modal ---------- */
.search-box { width: 640px; max-width: 92vw; max-height: 80vh; display: flex; flex-direction: column; }
.search-controls {
  padding: 12px 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  border-bottom: 1px solid var(--bg-elev);
}
.search-controls input[type="search"] {
  width: 100%;
  padding: 9px 12px;
  background: var(--bg);
  color: var(--fg);
  border: 1px solid #44454f;
  border-radius: 6px;
  font-size: 14px;
  box-sizing: border-box;
}
.search-controls input[type="search"]:focus { outline: none; border-color: var(--accent); }
.search-options {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  font-size: 13px;
  color: var(--fg-dim);
}
.search-radio, .search-checkbox {
  display: flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
}
.search-radio input, .search-checkbox input { accent-color: var(--accent); }
.search-status {
  padding: 8px 18px;
  font-size: 12px;
}
.search-results {
  list-style: none;
  margin: 0;
  padding: 0 0 12px;
  overflow-y: auto;
  flex: 1;
  min-height: 0;
}
.search-result-item {
  padding: 10px 18px;
  border-top: 1px solid var(--bg-elev);
  cursor: pointer;
}
.search-result-item:hover { background: var(--bg-elev-2); }
.search-result-meta {
  display: flex;
  gap: 8px;
  font-size: 12px;
  color: var(--fg-muted);
  margin-bottom: 4px;
  flex-wrap: wrap;
}
.search-result-source {
  color: var(--link);
  font-weight: 600;
}
.search-result-author { color: var(--fg-dim); }
.search-result-time { margin-left: auto; }
.search-result-snippet {
  font-size: 13px;
  color: var(--fg);
  line-height: 1.45;
  word-break: break-word;
}
.search-result-snippet mark {
  background: var(--accent);
  color: #fff;
  padding: 0 2px;
  border-radius: 2px;
}
.search-result-attachment-tag {
  background: var(--border);
  color: var(--fg-dim);
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 11px;
}
.search-empty { padding: 18px; color: var(--fg-muted); font-size: 13px; text-align: center; }

/* Highlight-Flash für gefundene Nachrichten nach Sprung */
.message.search-flash {
  animation: search-flash-anim 1200ms ease-out;
}
@keyframes search-flash-anim {
  0%   { background-color: rgba(98, 100, 167, 0.45); }
  100% { background-color: transparent; }
}
.call-status {
  background: #1f3a25; padding: 6px 10px; border-radius: 6px;
  font-size: 13px; color: #9be7a7;
  display: flex; align-items: center; gap: 10px;
}
.btn-end {
  background: var(--danger); color: #fff; border: none;
  padding: 4px 10px; border-radius: 4px; cursor: pointer;
  font-size: 12px;
}
.btn-end:hover { background: var(--danger); }

.messages {
  flex: 1; overflow-y: auto;
  padding: 18px;
  display: flex; flex-direction: column; gap: 10px;
}
.message {
  background: var(--message-bg);
  border-radius: 10px;
  padding: 8px 12px;
  max-width: 70%;
  word-wrap: break-word;
}
.message.own { align-self: flex-end; background: var(--message-own); }
.message-meta {
  font-size: 11px; color: var(--fg-muted);
  display: flex; gap: 8px; margin-bottom: 3px;
}
.message-time { color: var(--fg-very-muted); }
.message-body { font-size: 14px; color: #fff; white-space: pre-wrap; }

.chat-composer {
  border-top: 1px solid var(--bg-elev);
  background: #1f212a;
  position: relative;
}
.chat-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 2px;
  padding: 6px 10px;
  border-bottom: 1px solid var(--bg-elev);
}
.ttbtn {
  background: transparent;
  color: var(--fg-dim);
  border: 1px solid transparent;
  border-radius: 4px;
  padding: 4px 8px;
  cursor: pointer;
  font-size: 13px;
  line-height: 1;
  font-family: inherit;
  min-width: 28px;
}
.ttbtn:hover { background: var(--bg-elev); color: #fff; }
.ttbtn.active { background: var(--border); color: #fff; }
.toolbar-sep {
  width: 1px; height: 18px;
  background: var(--border);
  margin: 0 4px;
}
.color-btn {
  position: relative;
  display: inline-flex; align-items: center;
  cursor: pointer;
}
.color-btn input[type="color"] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  border: none;
  background: none;
  padding: 0;
  width: 100%;
  height: 100%;
}

.chat-form {
  display: flex; gap: 8px;
  padding: 10px 12px 12px;
  align-items: flex-end;
}
.chat-input {
  flex: 1;
  min-height: 40px;
  max-height: 200px;
  overflow-y: auto;
  padding: 10px 12px;
  border-radius: 6px;
  border: 1px solid var(--bg-elev);
  background: var(--message-bg);
  color: #fff;
  font-size: 14px;
  outline: none;
  white-space: pre-wrap;
  word-break: break-word;
}
.chat-input:focus { border-color: var(--accent); }
.chat-input[contenteditable="false"] { opacity: 0.4; cursor: not-allowed; }
.chat-input:empty::before {
  content: attr(data-placeholder);
  color: var(--fg-very-muted);
  pointer-events: none;
}
.chat-form button[type="submit"] {
  padding: 10px 18px;
  background: var(--accent);
  color: #fff;
  border: none; border-radius: 6px;
  cursor: pointer; font-weight: 600;
}
.chat-form button[type="submit"]:hover:not(:disabled) { background: var(--accent-soft); }
.chat-form button[type="submit"]:disabled { opacity: 0.4; cursor: not-allowed; }

/* Inhalt der Nachrichten + Editor — gemeinsame Regeln */
.message-body, .chat-input {
  font-size: 14px;
  line-height: 1.4;
}
.message-body ul, .chat-input ul,
.message-body ol, .chat-input ol { margin: 4px 0 4px 20px; padding: 0; }
.message-body li, .chat-input li { margin: 2px 0; }
.message-body code, .chat-input code {
  background: var(--bg-input);
  color: #ffd479;
  padding: 1px 5px;
  border-radius: 3px;
  font-family: 'Consolas', 'Cascadia Code', monospace;
  font-size: 12.5px;
}
.message-body pre, .chat-input pre {
  background: var(--bg-input);
  color: #d6d6dc;
  padding: 8px 10px;
  border-radius: 6px;
  font-family: 'Consolas', 'Cascadia Code', monospace;
  font-size: 12.5px;
  margin: 4px 0;
  white-space: pre-wrap;
  border-left: 3px solid var(--accent);
}
.message-body pre code, .chat-input pre code { background: transparent; padding: 0; color: inherit; }
.message-body blockquote, .chat-input blockquote {
  border-left: 3px solid var(--accent);
  padding: 2px 10px;
  margin: 4px 0;
  color: var(--fg-dim);
}
.message-body h1, .chat-input h1,
.message-body h2, .chat-input h2,
.message-body h3, .chat-input h3,
.message-body h4, .chat-input h4 {
  margin: 4px 0;
  font-size: 15px;
  font-weight: 700;
}
.message-body a, .chat-input a {
  color: var(--link);
  text-decoration: underline;
}
.message-body img.chat-image, .chat-input img.chat-image {
  max-width: 320px;
  max-height: 240px;
  border-radius: 6px;
  display: block;
  margin: 4px 0;
}
.chat-attachment {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 4px 10px;
  text-decoration: none !important;
  color: var(--fg) !important;
  margin: 2px 0;
}
.chat-attachment:hover { background: var(--bg-elev); }
.chat-attachment small { color: var(--fg-muted); }

/* ---------- Reply-Bar im Composer ---------- */
.reply-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: var(--bg-elev-2);
  border-top: 1px solid var(--bg-elev);
  border-left: 3px solid var(--accent);
  font-size: 12px;
  color: var(--fg-dim);
}
.reply-bar-content {
  flex: 1; min-width: 0;
  display: flex; align-items: baseline; gap: 6px;
  overflow: hidden;
}
.reply-bar-label { color: var(--fg-muted); text-transform: uppercase; letter-spacing: 0.4px; font-size: 10px; font-weight: 700; }
.reply-bar-text {
  color: #a0a0a8;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  flex: 1; min-width: 0;
}
.reply-bar-clear {
  background: transparent;
  color: var(--fg-muted);
  border: none;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  padding: 0 6px;
  border-radius: 3px;
}
.reply-bar-clear:hover { color: #fff; background: var(--border); }

/* ---------- Emoji-Picker-Popover ---------- */
.emoji-popover {
  position: fixed;
  z-index: 220;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.5);
  width: 300px;
  max-height: 300px;
  overflow-y: auto;
  padding: 8px;
}
.emoji-section { margin-bottom: 6px; }
.emoji-section-title {
  font-size: 10px;
  color: var(--fg-muted);
  text-transform: uppercase;
  letter-spacing: 0.4px;
  padding: 4px 6px 2px;
}
.emoji-grid {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 2px;
}
.emoji-btn {
  background: transparent;
  border: none;
  font-size: 18px;
  line-height: 1.6;
  padding: 0;
  cursor: pointer;
  border-radius: 4px;
  transition: background 80ms ease;
}
.emoji-btn:hover { background: var(--border); }

/* ---------- Reactions an Nachrichten ---------- */
.message-reactions {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 4px;
}
.reaction-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 1px 8px;
  font-size: 12px;
  color: var(--fg-dim);
  cursor: pointer;
  user-select: none;
  font-family: inherit;
}
.reaction-chip:hover { background: var(--bg-elev); }
.reaction-chip.mine { background: #3a3d6a; border-color: #5a5d8a; color: #fff; }
.reaction-chip-emoji { font-size: 14px; }
.reaction-chip-count { font-weight: 600; }

/* ---------- Hover-Aktionen pro Nachricht ---------- */
.message { position: relative; }
.message-actions {
  position: absolute;
  top: -10px;
  right: 8px;
  display: none;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 2px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
}
.message:hover .message-actions { display: flex; }
.message-action-btn {
  background: transparent;
  border: none;
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
  padding: 4px 6px;
  border-radius: 3px;
  color: var(--fg-dim);
}
.message-action-btn:hover { background: var(--border); color: #fff; }
.message-action-btn.on { background: rgba(98, 100, 167, 0.4); color: #fff; }

/* Thread-Header oberhalb der Messages, wenn ein Thread geöffnet ist */
.thread-header {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--bg-elev-2);
  border-bottom: 1px solid var(--bg-elev);
  padding: 8px 12px;
  margin: -12px -12px 12px;
  position: sticky;
  top: 0;
  z-index: 5;
}
.thread-back-btn {
  background: transparent;
  border: 1px solid #44454f;
  color: var(--fg-dim);
  width: 32px; height: 28px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 14px;
}
.thread-back-btn:hover { background: var(--bg-hover); color: #fff; }
.thread-header-title { font-weight: 600; font-size: 14px; color: #fff; }
.thread-header-sub { font-size: 11px; color: var(--fg-muted); margin-top: 2px; }

/* „💬 N Antworten"-Link unter Top-Level-Nachrichten */
.thread-count-link {
  background: transparent;
  border: 0;
  padding: 4px 0 0;
  margin-top: 4px;
  font-size: 12px;
  color: var(--link);
  cursor: pointer;
  text-align: left;
}
.thread-count-link:hover { text-decoration: underline; }

/* 📌-Indikator vor dem Author-Namen wenn die Nachricht geheftet ist */
.message-pinned-indicator {
  margin-right: 4px;
  font-size: 11px;
  color: #ffd54f;
  cursor: help;
}

/* ---------- Pinned-Modal ---------- */
.pinned-box {
  width: 640px;
  max-width: 92vw;
  max-height: 80vh;
  display: flex;
  flex-direction: column;
}
.pinned-list {
  overflow-y: auto;
  flex: 1;
  min-height: 0;
  padding: 4px 12px 14px;
}
.pinned-item {
  background: var(--bg-elev-2);
  border: 1px solid var(--divider);
  border-radius: 6px;
  padding: 10px 12px;
  margin-bottom: 8px;
  cursor: pointer;
}
.pinned-item:hover { border-color: #44454f; }
.pinned-meta {
  display: flex;
  gap: 8px;
  align-items: center;
  font-size: 12px;
  color: var(--fg);
  margin-bottom: 4px;
}
.pinned-meta .muted { color: var(--fg-muted); flex: 1; }
.pinned-unpin {
  background: transparent;
  border: 1px solid #44454f;
  color: var(--fg-muted);
  width: 22px; height: 22px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 13px;
  line-height: 1;
}
.pinned-unpin:hover { background: var(--danger); color: #fff; border-color: var(--danger); }
.pinned-body {
  font-size: 13px;
  color: var(--fg-dim);
  word-break: break-word;
}

/* ---------- Files-Modal ---------- */
.files-box {
  width: 720px;
  max-width: 92vw;
  max-height: 80vh;
  display: flex;
  flex-direction: column;
}
.files-grid {
  overflow-y: auto;
  flex: 1;
  min-height: 0;
  padding: 8px 12px 14px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 10px;
}
.files-item {
  background: var(--bg-elev-2);
  border: 1px solid var(--divider);
  border-radius: 6px;
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.files-item.image .files-thumb {
  display: block;
  width: 100%;
  height: 120px;
  overflow: hidden;
  border-radius: 4px;
  background: var(--divider);
}
.files-item.image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.files-item .files-link {
  color: var(--link);
  text-decoration: none;
  font-size: 13px;
  word-break: break-word;
  padding: 16px 4px;
  display: block;
}
.files-item .files-link:hover { color: #fff; text-decoration: underline; }
.files-meta {
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  color: var(--fg-muted);
  border-top: 1px solid var(--divider);
  padding-top: 6px;
}
.files-meta:hover { color: var(--fg-dim); }

/* @-Mention-Pill in Chat-Nachrichten + im Composer */
.mention {
  display: inline-block;
  background: rgba(98, 100, 167, 0.25);
  color: #cbd1ff;
  border-radius: 4px;
  padding: 0 4px;
  font-weight: 500;
  cursor: pointer;
  user-select: none;
}
.mention:hover { background: rgba(98, 100, 167, 0.4); }
/* Wenn die Nachricht MICH erwähnt: gelber Akzent links + dezenter Hintergrund */
.message.mentions-me {
  background: rgba(255, 213, 79, 0.07);
  border-left: 3px solid #ffd54f;
  padding-left: 9px;
}

/* @-Picker-Popup */
.mention-picker {
  position: fixed;
  z-index: 200;
  background: var(--bg-elev-2);
  border: 1px solid #44454f;
  border-radius: 6px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
  padding: 4px;
  min-width: 200px;
  max-width: 260px;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.mention-picker.hidden { display: none; }
.mention-picker-item {
  display: flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  border: 0;
  padding: 6px 8px;
  border-radius: 4px;
  color: var(--fg);
  cursor: pointer;
  text-align: left;
  font-size: 13px;
}
.mention-picker-item.active { background: var(--accent); color: #fff; }
.mention-picker-avatar {
  width: 22px; height: 22px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  color: #fff;
  font-weight: 600;
}
.mention-picker-name {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* System-Nachrichten („X hat jetzt das Wort" etc.) — zentral, dezent */
.message.system {
  align-self: center;
  background: transparent;
  padding: 4px 12px;
  margin: 6px auto;
  max-width: 80%;
  text-align: center;
}
.message.system .message-body {
  background: rgba(98, 100, 167, 0.12);
  border: 1px solid rgba(98, 100, 167, 0.3);
  border-radius: 12px;
  padding: 4px 12px;
  font-size: 12px;
  color: var(--fg-dim);
  font-style: italic;
  display: inline-block;
}

/* „bearbeitet HH:MM" hinter der Uhrzeit (nur wenn Edit > 30s nach Versand) */
.message-edited {
  margin-left: 6px;
  color: var(--fg-muted);
  font-size: 11px;
  font-style: italic;
  cursor: help;
}

/* Inline-Editor, ersetzt .message-body während des Bearbeitens */
.message-edit-input {
  min-height: 24px;
  padding: 6px 8px;
  border: 1px solid #44454f;
  border-radius: 4px;
  background: var(--bg);
  color: var(--fg);
  outline: none;
  white-space: pre-wrap;
  word-wrap: break-word;
}
.message-edit-input:focus { border-color: var(--accent); }
.message-edit-actions {
  display: flex;
  gap: 6px;
  justify-content: flex-end;
  margin-top: 4px;
}
.message-edit-actions button {
  padding: 4px 10px;
  border-radius: 4px;
  border: 1px solid #44454f;
  background: var(--bg-elev);
  color: var(--fg);
  font-size: 12px;
  cursor: pointer;
}
.message-edit-actions button.message-edit-save {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
.message-edit-actions button:hover { filter: brightness(1.1); }

/* ---------- Reply-Block über einer Antwort ---------- */
.message-reply-quote {
  border-left: 3px solid var(--accent);
  padding: 2px 8px;
  margin-bottom: 4px;
  font-size: 12px;
  color: #a0a0a8;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 0 4px 4px 0;
  cursor: pointer;
}
.message-reply-quote:hover { background: rgba(255, 255, 255, 0.06); }
.message-reply-quote .reply-from { color: var(--link); font-weight: 600; }
.message-reply-quote .reply-text { color: #b0b0b8; }

.chat-drop-overlay {
  position: absolute;
  inset: 0;
  background: rgba(98, 100, 167, 0.85);
  display: flex; align-items: center; justify-content: center;
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  pointer-events: none;
  border: 2px dashed #fff;
  border-radius: 8px;
  margin: 8px;
  z-index: 5;
}

/* ---------- Incoming call ---------- */
.incoming-call {
  position: fixed;
  top: 24px; right: 24px;
  z-index: 100;
}
.incoming-call-box {
  background: var(--bg-elev);
  padding: 16px 20px;
  border-radius: 10px;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.6);
  display: flex; flex-direction: column; gap: 10px;
  min-width: 280px;
  border: 1px solid var(--accent);
  animation: ring-pulse 1.4s ease-in-out infinite;
}
@keyframes ring-pulse {
  0%, 100% { box-shadow: 0 12px 32px rgba(0, 0, 0, 0.6), 0 0 0 0 rgba(98, 100, 167, 0.4); }
  50% { box-shadow: 0 12px 32px rgba(0, 0, 0, 0.6), 0 0 0 12px rgba(98, 100, 167, 0); }
}
.incoming-title { font-size: 12px; color: var(--fg-muted); text-transform: uppercase; letter-spacing: 0.5px; }
.incoming-from { font-size: 16px; }
.call-buttons { display: flex; gap: 8px; }
.btn-accept, .btn-reject {
  flex: 1; padding: 8px; border: none; border-radius: 4px;
  cursor: pointer; color: #fff; font-weight: 600; font-size: 13px;
}
.btn-accept { background: #2e7d32; }
.btn-accept:hover { background: #388e3c; }
.btn-reject { background: var(--danger); }
.btn-reject:hover { background: #d32f2f; }

/* ---------- Admin ---------- */
.admin-open-btn {
  margin: 8px 12px 4px;
  padding: 8px 12px;
  background: var(--border);
  color: #fff;
  border: 1px solid #4a4d5a;
  border-radius: 6px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  text-align: left;
}
.admin-open-btn:hover { background: #4a4d5a; }

.logout-btn {
  background: transparent;
  color: var(--fg-muted);
  border: none;
  font-size: 18px;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 4px;
  margin-left: auto;
}
.logout-btn:hover { color: #fff; background: #353946; }

.admin-modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 200;
}
.admin-modal-box {
  background: var(--bg-elev);
  border-radius: 12px;
  width: 720px;
  max-width: 90vw;
  max-height: 85vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.6);
  overflow: hidden;
}
.admin-modal-header {
  padding: 14px 18px;
  background: var(--bg-elev-2);
  border-bottom: 1px solid var(--divider);
  display: flex; justify-content: space-between; align-items: center;
  font-weight: 700; color: #fff;
}
.admin-close-btn {
  background: transparent;
  color: var(--fg-muted);
  border: none;
  font-size: 22px;
  cursor: pointer;
  line-height: 1;
}
.admin-close-btn:hover { color: #fff; }

.admin-tabs {
  display: flex;
  gap: 4px;
  padding: 0 18px;
  background: var(--bg-elev-2);
  border-bottom: 1px solid var(--divider);
}
.admin-tab {
  padding: 10px 14px;
  background: transparent;
  color: #a0a0a8;
  border: none;
  border-bottom: 2px solid transparent;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  margin-bottom: -1px;
}
.admin-tab:hover { color: #fff; }
.admin-tab.active { color: #fff; border-bottom-color: var(--accent); }
.admin-tab-pane { overflow: auto; flex: 1; min-height: 0; }

.admin-create-group {
  display: flex; gap: 8px;
  padding: 14px 18px 6px;
}
.admin-create-group input {
  flex: 1;
  background: var(--bg-input);
  color: #fff;
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 8px 10px;
  font-size: 13px;
  font-family: inherit;
}
.admin-create-group input:focus { outline: none; border-color: var(--accent); }
.admin-create-group button {
  padding: 8px 14px;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
}
.admin-create-group button:hover { background: var(--accent-soft); }

.admin-group-select {
  background: var(--bg-input);
  color: #fff;
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 4px 6px;
  font-size: 12px;
  font-family: inherit;
}
.admin-group-select:focus { outline: none; border-color: var(--accent); }

.admin-error { color: var(--err); padding: 0 18px; min-height: 0; font-size: 13px; }
.admin-error:not(:empty) { padding: 10px 18px; }

.admin-table-wrap { overflow: auto; padding: 8px 18px 18px; }
.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.admin-table th, .admin-table td {
  padding: 10px 8px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.admin-table th { color: var(--fg-muted); font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px; }
.admin-table td.col-actions { text-align: right; }
.role-badge { font-size: 11px; padding: 2px 8px; border-radius: 10px; background: var(--border); color: #ccc; }
.role-badge.admin { background: #5a4a8a; color: #fff; }

.status-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  padding: 2px 8px;
  border-radius: 10px;
}
.status-badge.pending { background: #5a4a1a; color: #f5d480; }
.status-badge.approved { background: #1f3a25; color: #9be7a7; }
.status-badge.rejected { background: #4a1d1d; color: var(--err); }
.status-badge.unverified { background: var(--border); color: var(--fg-dim); }

.admin-pending-badge {
  display: inline-block;
  background: var(--danger);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 10px;
  margin-left: 4px;
}

.btn-approve {
  background: #2e7d32;
  color: #fff;
  border: none;
  padding: 6px 10px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 12px;
  margin-right: 4px;
}
.btn-approve:hover { background: #388e3c; }
.btn-reject {
  background: var(--danger);
  color: #fff;
  border: none;
  padding: 6px 10px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 12px;
}
.btn-reject:hover { background: var(--danger); }
.invite-code {
  font-family: 'Consolas', 'Cascadia Code', monospace;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 1px;
  color: #fff;
  background: var(--bg-input);
  padding: 4px 8px;
  border-radius: 4px;
}

.perm-chips { display: flex; flex-wrap: wrap; gap: 4px; max-width: 380px; }
.perm-chip {
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 10px;
  background: var(--bg-input);
  color: var(--fg-dim);
  border: 1px solid var(--border);
}
.perm-chip.all { background: #5a4a8a; color: #fff; border-color: #5a4a8a; }

.role-edit-row td { background: #232531; padding: 14px; }
.role-edit-form {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.role-edit-name {
  background: var(--bg-input);
  color: #fff;
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 8px 10px;
  font-size: 13px;
  font-family: inherit;
  width: 280px;
}
.role-edit-name:focus { outline: none; border-color: var(--accent); }
.role-edit-perms {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 6px;
}
.role-edit-perms label {
  display: flex; gap: 8px; align-items: flex-start;
  font-size: 12px; color: var(--fg-dim);
  cursor: pointer;
  padding: 4px 6px;
  border-radius: 4px;
}
.role-edit-perms label:hover { background: var(--bg-elev); }
.role-edit-perms input[type="checkbox"] {
  margin-top: 2px;
  accent-color: var(--accent);
}
.role-edit-actions { display: flex; gap: 8px; }
.btn-save {
  background: var(--accent);
  color: #fff;
  border: none;
  padding: 8px 14px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
}
.btn-save:hover { background: var(--accent-soft); }
.btn-cancel {
  background: transparent;
  color: #a0a0a8;
  border: 1px solid var(--border);
  padding: 8px 14px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 13px;
}
.btn-cancel:hover { color: #fff; }

.btn-edit-role {
  background: var(--border);
  color: #fff;
  border: none;
  padding: 6px 10px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 12px;
  margin-right: 4px;
}
.btn-edit-role:hover { background: #4a4d5a; }

.role-edit-perms fieldset {
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 8px 10px;
  margin: 0;
}
.online-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: var(--ok); margin-right: 6px; }
.online-dot.offline { background: #555; }
.btn-delete-user {
  background: var(--danger);
  color: #fff;
  border: none;
  padding: 6px 10px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 12px;
}
.btn-delete-user:hover { background: var(--danger); }
.btn-delete-user:disabled { opacity: 0.4; cursor: not-allowed; }

/* ---------- Scrollbars ---------- */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--bg-input); }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: #4a4d5a; }

/* ---------- Responsive ---------- */
/* Schmaler Modus (Tablets im Hochformat & Phones): Spalten zu Tabs */
@media (max-width: 768px) {
  .app {
    grid-template-columns: 1fr !important;
    grid-template-rows: 48px 1fr;
  }
  .resize-handle { display: none; }
  .sidebar, .users-panel, .chat-panel {
    grid-column: 1;
    grid-row: 2;
    border-right: none;
    border-bottom: 1px solid var(--divider);
    min-width: 0;
  }
  /* Standardmäßig sind alle drei Panels in derselben Zelle übereinander
     gestapelt — die view-X-Klasse auf .app entscheidet, welches sichtbar ist. */
  .sidebar { display: none; }
  .users-panel { display: none; }
  .chat-panel { display: none; }
  .app.view-rooms .sidebar { display: flex; }
  .app.view-users .users-panel { display: flex; }
  .app.view-chat .chat-panel { display: flex; }

  .mobile-nav {
    display: flex;
    grid-column: 1;
    grid-row: 1;
    background: var(--bg-elev-2);
    border-bottom: 1px solid var(--divider);
  }
  .mobile-nav-btn {
    flex: 1;
    background: transparent;
    color: #a0a0a8;
    border: none;
    border-bottom: 2px solid transparent;
    padding: 0 8px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    margin-bottom: -1px;
  }
  .mobile-nav-btn:hover { color: #fff; }
  .mobile-nav-btn.active { color: #fff; border-bottom-color: var(--accent); }

  /* Eingehender Anruf nicht überdeckend, sondern oben angedockt */
  .incoming-call { top: 60px; right: 8px; left: 8px; }
  .incoming-call-box { min-width: 0; }

  /* Admin-Modal nimmt fast die ganze Höhe ein */
  .admin-modal-box { width: 100vw; max-width: 100vw; max-height: 100vh; border-radius: 0; }
  .admin-tabs { padding: 0 8px; overflow-x: auto; white-space: nowrap; }
  .admin-tab { padding: 10px 8px; font-size: 12px; }
  .admin-create-group { flex-wrap: wrap; padding: 10px; }
  .admin-create-group input { min-width: 0; flex: 1 1 100%; }
  .admin-create-group input[type="number"] { flex: 1 1 100% !important; }
  .admin-create-group button { flex: 1 1 100%; }

  /* Chat-Nachrichten dürfen breiter werden, weil keine Sidebar daneben */
  .message { max-width: 85%; }

  .login-box { padding: 24px 20px; }
  .login-box h1 { font-size: 22px; }

  /* iOS Safari zoomt automatisch auf jedes <input>/<textarea>/<select>
     mit font-size < 16px beim Fokussieren — was die Layout-Breite zerstört
     und dem User „die Seite springt rein". 16px ist die magische Grenze. */
  input, textarea, select {
    font-size: 16px !important;
  }
  /* Touch-Targets großzügiger — nach WCAG mindestens ~44×44px */
  button, .mobile-nav-btn, .room-row, .user-row {
    min-height: 40px;
  }
  /* Editor-/Eingabefeld nicht abschneiden, wenn die On-Screen-Tastatur kommt;
     Visual-Viewport-Anpassung über safe-area + 100dvh wo verfügbar */
  .app { height: 100dvh; }
}

/* Sehr schmale Phones */
@media (max-width: 380px) {
  .mobile-nav-btn { font-size: 11px; padding: 0 4px; }
  .users-filter { flex-wrap: wrap; }
  .users-filter select { flex: 1 1 100%; }
  .chat-form { padding: 8px; }
  .chat-form button { padding: 10px 12px; }
}

/* ===== Settings: App-Downloads ===== */
.settings-apps-buttons {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  margin: 10px 0;
}
@media (min-width: 520px) {
  .settings-apps-buttons { grid-template-columns: 1fr 1fr; }
}
.download-btn {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  background: var(--bg-elev2, rgba(255,255,255,.04));
  border: 1px solid var(--divider, rgba(255,255,255,.08));
  border-radius: 8px;
  color: var(--fg, #e2e2e6);
  text-decoration: none;
  cursor: pointer;
  font: inherit;
  width: 100%;
  text-align: left;
  transition: border-color .12s, background .12s;
}
.download-btn:hover {
  border-color: var(--accent, #6264a7);
  background: rgba(98,100,167,.08);
}
.download-btn.recommended {
  border-color: var(--accent, #6264a7);
  background: rgba(98,100,167,.12);
}
.download-icon { font-size: 22px; flex: 0 0 auto; }
.download-meta { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.download-label { font-weight: 600; font-size: 14px; }
.download-hint { color: var(--text-muted, #c0c0c8); font-size: 12px; }
.download-btn.pwa-install .download-icon { color: var(--accent, #6264a7); }

/* ===== Sicherheit / 2FA / Sessions / History ===== */
.auth-forgot { text-align: center; margin-top: 4px; font-size: 12px; }
.auth-forgot a { color: var(--text-muted, #c0c0c8); text-decoration: none; }
.auth-forgot a:hover { color: var(--accent, #6264a7); text-decoration: underline; }

.twofa-status { margin: 6px 0 12px; font-size: 14px; }
.twofa-state-on  { color: #9be7a7; font-weight: 600; margin-left: 6px; }
.twofa-state-off { color: var(--text-muted, #c0c0c8); margin-left: 6px; }

.twofa-setup { margin: 12px 0; padding: 14px; background: var(--bg-elev2, rgba(255,255,255,.04));
               border-radius: 8px; }
.twofa-qr { margin: 8px 0; }
.twofa-qr-link a { display: inline-block; word-break: break-all; color: var(--accent, #6264a7);
                   font-family: ui-monospace, Consolas, monospace; font-size: 11px; padding: 6px;
                   background: rgba(0,0,0,.18); border-radius: 4px; }
.twofa-secret { display: inline-block; padding: 6px 10px; background: rgba(0,0,0,.25);
                border-radius: 4px; font-family: ui-monospace, Consolas, monospace;
                letter-spacing: 0.5px; font-size: 13px; word-break: break-all; }
.twofa-disable-form { margin-top: 12px; padding: 12px; background: rgba(255,116,116,.08);
                      border-radius: 8px; }
.settings-hint-ok { color: #9be7a7; }

.sessions-list, .history-list { display: flex; flex-direction: column; gap: 6px; margin: 8px 0; }
.session-row, .history-row {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 10px 12px; background: var(--bg-elev2, rgba(255,255,255,.03));
  border-radius: 8px; border: 1px solid transparent;
}
.session-row.current { border-color: var(--accent, #6264a7); }
.session-meta, .history-meta { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.session-ua, .history-ts { font-weight: 600; font-size: 13px; }
.session-sub, .history-meta { display: flex; gap: 10px; flex-wrap: wrap;
  color: var(--text-muted, #c0c0c8); font-size: 12px; }
.session-current { color: var(--accent, #6264a7); font-weight: 600; }
.session-revoke { padding: 6px 12px; font-size: 12px; }
.history-row.suspicious { border-color: rgba(255,116,116,.5);
  background: rgba(255,116,116,.08); }
.history-flag { color: #ff7474; font-weight: 600; }
