:root,:root[data-theme=dark]{--bg: #0b1220;--surface: #111a2c;--surface-2: #182339;--text: #e7ecf3;--muted: #8a97ad;--accent: #4c8bf5;--accent-2: #356ad0;--mine: #2b5fcf;--theirs: #1c2740;--theirs-text: #e7ecf3;--meta-theirs: rgba(255, 255, 255, .7);--border: rgba(255, 255, 255, .06);--scrim: rgba(0, 0, 0, .2);--danger: #ef4444;--ok: #22c55e;color-scheme:dark}:root[data-theme=light]{--bg: #f5f7fb;--surface: #ffffff;--surface-2: #eef1f7;--text: #0f172a;--muted: #64748b;--accent: #2563eb;--accent-2: #1d4ed8;--mine: #2563eb;--theirs: #eef1f7;--theirs-text: #0f172a;--meta-theirs: rgba(0, 0, 0, .5);--border: rgba(15, 23, 42, .08);--scrim: rgba(15, 23, 42, .06);--danger: #dc2626;--ok: #16a34a;color-scheme:light}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Helvetica Neue,sans-serif;font-size:15px;-webkit-font-smoothing:antialiased}button,input,textarea{font:inherit;color:inherit}a{color:inherit;text-decoration:none}.screen{display:flex;flex-direction:column;height:100dvh;max-width:720px;margin:0 auto;background:var(--surface)}.loading{align-items:center;justify-content:center;color:var(--muted)}.login-screen{min-height:100dvh;display:grid;place-items:center;padding:24px}.login-card{width:100%;max-width:360px;background:var(--surface);border-radius:16px;padding:24px;display:flex;flex-direction:column;gap:12px;box-shadow:0 10px 40px #00000059}.login-card h1{margin:0 0 4px;font-size:28px}.login-card .mode-hint{margin:0 0 12px;color:var(--muted);font-size:13px}.login-card label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}.login-card input{background:var(--surface-2);border:1px solid transparent;border-radius:10px;padding:12px 14px;color:var(--text);outline:none}.login-card input:focus{border-color:var(--accent)}.login-card button{margin-top:6px;padding:12px;background:var(--accent);color:#fff;border:0;border-radius:10px;cursor:pointer}.login-card button:hover{background:var(--accent-2)}.login-card button:disabled{opacity:.6;cursor:default}.login-card .error{color:var(--danger);font-size:13px}.topbar{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:1}.topbar .title{font-size:18px;font-weight:600;flex:1}.topbar .back{font-size:28px;color:var(--accent);padding:4px 8px;margin-left:-8px;line-height:1}.link-btn{background:transparent;border:0;color:var(--accent);cursor:pointer;padding:6px 8px;font-size:14px}.icon-btn{display:grid;place-items:center;width:36px;height:36px;border-radius:50%;background:transparent;border:0;color:var(--muted);cursor:pointer;padding:0}.icon-btn:hover{background:var(--surface-2);color:var(--text)}.user-list{list-style:none;margin:0;padding:0;overflow-y:auto}.user-list .empty{padding:24px;color:var(--muted);text-align:center}.user-row{display:flex;gap:12px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border)}.user-row:hover{background:var(--surface-2)}.user-meta{flex:1;min-width:0}.user-name{display:flex;gap:8px;align-items:center;font-weight:600}.user-sub{color:var(--muted);font-size:13px;margin-top:2px}.online-dot{width:8px;height:8px;border-radius:50%;background:var(--ok);display:inline-block}.avatar{display:grid;place-items:center;border-radius:50%;background:linear-gradient(135deg,#4c8bf5,#8b5cf6);color:#fff;font-weight:600;flex-shrink:0}.chat{background:var(--bg)}.chat-topbar .peer{flex:1;min-width:0}.peer-name{font-weight:600}.peer-sub{color:var(--muted);font-size:12px;margin-top:2px}.peer-sub.typing{color:var(--accent);font-style:italic}.messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}.bubble{max-width:78%;padding:8px 12px;border-radius:16px;background:var(--theirs);color:var(--theirs-text);align-self:flex-start;word-wrap:break-word;overflow-wrap:anywhere}.bubble.mine{background:var(--mine);color:#fff;align-self:flex-end}.bubble .body{white-space:pre-wrap;line-height:1.35}.bubble .meta{display:flex;justify-content:flex-end;gap:6px;font-size:11px;margin-top:2px;color:var(--meta-theirs)}.bubble.mine .meta{color:#ffffffbf}.bubble .status-read{color:#a5ffd1}.bubble.theirs .status-read{color:var(--ok)}.bubble .attachments{display:flex;flex-direction:column;gap:6px;margin-bottom:6px}.bubble .attachments .image-tile{padding:0;background:transparent;border:0;cursor:zoom-in;border-radius:10px;overflow:hidden}.bubble .attachments .image-tile img{max-width:100%;max-height:320px;border-radius:10px;display:block}.bubble .attachments .media-audio{width:100%;min-width:240px;max-width:340px;height:40px}.bubble .attachments .media-video{max-width:100%;max-height:360px;border-radius:10px;background:#000;display:block}.bubble .attachments .file{display:flex;justify-content:space-between;gap:12px;padding:8px 10px;background:var(--scrim);border-radius:10px;font-size:13px}.bubble.mine .attachments .file{background:#0003}.bubble .attachments .file-size{color:var(--meta-theirs)}.bubble.mine .attachments .file-size{color:#ffffffa6}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;display:grid;place-items:center;z-index:50;padding:24px;padding-top:max(24px,env(safe-area-inset-top));padding-bottom:max(24px,env(safe-area-inset-bottom))}.lightbox img{max-width:100%;max-height:100%;object-fit:contain;cursor:zoom-out;-webkit-user-select:none;user-select:none}.lightbox-toolbar{position:absolute;top:max(12px,env(safe-area-inset-top));right:12px;display:flex;gap:8px;z-index:1}.lightbox-btn{display:grid;place-items:center;width:40px;height:40px;border-radius:50%;background:#ffffff1f;color:#fff;border:0;cursor:pointer;text-decoration:none}.lightbox-btn:hover{background:#ffffff38}.lightbox-caption{position:absolute;bottom:max(12px,env(safe-area-inset-bottom));left:50%;transform:translate(-50%);color:#ffffffb3;font-size:12px;background:#00000080;padding:6px 12px;border-radius:999px;max-width:80%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none}.composer{border-top:1px solid var(--border);padding:8px;background:var(--surface);padding-bottom:max(8px,env(safe-area-inset-bottom))}.composer .pending{display:flex;flex-wrap:wrap;gap:6px;padding:6px 4px 8px}.composer .pending-item{display:inline-flex;gap:6px;background:var(--surface-2);padding:4px 8px;border-radius:8px;font-size:12px;align-items:center}.composer .pending-item button{background:transparent;border:0;color:var(--muted);cursor:pointer;font-size:16px;line-height:1}.composer .row{display:flex;gap:8px;align-items:flex-end}.composer textarea{flex:1;min-height:40px;max-height:140px;background:var(--surface-2);border:0;border-radius:12px;padding:10px 12px;color:var(--text);resize:none;outline:none}.composer .attach-btn,.composer .send-btn{border:0;border-radius:12px;cursor:pointer;padding:0 14px;height:40px}.composer .attach-btn{background:var(--surface-2);color:var(--text);font-size:22px;width:40px;padding:0}.composer .send-btn,.composer .mic-btn,.composer .cancel-btn{display:grid;place-items:center;width:40px;padding:0}.composer .send-btn{background:var(--accent);color:#fff}.composer .mic-btn{background:var(--surface-2);color:var(--text)}.composer .cancel-btn{background:var(--surface-2);color:var(--danger)}.composer .send-btn:disabled,.composer .mic-btn:disabled,.composer .cancel-btn:disabled,.composer .attach-btn:disabled{opacity:.5;cursor:default}.composer .recording-row{align-items:center}.composer .rec-status{flex:1;display:flex;align-items:center;gap:10px;background:var(--surface-2);border-radius:12px;padding:10px 14px;height:40px;color:var(--muted)}.composer .rec-dot{width:10px;height:10px;border-radius:50%;background:var(--danger);animation:rec-pulse 1.2s ease-in-out infinite;flex-shrink:0}.composer .rec-time{font-variant-numeric:tabular-nums;color:var(--text)}@keyframes rec-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.composer .rec-error{margin:0 4px 6px;padding:6px 10px;background:#ef44441f;color:var(--danger);border-radius:8px;font-size:12px;cursor:pointer}@media (max-width: 720px){.screen{max-width:100%}}
