:root,:root[data-theme=dark]{--bg: #0b1220;--panel: #131b2e;--panel-2: #1a2540;--text: #e7ecf3;--muted: #8b96ad;--primary: #4f8cff;--primary-2: #2563eb;--bubble-me: #2563eb;--bubble-me-text: #ffffff;--bubble-them: #1f2a44;--bubble-them-text: #e7ecf3;--bubble-deleted: #2a2a3a;--danger: #ef4444;--ok: #10b981;--border: #1f2a44;--shadow: 0 8px 30px rgba(0,0,0,.4);--overlay: rgba(0,0,0,.55);--menu-bg: #1a2540}:root[data-theme=light]{--bg: #f5f7fb;--panel: #ffffff;--panel-2: #f0f3f8;--text: #0f172a;--muted: #64748b;--primary: #2563eb;--primary-2: #1d4ed8;--bubble-me: #2563eb;--bubble-me-text: #ffffff;--bubble-them: #e9eef7;--bubble-them-text: #0f172a;--bubble-deleted: #e2e8f0;--danger: #dc2626;--ok: #16a34a;--border: #e2e8f0;--shadow: 0 10px 25px rgba(15,23,42,.12);--overlay: rgba(15,23,42,.45);--menu-bg: #ffffff}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);overscroll-behavior:none;-webkit-tap-highlight-color:transparent}.login-wrap{min-height:100dvh;display:grid;place-items:center;padding:24px}.login-card{width:100%;max-width:360px;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:var(--shadow)}.login-card h1{margin:0 0 16px;font-size:22px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.field label{font-size:12px;color:var(--muted)}.field input{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:12px 14px;border-radius:10px;font-size:16px;outline:none}.field input:focus{border-color:var(--primary)}.btn{background:var(--primary);color:#fff;border:0;padding:12px 16px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer}.btn:disabled{opacity:.6;cursor:not-allowed}.btn.danger{background:var(--danger)}.btn-ghost{background:transparent;color:var(--muted);border:0;padding:6px 10px;border-radius:8px;cursor:pointer;font-size:14px}.btn-ghost:hover{color:var(--text);background:var(--panel-2)}.btn-ghost.icon{font-size:18px;padding:4px 8px}.err{color:var(--danger);font-size:13px;margin-top:6px}.chat{display:grid;grid-template-rows:auto 1fr auto;height:100dvh;max-width:720px;margin:0 auto;background:var(--bg)}.header{display:flex;align-items:center;gap:10px;padding:10px 12px;padding-top:max(10px,env(safe-area-inset-top));background:var(--panel);border-bottom:1px solid var(--border)}.avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#4f8cff,#8b5cf6);display:grid;place-items:center;font-weight:700;color:#fff}.header .name{font-weight:600}.header .status{font-size:12px;color:var(--muted)}.header .spacer{flex:1}.theme-select{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:6px 8px;font-size:13px}.messages{overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:6px;scroll-behavior:smooth}.day{text-align:center;color:var(--muted);font-size:12px;margin:8px 0}.msg-row{display:flex}.msg-row.me{justify-content:flex-end}.bubble{max-width:78%;padding:8px 12px;border-radius:16px;position:relative;word-wrap:break-word;white-space:pre-wrap;line-height:1.35;transition:background .25s,box-shadow .25s}.bubble.me{background:var(--bubble-me);color:var(--bubble-me-text);border-bottom-right-radius:4px}.bubble.them{background:var(--bubble-them);color:var(--bubble-them-text);border-bottom-left-radius:4px}.bubble.deleted{background:var(--bubble-deleted);color:var(--muted);font-style:italic}.bubble.failed{outline:1px dashed var(--danger)}.bubble.flash,.msg-row.flash .bubble{box-shadow:0 0 0 3px #4f8cff80}.bubble .meta{display:flex;gap:6px;align-items:center;justify-content:flex-end;font-size:11px;opacity:.75;margin-top:4px}.bubble.them .meta{color:var(--muted);opacity:1}.reply-quote{border-left:3px solid currentColor;padding:4px 8px;margin-bottom:6px;background:#0000002e;border-radius:6px;font-size:13px;opacity:.9;cursor:pointer}[data-theme=light] .bubble.them .reply-quote{background:#0000000d}.reply-quote .q-title{font-size:11px;opacity:.8;margin-bottom:2px}.deleted-text{opacity:.8}.file-card{display:flex;align-items:center;gap:10px;padding:8px;background:#0003;border-radius:10px;margin-top:4px}[data-theme=light] .bubble.them .file-card{background:#0000000d}.file-icon{width:36px;height:36px;border-radius:8px;background:#ffffff26;display:grid;place-items:center;font-size:18px}[data-theme=light] .bubble.them .file-icon{background:#00000014}.file-meta{flex:1;min-width:0}.file-meta .fn{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px}.file-meta .fs{font-size:11px;opacity:.8}.file-card a{color:inherit;text-decoration:none;padding:6px 10px;background:#ffffff26;border-radius:8px;font-size:12px}[data-theme=light] .bubble.them .file-card a{background:#00000014}.msg-menu{position:absolute;top:100%;right:0;margin-top:4px;background:var(--menu-bg);color:var(--text);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);z-index:5;display:flex;flex-direction:column;min-width:140px}.msg-menu button{background:transparent;color:inherit;border:0;padding:10px 14px;text-align:left;cursor:pointer;font-size:14px}.msg-menu button:hover{background:var(--panel-2)}.msg-menu button.danger{color:var(--danger)}.composer{display:flex;flex-direction:column;gap:8px;padding:10px;padding-bottom:max(10px,env(safe-area-inset-bottom));background:var(--panel);border-top:1px solid var(--border)}.composer .replying{display:flex;align-items:center;justify-content:space-between;background:var(--panel-2);padding:6px 10px;border-left:3px solid var(--primary);border-radius:8px;font-size:13px}.composer .replying .r-title{font-size:11px;color:var(--muted)}.composer .replying .r-body{font-size:13px}.composer .replying button{background:transparent;color:var(--muted);border:0;cursor:pointer}.composer .row{display:flex;gap:8px;align-items:end}.composer textarea{flex:1;background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:10px 12px;border-radius:18px;font-size:16px;resize:none;min-height:40px;max-height:140px;outline:none;font-family:inherit}.composer textarea:focus{border-color:var(--primary)}.icon-btn{background:var(--panel-2);border:1px solid var(--border);color:var(--text);width:40px;height:40px;border-radius:50%;display:grid;place-items:center;cursor:pointer;flex-shrink:0}.send-btn{background:var(--primary);color:#fff;border:0;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;cursor:pointer;flex-shrink:0}.send-btn:disabled{opacity:.5}.upload-progress{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:8px}.upload-progress .bar{flex:1;height:4px;background:var(--panel-2);border-radius:2px;overflow:hidden}.upload-progress .bar>div{height:100%;background:var(--primary);transition:width .15s}.ticks{display:inline-flex;align-items:center}.ticks.read{color:#7dd3fc}.ticks.failed{color:var(--danger);font-weight:700}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);z-index:50;display:grid;place-items:center;padding:20px}.modal{background:var(--panel);color:var(--text);border:1px solid var(--border);border-radius:14px;padding:20px;max-width:380px;width:100%;box-shadow:var(--shadow)}.modal h3{margin:0 0 8px}.modal p{color:var(--muted);margin:0 0 16px;font-size:14px}.modal-actions{display:flex;gap:8px;justify-content:flex-end}
