:root{color-scheme:dark;font-family:Inter,system-ui,-apple-system,sans-serif;background:#0b0d12;color:#f4f5f7}
*{box-sizing:border-box}body{margin:0;min-height:100dvh;background:radial-gradient(circle at top,#202341,#0b0d12 42%)}
button,input{font:inherit}button{cursor:pointer}.hidden{display:none!important}
.login-view{min-height:100dvh;display:grid;place-items:center;padding:24px}.login-card{width:min(100%,380px);padding:30px;border:1px solid #303442;border-radius:24px;background:#151821;box-shadow:0 24px 80px #0008}
.logo{width:58px;height:58px;display:grid;place-items:center;border-radius:18px;background:#6c63ff;font-size:26px;letter-spacing:2px}.login-card h1{margin:20px 0 5px}.login-card p{margin:0 0 24px;color:#979dac}.login-card label{display:grid;gap:7px;margin:15px 0;color:#bcc1cc;font-size:14px}.login-card input,.gif-search input{width:100%;border:1px solid #343947;border-radius:13px;background:#0e1118;color:#fff;padding:13px;outline:none}.login-card input:focus,.gif-search input:focus,#messageInput:focus{border-color:#7770ff}.login-card button,.send-button{border:0;border-radius:13px;background:#6c63ff;color:#fff;font-weight:700;padding:13px 18px}.login-card button{width:100%;margin-top:10px}.error{min-height:20px;margin-top:12px;color:#ff8f9b;font-size:13px}
.chat-view{height:100dvh;max-width:880px;margin:auto;display:grid;grid-template-rows:auto 1fr auto;background:#0b0d12;box-shadow:0 0 80px #0008}.chat-view header{padding:max(12px,env(safe-area-inset-top)) 15px 12px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #222631;background:#12151ddd}.chat-view header div{display:grid;gap:2px}.chat-view header span{font-size:11px;color:#8d94a3}.chat-view nav{display:flex;gap:8px}.icon-button,.round-button{border:1px solid #343947;background:#1a1e28;color:#d9dde5;border-radius:50%;width:38px;height:38px}
.messages{overflow-y:auto;padding:20px 14px calc(12px + env(safe-area-inset-bottom));scroll-behavior:smooth}.message-row{display:flex;margin:5px 0}.message-row.mine{justify-content:flex-end}.bubble{max-width:min(78%,540px);padding:9px 12px;border-radius:17px 17px 17px 5px;background:#252a36;box-shadow:0 4px 18px #0002;overflow:hidden}.mine .bubble{background:#5c55dc;border-radius:17px 17px 5px 17px}.bubble p{white-space:pre-wrap;overflow-wrap:anywhere;margin:0}.bubble img{display:block;max-width:100%;max-height:420px;border-radius:11px}.bubble img.thumbnail{max-width:80px;max-height:80px;object-fit:cover;cursor:pointer;transition:max-width .25s,max-height .25s;opacity:.8}.bubble img.thumbnail.expanded{max-width:100%;max-height:420px;object-fit:contain;opacity:1}.bubble{position:relative}.meta{display:block;margin-top:5px;text-align:right;color:#c6cad4;font-size:10px;opacity:.8}.meta .seen{color:#a5f3fc;font-weight:700}.status-dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:4px;vertical-align:middle}.status-dot.online{background:#22c55e;box-shadow:0 0 6px #22c55e}.status-dot.offline{background:#ef4444;box-shadow:0 0 6px #ef444466}.reactions{display:flex;gap:3px;flex-wrap:wrap;margin-top:4px}.reaction-badge{border:0;background:#2a2e3a;color:#e0e4ec;border-radius:12px;padding:1px 6px;font-size:13px;cursor:pointer;line-height:1.6}.reaction-badge.active{background:#3d3570;color:#c4b5ff}.emoji-picker{display:flex;gap:2px;padding:3px;margin-top:2px;background:#1f2330;border-radius:10px;justify-content:center;position:absolute;bottom:100%;left:0;right:0;z-index:2;box-shadow:0 -4px 20px #0008}.emoji-option{border:0;background:0 0;font-size:18px;padding:2px;cursor:pointer;border-radius:6px;transition:background .15s}.emoji-option:hover{background:#353a48}.date-separator{text-align:center;color:#9298a6;font-size:11px;margin:20px 0 12px}.date-separator span{padding:5px 10px;border-radius:20px;background:#1b1f29}
.composer{display:grid;grid-template-columns:auto 1fr auto auto;gap:7px;padding:10px 10px calc(10px + env(safe-area-inset-bottom));border-top:1px solid #222631;background:#12151d}.composer #messageInput{min-width:0;border:1px solid #303542;border-radius:20px;padding:9px 14px;background:#1b1f29;color:#fff;outline:none}.gif-button{font-size:11px;font-weight:800}.send-button{padding:9px 13px;border-radius:20px}
.gif-panel{position:absolute;inset:auto 0 calc(66px + env(safe-area-inset-bottom));z-index:3;max-width:880px;max-height:60dvh;margin:auto;padding:10px;background:#151922;border:1px solid #303542;border-radius:18px 18px 0 0;box-shadow:0 -20px 50px #0008;overflow:auto}.gif-search{display:flex;gap:8px;position:sticky;top:0;background:#151922;padding-bottom:10px}.gif-search button{border:0;background:transparent;color:#a9afba}.gif-results{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}.gif-results button{padding:0;border:0;border-radius:8px;overflow:hidden;background:#222631;aspect-ratio:1}.gif-results img{width:100%;height:100%;object-fit:cover}.empty{grid-column:1/-1;text-align:center;color:#969dab;padding:30px}
.toast{position:fixed;z-index:5;left:50%;bottom:92px;transform:translateX(-50%);max-width:90%;padding:10px 14px;border-radius:12px;background:#f0f1f5;color:#15171c;box-shadow:0 8px 35px #0008;font-size:13px}
@media(min-width:700px){body{padding:18px}.chat-view{height:calc(100dvh - 36px);border:1px solid #292e3a;border-radius:24px;overflow:hidden}.gif-panel{bottom:84px}}
