html, body { height:100%; overflow:hidden; overscroll-behavior:none; -webkit-overflow-scrolling:touch; }
body { padding:0; position:fixed; top:0; left:0; right:0; bottom:0; width:100%; }

.app-wrap {
  display:-webkit-box; display:-ms-flexbox; display:flex;
  position:fixed;
  top:0; left:0; right:0; bottom:0;
  width:100%;
  height:100%;
  max-width:100vw;
  overflow:hidden;
}

/* ── Login screen ──────────────────────────────────────────────────────── */
.login-screen {
  padding-top:20vh;
  padding-left:16px; padding-right:16px;
  height:100%; width:100%;
  overflow-y:auto;
  text-align:center;
}
.login-screen h1 { font-size:18px; font-weight:600; margin-bottom:4px; }
.login-screen p { font-size:11px; color:var(--text-muted); margin-bottom:16px; }
.login-screen > div {
  width:260px; max-width:100%;
  margin-left:auto; margin-right:auto;
  text-align:left;
}
.login-screen .inp { width:100%; margin-bottom:8px; display:block; }
.login-screen .btn { margin-bottom:4px; display:block; width:100%; }
.login-hint { font-size:10px; color:var(--text-muted); margin-bottom:12px; text-align:center; }
.login-error { font-size:10px; color:var(--danger, #e74c3c); margin-top:4px; min-height:14px; }

/* ── Sidebar ───────────────────────────────────────────────────────────── */
.sidebar {
  width:180px; min-width:180px;
  background:var(--bg-panel); border-right:1px solid var(--border);
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-orient:horizontal; -webkit-box-direction:normal;
  -ms-flex-direction:row; flex-direction:row;
  height:100%; position:relative;
  -webkit-transition:width .2s ease, min-width .2s ease;
  -o-transition:width .2s ease, min-width .2s ease;
  transition:width .2s ease, min-width .2s ease;
}
.sidebar.collapsed {
  width:44px; min-width:44px;
}
.sidebar-expanded {
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-orient:vertical; -webkit-box-direction:normal;
  -ms-flex-direction:column; flex-direction:column;
  width:100%; min-width:0; overflow:hidden;
}
.sidebar.collapsed .sidebar-expanded { display:none; }
.sidebar-collapsed {
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-orient:vertical; -webkit-box-direction:normal;
  -ms-flex-direction:column; flex-direction:column;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  width:100%; height:100%;
}
.sb-col-top {
  padding-top:10px;
  -webkit-box-flex:1; -ms-flex:1; flex:1;
}
.sb-col-bottom {
  padding-bottom:10px;
  border-top:1px solid var(--border);
}
.sb-icon-btn {
  position:relative; cursor:pointer; color:var(--text-muted);
  padding:8px; border-radius:4px; margin-bottom:4px;
}
.sb-icon-btn:hover { background:var(--bg-hover); color:var(--text); }
.sb-icon-badge {
  position:absolute; top:2px; right:2px;
  padding:1px 4px; font-size:8px; border-radius:2px;
  background:var(--accent); color:#fff;
  min-width:12px; text-align:center; line-height:1.3;
}
.sidebar-toggle {
  position:absolute; top:50%; right:-12px;
  -webkit-transform:translateY(-50%);
  -ms-transform:translateY(-50%);
  transform:translateY(-50%);
  width:24px; height:24px; border-radius:50%;
  background:var(--bg-panel); border:1px solid var(--border);
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  -webkit-box-pack:center; -ms-flex-pack:center; justify-content:center;
  cursor:pointer; z-index:10; color:var(--text-muted);
  -webkit-transition:-webkit-transform .2s ease;
  -o-transition:transform .2s ease;
  transition:transform .2s ease, -webkit-transform .2s ease;
}
.sidebar-toggle:hover { color:var(--text); background:var(--bg-hover); }
.sidebar.collapsed .sidebar-toggle {
  -webkit-transform:translateY(-50%) rotate(180deg);
  -ms-transform:translateY(-50%) rotate(180deg);
  transform:translateY(-50%) rotate(180deg);
}
.sidebar-hdr {
  padding:8px 10px;
  border-bottom:1px solid var(--border);
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  -webkit-box-pack:justify; -ms-flex-pack:justify; justify-content:space-between;
}
.sidebar-hdr .user-name { font-size:11px; font-weight:600; }
.sidebar-user {
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
}
.sidebar-section {
  padding:8px 0;
}
.sidebar-section-hdr {
  padding:0 10px 4px;
  font-size:10px; font-weight:600; color:var(--text-muted);
  text-transform:uppercase; letter-spacing:.04em;
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  -webkit-box-pack:justify; -ms-flex-pack:justify; justify-content:space-between;
}
.sidebar-section-hdr button {
  background:none; border:none; color:var(--text-muted); cursor:pointer;
  font-size:14px; line-height:1; padding:0 2px;
}
.sidebar-section-hdr button:hover { color:var(--text); }
.sidebar-list { list-style:none; }
.sidebar-item {
  padding:3px 10px;
  cursor:pointer;
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  -webkit-box-pack:justify; -ms-flex-pack:justify; justify-content:space-between;
  font-size:11px;
}
.sidebar-item:hover { background:var(--bg-hover); }
.sidebar-item.active { background:var(--accent); color:#fff; border-radius:2px; }
.sidebar-item.active .badge { background:rgba(255,255,255,.3); color:#fff; }
.sidebar-item .item-name {
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
  -webkit-box-flex:1; -ms-flex:1; flex:1; min-width:0;
}
.sidebar-bottom {
  margin-top:auto;
  padding:8px 10px;
  border-top:1px solid var(--border);
}
.invite-app-btn {
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  cursor:pointer; color:var(--text-muted); padding:2px 0; margin-bottom:4px;
}
.invite-app-btn:hover { color:var(--text); }
.invite-lbl { font-size:10px; margin-left:6px; }
.settings-btn {
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  cursor:pointer; color:var(--text-muted); padding:2px 0;
}
.settings-btn:hover { color:var(--text); }
.settings-lbl { font-size:10px; margin-left:6px; }
.admin-refresh-btn {
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  cursor:pointer; color:var(--text-muted); padding:2px 0; margin-top:4px;
}
.admin-refresh-btn:hover { color:var(--text); }
.admin-refresh-lbl { font-size:10px; margin-left:6px; }
.adv-item {
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  padding:6px 8px; cursor:pointer; font-size:12px; color:var(--text);
  border-radius:4px;
}
.adv-item:hover { background:var(--bg-hover); }
.adv-item.selected { background:var(--bg-hover); color:var(--accent); }
.settings-modal { width:280px; }
.setting-row {
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  -webkit-box-pack:justify; -ms-flex-pack:justify; justify-content:space-between;
  padding:6px 0;
}
.setting-row + .setting-row { border-top:1px solid var(--border); }
.setting-info { -webkit-box-flex:1; -ms-flex:1; flex:1; min-width:0; }
.setting-name { font-size:12px; color:var(--text); }
.setting-desc { font-size:10px; color:var(--text-muted); margin-top:1px; }
.toggle-switch { cursor:pointer; -ms-flex-negative:0; flex-shrink:0; margin-left:8px; }
.toggle-track {
  width:34px; height:18px; border-radius:9px;
  background:var(--bg-hover); position:relative;
  -webkit-transition:background .2s; transition:background .2s;
}
.toggle-thumb {
  width:14px; height:14px; border-radius:50%;
  background:var(--text-muted); position:absolute;
  top:2px; left:2px;
  -webkit-transition:left .2s, background .2s; transition:left .2s, background .2s;
}
.toggle-switch.on .toggle-track { background:var(--accent); }
.toggle-switch.on .toggle-thumb { left:18px; background:#fff; }
.setting-hint {
  font-size:10px; color:var(--text-muted); padding:4px 0 0;
}
.add-to-home-row { cursor:pointer; }
.add-to-home-row:hover .setting-name { color:var(--accent); }
.add-home-arrow { color:var(--text-muted); -ms-flex-negative:0; flex-shrink:0; margin-left:8px; }
.add-home-instructions { padding:6px 0 0; }
.add-home-steps { padding:0; }
.add-home-step {
  font-size:11px; color:var(--text); padding:4px 0;
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
}
.add-home-step + .add-home-step { border-top:1px solid var(--border); }
.step-num {
  width:18px; height:18px; border-radius:50%;
  background:var(--accent); color:#fff; font-size:10px; font-weight:700;
  display:-webkit-inline-box; display:-ms-inline-flexbox; display:inline-flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  -webkit-box-pack:center; -ms-flex-pack:center; justify-content:center;
  -ms-flex-negative:0; flex-shrink:0; margin-right:6px;
}
.share-icon-inline {
  display:-webkit-inline-box; display:-ms-inline-flexbox; display:inline-flex;
  vertical-align:middle; color:var(--accent); margin:0 2px;
}
.sidebar-scroll {
  overflow-y:auto; -webkit-box-flex:1; -ms-flex:1; flex:1;
}

/* ── Badge ─────────────────────────────────────────────────────────────── */
.badge {
  padding:1px 5px; font-size:9px; border-radius:2px;
  background:var(--accent); color:#fff;
  margin-left:4px; -ms-flex-negative:0; flex-shrink:0;
}

/* ── Main area ─────────────────────────────────────────────────────────── */
.main-area {
  -webkit-box-flex:1; -ms-flex:1; flex:1; min-width:0;
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-orient:vertical; -webkit-box-direction:normal;
  -ms-flex-direction:column; flex-direction:column;
  overflow:hidden;
}
.main-hdr {
  padding:8px 12px;
  border-bottom:1px solid var(--border);
  font-size:12px; font-weight:600;
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  -webkit-box-pack:justify; -ms-flex-pack:justify; justify-content:space-between;
}
.hdr-actions {
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
}
.hdr-actions > * + * { margin-left:6px; }
.hidden { display:none !important; }
.main-content {
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-flex:1; -ms-flex:1; flex:1; min-height:0;
  overflow:hidden;
}
.chat-area {
  -webkit-box-flex:1; -ms-flex:1; flex:1; min-width:0;
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-orient:vertical; -webkit-box-direction:normal;
  -ms-flex-direction:column; flex-direction:column;
  overflow:hidden;
}

/* ── Messages ──────────────────────────────────────────────────────────── */
.messages-list {
  -webkit-box-flex:1; -ms-flex:1; flex:1;
  overflow-y:auto; overflow-x:hidden; padding:8px 12px;
  overscroll-behavior:contain;
}
.msg {
  padding:4px 0;
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:start; -ms-flex-align:start; align-items:flex-start;
}
.msg > * + * { margin-left:8px; }
.msg:hover { background:var(--bg-panel); border-radius:2px; }
.msg-avatar {
  width:28px; height:28px; border-radius:50%;
  -ms-flex-negative:0; flex-shrink:0; margin-top:2px;
}
.msg-avatar-placeholder {
  width:28px; height:28px; border-radius:50%;
  background:var(--bg-input); -ms-flex-negative:0; flex-shrink:0;
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  -webkit-box-pack:center; -ms-flex-pack:center; justify-content:center;
  font-size:11px; font-weight:600; color:var(--text-muted); margin-top:2px;
}
.msg-body { -webkit-box-flex:1; -ms-flex:1; flex:1; min-width:0; }
.msg-meta {
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:baseline; -ms-flex-align:baseline; align-items:baseline;
}
.msg-meta > * + * { margin-left:6px; }
.msg-author { font-size:11px; font-weight:600; }
.msg-time { font-size:9px; color:var(--text-muted); }
.msg-text { font-size:11px; line-height:1.5; word-break:break-word; margin-top:1px; }
.msg-actions {
  margin-top:2px;
}
.msg-reply-btn {
  background:none; border:none; color:var(--text-muted); cursor:pointer;
  font-size:10px; padding:1px 4px; border-radius:2px;
}
.msg-reply-btn:hover { color:var(--accent); background:var(--bg-input); }
.msg-reply-count {
  font-size:10px; color:var(--text-muted); cursor:pointer;
  margin-left:4px;
}
.msg-reply-count.has-new { color:var(--accent); font-weight:600; }
.msg-reply-count:hover { text-decoration:underline; }

/* ── Links in messages ─────────────────────────────────────────────────── */
.msg-link {
  display:-webkit-inline-box; display:-ms-inline-flexbox; display:inline-flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  -webkit-box-pack:center; -ms-flex-pack:center; justify-content:center;
  color:var(--accent);
  text-decoration:none;
  vertical-align:middle;
  width:1.1em; height:1.1em;
  margin:0 2px;
  -webkit-transition:opacity 0.15s; -o-transition:opacity 0.15s; transition:opacity 0.15s;
}
.msg-link:hover {
  opacity:0.7;
}
.msg-link svg {
  width:1em; height:1em;
}

/* ── Link preview cards ───────────────────────────────────────────────── */
.link-previews { margin-top:4px; }
.link-preview-card {
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-orient:vertical; -webkit-box-direction:normal;
  -ms-flex-direction:column; flex-direction:column;
  background:var(--bg-input);
  border:1px solid var(--border);
  border-left:3px solid var(--accent);
  border-radius:4px;
  padding:6px 8px;
  margin-top:4px;
  max-width:360px;
  cursor:pointer;
  text-decoration:none;
  color:var(--text);
  -webkit-transition:background 0.15s;
  -o-transition:background 0.15s;
  transition:background 0.15s;
  overflow:hidden;
}
.link-preview-card:hover { background:var(--bg-hover); }
.link-preview-site {
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  margin-bottom:2px;
}
.link-preview-favicon {
  width:14px; height:14px; border-radius:2px;
  margin-right:5px; -ms-flex-negative:0; flex-shrink:0;
}
.link-preview-sitename {
  font-size:9px; color:var(--text-muted);
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.link-preview-title {
  font-size:11px; font-weight:600; line-height:1.3;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.link-preview-url {
  font-size:10px; color:var(--text-muted); line-height:1.3;
  margin-top:2px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.link-preview-desc {
  font-size:10px; color:var(--text-muted); line-height:1.4;
  margin-top:2px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.link-preview-img {
  width:100%; max-height:140px;
  -o-object-fit:cover; object-fit:cover;
  border-radius:3px;
  margin-top:4px;
}

/* ── Load older messages button ───────────────────────────────────────── */
.load-older-btn {
  display:block;
  margin:8px auto;
  padding:5px 16px;
  border:1px solid var(--border);
  border-radius:14px;
  background:transparent;
  color:var(--muted);
  font-size:12px;
  cursor:pointer;
  -webkit-transition:color 0.15s, border-color 0.15s;
  -o-transition:color 0.15s, border-color 0.15s;
  transition:color 0.15s, border-color 0.15s;
}
.load-older-btn:hover {
  color:var(--fg);
  border-color:var(--fg);
}

/* ── Shared images in messages ────────────────────────────────────────── */
.msg-image {
  max-width:100%;
  max-height:200px;
  border-radius:6px;
  cursor:pointer;
  display:block;
  -webkit-transition:opacity 0.15s; -o-transition:opacity 0.15s; transition:opacity 0.15s;
}
.msg-image:hover { opacity:0.85; }

/* ── Video player ─────────────────────────────────────────────────────── */
.vid-player {
  position:relative;
  display:inline-block;
  max-width:100%;
}
.msg-video {
  max-width:100%;
  max-height:200px;
  border-radius:6px;
  display:block;
  background:#000;
}
.vid-ctrl {
  position:absolute;
  width:28px; height:28px;
  border-radius:50%;
  background:rgba(0,0,0,0.55);
  color:#fff;
  border:none; cursor:pointer;
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  -webkit-box-pack:center; -ms-flex-pack:center; justify-content:center;
  padding:0;
  -webkit-transition:background 0.15s; -o-transition:background 0.15s; transition:background 0.15s;
  z-index:3;
  opacity:0.85;
}
.vid-ctrl:hover { background:rgba(0,0,0,0.8); opacity:1; }
.vid-play { bottom:6px; left:6px; }
.vid-mute { bottom:6px; right:6px; }
.vid-fs   { top:6px; right:6px; }

/* ── Slideshow ────────────────────────────────────────────────────────── */
.msg-slideshow {
  position:relative;
  display:block;
  width:320px;
  max-width:100%;
  margin:4px 0;
}
.slide-media-wrap {
  width:100%;
  height:200px;
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  -webkit-box-pack:center; -ms-flex-pack:center; justify-content:center;
  overflow:hidden;
  border-radius:6px;
  background:rgba(0,0,0,0.15);
}
.slide-arrow {
  position:absolute;
  top:50%;
  -webkit-transform:translateY(-50%); -ms-transform:translateY(-50%); transform:translateY(-50%);
  width:28px; height:28px;
  border-radius:50%;
  background:rgba(0,0,0,0.55);
  color:#fff;
  border:none; cursor:pointer;
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  -webkit-box-pack:center; -ms-flex-pack:center; justify-content:center;
  padding:0;
  -webkit-transition:background 0.15s; -o-transition:background 0.15s; transition:background 0.15s;
  z-index:2;
}
.slide-arrow:hover { background:rgba(0,0,0,0.75); }
.slide-prev { left:4px; }
.slide-next { right:4px; }
.slide-counter {
  position:absolute;
  bottom:6px; left:50%;
  -webkit-transform:translateX(-50%); -ms-transform:translateX(-50%); transform:translateX(-50%);
  background:rgba(0,0,0,0.55);
  color:#fff;
  font-size:11px;
  padding:1px 8px;
  border-radius:8px;
  z-index:2;
}

/* ── Image preview / drop zone ───────────────────────────────────────── */
.img-preview {
  display:none;
  margin-bottom:6px;
}
.img-preview-item {
  position:relative;
  display:inline-block;
  margin-right:6px;
  margin-bottom:4px;
}
.img-preview-item img,
.img-preview-item video {
  max-width:60px; max-height:50px;
  border-radius:4px;
  border:1px solid var(--border);
  vertical-align:middle;
}
.img-preview-item video {
  pointer-events:none;
}
.vid-cam-badge {
  position:absolute;
  top:50%; left:50%;
  -webkit-transform:translate(-50%,-50%); -ms-transform:translate(-50%,-50%); transform:translate(-50%,-50%);
  color:#fff;
  pointer-events:none;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,0.6));
}
.img-preview-remove {
  position:absolute; top:-6px; right:-6px;
  width:16px; height:16px;
  border-radius:50%;
  background:var(--danger, #e5534b); color:#fff;
  border:none; cursor:pointer;
  font-size:11px; line-height:14px;
  padding:0;
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  -webkit-box-pack:center; -ms-flex-pack:center; justify-content:center;
}
.img-drop-error {
  color:var(--danger, #e5534b);
  font-size:12px;
  padding:2px 0 4px;
}
.msg-input-area.drag-over {
  background:rgba(88,166,255,0.08);
  outline:2px dashed var(--accent);
  outline-offset:-2px;
}

/* ── Message compose (extends .ta from shared.css) ─────────────────────── */
.msg-input-area {
  padding:8px 12px;
  border-top:1px solid var(--border);
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -ms-flex-wrap:wrap; flex-wrap:wrap;
  min-width:0;
  -ms-flex-negative:0; flex-shrink:0;
  -webkit-box-align:end; -ms-flex-align:end; align-items:flex-end;
}
.msg-input-area .img-preview,
.msg-input-area .img-drop-error { width:100%; }
.compose-wrap {
  position:relative;
  -webkit-box-flex:1; -ms-flex:1; flex:1;
  min-width:0;
}
.msg-compose {
  width:100%;
  resize:none; min-height:32px; max-height:120px;
  overflow-y:auto;
  min-width:0;
  border-radius:7px;
  caret-color:var(--accent);
  padding-right:56px;
}
.compose-icons {
  position:absolute;
  right:6px; bottom:5px;
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
}
.compose-icons > * + * { margin-left:2px; }
.compose-icon-btn {
  width:26px; height:26px;
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  -webkit-box-pack:center; -ms-flex-pack:center; justify-content:center;
  background:transparent; border:none; border-radius:2px;
  cursor:pointer; color:var(--text-muted); padding:0;
}
.compose-icon-btn:hover { color:var(--text); }
.send-arrow { color:var(--accent); }
.send-arrow:hover { color:#6db3ff; }
.emoji-picker-wrap { position:relative; }
.emoji-flyout {
  display:none; position:absolute; bottom:calc(100% + 6px); right:0;
  background:var(--bg); border:1px solid var(--border); border-radius:2px;
  padding:4px; z-index:200; box-shadow:0 2px 8px rgba(0,0,0,.4);
}
.emoji-flyout.open { display:block; }
.emoji-flyout .icon-grid {
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -ms-flex-wrap:nowrap; flex-wrap:nowrap;
}
.emoji-opt {
  font-size:20px; width:32px; height:32px;
}
.emoji-opt:hover { background:var(--bg-hover); }
@media (max-width:600px) {
  .inp, .ta, select, input, textarea, .msg-compose {
    font-size:16px !important;
  }
  #members-btn {
    font-size:0; padding:4px 6px;
  }
  #members-btn svg {
    margin-right:0;
  }
  .overlay.open {
    -webkit-box-align:start; -ms-flex-align:start; align-items:flex-start;
    padding-top:60px;
  }
}

/* ── Thread panel ──────────────────────────────────────────────────────── */
.thread-panel {
  width:320px; min-width:320px;
  border-left:1px solid var(--border);
  background:var(--bg-panel);
  display:none;
  -webkit-box-orient:vertical; -webkit-box-direction:normal;
  -ms-flex-direction:column; flex-direction:column;
  overflow:hidden;
}
.thread-panel.open {
  display:-webkit-box; display:-ms-flexbox; display:flex;
}
.thread-hdr {
  padding:8px 12px;
  border-bottom:1px solid var(--border);
  font-size:11px; font-weight:600;
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  -webkit-box-pack:justify; -ms-flex-pack:justify; justify-content:space-between;
}
.thread-close {
  background:none; border:none; color:var(--text-muted); cursor:pointer;
  font-size:14px;
}
.thread-close:hover { color:var(--text); }
.thread-messages {
  -webkit-box-flex:1; -ms-flex:1; flex:1;
  overflow-y:auto; padding:8px 12px;
  overscroll-behavior:contain;
}
.thread-parent {
  padding:6px 0;
  border-bottom:1px solid var(--border-light);
  margin-bottom:6px;
}

/* ── Header action dropdowns ──────────────────────────────────────────── */
.hdr-actions .btn-s {
  height:24px; line-height:14px;
  -webkit-box-sizing:border-box; box-sizing:border-box;
}
.members-dd, .invite-dd { position:relative; }
.members-srch-mb { margin-bottom:4px; }
.members-dropdown, .invite-dropdown {
  display:none;
  position:absolute; right:0; top:100%; margin-top:4px;
  width:240px; max-height:300px;
  background:var(--bg-panel); border:1px solid var(--border);
  border-radius:6px; padding:8px;
  -webkit-box-shadow:0 4px 12px rgba(0,0,0,.3); box-shadow:0 4px 12px rgba(0,0,0,.3);
  z-index:100;
  overflow-y:auto;
}
.members-dropdown.open, .invite-dropdown.open { display:block; }
.members-results-item {
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  -webkit-box-pack:justify; -ms-flex-pack:justify; justify-content:space-between;
  padding:4px 2px; font-size:10px; color:var(--text);
}
.members-results-item + .members-results-item { border-top:1px solid var(--border-light); }
.members-results-item .member-tag {
  font-size:9px; color:var(--text-muted); margin-left:4px;
}

/* ── Empty state ───────────────────────────────────────────────────────── */
.empty-state {
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-orient:vertical; -webkit-box-direction:normal;
  -ms-flex-direction:column; flex-direction:column;
  -webkit-box-align:center; -ms-flex-align:center; align-items:center;
  -webkit-box-pack:center; -ms-flex-pack:center; justify-content:center;
  height:100%; color:var(--text-muted); font-size:11px;
}

/* ── Scrollbar ─────────────────────────────────────────────────────────── */
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--border); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--bg-hover); }
