/* ═══════════════════════════════════════════════════════════════
   Forge — Design System v2
   #0a0f1f base · #35d0ff/#7df6c7 accents · Space Grotesk + IBM Plex Mono
   ═══════════════════════════════════════════════════════════════ */

:root {
  --bg:          #0a0f1f;
  --bg-elev:     #0c1122;
  --card:        #121932;
  --card-solid:  #111827;
  --text:        #ebf0ff;
  --text-dim:    #9aa9c9;
  --line:        rgba(102,139,255,0.18);
  --accent:      #35d0ff;
  --accent-2:    #7df6c7;
  --danger:      #f87171;
  --warning:     #fbbf24;
  --shadow:      0 4px 16px rgba(0,0,0,.5);
  --panel:       #0f1628;
  --hover:       rgba(102,139,255,.1);

  --rail-w:  72px;
  --side-w:  240px;
  --mem-w:   240px;
  --hdr-h:   48px;
  --rail-bg: #050812;
  --side-bg: #080c18;

  /* Theme glow — overridden per theme */
  --glow-a: rgba(53,208,255,0.13);
  --glow-b: rgba(125,246,199,0.09);

  /* User accent — overridden per-user via JS */
  --user-accent: var(--accent);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  font-family: "Space Grotesk", sans-serif;
  font-size: 16px;
  color: var(--text);
  background: var(--bg);
  min-height: 100vh;
  overflow: hidden;
}
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }
button { font-family: "Space Grotesk", sans-serif; cursor: pointer; }
input, textarea, select { font-family: "Space Grotesk", sans-serif; }

/* ── Canvas grid — disabled ── */
#gridCanvas { display: none; }

/* ── Background glow — disabled (flat mode) ── */
body::after { display: none; }

/* ── Orb — removed ── */
body::before { display: none; }
body.grad-on::before { display: none; }

/* ── Flat card ── */
.glass { background:var(--card); border:1px solid var(--line); border-radius:1.2rem; }
body.grad-on .glass { box-shadow:var(--shadow); }

/* ── Gradient text — flat by default ── */
.grad { color:var(--accent); }
body.grad-on .grad { background:linear-gradient(120deg,var(--accent),var(--accent-2)); -webkit-background-clip:text; background-clip:text; color:transparent; }

/* ── Eyebrow ── */
.eyebrow { font-size:.72rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--accent); font-family:"IBM Plex Mono",monospace; }

