*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{--g:linear-gradient(135deg,#6a11cb,#a855f7 40%,#ec4899 70%,#3b82f6);--pu:#7c3aed;--pk:#ec4899;--tx:#1e1b4b;--gr:#6b7280}
html,body{height:100%;height:-webkit-fill-available;overflow:hidden;font-family:'Nunito',sans-serif;background:#f0f4ff;color:var(--tx)}

/* AUTH */
.auth-screen{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--g);padding:16px;overflow-y:auto}
.auth-card{background:#fff;border-radius:24px;padding:36px 28px;width:100%;max-width:400px;text-align:center;box-shadow:0 20px 60px rgba(100,60,200,.25)}
.auth-logo{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:14px}
.auth-logo img{width:52px;height:52px;border-radius:12px;object-fit:contain}
.auth-logo span{font-size:2rem;font-weight:800;background:var(--g);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
h1{font-size:1.4rem;font-weight:800;margin-bottom:18px}
.tabs{display:flex;background:#f3f0ff;border-radius:12px;padding:3px;margin-bottom:16px;gap:3px}
.tab{flex:1;padding:9px;border:none;background:none;border-radius:9px;font-family:'Nunito',sans-serif;font-weight:700;font-size:.9rem;color:var(--gr);cursor:pointer;touch-action:manipulation}
.tab.active{background:var(--g);color:#fff}
.inp{width:100%;padding:12px 15px;border:2px solid #e8e0ff;border-radius:12px;font-family:'Nunito',sans-serif;font-size:.93rem;margin-bottom:10px;outline:none;background:#faf9ff;display:block;-webkit-appearance:none}
.inp:focus{border-color:var(--pu)}
.btn-main{width:100%;padding:12px;background:var(--g);color:#fff;border:none;border-radius:12px;font-family:'Nunito',sans-serif;font-size:.95rem;font-weight:700;cursor:pointer;touch-action:manipulation;-webkit-appearance:none}
.auth-err{color:#ef4444;font-size:.83rem;margin-top:8px;min-height:16px}

/* APP */
.app{display:flex;position:fixed;inset:0;overflow:hidden;height:100%;height:-webkit-fill-available}

/* SIDEBAR */
.sidebar{width:400px;min-width:400px;background:#fff;border-right:1px solid #ede9fe;display:flex;flex-direction:column;height:100%;overflow:hidden;transition:transform .25s;z-index:20;flex-shrink:0}
.sb-head{background:var(--g);padding:14px;flex-shrink:0}
.sb-logo{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.sb-logo img{width:30px;height:30px;border-radius:8px;object-fit:contain}
.sb-logo span{font-size:1.1rem;font-weight:800;color:#fff}
.sb-user{display:flex;align-items:center;gap:8px}
.sb-ava{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.3);border:2px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;font-size:.95rem;flex-shrink:0;overflow:hidden;cursor:pointer;position:relative;transition:.2s}
.sb-ava:hover{border-color:#fff;transform:scale(1.05)}
.sb-ava-edit{position:absolute;inset:0;background:rgba(0,0,0,.45);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;opacity:0;transition:.2s}
.sb-ava:hover .sb-ava-edit{opacity:1}
#sbName{color:#fff;font-weight:700;font-size:.88rem;cursor:pointer;line-height:1.3}

.sb-profile-hint{font-size:.72rem;color:#fff;font-weight:700;opacity:1;margin-top:2px;display:block}
.btn-new{margin:10px;padding:11px;background:var(--g);color:#fff;border:none;border-radius:11px;font-family:'Nunito',sans-serif;font-weight:700;font-size:.9rem;cursor:pointer;flex-shrink:0;touch-action:manipulation;-webkit-appearance:none;width:calc(100% - 20px)}
.rooms{flex:1;overflow-y:auto;padding:6px;-webkit-overflow-scrolling:touch}
.rooms::-webkit-scrollbar{width:3px}
.rooms::-webkit-scrollbar-thumb{background:#d8b4fe;border-radius:3px}
.room-item{display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:11px;cursor:pointer;margin-bottom:2px;touch-action:manipulation;user-select:none;-webkit-user-select:none}
.room-item:active,.room-item.active{background:linear-gradient(135deg,#ede9fe,#fce7f3)}
.r-ava{width:40px;height:40px;border-radius:50%;background:var(--g);display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;flex-shrink:0;font-size:.95rem;overflow:hidden}
.r-info{flex:1;min-width:0}
.r-name{font-weight:700;font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.r-sub{font-size:.75rem;color:var(--gr)}
.r-side{display:flex;align-items:center;gap:4px;flex-shrink:0}
.udot{width:8px;height:8px;border-radius:50%;background:var(--pk);flex-shrink:0}
.r-del{background:none;border:none;font-size:.85rem;cursor:pointer;padding:4px;opacity:.35;border-radius:6px;touch-action:manipulation}
.room-item:active .r-del{opacity:1}
.btn-logout{margin:6px 10px 10px;padding:10px;background:#fef2f2;color:#ef4444;border:none;border-radius:10px;font-family:'Nunito',sans-serif;font-weight:700;cursor:pointer;flex-shrink:0;touch-action:manipulation}

/* ONLINE */
.gdot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#22c55e;box-shadow:0 0 4px #22c55e;vertical-align:middle;flex-shrink:0}

/* CHAT */
.chat{flex:1;display:flex;flex-direction:column;background:#f8f6ff;overflow:hidden;min-width:0}
.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#aaa}
.chat-head{padding:12px 14px;background:#fff;border-bottom:1px solid #ede9fe;display:flex;align-items:center;gap:10px;flex-shrink:0;min-height:56px}
.btn-back{display:none;background:none;border:none;font-size:1.5rem;color:var(--pu);cursor:pointer;padding:4px 8px;touch-action:manipulation;flex-shrink:0;line-height:1}
.ch-ava{width:38px;height:38px;border-radius:50%;background:var(--g);display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;flex-shrink:0;font-size:.9rem;overflow:hidden}
.ch-name{font-weight:800;font-size:.93rem;cursor:pointer}
.ch-name:hover{color:var(--pu)}
.ch-sub{font-size:.76rem;color:var(--gr);display:flex;align-items:center;gap:4px;margin-top:1px}

/* MESSAGES */
.msgs{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:6px;-webkit-overflow-scrolling:touch}
.msgs::-webkit-scrollbar{width:3px}
.msgs::-webkit-scrollbar-thumb{background:#d8b4fe;border-radius:3px}

/* TYPING */
.typing-row{padding:4px 14px 6px;display:flex;align-items:center;gap:8px;flex-shrink:0}
.typing-bub{background:#fff;border-radius:16px;padding:7px 11px;display:flex;align-items:center;gap:3px;box-shadow:0 1px 4px rgba(0,0,0,.08)}
.td{width:6px;height:6px;border-radius:50%;background:#a855f7;display:inline-block;animation:tdot 1.2s infinite}
.td:nth-child(2){animation-delay:.2s}.td:nth-child(3){animation-delay:.4s}
@keyframes tdot{0%,80%,100%{transform:scale(.55);opacity:.4}40%{transform:scale(1);opacity:1}}
#typingLabel{font-size:.8rem;color:var(--gr);font-style:italic}

/* MSG */
.mwrap{display:flex;flex-direction:column;max-width:74%;margin-bottom:5px;gap:0}
.mwrap.mine{align-self:flex-end;align-items:flex-end}
.mwrap.theirs{align-self:flex-start;align-items:flex-start}
.msender{font-size:.74rem;font-weight:700;color:var(--pu);margin-bottom:3px;padding:0 3px;cursor:pointer}
.msender:hover{opacity:.8}
.rprev{border-left:3px solid var(--pu);background:#ede9fe;border-radius:8px;padding:4px 9px;margin-bottom:4px;font-size:.78rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:220px}
.mine .rprev{background:rgba(255,255,255,.22);border-left-color:rgba(255,255,255,.8)}
.mbub{padding:9px 13px;border-radius:18px;font-size:.9rem;line-height:1.5;word-break:break-word;box-shadow:0 1px 4px rgba(0,0,0,.07)}
.mine .mbub{background:var(--g);color:#fff;border-bottom-right-radius:4px}
.theirs .mbub{background:#fff;color:var(--tx);border-bottom-left-radius:4px;border:1px solid #ede9fe}
.mtime{font-size:.68rem;color:var(--gr);margin-top:3px;padding:0 3px;display:block}
.mine .mtime{color:#374151}
.theirs .mtime{color:var(--gr)}

/* REPLY BTN */
.rbtn{background:#f3f0ff;border:none;font-size:.85rem;color:var(--pu);cursor:pointer;padding:6px 14px;border-radius:20px;margin-top:5px;opacity:.9;touch-action:manipulation;font-weight:700;font-family:'Nunito',sans-serif}
.rbtn:active{background:#ede9fe;transform:scale(.95)}

/* STAMPS */
.stamps{display:flex;gap:4px;margin-top:4px;width:fit-content;transition:opacity .15s,height .15s}
.stamps-hidden{opacity:0;pointer-events:none}

.stamp{background:#f3f0ff;border:2px solid #e8e0ff;border-radius:18px;padding:3px 8px;font-size:.9rem;cursor:pointer;touch-action:manipulation;-webkit-appearance:none;line-height:1.3;transition:.15s}
.stamp:hover{background:#f3f0ff;transform:scale(1.2)}
.stamp:active{transform:scale(1.1)}
.stamp.on{background:linear-gradient(135deg,#ede9fe,#fce7f3)}
.rcnts{display:flex;gap:3px;flex-wrap:wrap;margin-top:2px;min-height:0;padding:0}
.rpill{background:#f3f0ff;border:1px solid #e8e0ff;border-radius:14px;padding:3px 9px;font-size:.82rem;cursor:pointer}
.rpill:active{background:#ede9fe}

/* MEDIA */
.mimg{max-width:220px;max-height:220px;border-radius:11px;cursor:pointer;object-fit:cover;display:block}
.mvid-wrap{position:relative;width:100%;max-width:320px;border-radius:11px;overflow:hidden;background:#000}
.mvid{width:100%;max-height:480px;border-radius:11px;display:block;object-fit:contain;background:#000}
.maud{width:100%;max-width:220px;height:32px;margin-top:4px}
.dl{position:absolute;bottom:5px;right:5px;background:rgba(0,0,0,.5);color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.75rem;text-decoration:none}
/* Карточка файла */
.file-card{display:flex;align-items:flex-start;gap:10px;padding:8px 10px;border-radius:12px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);min-width:200px;max-width:260px}
.file-card-mine{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.3)}
.theirs .file-card{background:#f3f0ff;border-color:#e8e0ff}
.file-card-icon{font-size:1.6rem;flex-shrink:0;line-height:1;margin-top:2px}
.file-card-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}
.file-card-name{font-size:.78rem;font-weight:700;word-break:break-all;line-height:1.3;opacity:.95}
.file-card-dl{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;font-weight:700;text-decoration:none;padding:4px 10px;border-radius:20px;margin-top:2px;width:fit-content;transition:.15s;background:rgba(255,255,255,.25);color:inherit}
.file-card-dl:hover{background:rgba(255,255,255,.4)}
.theirs .file-card-dl{background:#ede9fe;color:#7c3aed}
.theirs .file-card-dl:hover{background:#ddd6fe}

/* INPUT */
.inp-area{background:#fff;border-top:1px solid #ede9fe;padding:7px 9px 9px;flex-shrink:0}
.reply-bar{padding:6px 10px;background:#ede9fe;border-radius:9px;margin-bottom:5px;display:flex;align-items:center;gap:8px;border-left:3px solid var(--pu)}
.reply-text{font-size:.8rem;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.reply-x{background:none;border:none;color:#aaa;cursor:pointer;font-size:.9rem;touch-action:manipulation}
.file-prev{padding:6px 10px;background:#f3f0ff;border-radius:9px;margin-bottom:5px;display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:.8rem}
.file-prev span{color:var(--pu);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.file-prev button{background:none;border:none;color:#ef4444;cursor:pointer;touch-action:manipulation}
.voice-ind{text-align:center;font-size:.8rem;font-weight:700;color:#ef4444;margin-bottom:5px}
.inp-row{display:flex;align-items:center;gap:5px}
.ic-btn{width:42px;height:42px;min-width:42px;border-radius:50%;background:#f3f0ff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--pu);flex-shrink:0;touch-action:manipulation;-webkit-appearance:none}
.ic-btn:active{background:#ede9fe}
.ic-btn.rec{background:#fecdd3;color:#ef4444;animation:pulse 1s infinite}
@keyframes pulse{50%{transform:scale(1.1)}}
.msg-inp{flex:1;min-width:0;padding:10px 13px;border:2px solid #e8e0ff;border-radius:20px;font-family:'Nunito',sans-serif;font-size:.9rem;outline:none;background:#faf9ff;-webkit-appearance:none}
.msg-inp:focus{border-color:var(--pu)}
.btn-send{width:42px;height:42px;min-width:42px;border-radius:50%;background:var(--g);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;flex-shrink:0;touch-action:manipulation;-webkit-appearance:none;box-shadow:0 2px 8px rgba(120,60,200,.3)}
.btn-send:active{transform:scale(.9)}

/* MODAL */
.modal{position:fixed;inset:0;background:rgba(10,5,40,.55);display:flex;align-items:center;justify-content:center;z-index:100;padding:14px;backdrop-filter:blur(3px)}
.modal-box{background:#fff;border-radius:20px;padding:20px;width:100%;max-width:400px;position:relative;max-height:88vh;overflow-y:auto;-webkit-overflow-scrolling:touch}
.modal-box h2{font-size:1.1rem;font-weight:800;margin-bottom:12px}
.modal-x{position:absolute;top:12px;right:12px;background:#f3f0ff;border:none;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:.85rem;display:flex;align-items:center;justify-content:center;color:var(--gr);touch-action:manipulation}
.hint{font-size:.82rem;color:var(--gr);margin-bottom:6px}
.ulist{display:flex;flex-direction:column;gap:4px;max-height:50vh;overflow-y:auto;-webkit-overflow-scrolling:touch}
.u-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;cursor:pointer;border:2px solid transparent;touch-action:manipulation}
.u-item:active,.u-item.selected{background:#f3f0ff;border-color:var(--pu)}
.u-ava{width:34px;height:34px;border-radius:50%;background:var(--g);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:.85rem;flex-shrink:0;overflow:hidden}
.u-nm{font-weight:700;flex:1;font-size:.9rem}
.del-user-btn{background:none;border:none;color:#ef4444;cursor:pointer;padding:4px 8px;border-radius:8px;font-size:.9rem;touch-action:manipulation}
.del-user-btn:active{background:#fef2f2}

.mtime-row{display:flex;align-items:center;gap:6px;margin-top:2px;padding:0 3px}
.mtime-row .mtime{padding:0}
.msg-status{font-size:.65rem;opacity:.85;white-space:nowrap}
.mine .msg-status{color:rgba(255,255,255,.5)}
.bub-row{display:flex;flex-direction:row;align-items:flex-end;gap:4px;max-width:100%}
.mine .bub-row{flex-direction:row-reverse}
.rcnts-inline{display:flex;align-items:flex-end;padding-bottom:2px}
/* DATE SEPARATOR */
.date-sep{display:flex;align-items:center;gap:10px;margin:10px 0;color:#aaa;font-size:.75rem;font-weight:600}
.date-sep::before,.date-sep::after{content:'';flex:1;height:1px;background:#e8e0ff}
.date-sep span{white-space:nowrap;padding:0 4px}

/* UNREAD BADGE */
.unread-badge{background:#ef4444;color:#fff;border-radius:12px;min-width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;padding:0 6px;letter-spacing:.2px;box-shadow:0 1px 4px rgba(239,68,68,.35);flex-shrink:0}
.has-unread{background:rgba(237,233,254,.45)}
.msg-checks{font-size:.75rem;margin-left:4px;flex-shrink:0;color:#374151}
.mtime-row{display:flex;align-items:center;gap:2px;margin-top:2px;padding:0 3px}
.mtime-row .mtime{padding:0}

/* NEW MSG BUTTON */
.new-msg-btn{position:absolute;bottom:80px;left:50%;transform:translateX(-50%);background:var(--g);color:#fff;border:none;border-radius:20px;padding:8px 16px;font-family:'Nunito',sans-serif;font-weight:700;font-size:.85rem;cursor:pointer;box-shadow:0 4px 12px rgba(100,60,200,.35);z-index:50;white-space:nowrap;animation:fadeInUp .2s ease}
@keyframes fadeInUp{from{opacity:0;transform:translateX(-50%) translateY(10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.new-msg-btn:active{transform:translateX(-50%) scale(.95)}

/* VIEWER */
.viewer{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:200;display:flex;align-items:center;justify-content:center;cursor:zoom-out}
.viewer img,.viewer video{max-width:96vw;max-height:96vh;border-radius:10px;object-fit:contain}

/* ══ MOBILE ══ */
@media(max-width:700px){
  .sidebar{position:fixed;inset:0;width:100%;min-width:unset;z-index:20}
  .sidebar.sb-hidden{transform:translateX(-100%)}
  .chat{position:fixed;inset:0;width:100%;display:none;z-index:10}
  .chat.chat-open{display:flex}
  .btn-back{display:flex!important}
  .mwrap{max-width:90%}
  .mimg{max-width:180px;max-height:180px}
  .mvid-wrap{max-width:85vw}
  .mvid{max-height:60vw}
  .r-del{opacity:.35}
  .rbtn{opacity:.9}
  .stamp{padding:6px 12px;font-size:1.1rem}
  .inp-area{position:sticky;bottom:0;z-index:5}
  .msgs{padding-bottom:8px}
  .chat,.sidebar{max-width:100vw;overflow-x:hidden}
}
.dl-inline{color:inherit;text-decoration:none;flex-shrink:0;opacity:.65;font-size:.95rem;padding:2px 5px;border-radius:6px;transition:.15s}
.dl-inline:hover{opacity:1;background:rgba(0,0,0,.08)}
.mine .dl-inline{color:#fff}

/* ─── BOUNCE LETTERS ─── */
@keyframes letterBounce {
  0%,100%{transform:translateY(0)}
  40%{transform:translateY(-8px)}
  60%{transform:translateY(-4px)}
}
.bounce-letter{display:inline-block;animation:letterBounce .6s ease infinite}

/* ─── МЕДИАГАЛЕРЕЯ ─── */
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;max-height:60vh;overflow-y:auto;padding:4px}
.gal-cell{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden;cursor:pointer;background:#f3f0ff}
.gal-cell img,.gal-cell video{width:100%;height:100%;object-fit:cover;transition:.2s}
.gal-cell:hover img,.gal-cell:hover video{opacity:.85;transform:scale(1.04)}
.gal-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:1.8rem;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.5)}
.gal-files{max-height:60vh;overflow-y:auto;display:flex;flex-direction:column;gap:6px;padding:4px}
.gal-file-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;background:#f8f5ff;border:1px solid #ede9fe}
.gal-file-icon{font-size:1.4rem;flex-shrink:0}
.gal-file-name{flex:1;font-size:.82rem;font-weight:700;word-break:break-all}

/* Кнопки в просмотрщике */
#viewerBack,#viewerClose{position:fixed;top:16px;background:rgba(255,255,255,.15);color:#fff;border:none;border-radius:20px;padding:7px 16px;font-size:.9rem;font-weight:700;cursor:pointer;z-index:201;backdrop-filter:blur(8px);transition:.15s}
#viewerBack{left:16px;display:flex;align-items:center;gap:6px}
#viewerClose{right:16px}
#viewerBack:hover,#viewerClose:hover{background:rgba(255,255,255,.3)}
.gal-dl-btn{position:absolute;top:6px;right:6px;background:rgba(0,0,0,.55);color:#fff;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:.8rem;text-decoration:none;opacity:0;transition:.2s;z-index:3}
.gal-cell:hover .gal-dl-btn{opacity:1}

/* ─── КНОПКА ТЕМЫ ─── */
.btn-theme{background:rgba(255,255,255,.2);border:none;border-radius:50%;width:30px;height:30px;font-size:1rem;cursor:pointer;margin-left:auto;flex-shrink:0;transition:.2s;display:flex;align-items:center;justify-content:center}
.btn-theme:hover{background:rgba(255,255,255,.35)}

/* ─── ПЕЧАТАЕТ В СПИСКЕ ─── */
.rsub-typing{display:inline-flex;align-items:center;gap:4px;color:var(--pu);font-size:.72rem;font-weight:700}
.rsub-typing .td{width:4px;height:4px;border-radius:50%;background:var(--pu);display:inline-block;animation:tdot .9s infinite}
.rsub-typing .td:nth-child(2){animation-delay:.2s}
.rsub-typing .td:nth-child(3){animation-delay:.4s}

/* ─── ТЁМНАЯ ТЕМА ─── */
body.dark{background:#0f0f13}
body.dark .sidebar{background:#1a1a24;border-color:#2d2d40}
body.dark .room-item{color:#e2e0ff}
body.dark .room-item:hover{background:#25253a}
body.dark .room-item.active{background:#2d2b4e}
body.dark .r-sub{color:#8884aa}
body.dark .chat{background:#13131c}
body.dark .msgs{background:#13131c}
body.dark .mbub{background:#23233a;color:#e8e6ff}
body.dark .chat-head{background:#1a1a24;border-color:#2d2d40}
body.dark .ch-name{color:#e8e6ff}
body.dark .ch-sub{color:#8884aa}
body.dark .inp-area{background:#1a1a24;border-color:#2d2d40}
body.dark .msg-inp{background:#25253a;color:#e8e6ff;border-color:#3d3d55}
body.dark .msg-inp::placeholder{color:#6664aa}
body.dark .modal-box{background:#1e1e2e;color:#e8e6ff}
body.dark .inp{background:#25253a;color:#e8e6ff;border-color:#3d3d55}
body.dark .inp::placeholder{color:#6664aa}
body.dark .date-sep{color:#6664aa}
body.dark .date-sep::before,.dark .date-sep::after{background:#2d2d40}
body.dark .typing-row{background:#1a1a24}
body.dark .rprev{background:#25253a;border-color:#3d3d55;color:#b8b4dd}
body.dark .reply-bar{background:#1e1e2e;border-color:#3d3d55}
body.dark .file-card{background:#25253a;border-color:#3d3d55}
body.dark .file-card-name{color:#e8e6ff}
body.dark .has-unread{background:#20203a}
body.dark .chat-empty{color:#6664aa}
body.dark .theirs .mbub{background:#23233a;color:#e8e6ff}
body.dark .btn-logout{background:#2d2d40;color:#f87171}
