/* /chat-e2e/chat-e2e.css — Diaspora.ro Chat E2E v2
 * Stil business — între WhatsApp și Telegram.
 * Font Inter (corp), JetBrains Mono (cod / cifre), suport temă light/dark.
 * --------------------------------------------------------------------- */

:root, [data-theme="dark"] {
  --bg:           #0b141a;
  --bg-2:         #111b21;
  --bg-3:         #202c33;
  --bg-4:         #2a3942;
  --hdr:          linear-gradient(180deg,#1f2c33 0%,#172127 100%);
  --txt:          #e9edef;
  --txt-2:        #aebac1;
  --txt-3:        #8696a0;
  --border:       rgba(255,255,255,.08);
  --border-2:     rgba(255,255,255,.14);
  --bubble-in:    #202c33;
  --bubble-out:   #005c4b;
  --accent:       #00a884;
  --accent-2:     #008f6e;
  --accent-soft:  rgba(0,168,132,.18);
  --danger:       #ef4444;
  --warn:         #f4b400;
  --link:         #53bdeb;
  --shadow-1:     0 1px 0.5px rgba(0,0,0,.13);
  --shadow-2:     0 8px 24px rgba(0,0,0,.55);
}
[data-theme="light"] {
  --bg:           #efeae2;
  --bg-2:         #f0f2f5;
  --bg-3:         #ffffff;
  --bg-4:         #f5f6f6;
  --hdr:          linear-gradient(180deg,#f0f2f5 0%,#e9eaee 100%);
  --txt:          #111b21;
  --txt-2:        #54656f;
  --txt-3:        #667781;
  --border:       rgba(11,20,26,.08);
  --border-2:     rgba(11,20,26,.14);
  --bubble-in:    #ffffff;
  --bubble-out:   #d9fdd3;
  --accent:       #00a884;
  --accent-2:     #008f6e;
  --accent-soft:  rgba(0,168,132,.16);
  --danger:       #c0392b;
  --warn:         #b88200;
  --link:         #027eb5;
  --shadow-1:     0 1px 1px rgba(11,20,26,.06);
  --shadow-2:     0 8px 24px rgba(11,20,26,.18);
}
[data-theme="light"] .ce-bubble.out { color:#111b21; }
[data-theme="light"] .ce-bubble.in  { color:#111b21; }

* { box-sizing: border-box; margin: 0; padding: 0; -webkit-tap-highlight-color: transparent; }
html, body { height: 100%; }
body.ce-body{
  font-family: 'Inter', -apple-system, 'Segoe UI', system-ui, Roboto, sans-serif;
  font-feature-settings: 'cv02','cv03','cv04','cv11';
  letter-spacing: -.005em;
  color: var(--txt); background: var(--bg);
  overflow: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  user-select: none;
}
input, textarea { user-select: text; }
.hidden { display: none; }
button { font: inherit; cursor: pointer; }
code, .mono { font-family: 'JetBrains Mono', 'SF Mono', Monaco, monospace; }

/* SCREENS */
.ce-screen{
  position: fixed; inset: 0;
  display: flex; flex-direction: column;
  background: var(--bg);
  padding-top: env(safe-area-inset-top);
  padding-bottom: env(safe-area-inset-bottom);
}

/* ============ LOBBY ============ */
.ce-lobby{
  align-items: center; justify-content: center;
  background:
    radial-gradient(ellipse at 20% -20%, #1f3a5f 0%, transparent 50%),
    radial-gradient(ellipse at 80% 110%, #0a3d2e 0%, transparent 50%),
    var(--bg);
  padding: 24px;
}
.ce-lobby-back{
  position: absolute; top: calc(14px + env(safe-area-inset-top)); left: 14px;
  width: 42px; height: 42px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.08); color:#fff;
  border-radius: 50%; text-decoration: none;
  border: 1px solid rgba(255,255,255,.10);
  transition: .15s;
}
.ce-lobby-back:hover{ background: rgba(255,255,255,.16); }
.ce-lobby-card{
  width: 100%; max-width: 420px;
  background: rgba(17,27,33,.85);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 22px;
  padding: 30px 24px;
  box-shadow: var(--shadow-2);
  backdrop-filter: blur(10px);
}
.ce-lobby-logo{ font-size: 46px; text-align: center; margin-bottom: 6px; }
.ce-lobby-card h1{
  font-size: 28px; font-weight: 800; text-align: center;
  letter-spacing: -.025em; color:#fff; margin-bottom: 8px;
}
.ce-lobby-sub{
  text-align: center; font-size: 14px; color:#aab8c2;
  line-height: 1.55; margin-bottom: 22px;
}
.ce-lobby-sub b{ color: var(--accent); font-weight: 700; }
.ce-field{ display: block; margin-bottom: 14px; }
.ce-field span{
  display: block; font-size: 12px; color:#8696a0;
  margin-bottom: 6px; text-transform: uppercase; letter-spacing: .06em; font-weight: 600;
}
.ce-field input{
  width: 100%; padding: 14px 14px;
  background: rgba(255,255,255,.05);
  border: 1.5px solid rgba(255,255,255,.10);
  border-radius: 12px;
  color:#fff; font-size: 16px; font-weight: 500;
  font-family: inherit;
  outline: none; transition: .15s;
}
.ce-field input:focus{ border-color: var(--accent); background: var(--accent-soft); }
#ce-code{ text-align:center; font-family:'JetBrains Mono',monospace; letter-spacing: 14px; font-size: 24px; }

.ce-btn{
  display: flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%; padding: 14px 16px;
  border: 0; border-radius: 12px;
  font-size: 15px; font-weight: 700;
  margin-bottom: 12px;
  transition: .18s;
  font-family: inherit; letter-spacing: -.01em;
}
.ce-btn-primary{
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff;
  box-shadow: 0 6px 20px rgba(0,168,132,.32);
}
.ce-btn-primary:active{ transform: scale(.98); }
.ce-btn-secondary{
  background: rgba(255,255,255,.06); color:#fff;
  border: 1px solid rgba(255,255,255,.14);
}
.ce-btn-secondary:active{ background: rgba(255,255,255,.12); }
.ce-divider{
  display:flex; align-items:center; gap:10px;
  margin: 18px 0 14px; color:#586a73; font-size:11px; text-transform: uppercase; letter-spacing:.08em;
}
.ce-divider::before, .ce-divider::after{
  content:''; flex:1; height:1px; background: rgba(255,255,255,.10);
}
.ce-warn{
  margin-top: 14px; padding: 10px 12px;
  background: rgba(244,180,0,.08);
  border: 1px solid rgba(244,180,0,.22);
  border-radius: 10px;
  font-size: 12.5px; color: var(--warn); line-height: 1.5;
}
.ce-lobby-foot{
  position: absolute; bottom: calc(12px + env(safe-area-inset-bottom));
  font-size: 11px; color:#56707d; letter-spacing:.06em;
}

/* ============ ROOM HEADER ============ */
.ce-room{ background: var(--bg); }
.ce-hdr{
  display: flex; align-items: center; gap: 4px;
  padding: 6px 6px;
  background: var(--hdr);
  border-bottom: 1px solid var(--border);
  position: relative; z-index: 5;
  min-height: 56px;
}
.ce-icon-btn{
  width: 40px; height: 40px;
  display: inline-flex; align-items: center; justify-content: center;
  background: transparent; border: 0; border-radius: 50%;
  color: var(--txt-2); transition: .12s;
}
.ce-icon-btn:hover{ background: rgba(127,127,127,.12); color: var(--txt); }
.ce-icon-btn:active{ background: rgba(127,127,127,.20); }
.ce-hdr-info{ flex:1; min-width:0; padding: 0 4px; }
.ce-hdr-title{ font-size: 15px; font-weight: 600; color: var(--txt); display:flex; align-items:center; gap:6px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; letter-spacing:-.01em; }
.ce-hdr-title b{ font-family:'JetBrains Mono',monospace; letter-spacing:2px; color: var(--txt); font-weight:700; }
.ce-hdr-lock{ font-size: 13px; opacity: .8; }
.ce-hdr-sub{ font-size: 12px; color: var(--txt-3); margin-top: 1px; font-weight: 500; }
#ce-hdr-timer{ font-family:'JetBrains Mono',monospace; }
.ce-hdr-host{ color: var(--accent); font-weight:600; }

/* MENU */
.ce-menu{
  position: absolute; right: 8px; top: 56px;
  background: var(--bg-3); border:1px solid var(--border);
  border-radius: 10px; padding: 6px;
  box-shadow: var(--shadow-2);
  z-index: 30; min-width: 264px;
}
.ce-menu button{
  display:block; width:100%; text-align:left;
  background: transparent; border:0; color: var(--txt);
  padding: 11px 14px; font-size: 14px; border-radius: 7px;
  transition: .12s; font-weight: 500;
}
.ce-menu button:hover{ background: rgba(127,127,127,.10); }
.ce-menu button.danger{ color: var(--danger); }

/* SEARCH BAR */
.ce-searchbar{
  display:flex; align-items:center; gap:10px;
  padding: 8px 12px;
  background: var(--bg-3);
  border-bottom: 1px solid var(--border);
}
.ce-searchbar input{
  flex:1; background: var(--bg-4); border:1px solid var(--border);
  color: var(--txt); padding: 8px 12px;
  border-radius: 20px; outline: none; font-size: 14px; font-family: inherit;
}
.ce-searchbar input:focus{ border-color: var(--accent); }
#ce-search-count{ font-size:12px; color: var(--txt-3); min-width: 24px; text-align:center; }
#ce-search-close{ background: transparent; border:0; color: var(--txt-2); font-size:18px; padding: 4px 8px; }

/* PEERS */
.ce-peers{
  display: flex; gap: 8px; overflow-x: auto;
  padding: 8px 12px;
  background: var(--bg-2);
  border-bottom: 1px solid var(--border);
  scrollbar-width: none;
}
.ce-peers::-webkit-scrollbar{ display:none; }
.ce-peer-chip{
  display:flex; align-items:center; gap:6px;
  padding: 5px 10px;
  background: rgba(127,127,127,.10);
  border-radius: 999px;
  font-size: 12px; color: var(--txt-2); white-space: nowrap; font-weight: 500;
}
.ce-peer-chip .dot{ width:8px; height:8px; border-radius:50%; background: var(--accent); }
.ce-peer-chip.me{ background: linear-gradient(135deg, var(--accent), var(--accent-2)); color:#fff; }
.ce-peer-chip.me .dot{ background:#fff; }
.ce-peer-chip.host::after{ content:'★'; margin-left: 2px; color: var(--warn); }

/* MESSAGES */
.ce-msgs{
  flex: 1;
  overflow-y: auto;
  padding: 12px 8px 16px;
  background:
    repeating-linear-gradient(45deg, rgba(127,127,127,.012) 0 2px, transparent 2px 6px),
    var(--bg);
  display: flex; flex-direction: column; gap: 4px;
  scroll-behavior: smooth;
}
.ce-day-divider{
  align-self: center;
  background: var(--bg-3); color: var(--txt-3);
  font-size: 12px; font-weight: 600;
  padding: 5px 14px; border-radius: 8px;
  margin: 4px 0 8px;
  text-transform: capitalize;
  box-shadow: var(--shadow-1);
}
.ce-system-msg{
  align-self: center; max-width: 92%;
  background: var(--bg-3); color: var(--txt-2);
  font-size: 12.5px; padding: 8px 14px;
  border-radius: 8px; margin: 4px 0; text-align: center;
  border: 1px solid var(--accent-soft);
  font-weight: 500;
}

/* ── Card de securitate (afișat la intrare) ── */
.ce-security-card{
  align-self: center; max-width: 560px; width: calc(100% - 16px);
  background: linear-gradient(180deg, rgba(0,168,132,.10), rgba(0,168,132,.04));
  border: 1px solid rgba(0,168,132,.30);
  border-radius: 16px;
  padding: 16px 18px; margin: 6px 0 14px;
  box-shadow: var(--shadow-1);
}
.ce-sec-head{ display:flex; align-items:center; gap:10px; margin-bottom: 10px; }
.ce-sec-shield{ font-size: 20px; }
.ce-sec-head h3{ font-size: 15px; font-weight: 700; color: var(--txt); letter-spacing:-.01em; }
.ce-sec-list{ list-style: none; padding: 0; margin: 0; }
.ce-sec-list li{
  position: relative; padding: 5px 0 5px 20px;
  font-size: 13px; line-height: 1.55; color: var(--txt-2);
}
.ce-sec-list li::before{
  content: '✓'; position: absolute; left: 0; top: 5px;
  color: var(--accent); font-weight: 700;
}
.ce-sec-list li b{ color: var(--txt); font-weight: 700; }
.ce-sec-note{
  margin-top: 10px; padding-top: 10px;
  border-top: 1px dashed var(--border-2);
  font-size: 12px; color: var(--txt-3); line-height: 1.55;
}

/* BUBBLES */
.ce-bubble{
  max-width: 75%;
  padding: 7px 10px 5px;
  border-radius: 8px;
  position: relative;
  word-wrap: break-word;
  box-shadow: var(--shadow-1);
  font-size: 14.5px; line-height: 1.4;
  animation: ce-bubble-in .15s ease-out;
  color: var(--txt);
  cursor: default;
}
@keyframes ce-bubble-in { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

.ce-bubble.in{ align-self: flex-start; background: var(--bubble-in); border-top-left-radius: 0; }
.ce-bubble.out{ align-self: flex-end; background: var(--bubble-out); border-top-right-radius: 0; }
.ce-bubble.highlight{ outline: 2px solid var(--warn); outline-offset: 2px; }
.ce-bubble.search-hit{ background: rgba(244,180,0,.20); }
.ce-bubble .author{ font-size: 12px; font-weight: 700; color: var(--accent); margin-bottom: 2px; display:block; }
.ce-bubble.out .author{ display:none; }
.ce-bubble .meta{
  display:inline-block; float:right; margin-left: 8px;
  font-size: 10.5px; color: var(--txt-3);
  position: relative; top: 4px; font-family:'JetBrains Mono',monospace;
}
.ce-bubble .text{ white-space: pre-wrap; }
.ce-bubble img.attach{ max-width: 100%; max-height: 320px; border-radius: 6px; display:block; margin-bottom: 4px; }

/* Reply quote */
.ce-bubble .quote{
  display:block; padding: 6px 10px; margin: 0 0 6px;
  background: rgba(0,0,0,.18);
  border-left: 3px solid var(--accent);
  border-radius: 6px;
  font-size: 12.5px; color: var(--txt-2);
  cursor: pointer;
}
.ce-bubble .quote b{ color: var(--accent); display:block; font-size:12px; margin-bottom: 2px; }
.ce-bubble .quote span{ display:block; max-height: 36px; overflow:hidden; text-overflow:ellipsis; }

/* Reactions on bubble */
.ce-reactions{
  position: absolute; bottom: -10px; right: 8px;
  display: flex; gap: 2px;
  background: var(--bg-3); border: 1px solid var(--border);
  border-radius: 999px; padding: 2px 6px;
  font-size: 12px; box-shadow: var(--shadow-1);
}
.ce-bubble.out .ce-reactions{ left: 8px; right: auto; }
.ce-reactions .r{ display:inline-flex; align-items:center; gap:1px; }
.ce-reactions .n{ font-size: 10px; color: var(--txt-3); margin-left: 1px; }

/* AUDIO */
.ce-audio{
  display:flex; align-items:center; gap:10px;
  min-width: 220px; max-width: 300px;
}
.ce-audio button{
  width:36px; height:36px; border-radius:50%;
  background: var(--accent); color:#fff;
  border:0; font-size: 18px;
  display:flex; align-items:center; justify-content:center;
  flex-shrink: 0;
}
.ce-audio .wav{ flex:1; display:flex; align-items:center; gap:2px; height: 28px; }
.ce-audio .wav i{
  flex:1; max-width: 3px;
  background: rgba(255,255,255,.45); border-radius: 2px;
  display:block;
}
[data-theme="light"] .ce-audio .wav i{ background: rgba(0,0,0,.35); }
.ce-audio .dur{ font-size: 11px; color: var(--txt-3); min-width: 32px; text-align:right; font-family:'JetBrains Mono',monospace; }

.ce-typing{
  align-self: flex-start;
  background: var(--bg-3);
  padding: 8px 12px;
  margin: 0 8px 4px;
  border-radius: 8px;
  display: flex; align-items: center; gap: 4px;
  font-size: 12px; color: var(--txt-3); font-weight: 500;
}
.ce-typing span{ width: 6px; height: 6px; border-radius: 50%; background: var(--accent); animation: ce-typing 1.2s infinite; }
.ce-typing span:nth-child(2){ animation-delay: .2s; }
.ce-typing span:nth-child(3){ animation-delay: .4s; }
@keyframes ce-typing { 0%,80%,100% { opacity: .3; transform: scale(.8); } 40% { opacity: 1; transform: scale(1); } }

/* REPLY BAR */
.ce-reply{
  background: var(--bg-3);
  border-top: 1px solid var(--border);
}
.ce-reply-bar{
  display:flex; align-items: center; gap: 12px;
  padding: 8px 14px;
  border-left: 3px solid var(--accent);
}
.ce-reply-info{ flex:1; min-width: 0; font-size: 13px; }
.ce-reply-author{ display:block; font-weight:700; color: var(--accent); font-size:12px; margin-bottom:2px; }
.ce-reply-text{ display:block; color: var(--txt-2); white-space: nowrap; overflow:hidden; text-overflow: ellipsis; }
#ce-reply-close{ background: transparent; border:0; color: var(--txt-2); font-size: 18px; padding: 4px 8px; }

/* EMOJI */
.ce-emoji{
  background: var(--bg-3); border-top: 1px solid var(--border);
  padding: 10px;
  display: grid; grid-template-columns: repeat(8, 1fr); gap: 4px;
  max-height: 220px; overflow-y: auto;
}
.ce-emoji button{
  background: transparent; border: 0;
  font-size: 22px; padding: 4px;
  border-radius: 6px;
}
.ce-emoji button:hover{ background: rgba(127,127,127,.10); }

/* COMPOSER */
.ce-composer{
  display: flex; align-items: flex-end; gap: 4px;
  padding: 8px 6px;
  background: var(--bg-3);
  border-top: 1px solid var(--border);
}
.ce-comp-btn{
  width: 42px; height: 42px;
  border-radius: 50%;
  background: transparent;
  border: 0; color: var(--txt-2);
  font-size: 22px;
  display:inline-flex; align-items:center; justify-content:center;
  flex-shrink: 0;
}
.ce-comp-btn:hover{ background: rgba(127,127,127,.10); color: var(--txt); }
.ce-comp-input-wrap{
  flex: 1;
  background: var(--bg-4);
  border-radius: 22px;
  padding: 8px 14px;
  min-height: 42px; max-height: 140px;
  display: flex; align-items: center;
}
#ce-input{
  width: 100%;
  background: transparent;
  border: 0; outline: 0; resize: none;
  color: var(--txt); font-size: 15px; line-height: 1.4;
  font-family: inherit;
  max-height: 120px;
}
#ce-input::placeholder{ color: var(--txt-3); }
.ce-comp-mic, .ce-comp-send{
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color:#fff;
  box-shadow: 0 4px 12px rgba(0,168,132,.30);
}
.ce-comp-mic:hover, .ce-comp-send:hover{ filter: brightness(1.08); color:#fff; }
.ce-comp-mic:active{ transform: scale(.94); }

/* RECORD */
.ce-recbar{
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px;
  background: var(--bg-3);
  border-top: 1px solid var(--border);
}
.ce-rec-cancel{
  width: 40px; height: 40px; border-radius: 50%;
  background: rgba(239,68,68,.18); color: var(--danger);
  border: 0; font-size: 18px;
}
.ce-rec-wave{
  flex:1; display:flex; align-items:center; gap:8px;
  color: var(--danger); font-weight: 600; font-size: 14px;
  font-family:'JetBrains Mono',monospace;
}
.ce-rec-dot{
  width:10px; height:10px; border-radius:50%;
  background: var(--danger); animation: ce-blink 1s infinite;
}
@keyframes ce-blink { 50% { opacity: .25; } }
.ce-rec-voice{
  display:flex; flex-direction: column; align-items:center; gap:2px;
  font-size: 10px; color: var(--txt-3);
}
.ce-rec-voice span{ text-transform: uppercase; letter-spacing: .04em; font-weight: 600; }
#ce-rec-voice{
  background: var(--bg-4); color: var(--txt);
  border:1px solid var(--border);
  padding:4px 8px; border-radius:8px;
  font-size: 12px; font-family: inherit;
}
.ce-rec-send{
  width: 44px; height: 44px; border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color:#fff; border:0; font-size: 18px;
  box-shadow: 0 4px 12px rgba(0,168,132,.32);
}

/* MSG CONTEXT MENU + REACTION BAR */
.ce-msgctx{
  position: fixed; z-index: 60;
  background: var(--bg-3); border:1px solid var(--border);
  border-radius: 10px; padding: 6px;
  box-shadow: var(--shadow-2); min-width: 200px;
}
.ce-msgctx button{
  display:block; width:100%; text-align:left;
  background: transparent; border:0; color: var(--txt);
  padding: 10px 12px; font-size: 14px; border-radius: 6px;
}
.ce-msgctx button:hover{ background: rgba(127,127,127,.10); }
.ce-msgctx button.danger{ color: var(--danger); }

.ce-reactbar{
  position: fixed; z-index: 61;
  display: flex; gap: 4px;
  background: var(--bg-3); border:1px solid var(--border);
  border-radius: 999px; padding: 6px 10px;
  box-shadow: var(--shadow-2);
}
.ce-reactbar button{
  background: transparent; border: 0; font-size: 22px; padding: 2px 4px;
  border-radius: 50%;
  transition: transform .12s;
}
.ce-reactbar button:hover{ transform: scale(1.25); }

/* VIDEO CALL */
.ce-call{ background: #000; }
.ce-call-hdr{
  display:flex; justify-content: space-between; align-items: center;
  padding: 12px 16px; color:#fff;
  background: rgba(0,0,0,.55);
  font-size: 14px; font-weight: 600;
}
.ce-call-title b{ font-family:'JetBrains Mono',monospace; letter-spacing: 2px; }
#ce-call-count{
  background: var(--accent); padding: 3px 10px; border-radius: 999px;
  font-weight: 700; font-size: 12px;
}
.ce-call-grid{
  flex: 1;
  display: grid; gap: 4px; padding: 4px;
  grid-template-columns: 1fr;
}
.ce-call-grid[data-n="2"]{ grid-template-columns: 1fr 1fr; }
.ce-call-grid[data-n="3"], .ce-call-grid[data-n="4"]{ grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; }
.ce-call-grid[data-n="5"], .ce-call-grid[data-n="6"]{ grid-template-columns: 1fr 1fr 1fr; grid-template-rows: 1fr 1fr; }
.ce-call-grid[data-n="7"], .ce-call-grid[data-n="8"], .ce-call-grid[data-n="9"], .ce-call-grid[data-n="10"]{
  grid-template-columns: repeat(3, 1fr); grid-template-rows: repeat(4, 1fr);
}
.ce-call-tile{
  position: relative;
  background: #1a1a1a;
  border-radius: 8px;
  overflow: hidden;
}
.ce-call-tile video{ width:100%; height:100%; object-fit: cover; background:#000; }
.ce-call-tile .label{
  position:absolute; bottom: 6px; left: 6px;
  background: rgba(0,0,0,.6); color:#fff;
  padding: 2px 8px; border-radius: 6px;
  font-size: 11px; font-weight: 600;
}
.ce-call-tile .mute-ico{
  position:absolute; top:6px; right:6px;
  background:rgba(239,68,68,.85); color:#fff;
  width:22px; height:22px; border-radius:50%;
  display:none; align-items:center; justify-content:center;
  font-size:12px;
}
.ce-call-tile.muted .mute-ico{ display:flex; }
.ce-call-bar{
  display:flex; justify-content: center; gap: 12px;
  padding: 16px;
  background: rgba(0,0,0,.7);
}
.ce-call-btn{
  width: 54px; height: 54px;
  border-radius: 50%;
  border: 0;
  background: rgba(255,255,255,.10);
  color:#fff; font-size: 22px;
  transition: .15s;
}
.ce-call-btn:hover{ background: rgba(255,255,255,.18); }
.ce-call-btn.off{ background: rgba(239,68,68,.85); }
.ce-call-btn.on{ background: rgba(0,168,132,.85); }
.ce-call-end{ background: var(--danger); box-shadow: 0 6px 18px rgba(239,68,68,.45); }

/* MODAL */
.ce-modal{
  position: fixed; inset: 0; z-index: 100;
  background: rgba(0,0,0,.65);
  display: flex; align-items: center; justify-content: center;
  padding: 20px; backdrop-filter: blur(6px);
}
.ce-modal-box{
  background: var(--bg-3); color: var(--txt);
  border-radius: 16px; padding: 24px 22px;
  max-width: 380px; width: 100%;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-2);
  position: relative; text-align: center;
}
.ce-modal-x{
  position: absolute; top: 8px; right: 8px;
  background: transparent; border: 0; color: var(--txt-2);
  font-size: 18px; padding: 8px;
}
.ce-modal-box h3{ font-size: 17px; font-weight: 700; margin-bottom: 6px; letter-spacing:-.01em; }
.ce-modal-sub{ font-size: 13px; color: var(--txt-3); margin-bottom: 14px; line-height:1.5; }
.ce-modal-code{
  font-family:'JetBrains Mono',monospace; font-size: 26px; font-weight: 700;
  letter-spacing: 8px; margin-top: 14px; color: var(--accent);
}
#ce-qr-canvas{ display:flex; justify-content: center; padding: 12px; background:#fff; border-radius: 12px; }

/* TOAST */
.ce-toast{
  position: fixed; bottom: 90px; left: 50%; transform: translateX(-50%);
  background: rgba(0,0,0,.85); color:#fff;
  padding: 10px 18px; border-radius: 22px;
  font-size: 13px; font-weight: 500;
  z-index: 9999;
  border: 1px solid rgba(255,255,255,.10);
  max-width: 90vw; text-align: center;
  animation: ce-toast-in .2s ease-out;
}
@keyframes ce-toast-in { from { opacity: 0; transform: translate(-50%, 8px); } to { opacity: 1; transform: translate(-50%, 0); } }

/* MOBILE */
@media (max-width: 520px){
  .ce-emoji{ grid-template-columns: repeat(7, 1fr); max-height: 180px; }
}

/* SCROLLBARS */
.ce-msgs::-webkit-scrollbar, .ce-emoji::-webkit-scrollbar{ width: 6px; }
.ce-msgs::-webkit-scrollbar-thumb, .ce-emoji::-webkit-scrollbar-thumb{ background: rgba(127,127,127,.20); border-radius: 3px; }