/* ── Buttons ── */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:7px; padding:.65rem 1.1rem; border-radius:.8rem; border:1px solid var(--line); background:transparent; color:var(--text); font-weight:500; font-size:.9rem; transition:background .15s,border-color .15s,transform .1s; text-decoration:none; white-space:nowrap; }
.btn:hover { background:rgba(102,139,255,.1); border-color:var(--accent); text-decoration:none; }
.btn:active { transform:scale(.98); }
.btn-primary { background:var(--accent); color:#03101d; border:none; font-weight:700; }
.btn-primary:hover { filter:brightness(1.1); }
.btn-danger  { background:var(--danger); color:#fff; border:none; font-weight:700; }
.btn-danger:hover { filter:brightness(1.1); }
.btn-full    { width:100%; }
.btn-sm      { padding:.4rem .8rem; font-size:.82rem; border-radius:.6rem; }
.inline-link { background:none; border:none; color:var(--accent); font-size:inherit; font-family:inherit; cursor:pointer; padding:0; }
.inline-link:hover { text-decoration:underline; }

/* ── Form ── */
.form-label { display:flex; flex-direction:column; gap:.35rem; font-size:.72rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--text-dim); font-family:"IBM Plex Mono",monospace; }
.form-input { background:var(--bg); border:1px solid var(--line); border-radius:.65rem; color:var(--text); padding:.65rem .8rem; font-size:.95rem; font-family:"Space Grotesk",sans-serif; outline:none; transition:border-color .15s; width:100%; }
.form-input:focus { border-color:var(--accent); }
.form-input::placeholder { color:var(--text-dim); }
.form-hint { font-size:.76rem; color:var(--text-dim); }
textarea.form-input { resize:vertical; min-height:80px; }

/* ── Toggle switch ── */
.toggle { width:42px; height:24px; border-radius:12px; background:rgba(102,139,255,.2); border:1px solid var(--line); position:relative; cursor:pointer; flex-shrink:0; transition:background .2s; }
.toggle::after { content:""; position:absolute; top:3px; left:3px; width:16px; height:16px; border-radius:50%; background:var(--text-dim); transition:transform .2s,background .2s; }
.toggle.on { background:var(--accent); border-color:var(--accent); }
.toggle.on::after { transform:translateX(18px); background:#03101d; }

/* ── Loader ── */
#forge-loader {
  position:fixed; inset:0; z-index:99999;
  background:var(--bg, #0a0f1f);
  display:flex; align-items:center; justify-content:center;
  transition:opacity .45s ease;
}
#forge-loader.nl-out { opacity:0; pointer-events:none; }
.nl-inner { display:flex; flex-direction:column; align-items:center; gap:1.6rem; }
.nl-svg { width:110px; height:110px; overflow:visible; }
.nl-word {
  font-family:"IBM Plex Mono",monospace; font-size:.78rem; font-weight:600;
  letter-spacing:.35em; color:rgba(53,208,255,.5);
  animation: nl-word-pulse 2.4s ease-in-out infinite;
}
@keyframes nl-word-pulse {
  0%,100% { opacity:.4; } 50% { opacity:.9; }
}

/* node pulse — each node gets a unique delay */
@keyframes nl-node {
  0%,100% { opacity:.25; transform:scale(1); }
  35%     { opacity:1;   transform:scale(1.6); }
  65%     { opacity:.7;  transform:scale(1.15); }
}
/* line signal — a dash traveling outward from center */
@keyframes nl-line {
  0%   { stroke-dashoffset:12; opacity:0; }
  15%  { opacity:.85; }
  80%  { stroke-dashoffset:-42; opacity:0; }
  100% { stroke-dashoffset:-42; opacity:0; }
}
/* center breathe */
@keyframes nl-center {
  0%,100% { opacity:.8; transform:scale(1); }
  50%     { opacity:1;  transform:scale(1.07); }
}

.nl-center { transform-origin:50px 50px; animation:nl-center 2.2s ease-in-out infinite; }

/* node transform-origins (SVG user-space coords) */
.nl-n0 { transform-origin:50px 14px; }
.nl-n1 { transform-origin:81px 32px; }
.nl-n2 { transform-origin:81px 68px; }
.nl-n3 { transform-origin:50px 86px; }
.nl-n4 { transform-origin:19px 68px; }
.nl-n5 { transform-origin:19px 32px; }

/* staggered delays — intentionally non-sequential to feel organic */
.nl-node { animation:nl-node 3s ease-in-out infinite; }
.nl-n0   { animation-delay:0s;    }
.nl-n1   { animation-delay:.75s;  }
.nl-n2   { animation-delay:1.55s; }
.nl-n3   { animation-delay:2.2s;  }
.nl-n4   { animation-delay:.38s;  }
.nl-n5   { animation-delay:1.9s;  }

.nl-line { animation:nl-line 3s ease-in-out infinite; opacity:.15; }
.nl-l0   { animation-delay:-.1s;   }
.nl-l1   { animation-delay:.65s;   }
.nl-l2   { animation-delay:1.45s;  }
.nl-l3   { animation-delay:2.1s;   }
.nl-l4   { animation-delay:.28s;   }
.nl-l5   { animation-delay:1.8s;   }

/* ── Status dots ── */
.sdot { width:10px; height:10px; border-radius:50%; flex-shrink:0; }
.sdot-online  { background:var(--accent-2); }
.sdot-idle    { background:var(--warning); }
.sdot-dnd     { background:var(--danger); }
.sdot-offline    { background:#6b7280; }
.sdot-invisible  { background:#6b7280; }

/* ── Toast ── */
#toasts { position:fixed; bottom:1.5rem; right:1.5rem; display:flex; flex-direction:column; gap:.5rem; z-index:9999; pointer-events:none; }
.toast { background:var(--bg-elev); border:1px solid var(--line); border-radius:.65rem; padding:.6rem 1rem; font-size:.86rem; animation:toast-in .2s ease; color:var(--text); pointer-events:none; max-width:280px; }
.toast.ok   { border-color:rgba(125,246,199,.45); }
.toast.err  { border-color:rgba(248,113,113,.45); }
.toast.info { border-color:rgba(53,208,255,.35); }
@keyframes toast-in { from{opacity:0;transform:translateX(12px)} to{opacity:1;transform:none} }

/* ════════════════════════════════════════════
   LOGIN PAGE — Split Terminal Layout
   ════════════════════════════════════════════ */

/* Compatibility shims — JS still queries these */
.login-tab { display:none; }
.login-form { display:flex; flex-direction:column; }
.login-form.hidden { display:none !important; }

/* ── Root layout ── */
.lx-body { overflow:auto; }
.adm-body { overflow:auto; }

.lx-wrap {
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:100vh;
  position:relative;
  z-index:1;
}

/* ─────────────────────────────────
   LEFT PANEL
───────────────────────────────── */
.lx-panel {
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  border-right:1px solid var(--line);
}

.lx-panel-bg {
  display: none;
}

/* Diagonal accent stripe — removed */
.lx-panel::after { display: none; }

.lx-panel-inner {
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  gap:2.5rem;
  padding:3.5rem;
  width:100%;
}

/* Brand row */
.lx-brand {
  display:flex;
  align-items:center;
  gap:1rem;
}

.lx-bigmark {
  width:88px;
  height:88px;
  flex-shrink:0;
}

.lx-wordmark {
  font-family:'Syne', sans-serif;
  font-size:2.4rem;
  font-weight:800;
  letter-spacing:-.025em;
  color:var(--accent);
  line-height:1;
}

/* Satellite nodes — static */
.lx-cntr { opacity:.85; }
.lx-sat  { opacity:.55; }
.lx-spk  { opacity:.35; }

/* Hero text */
.lx-headline {
  font-family:'Syne', sans-serif;
  font-size:clamp(1.9rem, 3vw, 2.8rem);
  font-weight:800;
  line-height:1.08;
  letter-spacing:-.025em;
  color:var(--text);
}

.lx-tagline {
  margin-top:.7rem;
  font-family:'IBM Plex Mono', monospace;
  font-size:.78rem;
  line-height:1.7;
  color:var(--text-dim);
}

/* Live indicator pills */
.lx-stats {
  display:flex;
  flex-direction:column;
  gap:.55rem;
}

.lx-stat {
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  font-family:'IBM Plex Mono', monospace;
  font-size:.72rem;
  color:var(--text-dim);
  letter-spacing:.04em;
}

.lx-stat-dot {
  width:7px; height:7px;
  border-radius:50%;
  background:#7df6c7;
  box-shadow:0 0 8px #7df6c7;
  flex-shrink:0;
}

.lx-dot-b {
  background:#35d0ff;
  box-shadow:0 0 8px #35d0ff;
  animation-delay:-1.1s;
}

@keyframes lx-blink {
  0%,100% { opacity:.5; }
  50%      { opacity:1;  }
}

/* Corner grid decoration */
.lx-corner-grid {
  position:absolute;
  bottom:0; right:0;
  width:200px; height:200px;
  pointer-events:none;
  opacity:.6;
}

/* ─────────────────────────────────
   RIGHT PANEL
───────────────────────────────── */
.lx-right {
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:3rem 4rem;
  position:relative;
}

/* Watermark eyebrow */
.lx-right::before {
  content:'// NEXUS';
  position:absolute;
  top:2rem; right:2.5rem;
  font-family:'IBM Plex Mono', monospace;
  font-size:.65rem;
  letter-spacing:.2em;
  color:var(--text-dim);
  opacity:.25;
  pointer-events:none;
}

/* Hidden tab ghost — required for JS querySelectorAll('.login-tab') */
.lx-tab-ghost { display:none; }

/* Mobile brand */
.lx-mobile-brand {
  display:none;
  align-items:center;
  gap:.7rem;
  margin-bottom:2.4rem;
}

/* ── Form ── */
.lx-form {
  width:100%;
  max-width:380px;
  gap:1.6rem;
}

.lx-form-hdr { display:flex; flex-direction:column; gap:.3rem; }

.lx-eyebrow {
  font-family:'IBM Plex Mono', monospace;
  font-size:.68rem;
  font-weight:500;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--accent);
  opacity:.75;
}

.lx-form-title {
  font-family:'Syne', sans-serif;
  font-size:2rem;
  font-weight:800;
  letter-spacing:-.025em;
  color:var(--text);
  line-height:1.1;
}

.lx-form-sub {
  font-size:.875rem;
  color:var(--text-dim);
  margin-top:.2rem;
}

/* ── Floating-label fields ── */
.lx-fields { display:flex; flex-direction:column; gap:1.1rem; }

.lx-field { position:relative; }

.lx-input {
  width:100%;
  background:rgba(255,255,255,.03);
  border:1px solid var(--line);
  border-radius:.7rem;
  color:var(--text);
  font-family:'Space Grotesk', sans-serif;
  font-size:.975rem;
  padding:1.35rem 1rem .55rem;
  outline:none;
  transition:border-color .2s, background .2s, box-shadow .2s;
  -webkit-appearance:none;
  position:relative;
  z-index:1;
}

.lx-input:focus {
  border-color:var(--accent);
  background:rgba(53,208,255,.04);
}

.lx-input::placeholder { color:transparent; }

/* Bottom border on focus */
.lx-border-anim {
  position:absolute;
  bottom:0; left:10%; right:10%;
  height:1px;
  background: var(--accent);
  border-radius:1px;
  transform:scaleX(0);
  transition:transform .2s ease;
  z-index:2;
  pointer-events:none;
}

.lx-field:focus-within .lx-border-anim { transform:scaleX(1); }

/* Floating label */
.lx-label {
  position:absolute;
  left:1rem;
  top:50%;
  transform:translateY(-50%);
  font-family:'Space Grotesk', sans-serif;
  font-size:.9rem;
  color:var(--text-dim);
  pointer-events:none;
  transition:top .2s ease, transform .2s ease, font-size .2s ease,
             color .2s ease, font-family .2s ease, letter-spacing .2s ease;
  z-index:2;
}

/* Float up: focused OR has content */
.lx-input:focus + .lx-label,
.lx-input:not(:placeholder-shown) + .lx-label {
  top:.6rem;
  transform:translateY(0);
  font-size:.63rem;
  font-family:'IBM Plex Mono', monospace;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--accent);
}

.lx-opt {
  font-size:.6rem;
  opacity:.55;
  font-style:normal;
  font-family:'IBM Plex Mono', monospace;
}

/* Field with forgot link — label needs to center before the link area */
.lx-forgot {
  display:block;
  text-align:right;
  font-size:.77rem;
  color:var(--text-dim);
  margin-top:.45rem;
  transition:color .15s;
  position:relative;
  z-index:3;
}
.lx-forgot:hover { color:var(--accent); text-decoration:none; }

/* ── Submit button ── */
.lx-submit {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.65rem;
  width:100%;
  padding:1rem 1.5rem;
  border-radius:.7rem;
  border:none;
  background: var(--accent);
  color:#03101d;
  font-family:'Syne', sans-serif;
  font-size:1.05rem;
  font-weight:700;
  letter-spacing:.01em;
  cursor:pointer;
  transition:opacity .15s ease;
}

.lx-submit::before { display: none; }
.lx-submit:hover { opacity:.88; }
.lx-submit:active { opacity:.75; }
.lx-submit:disabled { opacity:.4; cursor:not-allowed; }

.lx-arrow { flex-shrink:0; }

/* ── Switch / hint / footer ── */
.lx-switch-line {
  text-align:center;
  font-size:.84rem;
  color:var(--text-dim);
}

.lx-sw { font-size:.84rem; }

.lx-hint {
  font-family:'IBM Plex Mono', monospace;
  font-size:.72rem;
  color:var(--text-dim);
  text-align:center;
  line-height:1.6;
  margin-top:-.4rem;
}

.lx-footer {
  position:absolute;
  bottom:1.8rem;
  font-size:.76rem;
  color:var(--text-dim);
  text-align:center;
}

/* ── Entrance animations ── */
@keyframes lx-fade-up {
  from { opacity:0; transform:translateY(14px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ── Responsive ── */
@media (max-width:820px) {
  .lx-wrap { grid-template-columns:1fr; }
  .lx-panel { display:none; }
  .lx-right { padding:2.5rem 1.8rem; min-height:100vh; }
  .lx-mobile-brand { display:flex; }
  .lx-right::before { display:none; }
}

@media (max-width:480px) {
  .lx-right { padding:2rem 1.2rem; }
  .lx-form-title { font-size:1.7rem; }
}

/* ════════════════════════════════════════════
   APP CHROME
   ════════════════════════════════════════════ */
.app { position:relative; z-index:1; display:flex; height:100vh; overflow:hidden; }

/* ── Rail ── */
.rail { width:var(--rail-w); flex-shrink:0; background:var(--rail-bg); border-right:1px solid var(--line); display:flex; flex-direction:column; align-items:center; padding:10px 0; gap:10px; overflow-y:auto; overflow-x:hidden; scrollbar-width:none; }
.rail::-webkit-scrollbar { display:none; }
.ri { width:48px; height:48px; border-radius:50%; border:1px solid var(--line); background:var(--card); color:var(--text-dim); display:flex; align-items:center; justify-content:center; font-size:.82rem; font-weight:700; cursor:pointer; transition:border-radius .2s,background .2s,color .2s,border-color .2s; position:relative; flex-shrink:0; }
.ri:hover, .ri.active { border-radius:35%; background:var(--accent); color:#03101d; border-color:transparent; }
.ri.home  { background:var(--accent); color:#03101d; border-color:transparent; border-radius:35%; font-size:1rem; }
body.grad-on .ri:hover, body.grad-on .ri.active { background: var(--accent); }
body.grad-on .ri.home { background: var(--accent); }
.ri.home:hover { filter:brightness(1.08); }
.ri.add   { background:transparent; border:2px dashed rgba(125,246,199,.3); color:var(--accent-2); font-size:1.4rem; }
.ri.add:hover { background:rgba(125,246,199,.08); border-style:solid; border-color:var(--accent-2); border-radius:35%; }
.ri.discover { border-color:var(--line); color:var(--accent-2); }
.rail-div { width:32px; height:2px; background:var(--line); border-radius:1px; flex-shrink:0; margin:2px 0; }
#serverRail { display:flex; flex-direction:column; align-items:center; gap:10px; }
/* Active notch */
.ri::before { content:""; position:absolute; left:-12px; top:50%; transform:translateY(-50%); width:4px; height:0; background:var(--text); border-radius:0 4px 4px 0; transition:height .18s; }
.ri:hover::before { height:14px; }
.ri.active::before { height:34px; }

/* ── Sidebar ── */
.sidebar { width:var(--side-w); flex-shrink:0; background:var(--side-bg); border-right:1px solid var(--line); display:flex; flex-direction:column; overflow:hidden; }
#serverSidebar { flex:1; display:flex; flex-direction:column; min-height:0; overflow:hidden; }
.sb-head { height:var(--hdr-h); padding:0 14px; display:flex; align-items:center; justify-content:space-between; border-bottom:1px solid var(--line); flex-shrink:0; }
.sb-title { font-weight:700; font-size:.94rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sb-head-btn { background:none; border:none; color:var(--text-dim); padding:4px; border-radius:4px; display:flex; align-items:center; cursor:pointer; transition:color .12s; }
.sb-head-btn:hover { color:var(--text); }
.sb-search-wrap { padding:8px 10px 4px; flex-shrink:0; }
.sb-search { width:100%; background:rgba(5,8,18,.7); border:1px solid var(--line); border-radius:6px; color:var(--text); font-family:"Space Grotesk",sans-serif; font-size:.82rem; padding:6px 10px; outline:none; transition:border-color .18s; }
.sb-search:focus { border-color:var(--accent); }
.sb-search::placeholder { color:var(--text-dim); }
.sb-scroll { flex:1; overflow-y:auto; overflow-x:hidden; padding:8px 0; scrollbar-width:thin; scrollbar-color:var(--line) transparent; }
.sb-scroll::-webkit-scrollbar { width:3px; }
.sb-scroll::-webkit-scrollbar-thumb { background:var(--line); border-radius:2px; }

/* Category label */
.cat-label { font-size:.67rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--text-dim); font-family:"IBM Plex Mono",monospace; padding:10px 8px 4px 14px; display:flex; align-items:center; gap:4px; cursor:pointer; }
.cat-label:hover { color:var(--text); }

/* Channel button */
.ch-btn { display:flex; align-items:center; gap:6px; width:calc(100% - 8px); margin:1px 4px; padding:5px 8px 5px 14px; background:none; border:none; border-radius:6px; color:var(--text-dim); font-size:.88rem; font-family:"Space Grotesk",sans-serif; text-align:left; cursor:pointer; transition:background .1s,color .1s; }
.ch-btn:hover { background:rgba(102,139,255,.1); color:var(--text); }
.ch-btn.active { background:rgba(53,208,255,.13); color:var(--text); }
.ch-name { flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

/* DM item */
.dm-item { display:flex; align-items:center; gap:10px; padding:6px 10px; margin:1px 4px; border-radius:7px; cursor:pointer; transition:background .1s; background:none; border:none; width:calc(100% - 8px); text-align:left; font-family:"Space Grotesk",sans-serif; color:var(--text-dim); font-size:.9rem; }
.dm-item:hover { background:rgba(102,139,255,.1); color:var(--text); }
.dm-item.active { background:rgba(53,208,255,.13); color:var(--text); }
.dm-av { position:relative; flex-shrink:0; }
.dm-dot { position:absolute; bottom:-1px; right:-1px; width:10px; height:10px; border-radius:50%; border:2px solid var(--side-bg); z-index:1; }
.dm-info { min-width:0; flex:1; }
.dm-name { display:block; font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.dm-preview { display:block; font-size:.74rem; color:var(--text-dim); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

/* User panel */
.user-panel { height:52px; flex-shrink:0; border-top:1px solid var(--line); background:rgba(5,8,18,.65); display:flex; align-items:center; padding:0 6px; gap:4px; }
.up-me { display:flex; align-items:center; gap:8px; flex:1; min-width:0; background:none; border:none; color:inherit; cursor:pointer; padding:4px; border-radius:6px; text-align:left; transition:background .12s; }
.up-me:hover { background:rgba(102,139,255,.1); }
.up-av-wrap { position:relative; flex-shrink:0; }
.up-av { width:32px; height:32px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.72rem; font-weight:700; color:#03101d; overflow:hidden; }
.up-av img { width:100%; height:100%; object-fit:cover; }
.up-status { position:absolute; bottom:-1px; right:-1px; width:10px; height:10px; border-radius:50%; border:2px solid var(--side-bg); }
.up-names { min-width:0; }
.up-name { display:block; font-size:.84rem; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; color:var(--text); }
.up-tag  { display:block; font-size:.68rem; color:var(--text-dim); font-family:"IBM Plex Mono",monospace; }
.pc-btn { width:30px; height:30px; border-radius:6px; background:none; border:none; color:var(--text-dim); display:flex; align-items:center; justify-content:center; cursor:pointer; transition:background .12s,color .12s; flex-shrink:0; }
.pc-btn:hover { background:rgba(102,139,255,.12); color:var(--text); }
.pc-btn.muted { color:var(--danger); }

/* ── Main content ── */
.main { flex:1; min-width:0; display:flex; flex-direction:column; overflow:hidden; position:relative; }

/* Chat header */
.ch-header { height:var(--hdr-h); flex-shrink:0; border-bottom:1px solid var(--line); background:var(--bg-elev); display:flex; align-items:center; padding:0 16px; gap:10px; }
.ch-header-left { display:flex; align-items:center; gap:8px; flex:1; min-width:0; }
.ch-header-right { display:flex; align-items:center; gap:4px; flex-shrink:0; }
.hdr-btn { width:32px; height:32px; border-radius:6px; background:none; border:none; color:var(--text-dim); display:flex; align-items:center; justify-content:center; cursor:pointer; transition:background .1s,color .1s; }
.hdr-btn:hover { background:rgba(102,139,255,.12); color:var(--text); }
.hdr-btn.active { color:var(--accent); }

/* Messages */
.msg-list { flex:1; overflow-y:auto; overflow-x:hidden; padding:14px 0 4px; display:flex; flex-direction:column; scrollbar-width:thin; scrollbar-color:var(--line) transparent; }
.msg-list::-webkit-scrollbar { width:5px; }
.msg-list::-webkit-scrollbar-thumb { background:var(--line); border-radius:3px; }
.date-sep { display:flex; align-items:center; gap:10px; padding:10px 16px; color:var(--text-dim); font-size:.74rem; font-weight:600; position:relative; z-index:1; }
.date-sep::before, .date-sep::after { content:""; flex:1; height:1px; background:var(--line); }
.msg-row { display:flex; gap:12px; padding:3px 16px; transition:background .07s; position:relative; }
.msg-row:hover { background:rgba(102,139,255,.04); }
.msg-av { width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.76rem; font-weight:700; color:#03101d; flex-shrink:0; overflow:hidden; }
.msg-av img { width:100%; height:100%; object-fit:cover; }
.msg-body { flex:1; min-width:0; }
.msg-meta { display:flex; align-items:baseline; gap:7px; margin-bottom:2px; }
.msg-author { font-weight:600; font-size:.92rem; cursor:pointer; }
.msg-author:hover { text-decoration:underline; }
.msg-time { font-size:.7rem; color:var(--text-dim); font-family:"IBM Plex Mono",monospace; }
.bot-badge { display:inline-flex; align-items:center; font-size:.6rem; font-weight:700; letter-spacing:.04em; background:var(--accent); color:#03101d; border-radius:3px; padding:1px 4px; vertical-align:middle; line-height:1.4; text-transform:uppercase; margin-left:2px; flex-shrink:0; }
.member-bot-badge { font-size:.55rem; font-weight:700; letter-spacing:.04em; background:var(--accent); color:#03101d; border-radius:3px; padding:0 3px; display:inline-block; vertical-align:middle; line-height:1.5; text-transform:uppercase; }
.dev-badge { display:inline-flex; align-items:center; font-size:.6rem; font-weight:700; letter-spacing:.04em; background:linear-gradient(135deg,#a855f7,#6366f1); color:#fff; border-radius:3px; padding:1px 4px; vertical-align:middle; line-height:1.4; text-transform:uppercase; flex-shrink:0; }
.msg-text { font-size:.92rem; line-height:1.52; color:var(--text); word-break:break-word; white-space:pre-wrap; }
/* Hover actions - defined below in appended section */

/* Typing */
.typing-bar { padding:3px 16px 5px; display:flex; align-items:center; gap:6px; font-size:.78rem; color:var(--text-dim); min-height:22px; flex-shrink:0; }
.typing-bar:empty { min-height:22px; }
.t-dots span { display:inline-block; width:5px; height:5px; border-radius:50%; background:var(--text-dim); animation:tdot 1.2s ease infinite; }
.t-dots span:nth-child(2) { animation-delay:.2s; }
.t-dots span:nth-child(3) { animation-delay:.4s; }
@keyframes tdot { 0%,60%,100%{transform:translateY(0);opacity:.45} 30%{transform:translateY(-4px);opacity:1} }

/* Input area */
.input-area { flex-shrink:0; padding:0 14px 14px; }
.input-wrap { display:flex; align-items:center; background:var(--card); border:1px solid var(--line); border-radius:10px; padding:0 8px; gap:4px; transition:border-color .18s; }
.input-wrap:focus-within { border-color:rgba(53,208,255,.5); }
.msg-input { flex:1; background:none; border:none; outline:none; color:var(--text); font-family:"Space Grotesk",sans-serif; font-size:.93rem; padding:11px 4px; min-width:0; }
.msg-input::placeholder { color:var(--text-dim); }
.inp-btn { width:30px; height:30px; border-radius:6px; background:none; border:none; color:var(--text-dim); display:flex; align-items:center; justify-content:center; cursor:pointer; transition:color .12s; flex-shrink:0; }
.inp-btn:hover { color:var(--accent); }
.inp-btn.send { color:var(--accent); }

/* Channel welcome */
.ch-welcome { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; text-align:center; padding:3rem 2rem; flex:1; }
.ch-welcome .icon { font-size:3rem; }
.ch-welcome h3 { font-size:1.3rem; font-weight:700; }
.ch-welcome p { color:var(--text-dim); max-width:38ch; }

/* Welcome splash */
.welcome-splash { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:16px; text-align:center; padding:2rem; }
.ws-icon { font-size:3.5rem; }
.ws-title { font-size:clamp(1.4rem,3.5vw,2rem); font-weight:700; }
.ws-sub { color:var(--text-dim); max-width:38ch; }

/* ── Members sidebar ── */
.members { width:var(--mem-w); flex-shrink:0; background:var(--side-bg); border-left:1px solid var(--line); overflow-y:auto; overflow-x:hidden; scrollbar-width:thin; scrollbar-color:var(--line) transparent; transition:width .2s,opacity .2s; }
.members::-webkit-scrollbar { width:3px; }
.members::-webkit-scrollbar-thumb { background:var(--line); border-radius:2px; }
.members.hidden { width:0; opacity:0; overflow:hidden; }
.members-inner { padding:14px 8px; }
.mem-group { margin-bottom:8px; }
.mem-group-label { font-size:.67rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--text-dim); font-family:"IBM Plex Mono",monospace; padding:6px 8px 4px; }
.mem-row { display:flex; align-items:center; gap:9px; padding:5px 8px; border-radius:6px; cursor:pointer; transition:background .1s; }
.mem-row:hover { background:rgba(102,139,255,.1); }
.mem-av-wrap { position:relative; flex-shrink:0; }
.mem-av { width:32px; height:32px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.68rem; font-weight:700; color:#03101d; overflow:hidden; }
.mem-av img { width:100%; height:100%; object-fit:cover; }
.mem-sdot { position:absolute; bottom:-1px; right:-1px; width:10px; height:10px; border-radius:50%; border:2px solid var(--side-bg); }
.mem-info { min-width:0; flex:1; }
.mem-name { display:block; font-size:.84rem; font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; color:var(--text); }
.mem-role { display:block; font-size:.7rem; color:var(--accent); font-family:"IBM Plex Mono",monospace; }
.mem-row.offline { opacity:.48; }

/* ── Voice view ── */
.voice-view { display:flex; flex-direction:column; flex:1; position:relative; overflow:hidden; }
.vc-header { height:var(--hdr-h); flex-shrink:0; border-bottom:1px solid var(--line); background:var(--bg-elev); display:flex; align-items:center; gap:8px; padding:0 16px; font-weight:600; color:var(--accent-2); }
.vc-grid { display:grid; gap:8px; padding:12px; flex:1; align-content:start; overflow-y:auto; }
.vc-tile { display:flex; flex-direction:column; align-items:center; gap:5px; background:var(--card); border:1px solid var(--line); border-radius:10px; padding:10px 8px 8px; overflow:hidden; }
.vc-tile.speaking { border-color:var(--accent-2); box-shadow:0 0 0 2px rgba(125,246,199,.2); }
.vc-tile-media { width:52px; height:52px; border-radius:50%; overflow:hidden; flex-shrink:0; display:flex; align-items:center; justify-content:center; }
.vc-tile-av { width:100%; height:100%; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.1rem; font-weight:700; color:#03101d; }
.vc-tile-pfp { width:100%; height:100%; object-fit:cover; border-radius:50%; display:block; }
.vc-tile-name { font-size:.75rem; color:var(--text); font-weight:500; text-align:center; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:100%; }
video.vc-remote-vid { width:100%; aspect-ratio:16/9; background:#000; border-radius:8px; display:block; object-fit:contain; }
.vc-controls { display:flex; gap:10px; justify-content:center; padding:16px; flex-shrink:0; border-top:1px solid var(--line); }
.vc-btn { width:46px; height:46px; border-radius:50%; background:var(--card); border:1px solid var(--line); color:var(--text); display:flex; align-items:center; justify-content:center; cursor:pointer; transition:background .14s,border-color .14s,transform .1s; }
.vc-btn:hover { background:rgba(102,139,255,.18); border-color:var(--accent); transform:scale(1.06); }
.vc-btn.active { background:rgba(53,208,255,.2); border-color:var(--accent); color:var(--accent); }
.vc-btn.leave { background:rgba(248,113,113,.1); border-color:var(--danger); color:var(--danger); }
.vc-btn.leave:hover { background:var(--danger); color:#fff; }

/* ── VC mini floating window ── */
.vc-mini { position:fixed; bottom:18px; right:18px; z-index:900; background:var(--bg-elev); border:1px solid var(--line); border-radius:14px; padding:11px 13px 10px; width:230px; box-shadow:0 8px 40px rgba(0,0,0,.5); display:flex; flex-direction:column; gap:9px; }
.vcm-header { display:flex; flex-direction:column; gap:3px; cursor:pointer; padding-bottom:2px; border-bottom:1px solid var(--line); }
.vcm-header:hover .vcm-ch { color:var(--text); }
.vcm-live { display:flex; align-items:center; gap:5px; font-size:.7rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--accent-2); }
.vcm-dot { width:7px; height:7px; border-radius:50%; background:var(--accent-2); flex-shrink:0; animation:vcm-pulse 2s ease-in-out infinite; }
@keyframes vcm-pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.85)} }
.vcm-ch { display:flex; align-items:center; gap:4px; font-size:.8rem; color:var(--text-dim); transition:color .12s; }
.vcm-avatars { display:flex; align-items:center; cursor:pointer; padding:2px 0; }
.vcm-av { width:28px; height:28px; border-radius:50%; border:2px solid var(--bg-elev); display:inline-flex; align-items:center; justify-content:center; font-size:.58rem; font-weight:700; color:#03101d; object-fit:cover; margin-left:-7px; flex-shrink:0; transition:transform .1s; }
.vcm-av:first-child { margin-left:0; }
.vcm-avatars:hover .vcm-av { transform:translateY(-2px); }
img.vcm-av { color:transparent; }
.vcm-more { background:var(--card); color:var(--text-dim); font-size:.62rem; }
.vcm-btns { display:flex; gap:5px; }
.vcm-btn { flex:1; height:28px; border-radius:7px; background:var(--card); border:1px solid var(--line); color:var(--text-dim); display:flex; align-items:center; justify-content:center; cursor:pointer; transition:background .1s,color .1s,border-color .1s; }
.vcm-btn:hover { background:rgba(102,139,255,.15); color:var(--text); border-color:var(--accent); }
.vcm-btn.active { background:rgba(53,208,255,.15); border-color:var(--accent); color:var(--accent); }
.vcm-btn.leave { background:rgba(248,113,113,.08); border-color:var(--danger); color:var(--danger); }
.vcm-btn.leave:hover { background:var(--danger); color:#fff; border-color:var(--danger); }

/* ── VC sidebar members (Discord-style) ── */
.vc-ch-wrap { display:flex; flex-direction:column; }
.vc-channel-members { padding:2px 0 6px 26px; display:flex; flex-direction:column; gap:1px; }
.vc-sidebar-member { display:flex; align-items:center; gap:6px; padding:2px 6px 2px 2px; border-radius:4px; cursor:default; transition:background .1s; }
.vc-sidebar-member:hover { background:rgba(102,139,255,.1); }
.vc-sidebar-member.self .vc-sidebar-name { color:var(--accent-2); }
.vc-sidebar-av { width:18px; height:18px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; font-size:.5rem; font-weight:700; color:#03101d; flex-shrink:0; }
.vc-sidebar-av-img { width:18px; height:18px; border-radius:50%; object-fit:cover; flex-shrink:0; display:block; }
.vc-sidebar-name { font-size:.78rem; color:var(--text-dim); line-height:1.2; }
.vc-you { font-size:.7rem; opacity:.6; }

/* ═══════════════════════════════════════════
   MODALS
   ═══════════════════════════════════════════ */
.modal { position:fixed; inset:0; z-index:500; display:flex; align-items:center; justify-content:center; }
.modal[hidden] { display:none; }
.modal-scrim { position:absolute; inset:0; background:rgba(1,5,12,.82); }
.modal-card { position:relative; z-index:1; background:var(--bg-elev); border:1px solid var(--line); border-radius:1rem; animation:mpop .18s ease forwards; }
@keyframes mpop { from{opacity:0;transform:scale(.95) translateY(10px)} to{opacity:1;transform:none} }
.modal-x { position:absolute; top:12px; right:12px; z-index:10; background:var(--bg-elev); border:1px solid var(--line); color:var(--text-dim); width:28px; height:28px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.7rem; cursor:pointer; transition:background .12s,color .12s,border-color .12s; }
.modal-x:hover { background:rgba(248,113,113,.1); color:var(--danger); border-color:var(--danger); }

/* Discover */
.discover-card { width:min(800px,96vw); max-height:min(660px,92vh); display:flex; flex-direction:column; overflow:hidden; }
.disc-head { padding:20px 22px 0; display:flex; align-items:flex-start; justify-content:space-between; gap:14px; flex-wrap:wrap; }
.disc-head h3 { font-size:1.3rem; font-weight:700; margin:.2rem 0 .3rem; }
.disc-search { background:var(--card); border:1px solid var(--line); border-radius:8px; color:var(--text); font-family:"Space Grotesk",sans-serif; font-size:.88rem; padding:7px 12px; outline:none; width:220px; align-self:flex-end; transition:border-color .18s; }
.disc-search:focus { border-color:var(--accent); }
.disc-search::placeholder { color:var(--text-dim); }
.disc-filters { display:flex; gap:5px; padding:12px 22px 8px; flex-wrap:wrap; border-bottom:1px solid var(--line); flex-shrink:0; }
.f-pill { background:var(--card); border:1px solid var(--line); border-radius:999px; padding:4px 13px; color:var(--text-dim); font-size:.8rem; font-family:"Space Grotesk",sans-serif; cursor:pointer; transition:background .1s,border-color .1s,color .1s; }
.f-pill:hover { border-color:var(--accent); color:var(--text); }
.f-pill.active { background:rgba(53,208,255,.13); border-color:var(--accent); color:var(--text); }
.disc-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(210px,1fr)); gap:10px; padding:14px 22px 22px; overflow-y:auto; flex:1; scrollbar-width:thin; }
.srv-card { background:var(--card); border:1px solid var(--line); border-radius:10px; overflow:hidden; display:flex; flex-direction:column; transition:border-color .18s,transform .14s; cursor:pointer; }
.srv-card:hover { border-color:rgba(53,208,255,.4); transform:translateY(-2px); }
.srv-banner { height:60px; display:flex; align-items:center; justify-content:center; font-size:2rem; }
.srv-body { padding:10px 12px 12px; display:flex; flex-direction:column; flex:1; gap:4px; }
.srv-name { font-size:.9rem; font-weight:700; color:var(--text); }
.srv-desc { font-size:.76rem; color:var(--text-dim); line-height:1.4; flex:1; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.srv-meta { font-size:.7rem; color:var(--text-dim); font-family:"IBM Plex Mono",monospace; }

/* Create server */
.create-card { width:min(460px,96vw); padding:2rem; }
.create-card h3 { font-size:1.3rem; font-weight:700; margin:.3rem 0 .4rem; }
.create-form { display:flex; flex-direction:column; gap:1rem; margin-top:1rem; }
.vis-row { display:flex; align-items:center; justify-content:space-between; padding:6px 0; gap:10px; }

/* Settings */
.settings-card { width:min(840px,96vw); height:min(620px,92vh); padding:0; display:flex; overflow:hidden; }
.settings-nav { width:210px; flex-shrink:0; background:rgba(5,8,18,.65); border-right:1px solid var(--line); padding:14px 8px; display:flex; flex-direction:column; gap:2px; overflow-y:auto; }
.sn-head { font-size:.67rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--text-dim); font-family:"IBM Plex Mono",monospace; padding:5px 8px 8px; }
.sn-btn { background:none; border:none; color:var(--text-dim); font-family:"Space Grotesk",sans-serif; font-size:.88rem; text-align:left; padding:6px 10px; border-radius:6px; cursor:pointer; transition:background .1s,color .1s; }
.sn-btn:hover { background:rgba(102,139,255,.1); color:var(--text); }
.sn-btn.active { background:rgba(53,208,255,.14); color:var(--text); }
.sn-btn.danger { color:var(--danger); }
.sn-btn.danger:hover { background:rgba(248,113,113,.1); }
.sn-div { height:1px; background:var(--line); margin:5px 0; }
.settings-body { flex:1; overflow-y:auto; padding:26px; scrollbar-width:thin; scrollbar-color:var(--line) transparent; }
.settings-body::-webkit-scrollbar { width:4px; }
.settings-body::-webkit-scrollbar-thumb { background:var(--line); border-radius:2px; }
.s-section { margin-bottom:28px; }
.s-section h4 { font-size:.72rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--text-dim); font-family:"IBM Plex Mono",monospace; margin-bottom:10px; }
.s-row { display:flex; align-items:center; justify-content:space-between; padding:9px 0; border-bottom:1px solid var(--line); gap:10px; }
.s-row:last-child { border-bottom:none; }
.s-row-info .label { font-size:.9rem; font-weight:500; }
.s-row-info .desc  { font-size:.76rem; color:var(--text-dim); margin-top:1px; }
.s-close { position:absolute; top:12px; right:12px; }

/* Profile card in settings */
.profile-card { display:flex; gap:1rem; align-items:center; background:var(--card); border:1px solid var(--line); border-radius:10px; padding:1.2rem; margin-bottom:1.5rem; }
.profile-av { width:72px; height:72px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.4rem; font-weight:700; color:#03101d; overflow:hidden; flex-shrink:0; }
.profile-av img { width:100%; height:100%; object-fit:cover; }
.profile-info .name { font-size:1.1rem; font-weight:700; }
.profile-info .tag  { font-size:.82rem; color:var(--text-dim); font-family:"IBM Plex Mono",monospace; }
.profile-info .bio  { font-size:.84rem; color:var(--text-dim); margin-top:.25rem; max-width:32ch; }

/* Avatar upload zone */
.av-upload { display:flex; gap:.8rem; align-items:center; margin-bottom:1rem; }
.av-upload-btn { display:flex; gap:.5rem; align-items:center; }
.av-cam-overlay {
  position:absolute; inset:0; border-radius:50%;
  background:rgba(0,0,0,.55); display:flex; align-items:center; justify-content:center;
  color:#fff; opacity:0; transition:opacity .15s;
  pointer-events:none;
}
#avLabel:hover .av-cam-overlay { opacity:1; }
#avLabel:hover #avPreview { filter:brightness(.6); }

/* Color picker palette */
.color-palette { display:flex; flex-wrap:wrap; gap:8px; }
.cp { width:28px; height:28px; border-radius:50%; cursor:pointer; border:2px solid transparent; transition:transform .12s,border-color .12s; }
.cp:hover { transform:scale(1.15); }
.cp.active { border-color:var(--text); box-shadow:0 0 0 2px var(--bg); }

/* Friends */
.friend-item { display:flex; align-items:center; gap:10px; padding:8px; border-radius:8px; transition:background .1s; }
.friend-item:hover { background:rgba(102,139,255,.08); }
.friend-av { width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.78rem; font-weight:700; color:#03101d; position:relative; flex-shrink:0; overflow:hidden; }
.friend-av img { width:100%; height:100%; object-fit:cover; }
.friend-sdot { position:absolute; bottom:-1px; right:-1px; width:10px; height:10px; border-radius:50%; border:2px solid var(--card-solid); }
.friend-info { flex:1; min-width:0; }
.friend-name { font-size:.88rem; font-weight:600; }
.friend-status { font-size:.74rem; color:var(--text-dim); }
.friend-actions { display:flex; gap:4px; }
.fa-btn { width:32px; height:32px; border-radius:50%; background:var(--card); border:1px solid var(--line); color:var(--text-dim); display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:.85rem; transition:background .1s,color .1s,border-color .1s; }
.fa-btn:hover { border-color:var(--accent); color:var(--accent); }
.fa-btn.danger:hover { border-color:var(--danger); color:var(--danger); }
.fa-btn.accept:hover { border-color:var(--accent-2); color:var(--accent-2); background:rgba(125,246,199,.1); }

/* Context menu */
.ctx-menu { position:fixed; z-index:8000; background:var(--bg-elev); border:1px solid var(--line); border-radius:.85rem; padding:5px; min-width:210px; max-width:270px; animation:toast-in .1s ease; box-shadow:0 8px 32px rgba(0,0,0,.4),0 2px 8px rgba(0,0,0,.25); }
.ctx-menu[hidden] { display:none; }
.ctx-item { display:flex; align-items:center; gap:.6rem; width:100%; padding:7px 10px; border-radius:6px; background:none; border:none; color:var(--text); font-family:"Space Grotesk",sans-serif; font-size:.875rem; text-align:left; cursor:pointer; transition:background .08s,color .08s; white-space:nowrap; }
.ctx-item:hover { background:rgba(53,208,255,.13); color:#fff; }
.ctx-item.danger { color:var(--danger); }
.ctx-item.danger:hover { background:rgba(248,113,113,.13); color:#fca5a5; }
.ctx-item.disabled { opacity:.35; cursor:default; pointer-events:none; }
.ctx-icon { flex-shrink:0; width:15px; height:15px; display:flex; align-items:center; justify-content:center; opacity:.75; }
.ctx-item:hover .ctx-icon { opacity:1; }
.ctx-div { height:1px; background:var(--line); margin:4px 2px; }
.ch-type-btn { flex:1; display:flex; align-items:center; justify-content:center; gap:.4rem; padding:.55rem .8rem; border-radius:.55rem; border:1px solid var(--line); background:transparent; color:var(--text-dim); font-size:.85rem; font-family:"Space Grotesk",sans-serif; cursor:pointer; transition:all .15s; }
.ch-type-btn.active { background:rgba(53,208,255,.12); border-color:var(--accent); color:var(--accent); }
.msg-edited { font-size:.72rem; color:var(--text-dim); margin-left:.3rem; }
.msg-text.editing { outline:1px solid var(--accent); border-radius:4px; padding:2px 4px; background:rgba(53,208,255,.06); }

/* Emoji picker */
.emoji-picker { position:fixed; z-index:600; background:var(--bg-elev); border:1px solid var(--line); border-radius:10px; padding:8px; width:280px; animation:mpop .16s ease; bottom:80px; right:80px; }
.emoji-picker[hidden] { display:none; }
.emoji-grid { display:grid; grid-template-columns:repeat(8,1fr); gap:2px; }
.em-btn { width:30px; height:30px; background:none; border:none; border-radius:5px; cursor:pointer; font-size:1rem; display:flex; align-items:center; justify-content:center; transition:background .1s; }
.em-btn:hover { background:rgba(102,139,255,.14); }

/* ════════════════════════════════════════════
   FULL-PAGE LAYOUTS (discover / settings)
   ════════════════════════════════════════════ */

/* Shared page shell (discover) */
.page-shell { position:relative; z-index:1; display:flex; flex-direction:column; height:100vh; overflow:hidden; }
.page-nav { display:flex; align-items:center; gap:1.25rem; padding:0 2rem; height:64px; flex-shrink:0; border-bottom:1px solid var(--line); background:var(--bg-elev); }
.page-nav h1 { font-size:1.15rem; font-weight:700; }
.page-back { color:var(--text-dim); gap:6px; flex-shrink:0; }
.page-back:hover { color:var(--text); text-decoration:none; }
.page-filters { display:flex; gap:6px; flex-wrap:wrap; padding:.75rem 2rem; border-bottom:1px solid var(--line); background:rgba(8,12,24,.6); flex-shrink:0; }
.page-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:14px; padding:1.5rem 2rem; overflow-y:auto; flex:1; scrollbar-width:thin; scrollbar-color:var(--line) transparent; align-content:start; }
.page-grid::-webkit-scrollbar { width:5px; }
.page-grid::-webkit-scrollbar-thumb { background:var(--line); border-radius:3px; }
.page-loading { color:var(--text-dim); padding:2rem; grid-column:1/-1; }
.page-empty   { color:var(--text-dim); padding:2rem; grid-column:1/-1; }

/* Settings full-page */
.settings-page { position:relative; z-index:1; display:flex; height:100vh; overflow:hidden; }
.settings-page-nav { width:230px; flex-shrink:0; background:rgba(5,8,18,.98); border-right:1px solid var(--line); display:flex; flex-direction:column; padding:1.25rem 8px 1rem; gap:2px; overflow-y:auto; }
.settings-page-body { flex:1; overflow-y:auto; padding:2rem 2.5rem; max-width:720px; scrollbar-width:thin; scrollbar-color:var(--line) transparent; }
.settings-page-body::-webkit-scrollbar { width:4px; }
.settings-page-body::-webkit-scrollbar-thumb { background:var(--line); border-radius:2px; }

/* ── Theme presets ── */
.theme-aurora {
  --accent:#00e5a8; --accent-2:#00c4ff; --user-accent:#00e5a8;
  --bg:#091512; --bg-elev:#0c1b17; --card:#0f2219; --card-solid:#0d1e16;
  --panel:#0b1914; --side-bg:#071210; --rail-bg:#050f0c;
  --line:rgba(0,229,168,0.16); --hover:rgba(0,229,168,.08);
  --glow-a:rgba(0,229,168,0.18); --glow-b:rgba(0,196,255,0.12);
}
.theme-crimson {
  --accent:#f472b6; --accent-2:#fb7185; --user-accent:#f472b6;
  --bg:#14090d; --bg-elev:#1a0d13; --card:#211019; --card-solid:#1e0e16;
  --panel:#160b10; --side-bg:#0f080b; --rail-bg:#0b0508;
  --line:rgba(244,114,182,0.16); --hover:rgba(244,114,182,.08);
  --glow-a:rgba(244,114,182,0.18); --glow-b:rgba(251,113,133,0.12);
}
.theme-amethyst {
  --accent:#a78bfa; --accent-2:#c4b5fd; --user-accent:#a78bfa;
  --bg:#0f0a1a; --bg-elev:#150e22; --card:#1c1330; --card-solid:#19102b;
  --panel:#120c1e; --side-bg:#0b0814; --rail-bg:#08060f;
  --line:rgba(167,139,250,0.16); --hover:rgba(167,139,250,.08);
  --glow-a:rgba(167,139,250,0.18); --glow-b:rgba(196,181,253,0.12);
}
.theme-solar {
  --accent:#f59e0b; --accent-2:#fb923c; --user-accent:#f59e0b;
  --bg:#160f07; --bg-elev:#1e1508; --card:#261b0b; --card-solid:#221808;
  --panel:#1a1207; --side-bg:#110c05; --rail-bg:#0d0903;
  --line:rgba(245,158,11,0.16); --hover:rgba(245,158,11,.08);
  --glow-a:rgba(245,158,11,0.18); --glow-b:rgba(251,146,60,0.12);
}
.theme-oled {
  --accent:#35d0ff; --accent-2:#7df6c7; --user-accent:#35d0ff;
  --bg:#000000; --bg-elev:#070707; --card:#0e0e0e; --card-solid:#0a0a0a;
  --panel:#040404; --side-bg:#020202; --rail-bg:#000000;
  --line:rgba(53,208,255,0.13); --hover:rgba(53,208,255,.07);
  --glow-a:rgba(53,208,255,0.13); --glow-b:rgba(125,246,199,0.08);
}
.theme-void {
  --accent:#cbd5e1; --accent-2:#94a3b8; --user-accent:#cbd5e1;
  --bg:#090909; --bg-elev:#101010; --card:#181818; --card-solid:#121212;
  --panel:#0c0c0c; --side-bg:#070707; --rail-bg:#040404;
  --line:rgba(203,213,225,0.12); --hover:rgba(203,213,225,.07);
  --glow-a:rgba(203,213,225,0.09); --glow-b:rgba(148,163,184,0.06);
}
.theme-midnight {
  --accent:#818cf8; --accent-2:#a5b4fc; --user-accent:#818cf8;
  --bg:#0f1117; --bg-elev:#13161f; --card:#191d2a; --card-solid:#161a25;
  --panel:#111420; --side-bg:#0d1019; --rail-bg:#090c14;
  --line:rgba(129,140,248,0.16); --hover:rgba(129,140,248,.08);
  --glow-a:rgba(129,140,248,0.18); --glow-b:rgba(165,180,252,0.12);
}
.theme-forest {
  --accent:#4ade80; --accent-2:#86efac; --user-accent:#4ade80;
  --bg:#080f0b; --bg-elev:#0c1610; --card:#111e15; --card-solid:#0e1b12;
  --panel:#0a1309; --side-bg:#060d08; --rail-bg:#040a06;
  --line:rgba(74,222,128,0.16); --hover:rgba(74,222,128,.08);
  --glow-a:rgba(74,222,128,0.18); --glow-b:rgba(134,239,172,0.12);
}
.theme-white {
  --accent:#4f46e5; --accent-2:#7c3aed; --user-accent:#4f46e5;
  --bg:#f8fafc; --bg-elev:#f1f5f9; --card:#ffffff; --card-solid:#f8fafc;
  --panel:#e2e8f0; --side-bg:#edf2f7; --rail-bg:#e2e8f0;
  --text:#0f172a; --text-dim:#64748b;
  --line:rgba(79,70,229,0.18); --hover:rgba(79,70,229,.09);
  --glow-a:rgba(79,70,229,0.10); --glow-b:rgba(124,58,237,0.07);
  --warning:#d97706; --danger:#dc2626;
  --shadow:0 4px 16px rgba(0,0,0,.12);
}
.theme-white .btn-primary { color:#fff; }
.theme-white .ri:hover, .theme-white .ri.active { color:#fff; }
.theme-white .ri.home { color:#fff; }
.theme-white .toggle.on::after { background:#fff; }
.theme-white .sb-search { background:rgba(255,255,255,.85); }
.theme-white .user-panel { background:rgba(226,232,240,.9); }
.theme-white .msg-row:hover { background:rgba(79,70,229,.04); }
.theme-white .ch-btn:hover { background:rgba(79,70,229,.1); }
.theme-white .ch-btn.active { background:rgba(79,70,229,.13); }
.theme-white .dm-item:hover { background:rgba(79,70,229,.1); }
.theme-white .dm-item.active { background:rgba(79,70,229,.13); }
.theme-white .mem-row:hover { background:rgba(79,70,229,.1); }
.theme-white #gridCanvas { opacity:0.4; mix-blend-mode:multiply; }
.theme-white #mainGridSvg { opacity:0.35; mix-blend-mode:multiply; }

/* ── Background pattern toggle ── */
body.no-bg-dots #gridCanvas { display:none !important; }
body.no-bg-dots #mainGridSvg { display:none !important; }

/* ── Rail drag-and-drop ── */
.ri[draggable="true"] { cursor: grab; }
.ri[draggable="true"]:active { cursor: grabbing; }
.ri.dragging { opacity: .28; transform: scale(.88); }
.ri.drag-over-line { box-shadow: 0 0 0 2px var(--accent) !important; border-color: var(--accent) !important; }
.rail-drop-line { width: 38px; height: 3px; border-radius: 2px; background: var(--accent); margin: 0 5px; flex-shrink: 0; box-shadow: 0 0 8px var(--accent); pointer-events: none; }

/* ── Folder button ── */
.ri.ri-folder { padding: 5px !important; overflow: visible; }
.ri.ri-folder.drag-over-folder { border-color: var(--accent) !important; background: rgba(53,208,255,.18) !important; box-shadow: 0 0 0 2px var(--accent) !important; }
.ri-folder-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; width: 100%; height: 100%; border-radius: 6px; overflow: hidden; }
.ri-folder-icon { display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,.1); border-radius: 3px; overflow: hidden; font-size: .48rem; line-height: 1; }
.ri-folder-icon img { width: 100%; height: 100%; object-fit: cover; }
.ri-folder-solo { display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; font-size: 1.1rem; grid-column: span 2; }
.ri-folder-label { font-size: .48rem; font-weight: 700; color: var(--accent); text-align: center; width: 48px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; margin-top: 1px; font-family: "IBM Plex Mono", monospace; letter-spacing: .03em; }

/* ── Expanded folder panel ── */
.rail-folder-wrap { display: flex; flex-direction: column; align-items: center; gap: 2px; }
.rail-folder-panel { display: flex; flex-direction: column; align-items: center; gap: 3px; padding: 6px 4px; background: rgba(102,139,255,.07); border: 1px solid var(--line); border-radius: 10px; width: 60px; }
.rail-folder-panel .ri { width: 40px; height: 40px; font-size: .72rem; }
.rail-folder-panel .ri.dragging { opacity: .28; }

/* ── Message density ── */
.density-compact .msg-row { padding:1px 16px; }
.density-compact .msg-av  { width:28px; height:28px; font-size:.64rem; }
.density-compact .msg-meta { margin-bottom:0; }
.density-compact .msg-text { font-size:.84rem; }

/* ── User popover ── */
.user-popover { position:absolute; bottom:calc(100% + 8px); left:6px; right:6px; z-index:500; background:var(--bg-elev); border:1px solid var(--line); border-radius:12px; padding:1rem; animation:mpop .15s ease; }
.user-popover[hidden] { display:none; }
.up-pop-head { display:flex; align-items:center; gap:.75rem; margin-bottom:.85rem; }
.up-pop-av { position:relative; flex-shrink:0; }
.up-pop-av-img { width:52px; height:52px; border-radius:50%; overflow:hidden; display:flex; align-items:center; justify-content:center; font-size:1rem; font-weight:700; color:#03101d; }
.up-pop-av-img img { width:100%; height:100%; object-fit:cover; }
.up-pop-av .dm-dot { border-color:rgba(10,14,30,.97); }
.up-pop-names { min-width:0; }
.up-pop-name { font-weight:700; font-size:.95rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.up-pop-tag  { font-size:.7rem; color:var(--text-dim); font-family:"IBM Plex Mono",monospace; }
.up-pop-section { font-size:.62rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--text-dim); font-family:"IBM Plex Mono",monospace; margin-bottom:6px; }
.up-pop-statuses { display:grid; grid-template-columns:1fr 1fr; gap:5px; margin-bottom:.85rem; }
.up-pop-st { display:flex; align-items:center; gap:6px; padding:6px 9px; border-radius:8px; background:rgba(255,255,255,.04); border:1px solid var(--line); color:var(--text-dim); font-size:.78rem; cursor:pointer; transition:all .12s; }
.up-pop-st:hover { border-color:var(--accent); color:var(--text); background:rgba(53,208,255,.07); }
.up-pop-st.active { border-color:var(--accent); color:var(--text); background:rgba(53,208,255,.12); }
.up-pop-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.up-pop-actions { display:flex; gap:5px; }
.up-pop-act { flex:1; display:flex; flex-direction:column; align-items:center; gap:4px; padding:8px 4px; border-radius:8px; background:rgba(255,255,255,.04); border:1px solid var(--line); color:var(--text-dim); font-size:.7rem; cursor:pointer; transition:all .12s; }
.up-pop-act svg { flex-shrink:0; }
.up-pop-act:hover { border-color:var(--accent); color:var(--text); background:rgba(53,208,255,.07); }
.up-pop-act.danger.active { border-color:var(--danger); color:var(--danger); background:rgba(248,113,113,.1); }
.up-pop-act.active { border-color:var(--accent); color:var(--accent); background:rgba(53,208,255,.1); }
.up-pop-divider { height:1px; background:var(--line); margin:.75rem 0; }
.up-pop-settings { display:block; width:100%; padding:7px; border-radius:8px; font-size:.8rem; color:var(--text-dim); cursor:pointer; transition:background .12s; background:none; border:none; font-family:inherit; text-align:center; }
.up-pop-settings:hover { background:rgba(102,139,255,.1); color:var(--text); }

/* Theme preset cards */
.theme-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); gap:10px; }
.theme-card { padding:.75rem; border-radius:10px; border:2px solid var(--line); cursor:pointer; transition:border-color .15s,transform .12s; background:rgba(255,255,255,.03); }
.theme-card:hover { transform:translateY(-2px); }
.theme-card.active { border-color:var(--accent); }
.theme-swatch { display:flex; gap:5px; margin-bottom:.5rem; }
.theme-swatch span { width:20px; height:20px; border-radius:50%; }
.theme-card-name { font-size:.82rem; font-weight:600; }

/* Density cards */
.density-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.density-card { padding:.75rem; border-radius:10px; border:2px solid var(--line); cursor:pointer; transition:border-color .15s; background:rgba(255,255,255,.03); }
.density-card.active { border-color:var(--accent); }
.density-card-name { font-size:.84rem; font-weight:600; margin-bottom:3px; }
.density-card-desc { font-size:.74rem; color:var(--text-dim); }

/* ── Server Settings Modal ── */
.srv-settings-card { width:min(820px,96vw); height:min(600px,92vh); padding:0; display:flex; overflow:hidden; }
.srv-settings-layout { display:flex; width:100%; height:100%; }
.srv-settings-nav { width:200px; flex-shrink:0; background:rgba(5,8,18,.65); border-right:1px solid var(--line); padding:14px 8px 14px; display:flex; flex-direction:column; gap:2px; overflow-y:auto; }
.srv-settings-body { flex:1; overflow-y:auto; padding:3rem 1.75rem 1.5rem; scrollbar-width:thin; scrollbar-color:var(--line) transparent; min-height:0; }
.srv-settings-body:has(.roles-layout) { padding:3rem 0 0; overflow:hidden; }
.roles-layout { height:100%; }
.srv-settings-body::-webkit-scrollbar { width:4px; }
.srv-settings-body::-webkit-scrollbar-thumb { background:var(--line); border-radius:2px; }
.srv-set-heading { font-size:1.05rem; font-weight:700; margin-bottom:1.25rem; }
.srv-icon-preview { width:64px; height:64px; border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:1.9rem; border:1px solid var(--line); overflow:hidden; flex-shrink:0; }

/* ── Roles ── */
.role-row { display:flex; align-items:center; gap:.6rem; padding:.55rem .7rem; border-radius:8px; background:rgba(255,255,255,.03); border:1px solid var(--line); margin-bottom:.4rem; }
.role-dot { width:12px; height:12px; border-radius:50%; flex-shrink:0; }
.role-name { font-size:.88rem; font-weight:600; flex:1; min-width:0; }
.role-badge { font-size:.66rem; font-weight:700; letter-spacing:.04em; background:rgba(53,208,255,.12); color:var(--accent); border:1px solid rgba(53,208,255,.3); border-radius:4px; padding:1px 6px; font-family:"IBM Plex Mono",monospace; }

/* ── Discord-style role editor ── */
.roles-layout { display:flex; gap:0; height:100%; min-height:380px; }
.roles-sidebar { width:188px; flex-shrink:0; border-right:1px solid var(--line); padding:0; display:flex; flex-direction:column; overflow:hidden; }
.roles-sidebar-head { display:flex; align-items:center; justify-content:space-between; padding:.6rem .75rem; font-size:.7rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--text-dim); border-bottom:1px solid var(--line); }
.roles-sidebar-row { display:flex; align-items:center; gap:.5rem; padding:.45rem .7rem; cursor:pointer; transition:background .1s; font-size:.85rem; border-left:2px solid transparent; }
.roles-sidebar-row:hover { background:rgba(102,139,255,.07); }
.roles-sidebar-row.active { background:rgba(53,208,255,.1); border-left-color:var(--accent); }
#rolesList { overflow-y:auto; flex:1; scrollbar-width:thin; scrollbar-color:var(--line) transparent; }
.roles-editor-panel { flex:1; padding:1.25rem 1.5rem; overflow-y:auto; display:flex; flex-direction:column; gap:.85rem; scrollbar-width:thin; scrollbar-color:var(--line) transparent; }
.roles-editor-empty { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; color:var(--text-dim); }
.role-ed-head { display:flex; align-items:center; gap:.5rem; padding-bottom:.75rem; border-bottom:1px solid var(--line); }
.role-ed-tabs { display:flex; gap:2px; border-bottom:1px solid var(--line); }
.role-ed-tab { background:none; border:none; border-bottom:2px solid transparent; padding:.4rem .85rem; font-size:.83rem; font-weight:600; color:var(--text-dim); cursor:pointer; transition:color .15s,border-color .15s; font-family:inherit; margin-bottom:-1px; }
.role-ed-tab:hover { color:var(--text); }
.role-ed-tab.active { color:var(--text); border-bottom-color:var(--accent); }
.role-ed-footer { border-top:1px solid var(--line); padding-top:.75rem; display:flex; align-items:center; gap:.75rem; }
.perm-section-head { font-size:.68rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--text-dim); font-family:"IBM Plex Mono",monospace; padding:.5rem 0 .3rem; border-bottom:1px solid var(--line); margin-bottom:.1rem; }
.perm-row { display:flex; align-items:center; gap:.75rem; padding:.65rem 0; border-bottom:1px solid rgba(255,255,255,.04); }
.perm-row:last-child { border-bottom:none; }
.perm-row-admin { background:rgba(53,208,255,.04); border-radius:8px; padding:.65rem .5rem; margin-bottom:.25rem; border:1px solid rgba(53,208,255,.12); }
.perm-row-text { flex:1; min-width:0; }
.perm-row-label { font-size:.85rem; font-weight:600; }
.perm-row-desc { font-size:.74rem; color:var(--text-dim); margin-top:1px; }

/* ── Invite table ── */
.inv-table { width:100%; border-collapse:collapse; font-size:.83rem; }
.inv-table th { text-align:left; font-size:.68rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--text-dim); font-family:"IBM Plex Mono",monospace; padding:.4rem .5rem .6rem; border-bottom:1px solid var(--line); }
.inv-table td { padding:.55rem .5rem; border-bottom:1px solid rgba(255,255,255,.04); vertical-align:middle; }
.inv-table tr.inv-expired { opacity:.5; }
.inv-code { font-family:"IBM Plex Mono",monospace; font-size:.82rem; background:rgba(255,255,255,.06); border:1px solid var(--line); border-radius:5px; padding:2px 8px; cursor:pointer; transition:background .1s; }
.inv-code:hover { background:rgba(53,208,255,.12); }
.invite-form { background:rgba(255,255,255,.03); border:1px solid var(--line); border-radius:10px; padding:1rem; margin-bottom:1rem; }

/* ── Ban list ── */
.ban-row { display:flex; align-items:center; gap:.7rem; padding:.6rem .5rem; border-radius:8px; border:1px solid var(--line); background:rgba(255,255,255,.02); margin-bottom:.4rem; }

/* ── Member management ── */
.mem-mgmt-row { display:flex; align-items:center; gap:.65rem; padding:.55rem .5rem; border-radius:8px; margin-bottom:.3rem; transition:background .1s; }
.mem-mgmt-row:hover { background:rgba(102,139,255,.06); }

/* ── Channel management in settings ── */
.ch-mgmt-section-head { font-size:.68rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--text-dim); font-family:"IBM Plex Mono",monospace; padding:.4rem 0 .5rem; border-bottom:1px solid var(--line); margin-bottom:.4rem; }
.ch-mgmt-row { display:flex; align-items:center; gap:.6rem; padding:.5rem .45rem; border-radius:8px; border:1px solid var(--line); background:rgba(255,255,255,.02); margin-bottom:.3rem; transition:background .1s; }
.ch-mgmt-row:hover { background:rgba(255,255,255,.04); }

/* ── Custom emoji management ── */
.emoji-mgmt-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(110px,1fr)); gap:.6rem; }
.emoji-mgmt-card { display:flex; flex-direction:column; align-items:center; gap:.3rem; padding:.65rem .4rem; background:rgba(255,255,255,.03); border:1px solid var(--line); border-radius:10px; }
.emoji-mgmt-img { width:40px; height:40px; object-fit:contain; border-radius:4px; }
.emoji-mgmt-name { font-size:.7rem; color:var(--text-dim); font-family:"IBM Plex Mono",monospace; text-align:center; word-break:break-all; }

/* ── Audit log ── */
.audit-row { display:flex; align-items:flex-start; gap:.75rem; padding:.65rem .4rem; border-bottom:1px solid rgba(255,255,255,.05); }
.audit-row:last-child { border-bottom:none; }
.audit-icon { font-size:1.1rem; flex-shrink:0; width:26px; text-align:center; margin-top:1px; }
.audit-body { flex:1; min-width:0; }
.audit-desc { font-size:.85rem; line-height:1.4; }
.audit-target { color:var(--accent); font-family:"IBM Plex Mono",monospace; font-size:.8rem; }
.audit-time { font-size:.72rem; color:var(--text-dim); margin-top:2px; }

/* ── Moderation tab radio cards ── */
.moderation-radio { display:flex; align-items:center; gap:.85rem; cursor:pointer; padding:.6rem .85rem; border-radius:9px; border:2px solid var(--line); background:rgba(255,255,255,.02); transition:all .15s; max-width:480px; }
.moderation-radio.active { border-color:var(--accent); background:rgba(53,208,255,.07); }
.moderation-radio:hover { background:rgba(255,255,255,.04); }

/* ── Voice & Video settings ── */
.mode-card { display:flex; flex-direction:column; gap:.3rem; cursor:pointer; padding:.75rem .85rem; border-radius:9px; border:2px solid var(--line); background:rgba(255,255,255,.02); transition:all .15s; flex:1; }
.mode-card.active { border-color:var(--accent); background:rgba(53,208,255,.07); }
.mode-card:hover { background:rgba(255,255,255,.04); }
.mode-card-name { font-size:.87rem; font-weight:600; }
.mode-card-desc { font-size:.74rem; color:var(--text-dim); }

/* ── Notifications denied banner ── */
.notif-denied-banner { background:rgba(248,113,113,.1); border:1px solid rgba(248,113,113,.3); border-radius:8px; padding:.65rem .9rem; font-size:.83rem; color:#f87171; margin-bottom:.9rem; }

/* ── Accessibility ── */
.reduce-motion *, .reduce-motion body::before { animation:none !important; transition:none !important; }
.high-contrast { --text: #ffffff; --text-dim: rgba(255,255,255,.8); --line: rgba(255,255,255,.25); }

/* ── Settings page ── */
.settings-page { display:flex; height:100vh; overflow:hidden; }
.settings-page-nav { width:220px; flex-shrink:0; background:rgba(5,8,18,.8); border-right:1px solid var(--line); padding:1rem .75rem; display:flex; flex-direction:column; gap:2px; overflow-y:auto; }
.settings-page-body { flex:1; overflow-y:auto; padding:2rem 2.5rem; scrollbar-width:thin; scrollbar-color:var(--line) transparent; max-width:820px; }
.page-back { gap:.5rem; color:var(--text-dim); font-size:.84rem; text-decoration:none; padding:.4rem .6rem; }
.page-back:hover { color:var(--text); background:rgba(255,255,255,.06); }

/* Responsive */
@media(max-width:900px) { .members{display:none}:root{--mem-w:0px} }
@media(max-width:680px) { :root{--side-w:200px} }
@media(max-width:520px) { .sidebar{display:none}:root{--side-w:0px;--rail-w:56px} .ri{width:42px;height:42px} }
@media(prefers-reduced-motion:reduce) { *,body::before{animation:none!important;transition:none!important} }

/* ── Reply context (shown above message body) ── */
.msg-reply-ctx { display:flex; align-items:center; gap:.35rem; font-size:.78rem; color:var(--text-dim); margin-bottom:.2rem; cursor:pointer; max-width:100%; overflow:hidden; }
.msg-reply-ctx:hover .msg-reply-preview { color:var(--text); }
.msg-reply-line { width:2px; min-width:2px; height:14px; background:var(--text-dim); border-radius:1px; opacity:.6; }
.msg-reply-author { font-weight:600; color:var(--accent); white-space:nowrap; flex-shrink:0; }
.msg-reply-preview { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; opacity:.75; }

/* ── Reply bar (above input) ── */
/* display:flex overrides the UA [hidden]{display:none} rule, so we need to be explicit */
.reply-bar[hidden] { display: none; }
@keyframes reply-bar-enter {
  from { opacity:0; transform:translateY(6px); }
  to   { opacity:1; transform:translateY(0);   }
}
.reply-bar { display:flex; align-items:center; gap:.6rem; padding:.4rem .8rem; background:rgba(0,0,0,.15); border-top:1px solid var(--line); font-size:.82rem; flex-shrink:0; animation: reply-bar-enter 160ms cubic-bezier(0.22,1.25,0.42,1); }
.reply-bar-info { color:var(--text-dim); flex-shrink:0; }
.reply-bar-info strong { color:var(--accent); }
.reply-bar-preview { color:var(--text-dim); flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; opacity:.65; font-style:italic; }
.reply-bar-cancel { background:none; border:none; color:var(--text-dim); cursor:pointer; font-size:1rem; padding:.15rem .4rem; border-radius:4px; flex-shrink:0; line-height:1; }
.reply-bar-cancel:hover { color:var(--text); background:var(--hover); }

/* ── Message action bar ── */
.msg-row { position:relative; }
.msg-actions {
  opacity: 0;
  pointer-events: none;
  position: absolute; top: -.4rem; right: .5rem;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: .2rem .25rem;
  gap: .1rem;
  display: flex;
  flex-direction: row;
  z-index: 10;
  transition: opacity .12s ease;
}
.msg-row:hover .msg-actions,
.msg-row:focus-within .msg-actions {
  opacity: 1;
  pointer-events: all;
}
.ma-btn { background:none; border:none; color:var(--text-dim); cursor:pointer; padding:.25rem .35rem; border-radius:5px; font-size:.85rem; line-height:1; transition:color .12s, background .12s; }
.ma-btn:hover { color:var(--text); background:var(--hover); }

/* ── Reactions ── */
.msg-reactions { display:flex; flex-wrap:wrap; gap:.3rem; margin-top:.35rem; }
.react-pill { display:inline-flex; align-items:center; gap:.25rem; background:rgba(255,255,255,.06); border:1px solid var(--line); border-radius:100px; padding:.12rem .5rem; cursor:pointer; font-size:.82rem; transition:background .12s, border-color .12s; line-height:1.4; }
.react-pill:hover { background:rgba(255,255,255,.12); border-color:var(--accent); }
.react-pill.me { background:rgba(53,208,255,.14); border-color:var(--accent); }
.react-pill span { font-size:.75rem; color:var(--text-dim); font-weight:600; font-family:"IBM Plex Mono",monospace; }
.react-add-btn { display:inline-flex; align-items:center; justify-content:center; width:24px; height:24px; background:rgba(255,255,255,.05); border:1px dashed var(--line); border-radius:100px; cursor:pointer; font-size:.8rem; opacity:.6; transition:opacity .12s, background .12s; }
.react-add-btn:hover { opacity:1; background:rgba(255,255,255,.1); }

/* Reaction picker popup */
.react-picker { position:fixed; z-index:350; background:var(--bg-elev); border:1px solid var(--line); border-radius:10px; padding:.5rem; display:flex; flex-wrap:wrap; gap:.2rem; max-width:276px; }
.react-picker .em-btn { width:32px; height:32px; font-size:1.05rem; border-radius:6px; }

/* ── Markdown styles (inside msg-text) ── */
.msg-text { line-height:1.5; word-break:break-word; }
.msg-text strong { font-weight:700; }
.msg-text em { font-style:italic; }
.msg-text del { text-decoration:line-through; opacity:.65; }
.msg-text .md-code { background:rgba(0,0,0,.35); border:1px solid rgba(255,255,255,.08); border-radius:4px; padding:.1em .35em; font-family:"IBM Plex Mono",monospace; font-size:.85em; color:#7df6c7; }
.msg-text .md-pre { background:rgba(0,0,0,.4); border:1px solid rgba(255,255,255,.08); border-radius:8px; padding:.65rem 1rem; margin:.4rem 0; overflow-x:auto; }
.msg-text .md-pre code { background:none; border:none; padding:0; font-size:.83em; font-family:"IBM Plex Mono",monospace; color:#e2e8f0; white-space:pre; }
.msg-text .md-quote { border-left:3px solid var(--accent); padding-left:.65rem; margin:.15rem 0; color:var(--text-dim); }
.msg-text .md-link { color:var(--accent); text-decoration:underline; text-underline-offset:2px; }
.msg-text .md-link:hover { opacity:.8; }
.msg-text .spoiler { background:rgba(255,255,255,.15); color:transparent; border-radius:3px; cursor:pointer; padding:.05em .15em; user-select:none; }
.msg-text .spoiler.revealed { background:rgba(255,255,255,.08); color:inherit; }
.mention { color:var(--accent); background:rgba(53,208,255,.1); border-radius:3px; padding:.05em .2em; font-weight:500; cursor:pointer; }
.mention:hover { background:rgba(53,208,255,.2); }

/* ── Attachments ── */
.msg-attachments { display:flex; flex-direction:column; gap:.4rem; margin-top:.4rem; }
.msg-img-wrap { display:inline-block; border-radius:8px; overflow:hidden; cursor:pointer; max-width:min(400px, 100%); }
.msg-img { display:block; max-width:100%; max-height:300px; object-fit:contain; border-radius:8px; }
.msg-file-link { display:inline-flex; align-items:center; gap:.5rem; background:var(--card); border:1px solid var(--line); border-radius:8px; padding:.5rem .8rem; color:var(--text); text-decoration:none; font-size:.84rem; max-width:300px; transition:background .12s; }
.msg-file-link:hover { background:var(--hover); }
.msg-file-name { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

/* ── Load more spinner ── */
.load-more-sentinel { height:1px; }
.load-more-spinner { display:flex; justify-content:center; padding:.6rem; }
.load-more-spinner::after { content:''; width:20px; height:20px; border:2px solid var(--line); border-top-color:var(--accent); border-radius:50%; animation:spin .7s linear infinite; }
@keyframes spin { to{transform:rotate(360deg)} }

/* ── Pins panel ── */
.pins-panel { position:fixed; top:0; right:0; height:100vh; width:320px; background:var(--panel); border-left:1px solid var(--line); z-index:200; display:flex; flex-direction:column; transform:translateX(100%); transition:transform .22s ease; pointer-events:none; }
.pins-panel.open { transform:translateX(0); pointer-events:all; }
.pins-panel-scrim { position:fixed; inset:0; z-index:199; background:rgba(0,0,0,.35); }
.pins-panel-head { display:flex; align-items:center; justify-content:space-between; padding:1rem 1.1rem; border-bottom:1px solid var(--line); font-weight:700; font-size:.9rem; flex-shrink:0; }
.pins-panel-close { background:none; border:none; color:var(--text-dim); cursor:pointer; font-size:1rem; padding:.2rem .4rem; border-radius:5px; }
.pins-panel-close:hover { color:var(--text); background:var(--hover); }
.pins-list { flex:1; overflow-y:auto; padding:.4rem; }
.pin-row { padding:.65rem .8rem; border-radius:8px; cursor:pointer; margin-bottom:.25rem; }
.pin-row:hover { background:var(--hover); }
.pin-row-author { font-size:.76rem; font-weight:600; color:var(--accent); margin-bottom:.15rem; }
.pin-row-content { font-size:.84rem; color:var(--text-dim); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.pin-row-time { font-size:.72rem; color:var(--text-dim); opacity:.55; margin-top:.15rem; }
.pins-empty { padding:2rem 1rem; text-align:center; color:var(--text-dim); font-size:.88rem; }

/* ── Unified profile card popup ── */
.pcard {
  position:fixed; z-index:600;
  width:300px;
  background:#0c1325;
  border:1px solid rgba(102,139,255,.18);
  border-radius:14px; overflow:hidden;
  box-shadow:0 12px 48px rgba(0,0,0,.7);
  animation:pcard-in .14s ease;
}
@keyframes pcard-in { from { opacity:0; transform:scale(.96) translateY(4px); } to { opacity:1; transform:none; } }
.pcard-banner {
  height:80px; position:relative; overflow:hidden; cursor:default;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
}
.pcard-banner img { width:100%; height:100%; object-fit:cover; }
.pcard-banner-edit {
  display:none; position:absolute; inset:0;
  background:rgba(0,0,0,.5); align-items:center; justify-content:center;
  font-size:.72rem; font-weight:700; color:#fff; cursor:pointer;
}
.pcard-banner.editable:hover .pcard-banner-edit { display:flex; }
.pcard-av-row {
  display:flex; align-items:flex-end; justify-content:space-between;
  padding:0 14px; margin-top:-36px; margin-bottom:0;
}
.pcard-av {
  width:72px; height:72px; border-radius:50%;
  border:4px solid #0c1325;
  overflow:hidden; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:1.1rem; color:#03101d;
  position:relative; cursor:default;
}
.pcard-av img { width:100%; height:100%; object-fit:cover; }
.pcard-av-edit {
  display:none; position:absolute; inset:0; border-radius:50%;
  background:rgba(0,0,0,.55); align-items:center; justify-content:center;
  font-size:.62rem; font-weight:700; color:#fff; cursor:pointer;
}
.pcard-av.editable:hover .pcard-av-edit { display:flex; }
.pcard-av-actions { padding-bottom:6px; display:flex; align-items:center; gap:6px; }
.pcard-body { padding:.5rem 14px 14px; }
.pcard-name-row { display:flex; align-items:center; gap:6px; flex-wrap:wrap; margin-bottom:1px; }
.pcard-name { font-family:'Syne',sans-serif; font-weight:800; font-size:1rem; }
.pcard-username { font-size:.75rem; color:var(--text-dim); margin-bottom:6px; }
.pcard-custom-status { font-size:.78rem; color:var(--text-dim); margin-bottom:4px; }
.pcard-divider { height:1px; background:rgba(102,139,255,.1); margin:8px 0; }
.pcard-section-label {
  font-size:.63rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  color:var(--text-dim); margin-bottom:4px; font-family:"IBM Plex Mono",monospace;
}
.pcard-bio { font-size:.82rem; color:var(--text); line-height:1.5; white-space:pre-wrap; word-break:break-word; }
.pcard-roles { display:flex; flex-wrap:wrap; gap:4px; margin-top:2px; }
.pcard-role { font-size:.68rem; border:1px solid; border-radius:4px; padding:.1em .5em; }
.pcard-meta { font-size:.76rem; color:var(--text-dim); }
.pcard-actions { display:flex; gap:6px; margin-top:10px; }
.pcard-actions .btn { flex:1; font-size:.78rem; padding:.35rem .4rem; }

/* ── Edit Profile modal ── */
.ep-modal-body { display:flex; gap:20px; }
.ep-form { flex:1; min-width:0; }
.ep-preview { width:200px; flex-shrink:0; }
.ep-preview-label { font-size:.65rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--text-dim); margin-bottom:8px; font-family:"IBM Plex Mono",monospace; }
.ep-mini-card { background:#0c1325; border:1px solid rgba(102,139,255,.18); border-radius:10px; overflow:hidden; }
.ep-mini-banner { height:48px; }
.ep-mini-av-row { display:flex; padding:0 10px; margin-top:-22px; margin-bottom:0; }
.ep-mini-av { width:44px; height:44px; border-radius:50%; border:3px solid #0c1325; overflow:hidden; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:.72rem; color:#03101d; }
.ep-mini-av img { width:100%; height:100%; object-fit:cover; }
.ep-mini-body { padding:4px 10px 10px; }
.ep-mini-name { font-weight:800; font-size:.82rem; }
.ep-mini-un { font-size:.66rem; color:var(--text-dim); }
.ep-mini-bio { font-size:.72rem; color:var(--text-dim); margin-top:4px; line-height:1.4; }
.ep-color-row { display:flex; gap:6px; flex-wrap:wrap; margin-top:4px; }
.ep-color-swatch { width:22px; height:22px; border-radius:50%; cursor:pointer; border:2px solid transparent; transition:border-color .12s; }
.ep-color-swatch.active { border-color:#fff; }
@media (max-width:600px) { .ep-modal-body { flex-direction:column; } .ep-preview { width:100%; } }

/* ── Search bar ── */
.ch-search-bar { display:flex; align-items:center; gap:.5rem; padding:.5rem .8rem; background:rgba(0,0,0,.15); border-bottom:1px solid var(--line); flex-shrink:0; }
.ch-search-input { flex:1; background:rgba(0,0,0,.2); border:1px solid var(--line); border-radius:7px; padding:.35rem .65rem; color:var(--text); font-size:.86rem; outline:none; font-family:inherit; }
.ch-search-input:focus { border-color:var(--accent); }
.ch-search-close { background:none; border:none; color:var(--text-dim); cursor:pointer; font-size:.9rem; padding:.2rem .4rem; border-radius:5px; }
.ch-search-close:hover { color:var(--text); background:var(--hover); }
.search-results-wrap { flex:1; overflow-y:auto; padding:.4rem; }
.search-result-row { padding:.6rem .8rem; border-radius:8px; cursor:pointer; margin-bottom:.2rem; border:1px solid transparent; transition:background .12s, border-color .12s; }
.search-result-row:hover { background:var(--hover); border-color:var(--line); }
.search-result-author { font-size:.76rem; font-weight:600; color:var(--accent); margin-bottom:.15rem; }
.search-result-content { font-size:.84rem; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.search-result-content mark { background:rgba(53,208,255,.25); color:inherit; border-radius:2px; padding:.05em 0; }
.search-result-time { font-size:.72rem; color:var(--text-dim); margin-top:.1rem; opacity:.6; }
.search-empty { padding:2rem 1rem; text-align:center; color:var(--text-dim); font-size:.88rem; }

/* ── Lightbox ── */
.lightbox { position:fixed; inset:0; z-index:500; display:flex; align-items:center; justify-content:center; }
.lightbox[hidden] { display:none; }
.lightbox-scrim { position:absolute; inset:0; background:rgba(0,0,0,.85); }
.lightbox-img { position:relative; max-width:90vw; max-height:90vh; object-fit:contain; border-radius:8px; box-shadow:0 8px 48px rgba(0,0,0,.8); }
.lightbox-close { position:absolute; top:1rem; right:1rem; background:rgba(0,0,0,.6); border:1px solid rgba(255,255,255,.15); color:#fff; width:36px; height:36px; border-radius:50%; cursor:pointer; font-size:1rem; display:flex; align-items:center; justify-content:center; }
.lightbox-close:hover { background:rgba(255,255,255,.15); }

/* Search result highlight animation */
@keyframes highlight-pulse { 0%,100% { background:transparent; } 30% { background:rgba(53,208,255,.12); } }
.highlight-msg { animation: highlight-pulse 1.5s ease; }

/* ── Unread channel indicator ── */
.ch-btn.unread { color:var(--text); font-weight:600; }
.ch-btn.unread::after { content:""; width:6px; height:6px; border-radius:50%; background:var(--accent); flex-shrink:0; margin-left:auto; }

/* ── Compact (grouped) messages ── */
.msg-row.compact { padding-top:1px; padding-bottom:1px; }
.msg-row.compact .msg-av { visibility:hidden; }
.msg-row.compact .msg-meta { display:none; }
.msg-row.compact .msg-reply-ctx { display:none; }

/* ── @mention autocomplete dropdown ── */
.input-wrap { position:relative; }
.mention-drop { position:absolute; bottom:calc(100% + 6px); left:0; right:0; background:var(--bg-elev); border:1px solid var(--line); border-radius:8px; overflow:hidden; z-index:200; max-height:220px; overflow-y:auto; }
.mention-item { display:flex; align-items:center; gap:.6rem; padding:.45rem .75rem; cursor:pointer; font-size:.88rem; color:var(--text-dim); transition:background .08s; }
.mention-item:hover, .mention-item.selected { background:rgba(53,208,255,.1); color:var(--text); }
.mention-item-av { width:22px; height:22px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.6rem; font-weight:700; flex-shrink:0; overflow:hidden; color:#03101d; }
.mention-item-av img { width:100%; height:100%; object-fit:cover; }
.mention-item-name { font-weight:500; }
.mention-item-tag { font-size:.74rem; color:var(--text-dim); font-family:"IBM Plex Mono",monospace; }

/* ── Category collapse caret ── */
.cat-label { cursor:pointer; user-select:none; }
.cat-caret { transition:transform .15s; flex-shrink:0; }
.cat-caret.collapsed { transform:rotate(-90deg); }

/* ── System message ── */
.msg-system { text-align:center; color:var(--text-dim); font-size:.8rem; padding:4px 16px; font-style:italic; }

/* ── Input area re-layout after reply/attach moved out ── */
.input-area { padding:.5rem 14px 14px; }

/* ── Lightbox flat ── */
.lightbox-img { box-shadow:none; }

/* ── Settings nav in server settings ── */
.srv-settings-nav { background:var(--bg); }

/* ── Compact density support ── */
body.density-compact .msg-row { padding-top:1px; padding-bottom:1px; }
body.density-compact .msg-row.compact { padding-top:0; padding-bottom:0; }

/* ════════════════════════════════════════════
   TYPOGRAPHY — Syne heading system (always on)
   ════════════════════════════════════════════ */

h1, h2, h3, h4 {
  font-family: 'Syne', sans-serif;
  letter-spacing: -.015em;
}

.sb-title {
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  font-size: .96rem;
  letter-spacing: -.01em;
}

.up-name {
  font-family: 'Syne', sans-serif;
  font-size: .86rem;
  font-weight: 700;
  letter-spacing: -.01em;
}

.ws-title {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  letter-spacing: -.025em;
}

.ch-welcome h3 {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  letter-spacing: -.02em;
  font-size: 1.4rem;
}

.modal-card h3 {
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  letter-spacing: -.02em;
  font-size: 1.35rem;
  line-height: 1.15;
}

.create-card h3 {
  font-size: 1.5rem;
  font-weight: 800;
  letter-spacing: -.025em;
  margin-top: .2rem;
}

.disc-head h3 {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  font-size: 1.5rem;
  letter-spacing: -.025em;
}

.srv-name {
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  font-size: .92rem;
  letter-spacing: -.01em;
}

.page-nav h1 {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  font-size: 1.2rem;
  letter-spacing: -.02em;
}

.profile-info .name {
  font-family: 'Syne', sans-serif;
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: -.015em;
}

.sn-head {
  font-size: .63rem;
  letter-spacing: .1em;
  padding: 12px 10px 6px;
  opacity: .7;
}

.settings-page-nav { gap: 1px; }

.sn-btn {
  font-size: .9rem;
  font-weight: 500;
  padding: 7px 12px;
  border-radius: 7px;
  position: relative;
  transition: background .12s, color .12s, padding-left .12s;
}

.sn-btn.active {
  color: var(--text);
  background: rgba(53,208,255,.1);
  padding-left: 16px;
}

.sn-btn.active::before {
  content: '';
  position: absolute;
  left: 5px;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 60%;
  border-radius: 2px;
  background: var(--accent);
}

.s-section h4 {
  font-size: .65rem;
  letter-spacing: .1em;
}

.mem-group-label {
  font-size: .63rem;
  letter-spacing: .1em;
}

.vc-header {
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  letter-spacing: -.01em;
}

.up-pop-name {
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  font-size: .98rem;
  letter-spacing: -.015em;
}

.msg-author {
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  letter-spacing: -.01em;
}

#srvSettingsTitle {
  font-family: 'Syne', sans-serif;
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: -.01em;
  text-transform: none;
  color: var(--text);
  opacity: 1;
  padding: 14px 10px 10px;
}

.f-pill {
  font-family: 'IBM Plex Mono', monospace;
  font-size: .75rem;
  letter-spacing: .03em;
}

.input-wrap { border-radius: 12px; }
.modal-card { border-radius: 1.1rem; }

/* ════════════════════════════════════════════
   APP CHROME REFINEMENT — match login atmosphere
   ════════════════════════════════════════════ */

.rail {
  background: var(--rail-bg);
}

.sidebar {
  background: var(--side-bg);
}

/* Sidebar header — cleaner, matches eyebrow style */
.sb-head {
  background: transparent;
  border-bottom-color: var(--line);
}

/* Chat header — glass-ier, more premium */
.ch-header {
  background: color-mix(in srgb, var(--bg-elev) 85%, transparent 15%);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom-color: var(--line);
}

/* Channel name in the header */
.ch-header-left .ch-name-display,
.ch-header-left > span,
.ch-header-left [class*="name"] {
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  letter-spacing: -.01em;
}

.settings-page-nav {
  background: var(--bg);
}

/* Settings body — let the background glow show through */
.settings-page-body { background: transparent; }

/* User panel — blends into bg */
.user-panel {
  background: color-mix(in srgb, var(--rail-bg) 80%, transparent 20%);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.members {
  background: var(--side-bg);
}

/* ── New message entrance animation ─────────────────────────────── */
.msg-row.msg-new { animation: none; }

/* ── Avatar crop modal ───────────────────────────────────────────── */
.crop-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(3,16,29,.82);
  display: flex; align-items: center; justify-content: center;
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
  animation: crop-in .18s ease;
}
@keyframes crop-in { from { opacity:0; } to { opacity:1; } }
.crop-modal {
  background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: 18px; padding: 28px 24px 24px;
  display: flex; flex-direction: column; align-items: center; gap: 18px;
  box-shadow: 0 24px 64px rgba(0,0,0,.55);
  min-width: 350px;
}
.crop-modal-title {
  font-family: 'Syne', sans-serif; font-weight: 700; font-size: 1.1rem;
  letter-spacing: -.01em; align-self: flex-start;
}
.crop-vp {
  position: relative; width: 300px; height: 300px;
  overflow: hidden; border-radius: 10px;
  background: #000; cursor: grab;
}
.crop-vp.dragging { cursor: grabbing; }
.crop-vp img {
  position: absolute; user-select: none; pointer-events: none;
  will-change: transform;
}
.crop-circle-mask {
  position: absolute; inset: 0; pointer-events: none; z-index: 2;
  border-radius: 50%;
  width: 280px; height: 280px;
  top: 10px; left: 10px;
  box-shadow: 0 0 0 300px rgba(3,16,29,.72);
  border: 2px solid var(--accent);
}
.crop-zoom-row {
  display: flex; align-items: center; gap: 10px; width: 100%;
}
.crop-zoom-icon {
  font-size: 1.1rem; color: var(--muted); font-family: 'IBM Plex Mono', monospace;
  line-height: 1; user-select: none;
}
.crop-zoom-row input[type=range] {
  flex: 1; -webkit-appearance: none; appearance: none;
  height: 4px; border-radius: 2px;
  background: var(--accent);
  outline: none; cursor: pointer;
}
.crop-zoom-row input[type=range]::-webkit-slider-thumb {
  -webkit-appearance: none; width: 16px; height: 16px;
  border-radius: 50%; background: var(--accent);
  border: 2px solid var(--bg-elev);
}
.crop-actions {
  display: flex; gap: 10px; align-self: flex-end;
}

/* ── Banner notifications ─────────────────────────────────────────── */
#forge-banners {
  position: fixed; top: 0; left: 50%; transform: translateX(-50%);
  z-index: 10000; display: flex; flex-direction: column; align-items: center;
  gap: 6px; padding-top: 10px; pointer-events: none; width: 100%;
}
@keyframes banner-in {
  from { opacity: 0; transform: translateY(-18px) scale(.97); }
  to   { opacity: 1; transform: translateY(0)     scale(1); }
}
@keyframes banner-out {
  from { opacity: 1; transform: translateY(0)     scale(1); max-height: 80px; margin-bottom: 0; }
  to   { opacity: 0; transform: translateY(-12px) scale(.96); max-height: 0;   margin-bottom: -6px; }
}
.nx-banner {
  pointer-events: all;
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; border-radius: 12px;
  font-size: .88rem; font-family: 'Space Grotesk', sans-serif;
  border: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 8px 32px rgba(0,0,0,.45);
  max-width: 520px; width: max-content;
  animation: banner-in .25s cubic-bezier(0.22, 1, 0.36, 1) both;
}
.nx-banner-out { animation: banner-out .22s ease forwards; }
body.reduce-motion .nx-banner,
body.reduce-motion .nx-banner-out { animation: none; }

.nx-banner-broadcast {
  background: color-mix(in srgb, var(--bg-elev) 75%, var(--accent) 25%);
  border-color: color-mix(in srgb, var(--accent) 35%, transparent);
}
.nx-banner-mention {
  background: color-mix(in srgb, var(--bg-elev) 75%, #a78bfa 25%);
  border-color: rgba(167,139,250,.35);
}
.nx-banner-friend {
  background: color-mix(in srgb, var(--bg-elev) 75%, #34d399 25%);
  border-color: rgba(52,211,153,.35);
}
.nx-banner-info {
  background: color-mix(in srgb, var(--bg-elev) 80%, #60a5fa 20%);
  border-color: rgba(96,165,250,.3);
}
.nx-banner-icon {
  font-size: 1rem; flex-shrink: 0;
  font-family: 'IBM Plex Mono', monospace; font-weight: 500;
  color: var(--accent);
}
.nx-banner-mention  .nx-banner-icon { color: #a78bfa; }
.nx-banner-friend   .nx-banner-icon { color: #34d399; }
.nx-banner-info     .nx-banner-icon { color: #60a5fa; }
.nx-banner-text { flex: 1; color: var(--text); }
.nx-banner-action {
  padding: 3px 10px; border-radius: 6px; font-size: .78rem; font-weight: 600;
  border: 1px solid rgba(255,255,255,.15); background: rgba(255,255,255,.08);
  color: var(--text); cursor: pointer; flex-shrink: 0;
  transition: background .15s;
}
.nx-banner-action:hover { background: rgba(255,255,255,.16); }
.nx-banner-close {
  background: none; border: none; color: var(--text-dim);
  cursor: pointer; font-size: 1.1rem; line-height: 1; padding: 2px 4px;
  flex-shrink: 0; transition: color .15s;
}
.nx-banner-close:hover { color: var(--text); }

/* ── Admin panel ─────────────────────────────────────────────────── */
.adm-wrap {
  min-height: 100vh; padding: 2rem 2rem 5rem;
  max-width: 1300px; margin: 0 auto;
  display: flex; flex-direction: column; gap: 2rem;
}
.adm-header {
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem;
}
.adm-header-left { display: flex; align-items: center; gap: .75rem; }
.adm-logo { font-family: 'Syne', sans-serif; font-weight: 800; font-size: 1.5rem; color: var(--accent); }
.adm-badge { font-family: 'IBM Plex Mono', monospace; font-size: .68rem; font-weight: 500; padding: 2px 8px; border-radius: 4px; background: rgba(53,208,255,.15); border: 1px solid rgba(53,208,255,.3); color: var(--accent); letter-spacing: .06em; text-transform: uppercase; }
.adm-nav-link { font-size: .85rem; color: var(--text-dim); text-decoration: none; padding: 6px 14px; border-radius: 8px; border: 1px solid var(--border); transition: color .15s, border-color .15s; }
.adm-nav-link:hover { color: var(--text); border-color: var(--accent); }

.adm-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 1rem; }
.adm-stat {
  background: var(--bg-elev); border: 1px solid var(--border); border-radius: 14px;
  padding: 1.2rem 1.4rem; display: flex; flex-direction: column; gap: .3rem;
}
.adm-stat-val { font-family: 'Syne', sans-serif; font-size: 2rem; font-weight: 800; line-height: 1; color: var(--accent); }
.adm-stat-label { font-size: .78rem; color: var(--text-dim); font-family: 'IBM Plex Mono', monospace; text-transform: uppercase; letter-spacing: .06em; }

.adm-card { background: var(--bg-elev); border: 1px solid var(--border); border-radius: 16px; padding: 1.5rem; display: flex; flex-direction: column; gap: 1rem; }
.adm-card-title { font-family: 'Syne', sans-serif; font-weight: 700; font-size: 1rem; }

.adm-broadcast-row { display: flex; gap: .75rem; flex-wrap: wrap; }
.adm-broadcast-row .form-input { flex: 1; min-width: 200px; }
.adm-type-select { padding: .55rem .8rem; border-radius: 10px; border: 1.5px solid var(--border); background: var(--input-bg, var(--bg)); color: var(--text); font-size: .9rem; cursor: pointer; }

.adm-search { width: 100%; max-width: 320px; }
.adm-table-wrap { overflow-x: auto; border-radius: 10px; border: 1px solid var(--border); }
table.adm-table { width: 100%; border-collapse: collapse; font-size: .84rem; }
table.adm-table th { padding: .6rem 1rem; text-align: left; font-family: 'IBM Plex Mono', monospace; font-size: .72rem; text-transform: uppercase; letter-spacing: .06em; color: var(--text-dim); background: var(--bg); border-bottom: 1px solid var(--border); white-space: nowrap; }
table.adm-table td { padding: .65rem 1rem; border-bottom: 1px solid color-mix(in srgb, var(--border) 50%, transparent); vertical-align: middle; }
table.adm-table tr:last-child td { border-bottom: none; }
table.adm-table tr:hover td { background: rgba(53,208,255,.03); }
.adm-user-cell { display: flex; align-items: center; gap: .6rem; }
.adm-av { width: 30px; height: 30px; border-radius: 50%; object-fit: cover; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: .72rem; font-weight: 700; color: #03101d; }
.adm-tag { font-family: 'IBM Plex Mono', monospace; font-size: .75rem; color: var(--text-dim); }
.adm-status-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.adm-num { font-family: 'IBM Plex Mono', monospace; color: var(--text-dim); }
.adm-del-btn { padding: 3px 8px; border-radius: 6px; font-size: .72rem; border: 1px solid var(--danger); color: var(--danger); background: none; cursor: pointer; transition: background .15s; }
.adm-del-btn:hover { background: rgba(248,113,113,.12); }

.adm-actions { display: flex; align-items: center; gap: .3rem; flex-wrap: nowrap; }
.adm-act-btn {
  padding: 3px 8px; border-radius: 6px; font-size: .72rem; font-weight: 600;
  border: 1px solid var(--border); background: none; color: var(--text-dim);
  cursor: pointer; transition: background .15s, color .15s, border-color .15s; white-space: nowrap;
}
.adm-act-btn:hover { background: rgba(255,255,255,.07); color: var(--text); }
.adm-act-dm:hover    { border-color: var(--accent); color: var(--accent); }
.adm-act-mute.active { border-color: #f59e0b; color: #f59e0b; background: rgba(245,158,11,.1); }
.adm-act-ban.active  { border-color: var(--danger); color: var(--danger); background: rgba(248,113,113,.1); }
.adm-act-expand { font-size: .8rem; }

.adm-flag { font-family: 'IBM Plex Mono', monospace; font-size: .6rem; font-weight: 700; padding: 1px 5px; border-radius: 3px; letter-spacing: .05em; vertical-align: middle; }
.adm-flag-ban  { background: rgba(248,113,113,.2); color: #f87171; border: 1px solid rgba(248,113,113,.3); }
.adm-flag-mute { background: rgba(245,158,11,.2);  color: #fbbf24; border: 1px solid rgba(245,158,11,.3); }

.adm-detail-row td { padding: 0; }
.adm-detail {
  display: flex; flex-wrap: wrap; gap: 1.2rem; padding: .8rem 1rem 1rem 3.5rem;
  background: color-mix(in srgb, var(--bg) 60%, var(--accent) 3%);
  border-top: 1px solid var(--border);
}
.adm-detail-col { display: flex; flex-direction: column; gap: .2rem; min-width: 120px; }
.adm-detail-label { font-family: 'IBM Plex Mono', monospace; font-size: .65rem; text-transform: uppercase; letter-spacing: .06em; color: var(--text-dim); }
.adm-detail-val { font-size: .82rem; color: var(--text); }
.adm-badge-chip { font-family: 'IBM Plex Mono', monospace; font-size: .7rem; padding: 1px 6px; border-radius: 4px; background: rgba(53,208,255,.12); border: 1px solid rgba(53,208,255,.2); color: var(--accent); }

/* ── Confirm modal ───────────────────────────────────────────────── */
.confirm-overlay { position:fixed; inset:0; background:rgba(0,0,0,.65); z-index:9000; display:flex; align-items:center; justify-content:center; animation:toast-in .12s ease; }
.confirm-box { background:var(--bg-elev); border:1px solid var(--line); border-radius:1rem; padding:1.75rem 2rem; min-width:320px; max-width:420px; display:flex; flex-direction:column; gap:1rem; box-shadow:0 16px 48px rgba(0,0,0,.6); }
.confirm-title { font-family:'Syne',sans-serif; font-size:1.05rem; font-weight:700; color:var(--text); }
.confirm-msg { font-size:.88rem; color:var(--text-dim); line-height:1.5; }
.confirm-actions { display:flex; gap:.6rem; justify-content:flex-end; }

/* ── Announcement list (admin) ───────────────────────────────────── */
.ann-list { display:flex; flex-direction:column; gap:.5rem; }
.ann-row { display:flex; align-items:center; gap:.75rem; padding:.6rem .85rem; background:var(--bg); border:1px solid var(--line); border-radius:.6rem; font-size:.83rem; }
.ann-badge { font-family:'IBM Plex Mono',monospace; font-size:.62rem; font-weight:700; padding:1px 6px; border-radius:3px; letter-spacing:.04em; flex-shrink:0; }
.ann-badge-perm  { background:rgba(251,191,36,.18); color:#fbbf24; border:1px solid rgba(251,191,36,.3); }
.ann-badge-temp  { background:rgba(53,208,255,.12); color:var(--accent); border:1px solid rgba(53,208,255,.2); }
.ann-type { font-family:'IBM Plex Mono',monospace; font-size:.65rem; color:var(--text-dim); flex-shrink:0; text-transform:uppercase; }
.ann-msg { flex:1; color:var(--text); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.ann-time { font-family:'IBM Plex Mono',monospace; font-size:.65rem; color:var(--text-dim); flex-shrink:0; }
.ann-del { background:none; border:none; color:var(--danger); cursor:pointer; padding:2px 5px; border-radius:4px; font-size:.8rem; opacity:.6; flex-shrink:0; }
.ann-del:hover { opacity:1; background:rgba(248,113,113,.1); }

/* ── Permanent announcements on splash ───────────────────────────── */
.splash-announcements { display:flex; flex-direction:column; gap:.5rem; width:100%; max-width:480px; margin-bottom:.5rem; }
.splash-ann { display:flex; align-items:flex-start; gap:.65rem; padding:.7rem .9rem; background:rgba(53,208,255,.07); border:1px solid rgba(53,208,255,.18); border-radius:.6rem; font-size:.84rem; color:var(--text); position:relative; }
.splash-ann-icon { flex-shrink:0; opacity:.7; }
.splash-ann-text { flex:1; line-height:1.5; }
.splash-ann-close { background:none; border:none; color:var(--text-dim); cursor:pointer; font-size:1rem; padding:0 2px; line-height:1; }
.splash-ann-close:hover { color:var(--text); }

/* ── Announcement modal ──────────────────────────────────────────── */
.ann-modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.72); z-index:9500; display:flex; align-items:center; justify-content:center; padding:1rem; opacity:0; transition:opacity .18s ease; }
.ann-modal-overlay.ann-modal-in { opacity:1; }
.ann-modal { background:var(--bg-elev); border:1px solid var(--line); border-radius:1.1rem; width:100%; max-width:580px; max-height:80vh; display:flex; flex-direction:column; box-shadow:0 24px 64px rgba(0,0,0,.7); transform:translateY(8px); transition:transform .18s ease; overflow:hidden; }
.ann-modal-overlay.ann-modal-in .ann-modal { transform:translateY(0); }
.ann-modal-header { display:flex; align-items:center; justify-content:space-between; padding:.9rem 1.25rem; border-bottom:1px solid var(--line); flex-shrink:0; }
.ann-modal-title { display:flex; align-items:center; gap:.5rem; font-family:'Syne',sans-serif; font-weight:700; font-size:.95rem; color:var(--accent); }
.ann-modal-close { background:none; border:none; color:var(--text-dim); cursor:pointer; padding:4px; border-radius:6px; display:flex; align-items:center; }
.ann-modal-close:hover { background:rgba(255,255,255,.07); color:var(--text); }
.ann-modal-body { flex:1; overflow-y:auto; padding:1.25rem 1.5rem; }
.ann-modal-footer { padding:.9rem 1.25rem; border-top:1px solid var(--line); display:flex; justify-content:flex-end; flex-shrink:0; }

/* ── Markdown body ───────────────────────────────────────────────── */
.md-body { color:var(--text); line-height:1.65; font-size:.9rem; }
.md-body h1 { font-family:'Syne',sans-serif; font-size:1.4rem; font-weight:800; margin:.1rem 0 .6rem; color:var(--text); }
.md-body h2 { font-family:'Syne',sans-serif; font-size:1.1rem; font-weight:700; margin:.8rem 0 .4rem; color:var(--text); }
.md-body h3 { font-size:.95rem; font-weight:700; margin:.6rem 0 .3rem; color:var(--text); }
.md-body p  { margin:.3rem 0 .6rem; }
.md-body strong { color:var(--text); font-weight:700; }
.md-body em { font-style:italic; color:var(--text-dim); }
.md-body a  { color:var(--accent); text-decoration:underline; }
.md-body a:hover { color:var(--accent-2); }
.md-body code { font-family:'IBM Plex Mono',monospace; font-size:.82em; background:rgba(53,208,255,.1); border:1px solid rgba(53,208,255,.15); padding:1px 5px; border-radius:4px; color:var(--accent-2); }
.md-body pre  { background:rgba(0,0,0,.35); border:1px solid var(--line); border-radius:.5rem; padding:.85rem 1rem; overflow-x:auto; margin:.5rem 0; }
.md-body pre code { background:none; border:none; padding:0; color:var(--accent-2); font-size:.83rem; }
.md-body ul, .md-body ol { padding-left:1.4rem; margin:.3rem 0 .6rem; }
.md-body li  { margin:.15rem 0; }
.md-body blockquote { border-left:3px solid var(--accent); margin:.4rem 0; padding:.3rem .85rem; background:rgba(53,208,255,.05); border-radius:0 .4rem .4rem 0; color:var(--text-dim); font-style:italic; }
.md-body hr  { border:none; border-top:1px solid var(--line); margin:.8rem 0; }
.md-body-inline p { display:inline; margin:0; }

/* ── Broadcast form redesign ─────────────────────────────────────── */
.ann-display-seg { display:flex; gap:.4rem; background:rgba(0,0,0,.3); border:1px solid var(--line); border-radius:.6rem; padding:3px; width:fit-content; }
.ann-seg-btn { display:flex; align-items:center; gap:.4rem; padding:.4rem .9rem; border-radius:.45rem; border:none; background:none; color:var(--text-dim); font-family:'Space Grotesk',sans-serif; font-size:.83rem; font-weight:500; cursor:pointer; transition:background .1s, color .1s; }
.ann-seg-btn:hover { background:rgba(255,255,255,.06); color:var(--text); }
.ann-seg-btn.active { background:var(--accent); color:#03101d; font-weight:700; }

.ann-editor-wrap { display:flex; flex-direction:column; border:1px solid var(--line); border-radius:.7rem; overflow:hidden; }
.ann-editor-tabs { display:flex; align-items:center; gap:0; background:rgba(0,0,0,.25); border-bottom:1px solid var(--line); padding:.3rem .5rem .3rem; gap:.25rem; }
.ann-editor-tab { padding:.25rem .7rem; border-radius:.35rem; border:none; background:none; color:var(--text-dim); font-family:'Space Grotesk',sans-serif; font-size:.8rem; cursor:pointer; }
.ann-editor-tab.active { background:rgba(53,208,255,.13); color:var(--accent); font-weight:600; }
.ann-textarea { width:100%; min-height:140px; background:var(--bg); border:none; resize:vertical; color:var(--text); font-family:'IBM Plex Mono',monospace; font-size:.84rem; padding:.85rem 1rem; outline:none; box-sizing:border-box; line-height:1.6; }
.ann-textarea::placeholder { color:var(--text-dim); }
.ann-preview { padding:.85rem 1rem; min-height:100px; background:var(--bg); }

.ann-send-row { display:flex; align-items:center; gap:1rem; flex-wrap:wrap; }
.ann-perm-label { display:flex; align-items:center; gap:.45rem; cursor:pointer; font-size:.84rem; color:var(--text-dim); flex:1; }
.ann-perm-label input { flex-shrink:0; }

/* ── Announcement badge variants ─────────────────────────────────── */
.ann-badge-modal { background:rgba(125,246,199,.15); color:var(--accent-2); border:1px solid rgba(125,246,199,.25); }
.ann-badge-notif { background:rgba(53,208,255,.12); color:var(--accent); border:1px solid rgba(53,208,255,.2); }

/* ── Notification Bell ───────────────────────────────────────────── */
#notifBellWrap { position:fixed; top:12px; right:16px; z-index:7500; }

#notifBellBtn { position:relative; width:36px; height:36px; border-radius:50%; background:var(--bg-elev); border:1px solid var(--line); color:var(--text-dim); display:flex; align-items:center; justify-content:center; cursor:pointer; transition:background .1s, color .1s, border-color .1s; }
#notifBellBtn:hover, #notifBellBtn.active { background:rgba(53,208,255,.12); color:var(--accent); border-color:rgba(53,208,255,.3); }

#notifBadge { position:absolute; top:-4px; right:-4px; background:var(--danger); color:#fff; border-radius:999px; font-size:.6rem; font-weight:700; min-width:16px; height:16px; display:flex; align-items:center; justify-content:center; padding:0 3px; line-height:1; border:2px solid var(--bg); }

.notif-panel { position:absolute; top:calc(100% + 8px); right:0; width:320px; background:var(--bg-elev); border:1px solid var(--line); border-radius:.85rem; box-shadow:0 12px 40px rgba(0,0,0,.5); overflow:hidden; animation:toast-in .12s ease; }
.notif-panel-header { padding:.7rem 1rem; border-bottom:1px solid var(--line); font-family:'Syne',sans-serif; font-weight:700; font-size:.88rem; color:var(--text); display:flex; align-items:center; gap:.5rem; }
.notif-panel-header::before { content:''; display:block; width:7px; height:7px; border-radius:50%; background:var(--accent); }
.notif-panel-list { max-height:360px; overflow-y:auto; }

.notif-empty { padding:1.5rem 1rem; text-align:center; color:var(--text-dim); font-size:.83rem; }

.notif-item { padding:.7rem 1rem; border-bottom:1px solid color-mix(in srgb, var(--line) 60%, transparent); cursor:pointer; transition:background .08s; }
.notif-item:last-child { border-bottom:none; }
.notif-item:hover { background:rgba(53,208,255,.06); }
.notif-item.notif-unread { background:rgba(53,208,255,.04); }

.notif-item-top { display:flex; align-items:center; gap:.4rem; margin-bottom:.3rem; }
.notif-dot { width:7px; height:7px; border-radius:50%; background:var(--accent); flex-shrink:0; }
.notif-time { font-family:'IBM Plex Mono',monospace; font-size:.65rem; color:var(--text-dim); margin-left:auto; }
.notif-preview { font-size:.82rem; color:var(--text-dim); line-height:1.45; overflow:hidden; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; }
.notif-item:hover .notif-preview { color:var(--text); }

.notif-dtype-badge { font-family:'IBM Plex Mono',monospace; font-size:.6rem; font-weight:700; padding:1px 5px; border-radius:3px; letter-spacing:.04em; }
.notif-dtype-notification { background:rgba(53,208,255,.12); color:var(--accent); border:1px solid rgba(53,208,255,.2); }
.notif-dtype-modal { background:rgba(125,246,199,.12); color:var(--accent-2); border:1px solid rgba(125,246,199,.2); }

/* ── Server custom HTML area ─────────────────────────────────────── */
.srv-custom-html { border-bottom:1px solid var(--line); max-height:240px; overflow-y:auto; }
.srv-custom-html:empty { display:none; }
/* HTML injection zones */
.srv-zone { display:block; }
.srv-zone:empty { display:none; }
.srv-zone-header { border-bottom:1px solid var(--line); }
.srv-zone-header:empty { display:none; border:none; }
/* overlay zone — sits behind messages (z-index:0), messages paint above via DOM order */
.srv-zone-overlay { position:absolute; inset:0; pointer-events:none; z-index:0; overflow:hidden; }
.srv-zone-overlay:empty { display:none; }
.srv-zone-input { border-top:1px solid var(--line); }
.srv-zone-input:empty { display:none; border:none; }
/* msg-list is a positioned stacking context so srv-zone-overlay is relative to it */
.msg-list  { position:relative; }
.ch-header { position:relative; z-index:2; }
.input-area, .typing-bar, .reply-bar { position:relative; z-index:1; }
/* Zone editor blocks in settings */
.zone-block { margin-bottom:1rem; }
.zone-block-hdr { display:flex; flex-direction:column; gap:.15rem; margin-bottom:.4rem; }
.zone-block-label { font-size:.82rem; font-weight:700; color:var(--text); }
.zone-block-desc { font-size:.72rem; color:var(--text-dim); }

/* ── Custom Style settings tab ───────────────────────────────────── */
.style-editor-seg { display:flex; gap:.35rem; background:rgba(0,0,0,.3); border:1px solid var(--line); border-radius:.55rem; padding:3px; width:fit-content; margin-bottom:.6rem; }
.style-seg-btn { display:flex; align-items:center; gap:.35rem; padding:.3rem .8rem; border-radius:.35rem; border:none; background:none; color:var(--text-dim); font-family:'Space Grotesk',sans-serif; font-size:.82rem; font-weight:500; cursor:pointer; transition:background .1s, color .1s; }
.style-seg-btn:hover { background:rgba(255,255,255,.06); color:var(--text); }
.style-seg-btn.active { background:var(--accent); color:#03101d; font-weight:700; }

.style-editor-hint { font-size:.78rem; color:var(--text-dim); margin-bottom:.5rem; min-height:1.1em; }

.style-editor-outer { border:1px solid var(--line); border-radius:.6rem; overflow:hidden; margin-bottom:.75rem; }
.srv-code-editor { width:100%; min-height:260px; background:#050812; border:none; resize:vertical; color:#7df6c7; font-family:'IBM Plex Mono',monospace; font-size:.82rem; padding:.85rem 1rem; outline:none; box-sizing:border-box; line-height:1.65; tab-size:2; }
.srv-code-editor::placeholder { color:rgba(125,246,199,.3); }
.srv-code-editor[readonly] { opacity:.5; cursor:not-allowed; }

.style-editor-actions { display:flex; gap:.6rem; justify-content:flex-end; }
.sn-btn-style { margin-top:auto; border-top:1px solid var(--line); border-radius:0; }
.style-guide-link { display:flex; align-items:center; gap:.5rem; padding:.55rem .85rem; margin-bottom:.85rem; background:rgba(53,208,255,.06); border:1px solid rgba(53,208,255,.18); border-radius:.55rem; color:var(--accent); font-size:.82rem; font-weight:500; text-decoration:none; transition:background .15s, border-color .15s; }
.style-guide-link:hover { background:rgba(53,208,255,.12); border-color:rgba(53,208,255,.35); }

/* ── Full Custom Mode reset ──────────────────────────────────────── */
body.srv-full-custom,
body.srv-full-custom .app { background:#000 !important; }
/* Kill all background glows, gradients and canvas */
body.srv-full-custom::before,
body.srv-full-custom::after { display:none !important; }
body.srv-full-custom #gridCanvas { opacity:0 !important; pointer-events:none !important; }
/* Kill the orb/line SVG in the message area */
body.srv-full-custom #mainGridSvg { display:none !important; }
/* Server rail — solid black, no gradient, no accent bleed */
body.srv-full-custom .rail { background:#000 !important; border-right:none !important; box-shadow:none !important; }
body.srv-full-custom #serverRail { background:transparent !important; }
body.srv-full-custom .ri { background:rgba(255,255,255,.08) !important; border-color:rgba(255,255,255,.1) !important; color:rgba(255,255,255,.5) !important; box-shadow:none !important; }
body.srv-full-custom .ri:hover { background:rgba(255,255,255,.15) !important; border-color:rgba(255,255,255,.2) !important; color:#fff !important; border-radius:35% !important; }
body.srv-full-custom .ri.active { background:rgba(255,255,255,.18) !important; border-color:rgba(255,255,255,.25) !important; color:#fff !important; border-radius:35% !important; }
body.srv-full-custom .ri.home { background:rgba(255,255,255,.12) !important; border-color:rgba(255,255,255,.2) !important; color:#fff !important; }
body.srv-full-custom .ri.add { background:transparent !important; border-color:rgba(255,255,255,.15) !important; color:rgba(255,255,255,.4) !important; }
body.srv-full-custom .ri::before { background:#fff !important; }
body.srv-full-custom .rail-div { background:rgba(255,255,255,.08) !important; }
/* Sidebar / channel list */
body.srv-full-custom .sidebar,
body.srv-full-custom .sb-head,
body.srv-full-custom #channelList { background:#000 !important; border-right:none !important; border-bottom:none !important; box-shadow:none !important; }
body.srv-full-custom .sb-title { color:rgba(255,255,255,.7) !important; }
body.srv-full-custom .cat-label { color:rgba(255,255,255,.2) !important; background:none !important; }
body.srv-full-custom .ch-btn { background:transparent !important; color:rgba(255,255,255,.4) !important; border-radius:0 !important; }
body.srv-full-custom .ch-btn:hover { background:rgba(255,255,255,.05) !important; color:rgba(255,255,255,.9) !important; }
body.srv-full-custom .ch-btn.active { background:rgba(255,255,255,.08) !important; color:#fff !important; }
/* Main / messages */
body.srv-full-custom .main { background:#000 !important; }
body.srv-full-custom .ch-header { background:#000 !important; border-bottom:none !important; box-shadow:none !important; backdrop-filter:none !important; }
body.srv-full-custom .hdr-btn { color:rgba(255,255,255,.45) !important; }
body.srv-full-custom .msg-list { background:#000 !important; }
body.srv-full-custom .msg-row { background:transparent !important; border:none !important; box-shadow:none !important; }
body.srv-full-custom .msg-row:hover { background:rgba(255,255,255,.02) !important; }
body.srv-full-custom .msg-author { color:rgba(255,255,255,.85) !important; }
body.srv-full-custom .msg-time { color:rgba(255,255,255,.22) !important; }
body.srv-full-custom .msg-text { color:rgba(255,255,255,.78) !important; }
/* Input area */
body.srv-full-custom .ch-input-wrap { background:#000 !important; border-top:none !important; box-shadow:none !important; }
body.srv-full-custom .ch-input-bar { background:rgba(255,255,255,.05) !important; border:1px solid rgba(255,255,255,.08) !important; color:#fff !important; box-shadow:none !important; }
body.srv-full-custom .ch-input-bar::placeholder { color:rgba(255,255,255,.25) !important; }
body.srv-full-custom .typing-bar { background:transparent !important; }
/* Member list */
body.srv-full-custom .members { background:#000 !important; border-left:none !important; box-shadow:none !important; }
body.srv-full-custom .mem-group-label { color:rgba(255,255,255,.2) !important; }
body.srv-full-custom .mem-item { color:rgba(255,255,255,.5) !important; }
body.srv-full-custom .mem-item:hover { background:rgba(255,255,255,.05) !important; color:#fff !important; }
/* Custom HTML strip */
body.srv-full-custom .srv-custom-html { border-bottom:none !important; }

/* ── Style settings tab extras ───────────────────────────────────── */
.style-mode-card { display:flex; align-items:center; gap:1rem; padding:.9rem 1.1rem; background:rgba(53,208,255,.05); border:1px solid var(--line); border-radius:.75rem; margin-bottom:1rem; transition:border-color .2s, background .2s; }
.style-mode-card.active { background:rgba(53,208,255,.09); border-color:rgba(53,208,255,.3); }
.style-mode-info { flex:1; }
.style-mode-title { font-weight:700; font-size:.88rem; margin-bottom:.15rem; }
.style-mode-sub { font-size:.78rem; color:var(--text-dim); line-height:1.4; }

.asset-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:.6rem; margin-top:.75rem; }
.asset-item { background:var(--bg); border:1px solid var(--line); border-radius:.5rem; overflow:hidden; display:flex; flex-direction:column; }
.asset-item img { width:100%; height:90px; object-fit:cover; display:block; }
.asset-url { font-family:'IBM Plex Mono',monospace; font-size:.6rem; color:var(--text-dim); padding:.3rem .4rem; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.asset-copy { margin:.3rem .4rem .4rem; padding:.25rem; border-radius:.35rem; border:1px solid var(--line); background:none; color:var(--text-dim); font-size:.72rem; cursor:pointer; }
.asset-copy:hover { background:rgba(53,208,255,.1); color:var(--accent); border-color:rgba(53,208,255,.3); }


/* ══════════════════════════════════════════════
   TASK 1 — Message search highlight (msg-highlight)
   ══════════════════════════════════════════════ */
.msg-row.msg-highlight {
  background: rgba(255, 255, 255, 0.06);
  transition: background 2s ease;
}

/* ══════════════════════════════════════════════
   TASK 2 — Emoji picker expanded + positioned
   ══════════════════════════════════════════════ */
/* The picker now pops up above the input area, anchored to the button */
#emojiPicker {
  position: fixed;
  bottom: 80px;
  /* left is set dynamically by JS; fallback: */
  left: auto;
  right: 80px;
  width: 300px;
}
.emoji-grid {
  grid-template-columns: repeat(6, 1fr);
  max-height: 240px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--line) transparent;
}
.emoji-grid::-webkit-scrollbar { width: 3px; }
.emoji-grid::-webkit-scrollbar-thumb { background: var(--line); border-radius: 2px; }

/* ══════════════════════════════════════════════
   TASK 3 — Message hover actions are already fixed above
   (opacity transition added to .msg-actions)
   ══════════════════════════════════════════════ */

/* ══════════════════════════════════════════════
   TASK 5 — Member profile popover
   ══════════════════════════════════════════════ */
/* .member-profile-popover replaced by .pcard — see above */

/* ══════════════════════════════════════════════
   TASK 6 — Mention dot on channel with unread @
   ══════════════════════════════════════════════ */
.ch-btn.mention-unread::after {
  background: #a78bfa;
  width: 8px; height: 8px;
}
.ch-btn.mention-unread {
  color: var(--text);
}

/* ══════════════════════════════════════════════
   TASK 7 — Mobile layout improvements
   ══════════════════════════════════════════════ */
@media (max-width: 768px) {
  /* Hide server rail on mobile — accessed via a toggle if needed */
  .rail { display: none; }

  /* Hide member list on mobile */
  .members { display: none !important; }
  :root { --mem-w: 0px; }

  /* Sidebar is hidden by default on mobile; shown when toggled */
  .sidebar {
    position: fixed;
    top: 0; left: 0; bottom: 0;
    z-index: 700;
    transform: translateX(-100%);
    transition: transform .22s ease;
    width: var(--side-w);
    /* Show it when body has class */
  }
  body.mobile-sidebar-open .sidebar {
    transform: translateX(0);
  }

  /* Mobile sidebar backdrop */
  body.mobile-sidebar-open::after {
    content: '';
    position: fixed;
    inset: 0;
    z-index: 699;
    background: rgba(0,0,0,.55);
  }

  /* Main content takes full width */
  .main { width: 100%; }

  /* Prevent message input from being hidden behind virtual keyboard */
  .input-area {
    padding-bottom: env(safe-area-inset-bottom, 14px);
  }

  /* Channel header buttons — smaller tap targets are fine, but add min-size */
  .hdr-btn { width: 38px; height: 38px; }

  /* Make message rows a bit more touch-friendly */
  .msg-row { padding: 5px 12px; }

  /* Emoji picker: full-width on mobile */
  #emojiPicker {
    left: 8px !important;
    right: 8px !important;
    width: auto;
    bottom: 70px;
  }

  /* Profile card — full-width on mobile */
  #profileCard, .member-profile-popover {
    width: calc(100vw - 32px);
    left: 16px !important;
    right: 16px !important;
  }

  /* Notification bell — keep it accessible */
  #notifBellWrap { right: 8px; top: 8px; }

  /* Pins panel — full-width on mobile */
  .pins-panel { width: 100vw; }
}

/* Mobile sidebar toggle button (shown only on mobile) */
.mobile-menu-btn {
  display: none;
  width: 36px; height: 36px;
  border-radius: 8px; border: none;
  background: none; color: var(--text-dim);
  align-items: center; justify-content: center;
  cursor: pointer; flex-shrink: 0;
  transition: color .12s, background .12s;
}
.mobile-menu-btn:hover { color: var(--text); background: var(--hover); }
@media (max-width: 768px) {
  .mobile-menu-btn { display: flex; }
}

/* ── Server description in sidebar ── */
.sb-desc {
  font-size: .72rem;
  color: var(--text-dim);
  line-height: 1.4;
  padding: 4px 14px 6px;
  border-bottom: 1px solid var(--line);
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  flex-shrink: 0;
}

/* ── Scroll-to-bottom button ── */
#scrollToBottomBtn {
  position: absolute;
  bottom: 8px;
  right: 16px;
  z-index: 10;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 20px;
  color: var(--text);
  font-size: .78rem;
  padding: 5px 12px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 5px;
  font-family: "Space Grotesk", sans-serif;
  transition: border-color .15s;
}
#scrollToBottomBtn:hover { border-color: var(--accent); color: var(--accent); }
