:root{color-scheme:light dark;font-family:system-ui,-apple-system,Segoe UI,sans-serif;--bg: light-dark(#f5f6f8, #14161a);--panel: light-dark(#ffffff, #1e2126);--border: light-dark(#e2e5e9, #2c3038);--text: light-dark(#1c1e21, #e8eaed);--muted: light-dark(#5c6370, #9aa2ad);--accent: light-dark(#2f6fed, #5b8def);--accent-soft: light-dark(#e8f0fe, #24304a);--good: light-dark(#0a7a3d, #4ade80);--bad: light-dark(#c0392b, #f87171)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--bg);color:var(--text)}#root{height:100vh;height:100dvh}.back-button{display:none}button{font:inherit;cursor:pointer}input{font:inherit;color:inherit}button.link{background:none;border:none;color:var(--accent);padding:.25rem 0}.splash{height:100vh;display:grid;place-items:center;color:var(--muted)}.login{height:100vh;display:grid;place-items:center}.login-card{width:min(400px,92vw);background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:2rem}.login-card h1{margin:0 0 1rem;font-size:1.5rem}.login-card p{color:var(--muted);margin:0 0 1rem}.login-card form{display:flex;flex-direction:column;gap:.75rem}.login-card input{padding:.65rem .8rem;border-radius:10px;border:1px solid var(--border);background:var(--bg);font-size:1rem}.login-card button[type=submit]{padding:.65rem;border-radius:10px;border:none;background:var(--accent);color:#fff;font-weight:600}.login-card button[type=submit]:disabled{opacity:.5;cursor:default}.login-error{color:var(--bad);margin-top:1rem}.chat-app{display:grid;grid-template-columns:320px 1fr;height:100vh}.chat-empty{display:grid;place-items:center;color:var(--muted)}.sidebar{border-right:1px solid var(--border);background:var(--panel);display:flex;flex-direction:column;min-height:0}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--border)}.sidebar-email{color:var(--muted);font-size:.8rem}.sidebar-search{margin:.75rem;padding:.55rem .8rem;border-radius:10px;border:1px solid var(--border);background:var(--bg)}.sidebar-list{list-style:none;margin:0;padding:0 .5rem .5rem;overflow-y:auto;flex:1}.sidebar-hint{color:var(--muted);padding:1rem;font-size:.9rem}.sidebar-item{display:flex;gap:.7rem;align-items:center;width:100%;padding:.6rem;border:none;border-radius:10px;background:none;color:inherit;text-align:left}.sidebar-item:hover{background:var(--bg)}.sidebar-item.selected{background:var(--accent-soft)}.sidebar-item-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.sidebar-item-title{display:flex;justify-content:space-between;align-items:baseline;font-weight:600;gap:.5rem}.sidebar-item-time{color:var(--muted);font-size:.75rem;font-weight:400;flex-shrink:0}.sidebar-item-sub{display:flex;align-items:center;gap:.5rem;color:var(--muted);font-size:.85rem}.sidebar-item-preview{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unread-badge{background:var(--accent);color:#fff;border-radius:999px;font-size:.72rem;font-weight:700;padding:.1rem .45rem;flex-shrink:0}.avatar{position:relative;width:40px;height:40px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-weight:700;flex-shrink:0}.presence-dot{position:absolute;bottom:0;right:0;width:11px;height:11px;border-radius:50%;background:var(--good);border:2px solid var(--panel)}.chat-view{display:flex;flex-direction:column;min-height:0}.chat-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;border-bottom:1px solid var(--border);background:var(--panel)}.chat-presence{font-size:.8rem;color:var(--muted)}.chat-presence.online{color:var(--good)}.message-list{flex:1;overflow-y:auto;padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.35rem}.load-older{align-self:center;margin-bottom:.75rem;border:1px solid var(--border);background:var(--panel);color:var(--muted);border-radius:999px;padding:.35rem .9rem;font-size:.85rem}.bubble-row{display:flex}.bubble-row.mine{justify-content:flex-end}.bubble{max-width:min(60ch,78%);background:var(--panel);border:1px solid var(--border);border-radius:14px 14px 14px 4px;padding:.5rem .75rem;display:inline-flex;align-items:flex-end;gap:.6rem}.bubble.mine{background:var(--accent-soft);border-color:transparent;border-radius:14px 14px 4px}.bubble-content{white-space:pre-wrap;overflow-wrap:anywhere}.bubble-meta{color:var(--muted);font-size:.7rem;white-space:nowrap;display:inline-flex;gap:.25rem}.ticks{letter-spacing:-.15em}.ticks.read{color:var(--accent)}.ticks.pending{opacity:.7}.typing-bubble{color:var(--muted);font-style:italic;font-size:.85rem}.sidebar-header-actions{display:flex;gap:.6rem;align-items:center}.sidebar-toolbar{display:flex;gap:.5rem;align-items:center;margin:.75rem}.sidebar-toolbar .sidebar-search{flex:1;margin:0}.new-group{border:1px solid var(--border);background:var(--panel);color:var(--accent);border-radius:10px;padding:.5rem .7rem;font-weight:600;white-space:nowrap}.sidebar-section{color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;padding:.75rem .6rem .25rem}.modal-backdrop{position:fixed;inset:0;background:#00000073;display:grid;place-items:center;z-index:20}.modal{width:min(440px,92vw);background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:1.5rem}.modal h2{margin:0 0 1rem;font-size:1.2rem}.modal form{display:flex;flex-direction:column;gap:.75rem}.modal input{padding:.6rem .8rem;border-radius:10px;border:1px solid var(--border);background:var(--bg)}.modal-results{list-style:none;margin:0;padding:0;max-height:180px;overflow-y:auto;border:1px solid var(--border);border-radius:10px}.modal-results button{width:100%;text-align:left;background:none;border:none;color:inherit;padding:.55rem .8rem}.modal-results button:hover{background:var(--bg)}.muted{color:var(--muted);font-size:.85em}.chip-row{display:flex;flex-wrap:wrap;gap:.4rem}.chip{border:1px solid var(--border);background:var(--accent-soft);color:inherit;border-radius:999px;padding:.25rem .7rem;font-size:.85rem}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;align-items:center}.modal-actions button[type=submit]{border:none;background:var(--accent);color:#fff;font-weight:600;border-radius:10px;padding:.6rem 1.1rem}.modal-actions button[type=submit]:disabled{opacity:.5}.group-menu{border-bottom:1px solid var(--border);background:var(--panel);padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.7rem;max-height:45vh;overflow-y:auto}.group-menu input{padding:.5rem .7rem;border-radius:8px;border:1px solid var(--border);background:var(--bg)}.group-menu-header{display:flex;justify-content:space-between;align-items:center}.group-menu-row{display:flex;gap:.5rem}.group-menu-row input{flex:1}.group-menu-row button{border:1px solid var(--border);background:var(--bg);color:var(--accent);border-radius:8px;padding:0 .8rem}.group-menu-section{color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.group-menu-members{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.35rem}.group-menu-members li{display:flex;justify-content:space-between;align-items:center}.role-badge{margin-left:.5rem;font-size:.7rem;color:var(--accent);border:1px solid var(--accent);border-radius:999px;padding:.05rem .45rem}.danger{color:var(--bad)!important}.group-menu-leave{align-self:flex-start}.system-message{align-self:center;color:var(--muted);font-size:.8rem;background:var(--panel);border:1px solid var(--border);border-radius:999px;padding:.2rem .9rem;margin:.25rem 0}.bubble-stack{display:flex;flex-direction:column;max-width:min(60ch,78%)}.bubble-row.mine .bubble-stack{align-items:flex-end}.bubble-stack .bubble{max-width:100%;display:block}.bubble-sender{font-size:.78rem;font-weight:700;color:var(--accent);margin-bottom:.15rem}.bubble-quote{border-left:3px solid var(--accent);background:#7f7f7f14;border-radius:6px;padding:.3rem .6rem;font-size:.82rem;color:var(--muted);margin-bottom:.3rem;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.bubble-quote-sender{display:block;font-weight:700;color:var(--accent)}.bubble-deleted{color:var(--muted)}.bubble-image{display:block;max-width:320px;max-height:320px;border-radius:10px;margin-bottom:.25rem}.bubble-video{display:block;max-width:360px;border-radius:10px;margin-bottom:.25rem}.bubble-file{display:inline-flex;gap:.6rem;align-items:center;text-decoration:none;color:inherit;background:#7f7f7f1a;border-radius:10px;padding:.5rem .8rem;margin-bottom:.25rem}.bubble-file-icon{font-size:1.4rem}.bubble-file-name{display:block;font-weight:600}.bubble-file-size{display:block;color:var(--muted);font-size:.78rem}.bubble-meta .edited{font-style:italic;margin-right:.3rem}.reaction-chips{display:flex;gap:.3rem;margin-top:.2rem;flex-wrap:wrap}.reaction-chip{border:1px solid var(--border);background:var(--panel);border-radius:999px;padding:.1rem .5rem;font-size:.85rem;color:inherit}.reaction-chip.reacted{border-color:var(--accent);background:var(--accent-soft)}.bubble-actions{display:none;gap:.3rem;margin-top:.2rem}.bubble-stack:hover .bubble-actions{display:flex}.bubble-actions button{border:1px solid var(--border);background:var(--panel);color:var(--muted);border-radius:999px;padding:.1rem .6rem;font-size:.75rem}.bubble-actions button:hover{color:inherit}.emoji-picker{display:flex;gap:.2rem}.emoji-picker button{font-size:.95rem}.typing-note{color:var(--muted);font-style:italic;font-size:.85rem;padding:.25rem 0}.composer-context{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.5rem 1.25rem;border-top:1px solid var(--border);background:var(--panel);color:var(--muted);font-size:.85rem}.composer .attach{border:none;background:none;font-size:1.2rem;padding:0 .2rem}.composer .gif-button{font-size:.8rem;font-weight:800;letter-spacing:.03em;color:var(--accent);border:1.5px solid var(--accent);border-radius:6px;padding:.15rem .35rem;align-self:center}.kind-toggle{display:flex;gap:.5rem;margin-bottom:.5rem}.kind-toggle button{flex:1;border:1px solid var(--border);background:var(--bg);color:inherit;border-radius:10px;padding:.5rem}.kind-toggle button.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent);font-weight:600}.pinned-banner{display:flex;gap:.5rem;align-items:center;padding:.45rem 1.25rem;border-bottom:1px solid var(--border);background:var(--panel);font-size:.85rem;color:var(--muted)}.pinned-preview{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pin-tag{font-size:.7rem;color:var(--muted);margin-bottom:.15rem}.bubble-row.mine .pin-tag{text-align:right}.channel-readonly{padding:1rem 1.25rem;text-align:center;color:var(--muted);border-top:1px solid var(--border);background:var(--panel);font-size:.9rem}.sidebar-username{background:none;border:none;color:var(--accent);font-size:.8rem;padding:0;cursor:pointer;display:block}.group-menu-row input[readonly]{flex:1;font-family:ui-monospace,monospace}.secret-badge{color:var(--good);font-size:.75rem;font-weight:600}.expiry-select{border:1px solid var(--border);background:var(--bg);color:var(--muted);border-radius:8px;padding:.25rem .4rem;font-size:.8rem}.safety-number{font-family:ui-monospace,monospace;font-size:1.05rem;letter-spacing:.05em;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:.8rem;word-break:break-all;-webkit-user-select:all;user-select:all}.verify-toggle{display:flex;gap:.5rem;align-items:center;margin:.75rem 0}.gif-picker{border-top:1px solid var(--border);background:var(--panel);padding:.75rem 1.25rem}.gif-picker-header{display:flex;gap:.6rem;align-items:center;margin-bottom:.6rem}.gif-picker-header input{flex:1;padding:.5rem .8rem;border-radius:10px;border:1px solid var(--border);background:var(--bg)}.gif-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.4rem;max-height:260px;overflow-y:auto}.gif-cell{border:none;padding:0;background:var(--bg);border-radius:8px;overflow:hidden;cursor:pointer;aspect-ratio:4 / 3}.gif-cell img{width:100%;height:100%;object-fit:cover;display:block}.chat-header-main{flex:1}.composer{display:flex;gap:.6rem;padding:.85rem 1.25rem;border-top:1px solid var(--border);background:var(--panel)}.composer input{flex:1;padding:.65rem .9rem;border-radius:999px;border:1px solid var(--border);background:var(--bg)}.composer button{border:none;background:var(--accent);color:#fff;font-weight:600;border-radius:999px;padding:0 1.4rem}.composer button:disabled{opacity:.5;cursor:default}.sidebar-header{padding-top:max(1rem,env(safe-area-inset-top))}.composer{padding-bottom:max(.85rem,env(safe-area-inset-bottom))}@media(max-width:768px){.chat-app{grid-template-columns:1fr}.sidebar,.chat-view,.chat-empty{grid-column:1;grid-row:1}.chat-app:not(.show-chat) .chat-view,.chat-app:not(.show-chat) .chat-empty{display:none}.chat-app.show-chat .sidebar{display:none}.back-button{display:inline-flex;align-items:center;justify-content:center;border:none;background:none;color:var(--accent);font-size:2rem;line-height:1;width:2.2rem;height:2.2rem;margin-right:.15rem;flex-shrink:0}.sidebar-item{padding:.75rem .6rem}.composer button,.composer .attach,.composer .gif-button,.expiry-select,.chat-header .link{min-height:40px}.composer input{font-size:16px}.bubble-stack{max-width:88%}.bubble-image{max-width:min(72vw,320px)}.bubble-video{max-width:min(80vw,360px)}.gif-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr));max-height:40dvh}.login-card{padding:1.5rem}.modal{width:94vw}}
