:root{--bg: #0b141a;--panel: #111b21;--panel-2: #182229;--line: #20303a;--text: #e9edef;--muted: #8696a0;--accent: #00a884;--bubble-me: #005c4b;--bubble-other: #202c33;--danger: #f15c6d;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--link-other: #53bdeb;--link-me: #aef0e0;--chat-bg: #0b141a;--msg-font: 16px}body.light{--bg: #eef0f2;--panel: #ffffff;--panel-2: #e4e9ec;--line: #cfd6da;--text: #0b141a;--muted: #5b6770;--accent: #008f72;--bubble-me: #d6fcc8;--bubble-other: #ffffff;--danger: #d11a2a;--link-other: #027eb5;--link-me: #027a63;--chat-bg: #e5ddd5}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:16px;overflow:hidden}button,input,textarea{font-family:inherit;font-size:16px}.screen{position:fixed;inset:0;display:none;flex-direction:column;background:var(--bg)}.screen.active{display:flex}.topbar{display:flex;align-items:center;gap:8px;padding:calc(10px + var(--safe-top)) 12px 10px;background:var(--panel);border-bottom:1px solid var(--line);min-height:52px}.topbar .title{font-weight:600;font-size:18px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar .actions{display:flex;gap:4px}.topbar button{background:none;border:none;color:var(--text);font-size:22px;padding:6px 10px;border-radius:8px;cursor:pointer}.topbar button:active{background:var(--panel-2)}.topbar button svg{width:22px;height:22px;display:block}.back{font-size:30px!important;line-height:1;padding:0 8px!important}.login-box{margin:auto;width:min(360px,88vw);display:flex;flex-direction:column;gap:14px;padding:28px;background:var(--panel);border-radius:16px}.login-box h1{margin:0 0 6px;text-align:center}.brand{color:var(--accent)}.login-box input,.card input,.group-name-row input{background:var(--panel-2);border:1px solid var(--line);color:var(--text);padding:13px 14px;border-radius:10px}.login-box button,.card button,.card-btn{background:var(--accent);color:#04231c;border:none;padding:13px;border-radius:10px;font-weight:600;cursor:pointer}.error{color:var(--danger);min-height:18px;margin:0;font-size:14px;text-align:center}.chat-list{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1}body.light .chat-list{background:var(--panel)}.chat-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--line);cursor:pointer}.chat-item:active{background:var(--panel-2)}.avatar{width:46px;height:46px;border-radius:50%;background:var(--panel-2);color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:18px;flex-shrink:0}.avatar.group{color:#f0a93b}.avatar.quiz{color:var(--accent)}.chat-meta{flex:1;min-width:0}.chat-name{font-weight:600}.chat-sub{color:var(--muted);font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.chat-time{color:var(--muted);font-size:12px;white-space:nowrap}.chat-time.online{color:var(--accent)}.badge{background:var(--accent);color:#04231c;min-width:20px;height:20px;padding:0 6px;border-radius:10px;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center}.messages{flex:1;overflow-y:auto;padding:12px 10px;display:flex;flex-direction:column;gap:4px;background:var(--chat-bg)}.msg{max-width:82%;padding:7px 10px 5px;border-radius:10px;background:var(--bubble-other);align-self:flex-start;word-wrap:break-word;position:relative}.msg.me{align-self:flex-end;background:var(--bubble-me)}.msg .sender{font-size:13px;font-weight:600;color:var(--accent);margin-bottom:2px}.msg.me .sender{display:none}.msg .body{white-space:pre-wrap;line-height:1.35;font-size:var(--msg-font)}.msg .body a{color:var(--link-other);text-decoration:underline;word-break:break-all}.msg.me .body a{color:var(--link-me)}.msg img{max-width:100%;border-radius:8px;display:block;cursor:pointer}.msg video{max-width:100%;max-height:60vh;border-radius:8px;display:block;background:#000}.msg .time{font-size:11px;color:var(--muted);text-align:right;margin-top:2px}.ticks{display:inline-block;margin-left:4px;vertical-align:-1px}.ticks .tick{width:15px;height:11px;display:inline-block;color:var(--muted)}.ticks.read .tick{color:#5bc0f8}.day-sep{align-self:center;background:var(--panel-2);color:var(--muted);font-size:12px;padding:4px 10px;border-radius:8px;margin:8px 0}.composer{display:flex;align-items:flex-end;gap:8px;padding:8px 10px calc(8px + var(--safe-bottom));background:var(--panel);border-top:1px solid var(--line)}.composer textarea{flex:1;resize:none;max-height:120px;background:var(--panel-2);color:var(--text);border:1px solid var(--line);border-radius:20px;padding:10px 14px;line-height:1.3;overflow-y:hidden}.composer textarea:focus{outline:none;border-color:var(--accent)}.img-btn,.composer .send{background:var(--panel-2);border:none;color:var(--text);width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;cursor:pointer;flex-shrink:0}.composer .send{background:var(--accent);color:#04231c}.img-btn span{pointer-events:none}.img-btn svg{width:24px;height:24px;pointer-events:none}.composer .send svg{width:22px;height:22px;pointer-events:none;transform:translate(1px)}.smile-panel{background:var(--panel);border-top:1px solid var(--line);display:flex;flex-direction:column;max-height:290px}.emoji-tabs{display:flex;gap:2px;padding:6px 8px;border-bottom:1px solid var(--line);overflow-x:auto}.emoji-tab{background:none;border:none;padding:4px 6px;border-radius:8px;cursor:pointer;flex:0 0 auto;font-size:20px;line-height:1;opacity:.6}.emoji-tab.active{background:var(--panel-2);opacity:1}.emoji-search{margin:8px;background:var(--panel-2);border:1px solid var(--line);color:var(--text);border-radius:10px;padding:8px 12px}.emoji-search:focus{outline:none;border-color:var(--accent)}.emoji-grid{flex:1;overflow-y:auto;padding:4px 8px 12px;display:grid;grid-template-columns:repeat(auto-fill,40px);gap:4px;justify-content:center}.emoji-pick{width:40px;height:40px;background:none;border:none;cursor:pointer;border-radius:6px;font-size:26px;line-height:1;padding:0}.emoji-pick:active{background:var(--panel-2)}.avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block}.profile-av{width:96px;height:96px;border-radius:50%;margin:4px auto 10px;background:var(--panel-2);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:34px;font-weight:600;overflow:hidden;cursor:pointer;position:relative}.profile-av img{width:100%;height:100%;object-fit:cover}.profile-av .edit-hint{position:absolute;bottom:0;left:0;right:0;background:#0000008c;color:#fff;font-size:11px;text-align:center;padding:2px 0}.group-name-row{padding:12px 16px;border-bottom:1px solid var(--line)}.group-name-row input{width:100%}.user-check{margin-left:auto;width:22px;height:22px}.admin-body{overflow-y:auto;padding:16px}.admin-body h2{font-size:15px;color:var(--muted);margin:18px 0 8px;text-transform:uppercase;letter-spacing:.04em}.card{display:flex;flex-direction:column;gap:10px;background:var(--panel);padding:16px;border-radius:12px}.card-btn{width:100%}.check{display:flex;align-items:center;gap:8px;color:var(--muted)}.picker-actions button{color:var(--accent);font-weight:600}.card-btn.danger-btn{background:var(--danger);color:#2a0a0e}.remove-btn{margin-left:auto;background:none;border:none;color:var(--danger);font-size:24px;line-height:1;padding:4px 10px;cursor:pointer}.notif-banner{display:block;width:100%;text-align:left;background:var(--panel-2);color:var(--accent);border:none;border-bottom:1px solid var(--line);padding:12px 16px;font-size:15px;cursor:pointer}.notif-banner:active{background:var(--panel)}.header-av{width:38px;height:38px;font-size:15px;flex-shrink:0}.avatar .ic{width:54%;height:54%}.chat-head-meta{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;line-height:1.2}.chat-head-meta .title{flex:none}.chat-status{font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-status.online{color:var(--accent)}.search-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--panel);border-bottom:1px solid var(--line)}.search-bar input{flex:1;background:var(--panel-2);border:1px solid var(--line);color:var(--text);border-radius:10px;padding:10px 12px}.search-bar input:focus{outline:none;border-color:var(--accent)}.search-bar #search-close{background:none;border:none;color:var(--muted);font-size:24px;cursor:pointer;padding:0 6px}.search-results{flex:1;overflow-y:auto;background:var(--bg)}.search-item{padding:12px 16px;border-bottom:1px solid var(--line);cursor:pointer}.search-item:active{background:var(--panel)}.search-top{display:flex;justify-content:space-between;gap:8px}.search-sender{color:var(--accent);font-weight:600;font-size:14px}.search-date{color:var(--muted);font-size:12px;flex-shrink:0}.search-snippet{color:var(--text);font-size:14px;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-empty{padding:24px;text-align:center;color:var(--muted)}.msg.has-av{margin-left:40px}.msg-avatar{position:absolute;left:-40px;bottom:0;width:32px;height:32px;font-size:13px}.reply-quote{display:block;border-left:3px solid var(--accent);background:#0000002e;border-radius:4px;padding:3px 8px;margin-bottom:4px;cursor:pointer;overflow:hidden}.reply-quote .reply-name{display:block;color:var(--accent);font-size:12px;font-weight:600}.reply-quote .reply-text{color:var(--muted);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.mention-box{max-height:220px;overflow-y:auto;background:var(--panel);border-top:1px solid var(--line)}.mention-item{display:flex;align-items:center;gap:10px;padding:8px 14px;cursor:pointer}.mention-item:active{background:var(--panel-2)}.mention-item .avatar{width:34px;height:34px;font-size:14px}.mention-name{font-weight:600}.reply-bar{display:flex;align-items:center;gap:8px;background:var(--panel);border-top:1px solid var(--line);padding:8px 12px}.reply-bar .reply-info{flex:1;min-width:0;border-left:3px solid var(--accent);padding-left:8px}.reply-bar .reply-name{display:block;color:var(--accent);font-size:13px;font-weight:600}.reply-bar .reply-text{color:var(--muted);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.reply-bar #reply-cancel{background:none;border:none;color:var(--muted);font-size:24px;cursor:pointer;padding:0 6px}.menu-sheet{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:8px;min-width:220px;display:flex;flex-direction:column;gap:4px}.menu-sheet button{background:var(--panel-2);border:none;color:var(--text);padding:14px;border-radius:8px;font-size:16px;cursor:pointer}.menu-sheet .ms-del{color:var(--danger)}.msg-info{max-height:34vh;overflow-y:auto;padding:2px 6px 8px;border-bottom:1px solid var(--line);margin-bottom:4px}.mi-row{display:flex;align-items:baseline;gap:8px;padding:5px 2px}.mi-row+.mi-row{border-top:1px solid var(--line)}.mi-emoji{font-size:18px;line-height:1;flex-shrink:0}.mi-label{display:inline-flex;align-items:center;gap:4px;color:var(--accent);font-size:13px;font-weight:600;flex-shrink:0}.mi-label .tick{width:15px;height:11px;color:#5bc0f8}.mi-names{color:var(--text);font-size:14px;line-height:1.3}.mi-empty,.mi-loading{color:var(--muted);font-size:13px;padding:6px 2px;text-align:center}.chat-head-meta.tappable{cursor:pointer}.select-bar{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--panel);border-bottom:1px solid var(--line)}.select-bar button{background:none;border:none;color:var(--text);cursor:pointer;padding:6px;border-radius:8px}.select-bar #select-cancel{font-size:26px;line-height:1;padding:0 6px}.select-count{flex:1;font-weight:600}.select-delete{color:var(--danger)!important}.select-delete svg{width:22px;height:22px;display:block}.select-delete:disabled{opacity:.4;cursor:default}.messages.selecting .msg.me{cursor:pointer}.sel-box{position:absolute;left:-30px;top:50%;transform:translateY(-50%);width:22px;height:22px;border-radius:50%;border:2px solid var(--muted);background:var(--panel);display:flex;align-items:center;justify-content:center}.sel-box svg{display:none;width:14px;height:10px;color:#04231c}.msg.selected .sel-box{background:var(--accent);border-color:var(--accent)}.msg.selected .sel-box svg{display:block}.msg.selected{background:var(--bubble-other);box-shadow:0 0 0 2px var(--accent)}.msg.me.selected{background:var(--bubble-me)}.media-cap .mc-preview{display:flex;justify-content:center;background:#000;border-radius:10px;overflow:hidden;margin-bottom:8px}.media-cap .mc-preview img,.media-cap .mc-preview video{max-width:100%;max-height:50vh;display:block}.font-preview{display:flex;flex-direction:column;gap:6px;padding:10px;background:var(--chat-bg);border-radius:10px;margin:4px 0}.fp-bubble{max-width:80%;padding:6px 10px;border-radius:10px}.fp-bubble.in{align-self:flex-start;background:var(--bubble-other);color:var(--text)}.fp-bubble.me{align-self:flex-end;background:var(--bubble-me);color:var(--text)}.font-preview .body{font-size:var(--msg-font);line-height:1.35}.font-range{width:100%;accent-color:var(--accent)}.font-val{color:var(--accent);font-weight:600}.msg.flash{animation:flashbg 1.2s ease}@keyframes flashbg{0%,to{box-shadow:0 0 #00a88400}30%{box-shadow:0 0 0 3px var(--accent)}}.screen.dragging:after{content:"\41e\442\43f\443\441\442\438\442\435, \447\442\43e\431\44b  \43e\442\43f\440\430\432\438\442\44c  \43a\430\440\442\438\43d\43a\443";position:absolute;inset:0;z-index:50;background:#00a88426;border:2px dashed var(--accent);display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:18px;padding:20px;text-align:center;pointer-events:none}.reactions{display:flex;flex-wrap:wrap;gap:4px;margin-top:5px}.react-pill{display:inline-flex;align-items:center;gap:3px;background:var(--panel-2);border:1px solid var(--line);border-radius:12px;padding:2px 8px 2px 5px;cursor:pointer;font-size:12px;color:var(--text)}.react-pill .re{font-size:14px;line-height:1}.react-pill.mine{background:#00a88440;border-color:var(--accent)}.react-bar{display:flex;gap:4px;justify-content:space-between;padding:4px 4px 10px;border-bottom:1px solid var(--line);margin-bottom:4px}.react-pick{width:38px;height:38px;cursor:pointer;border-radius:8px;background:none;border:none;font-size:24px;line-height:1;padding:0;display:flex;align-items:center;justify-content:center}.react-pick:active{background:var(--panel-2)}.unread-sep{align-self:center;background:var(--accent);color:#04231c;font-size:12px;font-weight:600;padding:3px 12px;border-radius:8px;margin:8px 0}.scroll-down{position:absolute;right:14px;bottom:78px;width:42px;height:42px;border-radius:50%;background:var(--panel);border:1px solid var(--line);color:var(--text);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:20}.scroll-down svg{width:24px;height:24px}.sd-badge{position:absolute;top:-6px;right:-4px;background:var(--accent);color:#04231c;font-size:11px;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 5px;font-weight:700}.quiz-bar{display:flex;gap:6px;padding:8px 10px;background:var(--panel);border-top:1px solid var(--line)}.quiz-cmd{flex:1;background:var(--panel-2);border:1px solid var(--line);color:var(--text);padding:9px 4px;border-radius:10px;font-size:13px;cursor:pointer;white-space:nowrap}.quiz-cmd:active{background:var(--accent);color:#04231c}.caption{margin-top:5px;white-space:pre-wrap;line-height:1.35;font-size:var(--msg-font)}.hidden{display:none!important}.admin-only{display:none}body.is-admin .admin-only{display:inline-flex}.toast{position:fixed;bottom:calc(20px + var(--safe-bottom));left:50%;transform:translate(-50%) translateY(20px);background:var(--panel-2);color:var(--text);padding:10px 18px;border-radius:20px;font-size:14px;opacity:0;pointer-events:none;transition:.25s;border:1px solid var(--line);z-index:100}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:150;padding:20px}.modal{width:min(420px,100%);background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:20px;display:flex;flex-direction:column;gap:8px}.modal-title{font-weight:600;font-size:18px;margin-bottom:6px}.modal-label{color:var(--muted);font-size:13px;margin-top:6px}.modal-row{display:flex;gap:8px}.modal-row input{flex:1;background:var(--panel-2);border:1px solid var(--line);color:var(--text);padding:11px 12px;border-radius:10px}.modal-row button{background:var(--accent);color:#04231c;border:none;padding:0 16px;border-radius:10px;font-weight:600;cursor:pointer}.modal-actions{display:flex;flex-direction:column;gap:8px;margin-top:14px}.modal-actions button{padding:12px;border-radius:10px;border:none;cursor:pointer;background:var(--panel-2);color:var(--text)}.gender-row{display:flex;gap:8px}.gender-row button{flex:1;background:var(--panel-2);border:1px solid var(--line);color:var(--text);padding:11px;border-radius:10px;cursor:pointer}.gender-row button.active{background:var(--accent);color:#04231c;border-color:var(--accent);font-weight:600}.members-list{max-height:60vh;overflow-y:auto;margin:6px 0;border:1px solid var(--line);border-radius:10px}.members-list .chat-item{padding:10px 12px;cursor:default}.vis-modal{max-height:85vh}.vis-list{max-height:50vh;overflow-y:auto;margin:6px 0;border:1px solid var(--line);border-radius:10px}.vis-list .chat-item{padding:10px 12px}.modal-actions .m-save{background:var(--accent);color:#04231c;font-weight:600}.modal-actions .m-delete{background:var(--danger);color:#2a0a0e;font-weight:600}.lightbox{position:fixed;inset:0;background:#000000eb;display:flex;align-items:center;justify-content:center;z-index:200;padding:16px;overflow:hidden;touch-action:none}.lightbox img{max-width:100%;max-height:100%;border-radius:6px;touch-action:none;will-change:transform;transform-origin:center center;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.lb-close{position:absolute;top:calc(10px + var(--safe-top));right:14px;width:40px;height:40px;border-radius:50%;background:#00000073;border:none;color:#fff;font-size:26px;line-height:1;cursor:pointer;z-index:1;display:flex;align-items:center;justify-content:center}#btn-mute svg{width:22px;height:22px;display:block}#btn-mute.muted{color:var(--muted)}.chat-right-row{display:flex;align-items:center;gap:6px}.mute-mark{color:var(--muted);display:inline-flex}.mute-mark .ic-mute{width:15px;height:15px;display:block}
