@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";:root,[data-theme=dark]{--overlay-bg:#0009;--modal-ambient:#00000080;--bg:#071212;--bg2:#0b1a1a;--surface:#102423;--surface2:#152e2d;--surface3:#1b3b3a;--surface4:#224a49;--neo-shadow-out:6px 6px 12px #000000a6, -6px -6px 12px #ffffff12;--neo-shadow-in:inset 6px 6px 12px #0009, inset -6px -6px 12px #ffffff0f;--neo-shadow-btn:4px 4px 8px #0000008c, -4px -4px 8px #ffffff0f;--neo-shadow-sm:2px 2px 4px #0000008c, -2px -2px 4px #ffffff0d;--divider-dark:#000000a6;--divider-light:#ffffff12;--border:#2da89a1a;--border2:#2da89a33;--accent:#2da89a;--accent-light:#3dbfb0;--accent-dark:#1d8b7e;--accent-glow:#2da89a38;--accent2:#2da89a;--accent3:#2da89a;--own-bubble:#1c403e;--own-bubble2:#224a49;--other-bubble:#15302f;--text:#e8f5f3;--text2:#9cbdba;--text3:#5a8582;--success:#27ae60;--danger:#c0392b;--warn:#e67e22;--sidebar-w:300px;--topbar-h:56px;--acrylic-panel:#102423bf;--acrylic-modal:#102423d9;--acrylic-blur:blur(16px);--font-ui:"Space Grotesk", sans-serif;--font-mono:"JetBrains Mono", monospace;--font-brand:"Space Grotesk", sans-serif}[data-theme=light]{--overlay-bg:#5c8c8859;--modal-ambient:#5c8c884d;--bg:#b8d4d2;--bg2:#c0dada;--surface:#cce2e0;--surface2:#d4e8e6;--surface3:#ddf0ee;--surface4:#e8f5f3;--neo-shadow-out:6px 6px 12px #5c8c8880, -6px -6px 12px #ffffffb3;--neo-shadow-in:inset 6px 6px 12px #5c8c8873, inset -6px -6px 12px #ffffffa6;--neo-shadow-btn:4px 4px 8px #5c8c8873, -4px -4px 8px #ffffffa6;--neo-shadow-sm:2px 2px 4px #5c8c8866, -2px -2px 4px #fff9;--divider-dark:#5c8c8880;--divider-light:#ffffffb3;--border:#2da89a26;--border2:#2da89a47;--accent:#2da89a;--accent-light:#3dbfb0;--accent-dark:#1d8b7e;--accent-glow:#2da89a33;--accent2:#2da89a;--accent3:#2da89a;--own-bubble:#c2dbd8;--own-bubble2:#aecfcc;--other-bubble:#cde4e2;--text:#1a4040;--text2:#2d6060;--text3:#7aacaa;--success:#27ae60;--danger:#c0392b;--warn:#e67e22;--acrylic-panel:#cce2e0bf;--acrylic-modal:#cce2e0d9;--acrylic-blur:blur(16px)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{font-family:var(--font-ui);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;transition:background .3s,color .3s}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px;transition:background .2s}::-webkit-scrollbar-thumb:hover{background:var(--accent);box-shadow:0 0 6px var(--accent-glow)}.app-layout{background:var(--bg);height:100dvh;display:flex;position:relative;overflow:hidden}.app-layout:before,.app-layout:after{content:"";filter:blur(100px);z-index:0;pointer-events:none;opacity:.6;border-radius:50%;animation:15s ease-in-out infinite alternate ambient-drift;position:absolute}.app-layout:before{background:radial-gradient(circle, var(--accent-glow) 0%, transparent 70%);width:40vw;height:40vw;animation-delay:0s;top:-10vw;left:-10vw}.app-layout:after{background:radial-gradient(circle,#1d8b7e26 0%,#0000 70%);width:50vw;height:50vw;animation-delay:-5s;bottom:-15vw;right:-10vw}@keyframes ambient-drift{0%{opacity:.5;transform:translate(0)scale(1)}33%{opacity:.7;transform:translate(5vw,8vh)scale(1.1)}66%{opacity:.6;transform:translate(-3vw,12vh)scale(.9)}to{opacity:.5;transform:translate(-8vw,-5vh)scale(1.05)}}.auth-page{background:var(--bg2);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.auth-page:before{content:"";pointer-events:none;background:radial-gradient(60% 50% at 20%,#2da89a14 0%,#0000 60%),radial-gradient(40% 60% at 80% 30%,#1d8b7e0f 0%,#0000 60%);animation:8s ease-in-out infinite alternate ambient-shift;position:absolute;inset:0}@keyframes ambient-shift{0%{opacity:1;transform:scale(1)}to{opacity:.7;transform:scale(1.08)}}.auth-card{background:var(--acrylic-panel);-webkit-backdrop-filter:var(--acrylic-blur);box-shadow:var(--neo-shadow-out);border:.5px solid var(--divider-light);border-radius:20px;width:100%;max-width:400px;padding:40px;animation:.5s cubic-bezier(.34,1.3,.64,1) auth-card-spring;position:relative}@keyframes auth-card-spring{0%{opacity:0;transform:translateY(32px)scale(.94)}to{opacity:1;transform:none}}.auth-logo{align-items:center;gap:10px;margin-bottom:28px;display:flex}.logo-mark{color:var(--accent);font-size:24px;line-height:1;animation:4s ease-in-out infinite logo-float;display:inline-block}.logo-mark.xl{opacity:.25;font-size:48px;animation:none}@keyframes logo-float{0%,to{filter:drop-shadow(0 0 8px var(--accent-glow));transform:translateY(0)}50%{filter:drop-shadow(0 0 16px var(--accent-glow));transform:translateY(-3px)}}.logo-text{font-family:var(--font-brand);letter-spacing:.08em;color:var(--text);font-size:16px;font-weight:700}.logo-tag{font-family:var(--font-mono);background:var(--accent);color:var(--bg);letter-spacing:.12em;border-radius:4px;padding:2px 6px;font-size:9px;font-weight:600}.auth-card h2{font-size:22px;font-weight:700;font-family:var(--font-brand);color:var(--text);margin-bottom:24px}.input-group{margin-bottom:14px}.input-group label{letter-spacing:.06em;text-transform:uppercase;color:var(--text3);font-size:11px;font-weight:600;font-family:var(--font-mono);margin-bottom:6px;display:block}input[type=email],input[type=password],input[type=text],.input-group input{background:var(--surface2);width:100%;box-shadow:var(--neo-shadow-in);border:.5px solid var(--border);color:var(--text);font-family:var(--font-ui);border-radius:10px;outline:none;padding:10px 14px;font-size:14px;transition:border-color .25s,box-shadow .35s cubic-bezier(.16,1,.3,1)}input:focus{border-color:var(--accent);box-shadow:var(--neo-shadow-in), 0 0 0 3px var(--accent-glow)}.input-with-prefix{background:var(--surface2);box-shadow:var(--neo-shadow-in);border:.5px solid var(--border);border-radius:10px;align-items:center;transition:border-color .25s,box-shadow .35s cubic-bezier(.16,1,.3,1);display:flex;overflow:hidden}.input-with-prefix:focus-within{border-color:var(--accent);box-shadow:var(--neo-shadow-in), 0 0 0 3px var(--accent-glow)}.input-with-prefix input{box-shadow:none;background:0 0;border:none;flex:1;padding:10px 14px}.input-prefix{color:var(--text3);font-family:var(--font-mono);-webkit-user-select:none;user-select:none;padding:0 10px;font-size:13px}.btn-primary{background:linear-gradient(135deg, var(--accent-light), var(--accent-dark));color:#fff;width:100%;font-family:var(--font-ui);cursor:pointer;box-shadow:4px 4px 8px #0006, -2px -2px 6px #ffffff14, 0 0 20px var(--accent-glow);border:none;border-radius:12px;padding:12px;font-size:14px;font-weight:700;transition:opacity .2s,box-shadow .2s,transform .1s;position:relative;overflow:hidden}.btn-primary:before{content:"";background:linear-gradient(90deg,#0000,#fff3,#0000);width:60%;height:100%;transition:left;position:absolute;top:0;left:-100%;transform:skew(-15deg)}.btn-primary:hover:not(:disabled):before{transition:left .55s;left:160%}.btn-primary:hover:not(:disabled){opacity:.9;box-shadow:4px 4px 8px #0006, -2px -2px 6px #ffffff14, 0 0 28px var(--accent-glow);animation:1.5s ease-in-out infinite alternate btn-pulse}@keyframes btn-pulse{0%{box-shadow:4px 4px 8px #0006, -2px -2px 6px #ffffff14, 0 0 28px var(--accent-glow)}to{box-shadow:4px 4px 8px #0006, -2px -2px 6px #ffffff14, 0 0 40px var(--accent-light)}}.btn-primary:active:not(:disabled){transform:scale(.97)}.btn-primary:disabled{opacity:.35;cursor:not-allowed;box-shadow:none}.btn-ghost{border:1px solid var(--border2);color:var(--text2);font-family:var(--font-ui);cursor:pointer;background:0 0;border-radius:10px;padding:7px 14px;font-size:13px;transition:all .15s}.btn-ghost:hover{background:var(--surface3);color:var(--text);border-color:var(--accent)}.auth-switch{text-align:center;color:var(--text3);margin-top:16px;font-size:13px}.auth-switch button{color:var(--accent);cursor:pointer;font-family:var(--font-ui);background:0 0;border:none;font-size:13px;font-weight:600;transition:color .15s}.auth-switch button:hover{color:var(--accent-light)}.auth-error{color:var(--danger);background:#c0392b1a;border:1px solid #c0392b47;border-radius:8px;margin-bottom:14px;padding:8px 12px;font-size:12px}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--acrylic-panel);-webkit-backdrop-filter:var(--acrylic-blur);box-shadow:1.2px 0 0 var(--divider-dark), 2px 0 0 var(--divider-light), 4px 0 20px #00000059;z-index:10;border-right:none;flex-direction:column;display:flex;overflow:hidden}.sidebar-header{height:var(--topbar-h);box-shadow:0 -.8px 0 var(--divider-light) inset, 0 -1.2px 0 var(--divider-dark) inset, 0 4px 8px #00000040;flex-shrink:0;justify-content:space-between;align-items:center;padding:16px;display:flex}.sidebar-brand{align-items:center;gap:8px;display:flex}.sidebar-brand .logo-text{letter-spacing:.1em;font-size:14px;font-family:var(--font-brand);font-weight:700}.sidebar-brand .logo-mark{font-size:16px;animation:none}.icon-btn{background:var(--surface2);box-shadow:var(--neo-shadow-btn);border:.5px solid var(--divider-light);color:var(--text2);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;transition:color .15s,border-color .15s,box-shadow .15s,transform .2s cubic-bezier(.34,1.56,.64,1);display:flex}.icon-btn:hover{color:var(--accent);border-color:var(--accent);box-shadow:0 0 10px var(--accent-glow), var(--neo-shadow-btn);transform:scale(1.1)}.icon-btn:active{box-shadow:var(--neo-shadow-in);transition:transform .1s;transform:scale(.92)}.icon-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px;box-shadow:0 0 0 3px var(--accent-glow), var(--neo-shadow-btn)}.icon-btn-active{color:var(--accent)!important;border-color:var(--accent)!important;box-shadow:0 0 8px var(--accent-glow), var(--neo-shadow-in)!important}.sidebar-user{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:8px;padding:10px 14px;display:flex}.sidebar-user-info{cursor:pointer;border-radius:10px;outline:none;flex:1;align-items:center;gap:10px;min-width:0;padding:6px 8px;transition:background .15s;display:flex}.sidebar-user-info:hover{background:var(--surface3);box-shadow:var(--neo-shadow-in)}.sidebar-user-info:focus-visible{background:var(--surface3);box-shadow:0 0 0 2px var(--accent), 0 0 10px var(--accent-glow), var(--neo-shadow-in)}.user-name{color:var(--text);font-size:13px;font-weight:600;font-family:var(--font-brand)}.user-handle{color:var(--accent);font-size:11px;font-family:var(--font-mono)}.chat-list{flex:1;padding:6px 0;overflow-y:auto}.empty-state{text-align:center;color:var(--text2);padding:40px 20px;font-size:13px}.empty-state p{margin-bottom:12px}.muted{color:var(--text3);font-style:italic}.chat-item{cursor:pointer;border-radius:12px;align-items:center;gap:10px;margin:2px 8px;padding:10px 14px;transition:background .15s,box-shadow .15s;animation:.35s cubic-bezier(.16,1,.3,1) both chat-item-in;display:flex;position:relative}.chat-item:first-child{animation-delay:30ms}.chat-item:nth-child(2){animation-delay:60ms}.chat-item:nth-child(3){animation-delay:90ms}.chat-item:nth-child(4){animation-delay:.12s}.chat-item:nth-child(5){animation-delay:.15s}.chat-item:nth-child(6){animation-delay:.18s}.chat-item:nth-child(7){animation-delay:.21s}.chat-item:nth-child(8){animation-delay:.24s}.chat-item:nth-child(n+9){animation-delay:.27s}@keyframes chat-item-in{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:none}}.chat-item:hover{background:var(--surface3);box-shadow:var(--neo-shadow-sm);transform:translate(4px)}.chat-item.active{background:var(--surface3);box-shadow:var(--neo-shadow-in)}.chat-item:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;background:var(--surface3);box-shadow:0 0 0 3px var(--accent-glow), var(--neo-shadow-sm);z-index:1}.chat-item.active:before{content:"";background:var(--accent);width:3px;box-shadow:0 0 8px var(--accent-glow);border-radius:0 3px 3px 0;animation:2.5s ease-in-out infinite indicator-glow;position:absolute;top:25%;bottom:25%;left:0}@keyframes indicator-glow{0%,to{box-shadow:0 0 8px var(--accent-glow);opacity:1}50%{box-shadow:0 0 20px var(--accent-glow), 0 0 4px var(--accent);opacity:.7}}.chat-item-info{flex:1;min-width:0}.chat-item-top{justify-content:space-between;align-items:baseline;margin-bottom:3px;display:flex}.chat-item-name{color:var(--text);font-size:13px;font-weight:600;font-family:var(--font-brand)}.chat-item-time{color:var(--text3);font-size:10px;font-family:var(--font-mono);flex-shrink:0;margin-left:6px}.chat-item-preview{color:var(--text2);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.unread-badge{background:var(--accent);color:#fff;min-width:18px;height:18px;font-size:10px;font-weight:700;font-family:var(--font-mono);box-shadow:0 0 8px var(--accent-glow), var(--neo-shadow-sm);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;padding:0 5px;animation:.3s cubic-bezier(.34,1.56,.64,1) badge-pop,3s ease-in-out 1s infinite badge-bounce;display:flex}@keyframes badge-pop{0%{transform:scale(0)}to{transform:scale(1)}}@keyframes badge-bounce{0%,90%,to{transform:scale(1)}95%{transform:scale(1.2)}}.avatar{background:linear-gradient(135deg, var(--accent-dark), var(--accent));color:#fff;width:38px;height:38px;box-shadow:var(--neo-shadow-btn);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:15px;font-weight:700;transition:box-shadow .3s;animation:.4s cubic-bezier(.16,1,.3,1) both avatar-appear;display:flex;overflow:hidden}@keyframes avatar-appear{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.avatar.sm{width:32px;height:32px;font-size:13px}.avatar img{object-fit:cover;width:100%;height:100%}.avatar-wrap{cursor:pointer;flex-shrink:0;transition:transform .2s cubic-bezier(.34,1.56,.64,1);position:relative}.avatar-wrap.sm .avatar{width:32px;height:32px;font-size:13px}.avatar-wrap:hover{transform:scale(1.08)translateY(-3px)}.avatar-wrap:hover .avatar{box-shadow:var(--neo-shadow-btn), 0 0 16px var(--accent-glow)}.avatar-dot{background:var(--success);border:2px solid var(--surface);border-radius:50%;width:9px;height:9px;animation:.3s cubic-bezier(.16,1,.3,1) dot-pop,2.5s ease-in-out .5s infinite dot-pulse;position:absolute;bottom:1px;right:1px}@keyframes dot-pop{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}@keyframes dot-pulse{0%,to{box-shadow:0 0 6px var(--success);transform:scale(1)}50%{box-shadow:0 0 14px var(--success), 0 0 4px var(--success);transform:scale(1.15)}}.chat-item.active .avatar-dot{border-color:var(--surface3)}.chat-window{z-index:1;background:0 0;flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.chat-window.empty{justify-content:center;align-items:center}.chat-empty-state{text-align:center;color:var(--text2)}.chat-empty-state p{margin-top:12px;font-size:14px}.chat-topbar{height:var(--topbar-h);background:var(--acrylic-panel);-webkit-backdrop-filter:var(--acrylic-blur);box-shadow:0 1.2px 0 var(--divider-dark), 0 2px 0 var(--divider-light), 0 4px 16px #0000004d;z-index:20;flex-shrink:0;align-items:center;gap:12px;padding:0 20px;display:flex}.chat-topbar-name{color:var(--text);font-size:15px;font-weight:600;font-family:var(--font-brand)}.chat-topbar-sub{margin-top:1px}.topbar-actions{gap:6px;margin-left:auto;display:flex}.chat-topbar .avatar.sm{justify-content:center;align-items:center;display:flex;overflow:hidden}.chat-topbar .avatar.sm img{object-fit:cover;border-radius:50%;width:100%;height:100%;display:block}.online-status{font-size:11px;font-family:var(--font-mono);align-items:center;gap:4px;display:flex}.online-status.online{color:var(--success)}.online-status.offline{color:var(--text3)}.online-dot{background:var(--success);width:6px;height:6px;box-shadow:0 0 6px var(--success);border-radius:50%;flex-shrink:0;animation:2s ease-in-out infinite pulse-online}@keyframes pulse-online{0%,to{opacity:1}50%{opacity:.4}}.messages-area{flex-direction:column;flex:1;gap:3px;padding:16px 20px 8px;display:flex;overflow-y:auto}.load-more-btn{background:var(--surface);box-shadow:var(--neo-shadow-btn);border:.5px solid var(--border);color:var(--text2);font-family:var(--font-mono);cursor:pointer;border-radius:20px;align-self:center;margin-bottom:8px;padding:6px 16px;font-size:11px;transition:color .15s,border-color .15s,box-shadow .15s;animation:3s ease-in-out infinite load-more-pulse}@keyframes load-more-pulse{0%,to{box-shadow:var(--neo-shadow-btn)}50%{box-shadow:var(--neo-shadow-btn), 0 0 14px var(--accent-glow)}}.load-more-btn:hover{color:var(--accent);border-color:var(--accent);box-shadow:0 0 10px var(--accent-glow), var(--neo-shadow-btn)}.load-more-btn:disabled{opacity:.4;cursor:not-allowed;animation:none}.date-separator{align-self:center;align-items:center;gap:10px;width:100%;margin:10px 0 6px;animation:.4s both fade-in-up;display:flex}@keyframes fade-in-up{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.date-separator:before,.date-separator:after{content:"";background:var(--border);flex:1;height:1px}.date-separator span{font-size:10px;font-family:var(--font-mono);color:var(--text3);white-space:nowrap;letter-spacing:.06em}.bubble-wrap{flex-direction:row;flex-shrink:0;align-items:flex-end;gap:8px;width:100%;margin-bottom:24px;display:flex;position:relative}.bubble-wrap.own{justify-content:flex-end}.bubble-wrap.other{justify-content:flex-start}.bubble-wrap-anim{animation:.22s cubic-bezier(.16,1,.3,1) both bubble-in}.bubble-wrap.own.bubble-wrap-anim{animation-name:bubble-in-own}@keyframes bubble-in{0%{opacity:0;transform:translate(-14px)scale(.95)}60%{transform:translate(4px)scale(1.03)}to{opacity:1;transform:none}}@keyframes bubble-in-own{0%{opacity:0;transform:translate(14px)scale(.95)}60%{transform:translate(-4px)scale(1.03)}to{opacity:1;transform:none}}.bubble-and-reactions{flex-direction:column;min-width:0;max-width:65%;display:flex}.bubble-wrap.own .bubble-and-reactions{align-items:flex-end;margin-left:auto}.bubble-wrap.other .bubble-and-reactions{align-items:flex-start;margin-right:auto}.msg-highlight .bubble{animation:1.5s forwards highlight-flash}@keyframes highlight-flash{0%{box-shadow:0 0 0 2px var(--accent), 0 0 16px var(--accent-glow), var(--neo-shadow-out)}60%{box-shadow:0 0 0 2px #2da89a4d, var(--neo-shadow-out)}to{box-shadow:var(--neo-shadow-out)}}.bubble{box-sizing:border-box;word-wrap:break-word;word-break:break-word;border-radius:18px;flex-direction:column;width:fit-content;max-width:260px;padding:7px 10px 4px;font-size:14px;transition:transform .1s;display:flex;position:relative}.bubble p{white-space:pre-wrap;width:100%;margin:0;line-height:1.4;display:block}.bubble:after{content:"";background:var(--divider-light);pointer-events:none;border-radius:4px;height:1.2px;position:absolute;top:4px;left:12px;right:12px}.bubble-own{background:color-mix(in srgb, var(--own-bubble) 88%, transparent);-webkit-backdrop-filter:blur(8px);color:var(--text);box-shadow:var(--neo-shadow-out);border:.5px solid color-mix(in srgb, var(--own-bubble2) 70%, transparent);border-radius:18px 18px 4px}.bubble-other{background:color-mix(in srgb, var(--other-bubble) 84%, transparent);-webkit-backdrop-filter:blur(8px);color:var(--text);box-shadow:var(--neo-shadow-out);border:.5px solid color-mix(in srgb, var(--border) 70%, transparent);border-radius:4px 18px 18px}.bubble-sticker{box-shadow:none!important;background:0 0!important;border:none!important;max-width:140px!important;padding:0!important}.bubble-deleted{opacity:.45;align-items:center;gap:6px;font-style:italic;flex-direction:row!important}.deleted-icon{opacity:.7;display:flex}.deleted-text{color:var(--text3);flex:1;font-size:13px}.bubble-time{opacity:.55;font-size:10px;font-family:var(--font-mono);flex-shrink:0}.bubble-own .bubble-time{color:var(--text2)}.bubble-other .bubble-time{color:var(--text3)}.msg-actions{opacity:0;flex-shrink:0;align-self:center;align-items:center;gap:4px;height:fit-content;transition:opacity .2s;display:flex}.bubble-wrap:hover .msg-actions,.msg-actions.visible{opacity:1}.msg-actions-left{order:-1}.msg-actions-right{order:1}.msg-action-btn{background:var(--surface);box-shadow:var(--neo-shadow-btn);border:.5px solid var(--divider-light);color:var(--text2);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;transition:color .15s,border-color .15s,box-shadow .15s,transform .2s cubic-bezier(.34,1.56,.64,1);display:flex}.msg-action-btn:hover:not(:disabled){color:var(--accent);border-color:var(--accent);box-shadow:0 0 8px var(--accent-glow), var(--neo-shadow-btn);transform:scale(1.15)translateY(-1px)}.msg-action-btn:active:not(:disabled){box-shadow:var(--neo-shadow-in);transform:scale(.92)}.msg-action-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.msg-action-danger:hover{color:var(--danger)!important;border-color:var(--danger)!important;box-shadow:0 0 8px #c0392b4d!important}.msg-action-wrap,.action-item-wrap{position:relative}.emoji-picker{background:var(--acrylic-panel);-webkit-backdrop-filter:var(--acrylic-blur);box-shadow:var(--neo-shadow-out), 0 0 20px #0000004d;border:.5px solid var(--border2);z-index:60;white-space:nowrap;border-radius:14px;gap:2px;padding:6px 8px;animation:.15s cubic-bezier(.16,1,.3,1) picker-in;display:flex;position:absolute;bottom:calc(100% + 6px)}@keyframes picker-in{0%{opacity:0;transform:translateY(6px)scale(.9)}to{opacity:1;transform:none}}.picker-left{right:0}.picker-right{left:0}.emoji-option{cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;transition:background .1s,transform .2s cubic-bezier(.34,1.56,.64,1);display:flex}.emoji-option:hover{background:var(--surface3);transform:scale(1.35)translateY(-2px)}.emoji-popover{background:var(--acrylic-panel);-webkit-backdrop-filter:var(--acrylic-blur);border:.5px solid var(--border2);z-index:1000;box-shadow:var(--neo-shadow-out), 0 8px 24px #0000004d;border-radius:12px;grid-template-columns:repeat(6,1fr);gap:4px;margin-bottom:8px;padding:8px;display:grid;position:absolute;bottom:100%;left:50%;transform:translate(-50%)}.emoji-popover button{cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;font-size:18px;transition:background .1s}.emoji-popover button:hover{background:var(--surface2)}.reactions-under{z-index:5;flex-wrap:wrap;gap:4px;margin-top:-10px;padding:0 8px;display:flex}.reactions-under-own{justify-content:flex-end}.reactions-under-other{justify-content:flex-start}.reaction-chip{background:var(--surface);box-shadow:var(--neo-shadow-sm);border:.5px solid var(--border);cursor:pointer;border-radius:12px;align-items:center;gap:3px;margin-bottom:2px;padding:2px 6px;font-size:13px;transition:border-color .15s,box-shadow .15s,transform .2s cubic-bezier(.34,1.56,.64,1);animation:.2s cubic-bezier(.16,1,.3,1) chip-in;display:flex}@keyframes chip-in{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.reaction-chip:hover{box-shadow:0 0 8px var(--accent-glow), var(--neo-shadow-btn);transform:scale(1.15)translateY(-1px)}.reaction-chip.mine{border-color:var(--accent);box-shadow:0 0 8px var(--accent-glow), var(--neo-shadow-sm);background:#2da89a1a}.reaction-count{font-size:11px;font-family:var(--font-mono);color:var(--text2)}.reaction-add-btn{background:var(--surface);box-shadow:var(--neo-shadow-sm);border:.5px solid var(--border);color:var(--text3);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;transition:color .15s,border-color .15s,box-shadow .15s;display:flex}.reaction-add-btn:hover{color:var(--accent);border-color:var(--accent);box-shadow:0 0 6px var(--accent-glow)}.reply-preview{cursor:pointer;border-radius:8px;align-items:stretch;width:100%;min-width:0;margin-bottom:6px;transition:opacity .15s;display:flex;overflow:hidden}.reply-preview:hover{opacity:.75}.reply-own{background:#00000026}.reply-other{background:#ffffff0f}[data-theme=light] .reply-other{background:#00000012}.reply-bar{flex-shrink:0;width:3px}.reply-own .reply-bar{background:var(--divider-light)}.reply-other .reply-bar{background:var(--accent);box-shadow:0 0 6px var(--accent-glow)}.reply-content{flex-direction:column;flex:1;gap:1px;min-width:0;padding:5px 8px;display:flex}.reply-name{font-size:11px;font-weight:600;font-family:var(--font-brand);color:var(--accent)}.reply-text{opacity:.6;white-space:nowrap;text-overflow:ellipsis;font-size:12px;display:block;overflow:hidden}.reply-thumb{object-fit:cover;flex-shrink:0;width:38px;height:38px}.reply-bar-active{background:var(--surface);border-top:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;padding:8px 16px;animation:.2s cubic-bezier(.16,1,.3,1) slide-up;display:flex}@keyframes slide-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.reply-bar-line{background:var(--accent);width:3px;height:32px;box-shadow:0 0 8px var(--accent-glow);border-radius:3px;flex-shrink:0}.reply-bar-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.reply-bar-name{color:var(--accent);font-size:11px;font-weight:600;font-family:var(--font-brand)}.reply-bar-text{color:var(--text2);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.reply-bar-close{color:var(--text3);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:4px;font-size:14px;line-height:1;transition:color .15s}.reply-bar-close:hover{color:var(--text)}.typing-wrap{align-items:center;gap:8px;padding:4px 0 8px;animation:.2s both bubble-in;display:flex}.typing-bubble{background:var(--other-bubble);border:.5px solid var(--border);box-shadow:var(--neo-shadow-out);border-radius:18px 18px 18px 4px;align-items:center;gap:5px;padding:10px 14px;display:flex}.typing-dot{background:var(--text3);border-radius:50%;width:7px;height:7px;animation:1.2s ease-in-out infinite typing-bounce}.typing-dot:nth-child(2){animation-delay:.15s}.typing-dot:nth-child(3){animation-delay:.3s}@keyframes typing-bounce{0%,60%,to{opacity:.35;transform:translateY(0)}30%{opacity:1;transform:translateY(-7px)}}.message-form{background:var(--acrylic-panel);-webkit-backdrop-filter:var(--acrylic-blur);box-shadow:0 -1.2px 0 var(--divider-light), 0 -2px 0 var(--divider-dark), 0 -4px 12px #0003;z-index:20;flex-shrink:0;align-items:flex-end;gap:8px;padding:10px 14px 14px;display:flex;position:relative;overflow:visible}.message-input{background:var(--surface2);min-width:0;box-shadow:var(--neo-shadow-in);border:.5px solid var(--border);color:var(--text);font-family:var(--font-ui);resize:none;border-radius:12px;outline:none;flex:1;max-height:120px;padding:10px 14px;font-size:14px;line-height:1.5;transition:border-color .25s,box-shadow .35s cubic-bezier(.16,1,.3,1);overflow-y:auto}.message-input:focus{border-color:var(--accent);box-shadow:var(--neo-shadow-in), 0 0 0 3px var(--accent-glow), 0 0 20px #2da89a0f}.message-input::placeholder{color:var(--text3)}.message-input:disabled{opacity:.5;cursor:not-allowed}.send-btn{background:linear-gradient(135deg, var(--accent-light), var(--accent-dark));color:#fff;cursor:pointer;width:40px;height:40px;box-shadow:4px 4px 8px #00000073, -2px -2px 6px #ffffff14, 0 0 16px var(--accent-glow);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:opacity .2s,box-shadow .2s,transform .1s;display:flex;position:relative;overflow:hidden}.send-btn:after{content:"";border-radius:inherit;opacity:0;background:radial-gradient(circle,#ffffff4d 0%,#0000 70%);transition:transform .4s,opacity .4s;position:absolute;inset:0;transform:scale(0)}.send-btn:hover:not(:disabled){opacity:.9;box-shadow:4px 4px 8px #00000073, -2px -2px 6px #ffffff14, 0 0 24px var(--accent-glow)}.send-btn:active:not(:disabled){box-shadow:var(--neo-shadow-in), 0 0 12px var(--accent-glow);animation:.3s cubic-bezier(.34,1.56,.64,1) send-burst}.send-btn:focus-visible{outline:2px solid var(--accent-light);outline-offset:2px;box-shadow:0 0 0 3px var(--accent-glow)}@keyframes send-burst{0%{transform:scale(1)}40%{transform:scale(.84)}70%{transform:scale(1.06)}to{transform:scale(1)}}.send-btn:disabled{opacity:.35;cursor:not-allowed;box-shadow:none}.send-btn-mic{background:var(--surface2)!important;box-shadow:var(--neo-shadow-btn)!important;color:var(--text2)!important}.send-btn-mic:hover:not(:disabled){color:var(--accent)!important;box-shadow:0 0 12px var(--accent-glow), var(--neo-shadow-btn)!important}.tool-btn{color:var(--text3);cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:color .15s,background .15s,transform .2s cubic-bezier(.34,1.56,.64,1);display:flex}.tool-btn:hover{color:var(--accent);background:var(--surface3);transform:scale(1.1)}.tool-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px;box-shadow:0 0 0 3px var(--accent-glow)}.tool-btn:disabled{opacity:.4;cursor:not-allowed}.voice-recording-bar{background:var(--surface2);box-shadow:0 -1.2px 0 var(--divider-light), 0 -2px 0 var(--divider-dark);flex-shrink:0;align-items:center;gap:10px;padding:10px 16px;animation:.2s slide-up;display:flex}.voice-rec-dot{background:var(--danger);border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:1s ease-in-out infinite pulse-dot;box-shadow:0 0 8px #c0392b99}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.voice-rec-label{color:var(--danger);font-size:13px;font-weight:600}.voice-rec-timer{font-family:var(--font-mono);color:var(--text2);min-width:36px;font-size:13px}.voice-cancel-btn{color:var(--text2);font-family:var(--font-ui);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:5px;margin-left:auto;padding:5px 10px;font-size:12px;transition:color .15s,background .15s;display:flex}.voice-cancel-btn:hover{color:var(--danger);background:#c0392b1a}.voice-send-btn-bar{background:linear-gradient(135deg, var(--accent-light), var(--accent-dark));color:#fff;font-family:var(--font-ui);cursor:pointer;box-shadow:0 0 12px var(--accent-glow);border:none;border-radius:8px;align-items:center;gap:5px;padding:5px 12px;font-size:12px;font-weight:700;transition:opacity .15s;display:flex}.voice-send-btn-bar:hover{opacity:.85}.voice-msg{align-items:center;gap:8px;min-width:180px;max-width:240px;display:flex}.voice-play-btn{width:30px;height:30px;box-shadow:var(--neo-shadow-sm);color:currentColor;cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,transform .1s;display:flex}.voice-play-btn:hover{background:#fff3;transform:scale(1.1)}.bubble-other .voice-play-btn{background:var(--surface3);color:var(--text)}.bubble-other .voice-play-btn:hover{background:var(--surface4)}.voice-progress-wrap{cursor:pointer;flex:1;padding:8px 0}.voice-progress-track{background:var(--surface2);border-radius:3px;height:3px;overflow:hidden;box-shadow:inset 1px 1px 3px #0006}.bubble-other .voice-progress-track{background:var(--surface3)}.voice-progress-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .1s linear}.bubble-other .voice-progress-fill{background:var(--accent)}.voice-time{font-size:11px;font-family:var(--font-mono);color:var(--text3);white-space:nowrap}.msg-image-wrap{cursor:zoom-in;border-radius:10px;max-width:280px;overflow:hidden}.msg-image{object-fit:cover;border-radius:10px;width:100%;max-width:280px;max-height:320px;display:block}.img-lightbox{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:200;cursor:zoom-out;background:#000000e6;justify-content:center;align-items:center;animation:.2s overlay-in;display:flex;position:fixed;inset:0}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.img-lightbox img{max-width:90vw;max-height:90vh;box-shadow:var(--neo-shadow-out), 0 20px 80px #0009;border-radius:12px;animation:.25s cubic-bezier(.16,1,.3,1) modal-in}@keyframes modal-in{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:none}}.msg-sticker{object-fit:contain;width:120px;height:120px;display:block}.sticker-picker{background:var(--acrylic-panel);width:300px;height:380px;-webkit-backdrop-filter:var(--acrylic-blur);box-shadow:var(--neo-shadow-out), 0 8px 32px #0006;border:.5px solid var(--border2);z-index:100;border-radius:16px;flex-direction:column;animation:.2s cubic-bezier(.16,1,.3,1) picker-in;display:flex;position:absolute;bottom:calc(100% + 12px);left:0;overflow:hidden}.sticker-picker-header{box-shadow:0 1.2px 0 var(--divider-dark), 0 2px 0 var(--divider-light);color:var(--text);font-size:13px;font-weight:600;font-family:var(--font-brand);flex-shrink:0;align-items:center;gap:6px;padding:10px 12px;display:flex}.sticker-empty{text-align:center;color:var(--text2);padding:24px 16px;font-size:13px}.sticker-empty p{margin-bottom:10px}.sticker-grid{grid-template-columns:repeat(4,1fr);gap:4px;max-height:220px;padding:8px;display:grid;overflow-y:auto}.sticker-item{aspect-ratio:1;cursor:pointer;background:var(--surface2);box-shadow:var(--neo-shadow-sm);border-radius:8px;transition:background .15s,transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .15s;position:relative;overflow:hidden}.sticker-item:hover{background:var(--surface3);transform:scale(1.1)translateY(-2px);box-shadow:0 4px 12px #0000004d}.sticker-item img{object-fit:contain;width:100%;height:100%;padding:4px}.sticker-remove{color:#fff;cursor:pointer;background:#000000a6;border:none;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:9px;line-height:1;display:none;position:absolute;top:2px;right:2px}.sticker-item:hover .sticker-remove{display:flex}.sp-pack-list,.sticker-grid{flex:1;max-height:none;overflow-y:auto}.sp-pack-title{flex:1}.sp-header-actions{gap:4px;display:flex}.sp-back{margin-right:2px}.sp-delete-pack{color:var(--danger)}.sp-pack-row{cursor:pointer;border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:10px 12px;transition:background .12s;display:flex}.sp-pack-row:last-child{border-bottom:none}.sp-pack-row:hover{background:var(--surface3)}.sp-pack-icon{flex-shrink:0;font-size:22px}.sp-pack-info{flex:1;min-width:0}.sp-pack-name{color:var(--text);font-size:13px;font-weight:600;font-family:var(--font-brand);display:block}.sp-pack-count{color:var(--text2);font-size:11px;display:block}.sp-pack-preview{flex-shrink:0;gap:2px;display:flex}.sp-preview-thumb{object-fit:contain;background:var(--surface2);border-radius:4px;width:28px;height:28px}.sp-chevron{color:var(--text2);flex-shrink:0}.sp-sticker-emoji{pointer-events:none;font-size:12px;line-height:1;position:absolute;bottom:2px;right:4px}.sp-create-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#000000a6;border-radius:12px;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.sp-create-box{background:var(--surface);border:.5px solid var(--border);width:240px;box-shadow:var(--neo-shadow-out), 0 8px 32px #00000080;border-radius:10px;flex-direction:column;gap:12px;padding:16px;display:flex}.sp-create-title{color:var(--text);font-size:13px;font-weight:700;font-family:var(--font-brand);margin:0}.sp-create-row{align-items:center;gap:8px;display:flex}.sp-emoji-input{text-align:center;border:.5px solid var(--border);background:var(--surface2);width:36px;color:var(--text);border-radius:6px;padding:4px;font-size:18px}.sp-name-input{border:.5px solid var(--border);background:var(--surface2);color:var(--text);border-radius:6px;flex:1;padding:5px 8px;font-size:13px}.sp-emoji-centered{text-align:center;align-self:center;width:48px;font-size:22px}.sp-hint{color:var(--text2);text-align:center;margin:0;font-size:11px}.sp-sticker-preview{object-fit:contain;background:var(--surface2);border-radius:8px;align-self:center;width:80px;height:80px;padding:4px}.sp-create-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.sp-create-actions button{cursor:pointer;border:none;border-radius:6px;padding:8px 14px;font-size:13px;font-weight:500;transition:opacity .2s}.sp-create-actions .btn-ghost{color:var(--text2);background:0 0}.sp-create-actions .btn-ghost:hover{background:var(--surface3);color:var(--text)}.sp-create-actions .btn-primary{background:var(--accent);color:#fff}.sp-create-actions .btn-primary:disabled{opacity:.5;cursor:not-allowed}.sp-add-banner{background:var(--surface2);box-shadow:var(--neo-shadow-sm);border:.5px solid var(--border);color:var(--text);cursor:pointer;border-radius:20px;align-items:center;gap:6px;width:fit-content;margin-top:4px;padding:5px 10px;font-size:12px;transition:background .12s;display:flex}.sp-add-banner:hover{background:var(--surface3)}.sp-add-banner--done{color:var(--text2);cursor:default;pointer-events:none;background:0 0;border-color:#0000}.sp-add-pack-icon{font-size:15px}.sp-add-pack-text{font-weight:500}.sp-add-icon{flex-shrink:0}.modal-overlay{background:var(--overlay-bg);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:100;justify-content:center;align-items:center;animation:.2s overlay-in;display:flex;position:fixed;inset:0}.modal{background:var(--acrylic-modal);-webkit-backdrop-filter:var(--acrylic-blur);box-shadow:var(--neo-shadow-out), 0 20px 60px var(--modal-ambient);border:.5px solid var(--border2);border-radius:20px;width:100%;max-width:360px;padding:24px;animation:.35s cubic-bezier(.34,1.56,.64,1) modal-spring}@keyframes modal-spring{0%{opacity:0;transform:scale(.88)translateY(16px)}to{opacity:1;transform:none}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.modal-header h3{font-size:16px;font-weight:700;font-family:var(--font-brand)}.modal-close{background:var(--surface2);box-shadow:var(--neo-shadow-sm);border:.5px solid var(--border);color:var(--text2);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;padding:0;font-size:14px;line-height:1;transition:color .15s,border-color .15s,box-shadow .15s;display:flex}.modal-close:hover{color:var(--accent);border-color:var(--accent);box-shadow:0 0 8px var(--accent-glow)}.back-btn{background:var(--surface2);box-shadow:var(--neo-shadow-sm);border:.5px solid var(--border);color:var(--text2);cursor:pointer;border-radius:50%;align-items:center;padding:6px;transition:color .15s,box-shadow .15s;display:flex}.back-btn:hover{color:var(--accent);box-shadow:0 0 8px var(--accent-glow)}.settings-modal{max-width:440px}.settings-tabs{background:var(--surface2);box-shadow:var(--neo-shadow-in);scrollbar-width:none;-ms-overflow-style:none;border-radius:10px;gap:4px;margin-bottom:20px;padding:4px;display:flex;overflow-x:auto}.settings-modal .settings-tabs::-webkit-scrollbar{display:none}.settings-tab{color:var(--text2);font-family:var(--font-ui);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:7px 12px;font-size:13px;font-weight:600;transition:background .15s,color .15s,box-shadow .15s}.settings-tab:hover{color:var(--text)}.settings-tab.active{background:var(--surface3);box-shadow:var(--neo-shadow-btn);color:var(--accent)}.settings-body{flex-direction:column;gap:14px;display:flex}.avatar-section{align-items:center;gap:16px;padding:4px 0 8px;display:flex}.settings-avatar{background:linear-gradient(135deg, var(--accent-dark), var(--accent));color:#fff;cursor:pointer;width:72px;min-width:72px;height:72px;box-shadow:var(--neo-shadow-out), 0 0 20px var(--accent-glow);border-radius:50%;justify-content:center;align-items:center;font-size:26px;font-weight:700;transition:transform .15s;display:flex;position:relative;overflow:hidden}.settings-avatar:hover{transform:scale(1.05)}.settings-avatar:hover .settings-avatar-overlay{opacity:1}.settings-avatar:after{content:"";background:conic-gradient(var(--accent) 0deg, var(--accent-dark) 120deg, var(--accent-light) 240deg, var(--accent) 360deg);z-index:-1;opacity:0;border-radius:50%;transition:opacity .3s;animation:3s linear infinite paused ring-spin;position:absolute;inset:-2px}.settings-avatar:hover:after{opacity:.5;animation-play-state:running}@keyframes ring-spin{to{transform:rotate(360deg)}}.settings-avatar-img{object-fit:cover;border-radius:50%;width:100%;height:100%}.settings-avatar-overlay{opacity:0;color:#fff;background:#00000080;border-radius:50%;justify-content:center;align-items:center;transition:opacity .15s;display:flex;position:absolute;inset:0}.avatar-section-info{flex-direction:column;gap:3px;display:flex}.avatar-hint{color:var(--text);font-size:13px;font-weight:600;font-family:var(--font-brand)}.avatar-hint-sub{color:var(--text3);font-size:11px}.settings-bio{background:var(--surface2);width:100%;box-shadow:var(--neo-shadow-in);border:.5px solid var(--border);color:var(--text);font-family:var(--font-ui);resize:none;border-radius:10px;outline:none;padding:10px 14px;font-size:14px;line-height:1.5;transition:border-color .25s,box-shadow .35s}.settings-bio:focus{border-color:var(--accent);box-shadow:var(--neo-shadow-in), 0 0 0 3px var(--accent-glow)}.settings-bio::placeholder{color:var(--text3)}.bio-count{font-size:10px;font-family:var(--font-mono);color:var(--text3);float:right}.settings-info-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.settings-info-label{letter-spacing:.06em;text-transform:uppercase;color:var(--text3);font-size:11px;font-weight:600;font-family:var(--font-mono)}.settings-info-value{color:var(--text);font-size:13px;font-family:var(--font-mono)}.username-input-wrap{position:relative}.username-input-wrap input{padding-right:36px}.username-status-icon{font-size:14px;font-weight:700;line-height:1;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.username-status-icon.ok{color:var(--success)}.username-status-icon.err{color:var(--danger)}.username-status-icon.spin{color:var(--text3);animation:1s linear infinite spin;display:inline-block}@keyframes spin{to{transform:translateY(-50%)rotate(360deg)}}.username-hint{font-size:11px;font-family:var(--font-mono);margin-top:5px;padding-left:2px}.username-hint.available{color:var(--success)}.username-hint.taken,.username-hint.invalid{color:var(--danger)}.username-hint.checking{color:var(--text3)}.settings-success{color:var(--success);background:#27ae6014;border:1px solid #27ae6040;border-radius:8px;padding:8px 12px;font-size:12px;animation:.2s slide-up}.settings-section-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text3);font-size:11px;font-weight:600;font-family:var(--font-brand)}.appearance-options{gap:10px;display:flex}.appearance-option{background:var(--surface2);box-shadow:var(--neo-shadow-btn);border:.5px solid var(--border);cursor:pointer;color:var(--text2);font-family:var(--font-ui);border-radius:14px;flex-direction:column;flex:1;align-items:center;gap:6px;padding:14px 10px;font-size:13px;font-weight:500;transition:all .2s;display:flex;position:relative}.appearance-option:hover{border-color:var(--accent);color:var(--text);background:var(--surface3)}.appearance-option.active{border-color:var(--accent);background:var(--surface3);color:var(--text);box-shadow:0 0 0 2px var(--accent-glow), var(--neo-shadow-btn)}.appearance-icon{font-size:22px;line-height:1}.appearance-check{color:var(--accent);font-size:12px;font-weight:700;position:absolute;top:8px;right:10px}.accounts-modal{max-width:320px}.accounts-list{flex-direction:column;gap:4px;margin-bottom:4px;display:flex}.account-item{cursor:pointer;border:.5px solid #0000;border-radius:10px;align-items:center;gap:10px;padding:10px 12px;transition:background .15s;display:flex}.account-item:hover:not(.active):not(.disabled){background:var(--surface3)}.account-item.active{background:var(--surface3);border-color:var(--border2);box-shadow:var(--neo-shadow-in)}.account-item.disabled{opacity:.5;cursor:wait}.acc-avatar{background:linear-gradient(135deg, var(--accent-dark), var(--accent))}.account-info{flex:1;min-width:0}.account-name{font-size:13px;font-weight:600;font-family:var(--font-brand);align-items:center;gap:6px;display:flex}.account-handle{color:var(--accent);font-size:11px;font-family:var(--font-mono)}.active-badge{background:var(--accent);color:#fff;font-size:9px;font-family:var(--font-mono);letter-spacing:.05em;border-radius:4px;padding:1px 6px;font-weight:600}.remove-account-btn{color:var(--text3);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;padding:4px;transition:color .15s,background .15s;display:flex}.remove-account-btn:hover{color:var(--danger);background:#c0392b1a}.accounts-divider{background:var(--border);height:1px;margin:8px 0}.accounts-actions{flex-direction:column;gap:4px;display:flex}.account-action-btn{color:var(--text2);font-family:var(--font-ui);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;width:100%;padding:8px 10px;font-size:13px;transition:background .15s,color .15s;display:flex}.account-action-btn:hover{background:var(--surface3);color:var(--text)}.account-action-btn.danger:hover{color:var(--danger);background:#c0392b1a}.add-account-form{flex-direction:column;gap:8px;display:flex}.add-account-form input{width:100%}.add-account-btns{justify-content:flex-end;align-items:center;gap:10px;margin-top:4px;display:flex}.profile-overlay{z-index:90;position:fixed;inset:0}.profile-panel{background:var(--surface);border-left:.5px solid var(--border2);z-index:91;width:300px;box-shadow:-20px 0 60px #0006, var(--neo-shadow-out);flex-direction:column;animation:.32s cubic-bezier(.34,1.2,.64,1) panel-spring;display:flex;position:fixed;top:0;bottom:0;right:0;overflow-y:auto}@keyframes panel-spring{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:none}}.profile-close{background:var(--surface2);box-shadow:var(--neo-shadow-btn);border:.5px solid var(--border);color:var(--text2);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:color .15s,border-color .15s,box-shadow .15s;display:flex;position:absolute;top:14px;right:14px}.profile-close:hover{color:var(--accent);border-color:var(--accent);box-shadow:0 0 8px var(--accent-glow)}.profile-header{text-align:center;border-bottom:1px solid var(--border);flex-direction:column;align-items:center;padding:52px 24px 28px;display:flex}.profile-avatar{background:linear-gradient(135deg, var(--accent-dark), var(--accent));color:#fff;width:80px;height:80px;box-shadow:var(--neo-shadow-out), 0 0 24px var(--accent-glow);border-radius:50%;justify-content:center;align-items:center;margin-bottom:14px;font-size:28px;font-weight:700;display:flex;position:relative;overflow:hidden}.profile-avatar img{object-fit:cover;width:100%;height:100%}.profile-online-dot{background:var(--success);border:2px solid var(--surface);width:12px;height:12px;box-shadow:0 0 8px var(--success);border-radius:50%;position:absolute;bottom:4px;right:4px}.profile-name{font-size:18px;font-weight:700;font-family:var(--font-brand);margin-bottom:4px}.profile-handle{color:var(--accent);font-size:12px;font-family:var(--font-mono);margin-bottom:6px}.profile-status-text{color:var(--text3);font-size:12px;font-family:var(--font-mono)}.profile-online-label{color:var(--success)}.profile-section{border-bottom:1px solid var(--border);padding:16px 20px}.profile-section-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text3);font-size:10px;font-weight:600;font-family:var(--font-mono);margin-bottom:6px}.profile-bio{color:var(--text2);font-size:14px;line-height:1.6}.profile-info-value{color:var(--text2);font-size:13px;font-family:var(--font-mono)}.profile-action{justify-content:center;align-items:center;gap:8px;margin:20px 20px 24px;display:flex}.theme-toggle{background:var(--surface2);box-shadow:var(--neo-shadow-btn);border:.5px solid var(--border);color:var(--text2);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:15px;transition:color .15s,border-color .15s,box-shadow .15s;display:flex}.theme-toggle:hover{color:var(--accent);border-color:var(--accent);box-shadow:0 0 10px var(--accent-glow), var(--neo-shadow-btn);animation:.4s cubic-bezier(.34,1.56,.64,1) icon-spin}@keyframes icon-spin{0%{transform:rotate(-30deg)scale(1.1)}to{transform:rotate(0)scale(1)}}.bubble-footer{opacity:.7;justify-content:flex-end;align-items:center;gap:4px;margin-top:4px;font-size:10px;display:flex}.read-receipt{opacity:.85;flex-shrink:0;align-items:center;display:flex}.read-receipt svg{transition:stroke .3s}.group-settings-modal{max-width:480px}.found-chat-card{background:var(--surface2);box-shadow:var(--neo-shadow-out);border:.5px solid var(--border2);text-align:center;border-radius:14px;flex-direction:column;align-items:center;gap:6px;margin-top:16px;padding:16px;display:flex}.found-avatar{background:linear-gradient(135deg, var(--accent-dark), var(--accent));color:#fff;width:56px;height:56px;box-shadow:0 0 16px var(--accent-glow), var(--neo-shadow-btn);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:22px;font-weight:700;display:flex;overflow:hidden}.found-avatar img{object-fit:cover;width:100%;height:100%}.found-name{font-size:16px;font-weight:700;font-family:var(--font-brand)}.found-tag{color:var(--accent);font-size:12px;font-family:var(--font-mono)}.found-desc{color:var(--text2);font-size:13px}.found-meta{color:var(--text3);font-size:11px;font-family:var(--font-mono)}.settings-toggles{border:.5px solid var(--border);box-shadow:var(--neo-shadow-in);border-radius:12px;flex-direction:column;gap:2px;display:flex;overflow:hidden}.settings-toggle-row{background:var(--surface2);justify-content:space-between;align-items:center;padding:12px 14px;transition:background .15s;display:flex}.settings-toggle-row:hover{background:var(--surface3)}.settings-toggle-label{color:var(--text);font-size:13px;font-weight:600}.settings-toggle-sub{color:var(--text3);margin-top:2px;font-size:11px}.toggle-switch{flex-shrink:0;width:40px;height:22px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-track{background:var(--surface4);box-shadow:var(--neo-shadow-in);cursor:pointer;border-radius:22px;transition:background .2s;position:absolute;inset:0}.toggle-track:before{content:"";width:16px;height:16px;box-shadow:var(--neo-shadow-sm);background:#fff;border-radius:50%;transition:transform .2s;position:absolute;top:3px;left:3px}.toggle-switch input:checked+.toggle-track{background:var(--accent);box-shadow:0 0 8px var(--accent-glow), var(--neo-shadow-in)}.toggle-switch input:checked+.toggle-track:before{transform:translate(18px)}.invite-link-box{background:var(--surface2);box-shadow:var(--neo-shadow-in);border:.5px solid var(--border);border-radius:10px;padding:10px 12px}.invite-link-label{color:var(--text3);font-size:11px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.invite-link-row{align-items:center;gap:6px;display:flex}.invite-link-input{background:var(--surface3);box-shadow:var(--neo-shadow-in);border:.5px solid var(--border);color:var(--text2);font-family:var(--font-mono);border-radius:8px;outline:none;flex:1;padding:6px 10px;font-size:11px}.member-list{flex-direction:column;gap:3px;max-height:320px;display:flex;overflow-y:auto}.member-list::-webkit-scrollbar{width:3px}.member-list::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}.member-row{border-radius:10px;align-items:center;gap:10px;padding:8px 10px;transition:background .15s;display:flex;position:relative}.member-row:hover{background:var(--surface3);box-shadow:var(--neo-shadow-sm)}.member-info{flex:1;min-width:0}.member-name{font-size:13px;font-weight:600;font-family:var(--font-brand);align-items:center;gap:5px;display:flex}.member-role-badge{font-size:10px;font-family:var(--font-mono);letter-spacing:.04em;font-weight:600}.member-status{flex-wrap:wrap;gap:5px;margin-top:2px;display:flex}.mod-tag{font-size:10px;font-family:var(--font-mono);border-radius:4px;padding:1px 6px}.mod-tag.muted{color:var(--warn);background:#e67e2226}.mod-tag.restricted{color:var(--danger);background:#c0392b1a}.mod-tag.banned{color:var(--danger);background:#c0392b26}.member-actions{position:relative}.member-menu{background:var(--surface);box-shadow:var(--neo-shadow-out), 0 8px 32px #0006;border:.5px solid var(--border2);z-index:60;border-radius:12px;min-width:160px;padding:6px;animation:.15s picker-in;position:absolute;top:calc(100% + 4px);right:0}.member-menu button{width:100%;color:var(--text2);font-family:var(--font-ui);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;padding:7px 10px;font-size:13px;transition:background .1s,color .1s;display:block}.member-menu button:hover{background:var(--surface3);color:var(--text)}.member-menu button.danger{color:var(--danger)}.member-menu button.danger:hover{background:#c0392b1a}.new-menu{background:var(--surface);box-shadow:var(--neo-shadow-out), 0 8px 32px #0006;border:.5px solid var(--border2);z-index:60;border-radius:14px;min-width:200px;padding:6px;animation:.15s cubic-bezier(.16,1,.3,1) picker-in;position:absolute;top:calc(100% + 6px);right:0}.new-menu button{width:100%;color:var(--text2);font-family:var(--font-ui);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:9px;align-items:center;gap:9px;padding:8px 12px;font-size:13px;transition:background .1s,color .1s;display:flex}.new-menu button:hover{background:var(--surface3);color:var(--text)}.avatar-group{background:linear-gradient(135deg, var(--accent-dark), var(--accent))!important}.chat-type-badge{opacity:.7;margin-left:4px;font-size:13px}.topbar-type-tag{font-family:var(--font-mono);background:var(--surface3);box-shadow:var(--neo-shadow-sm);color:var(--text3);vertical-align:middle;letter-spacing:.06em;border-radius:4px;margin-left:7px;padding:1px 6px;font-size:9px}.comments-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:150;background:#00000080;justify-content:flex-end;display:flex;position:fixed;inset:0}.comments-sheet{background:var(--surface);border-left:.5px solid var(--border2);flex-direction:column;width:420px;max-width:100vw;height:100%;animation:.28s cubic-bezier(.16,1,.3,1) panel-spring;display:flex;box-shadow:-20px 0 60px #0006}.comments-header{box-shadow:0 1.2px 0 var(--divider-dark), 0 2px 0 var(--divider-light);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.comments-header-left{align-items:center;gap:10px;display:flex}.comments-header h3{font-size:15px;font-weight:700;font-family:var(--font-brand);align-items:center;gap:6px;display:flex}.comments-count{background:var(--surface3);box-shadow:var(--neo-shadow-in);color:var(--text3);font-size:11px;font-family:var(--font-mono);border-radius:10px;padding:1px 7px;font-weight:500}.comments-close{color:var(--text2);cursor:pointer;background:0 0;border:none;border-radius:50%;align-items:center;padding:5px;transition:color .15s;display:flex}.comments-close:hover{color:var(--accent)}.comments-toggle-btn{background:var(--surface2);box-shadow:var(--neo-shadow-btn);border:.5px solid var(--border2);color:var(--text2);font-family:var(--font-ui);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:5px 10px;font-size:12px;transition:all .15s;display:flex}.comments-toggle-btn:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 8px var(--accent-glow), var(--neo-shadow-btn)}.comments-toggle-btn.disabled{border-color:var(--danger);color:var(--danger)}.comments-post-preview{border-bottom:1px solid var(--border);background:var(--surface2);flex-shrink:0;padding:10px 16px}.comments-post-text{color:var(--text2);-webkit-line-clamp:3;-webkit-box-orient:vertical;max-height:60px;font-size:13px;display:-webkit-box;overflow:hidden}.comments-list{flex-direction:column;flex:1;gap:3px;padding:12px 16px 8px;display:flex;overflow-y:auto}.comments-list::-webkit-scrollbar{width:3px}.comments-list::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}.comments-empty{text-align:center;color:var(--text3);padding:32px 0;font-size:13px}.comments-empty p{color:var(--text2);margin-bottom:4px;font-weight:600}.comment-author{color:var(--accent);font-size:11px;font-weight:600;font-family:var(--font-brand);margin-bottom:3px;display:block}.comments-form{box-shadow:0 -1.2px 0 var(--divider-light), 0 -2px 0 var(--divider-dark);background:var(--surface);flex-shrink:0;align-items:flex-end;gap:8px;padding:10px 14px 14px;display:flex}.comments-disabled-bar{border-top:1px solid var(--border);color:var(--text3);flex-shrink:0;justify-content:center;align-items:center;gap:7px;padding:12px 16px;font-size:13px;font-style:italic;display:flex}.comments-btn-wrap{margin-top:-6px;margin-bottom:6px}.comments-btn-wrap.comments-btn-own{justify-content:flex-end;display:flex}.comments-btn-wrap.comments-btn-other{justify-content:flex-start;display:flex}.comments-btn{background:var(--surface);box-shadow:var(--neo-shadow-sm);border:.5px solid var(--border);color:var(--text2);font-family:var(--font-ui);cursor:pointer;border-radius:20px;align-items:center;gap:5px;padding:4px 10px;font-size:12px;transition:border-color .15s,color .15s,box-shadow .15s;display:flex}.comments-btn:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 8px var(--accent-glow), var(--neo-shadow-sm)}.ie-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:200;background:#000000e0;justify-content:center;align-items:center;animation:.2s overlay-in;display:flex;position:fixed;inset:0}.ie-modal{background:var(--surface);border:.5px solid var(--border2);box-shadow:var(--neo-shadow-out), 0 24px 80px #000000a6;border-radius:20px;flex-direction:column;width:min(680px,96vw);max-height:94vh;animation:.25s cubic-bezier(.16,1,.3,1) modal-spring;display:flex;overflow:hidden}.ie-header{box-shadow:0 1.2px 0 var(--divider-dark), 0 2px 0 var(--divider-light);flex-shrink:0;justify-content:space-between;align-items:center;padding:15px 20px;display:flex}.ie-header h3{font-size:15px;font-weight:700;font-family:var(--font-brand)}.ie-preview-wrap{background:var(--bg);flex:1;justify-content:center;align-items:center;min-height:0;display:flex;position:relative;overflow:hidden}.ie-canvas{object-fit:contain;pointer-events:none;border-radius:3px;max-width:100%;max-height:360px;display:block}.ie-crop-overlay{cursor:crosshair;position:absolute;inset:0}.ie-shade{pointer-events:none;background:#00000094;position:absolute}.ie-shade-t{top:0;left:0;right:0}.ie-shade-b{bottom:0;left:0;right:0}.ie-shade-l{left:0}.ie-shade-r{right:0}.ie-crop-box{border:2px solid var(--accent);cursor:move;box-sizing:border-box;position:absolute;box-shadow:0 0 0 1px #00000080}.ie-crop-grid{pointer-events:none;background-image:linear-gradient(90deg,#ffffff1f 1px,#0000 1px),linear-gradient(#ffffff1f 1px,#0000 1px);background-size:33.33% 33.33%;position:absolute;inset:0}.ie-handle{background:var(--accent);width:13px;height:13px;box-shadow:0 0 8px var(--accent-glow);border:2px solid #fff;border-radius:3px;position:absolute}.ie-handle-nw{cursor:nw-resize;top:-7px;left:-7px}.ie-handle-ne{cursor:ne-resize;top:-7px;right:-7px}.ie-handle-sw{cursor:sw-resize;bottom:-7px;left:-7px}.ie-handle-se{cursor:se-resize;bottom:-7px;right:-7px}.ie-controls{box-shadow:0 -1.2px 0 var(--divider-light), 0 -2px 0 var(--divider-dark);background:var(--surface2);flex-direction:column;flex-shrink:0;gap:10px;padding:12px 18px;display:flex}.ie-actions{flex-wrap:wrap;gap:7px;display:flex}.ie-action-btn{background:var(--surface3);box-shadow:var(--neo-shadow-btn);border:.5px solid var(--border);color:var(--text2);font-family:var(--font-ui);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;transition:color .15s,border-color .15s,box-shadow .15s;display:flex}.ie-action-btn:hover{color:var(--accent);border-color:var(--accent);box-shadow:0 0 8px var(--accent-glow), var(--neo-shadow-btn)}.ie-action-active{background:#2da89a1a;color:var(--accent)!important;border-color:var(--accent)!important;box-shadow:0 0 8px var(--accent-glow), var(--neo-shadow-in)!important}.ie-slider-row{align-items:center;gap:10px;display:flex}.ie-slider-label{color:var(--text3);font-size:11px;font-weight:600;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0;width:40px}.ie-slider{appearance:none;background:var(--surface4);height:4px;box-shadow:var(--neo-shadow-in);cursor:pointer;border-radius:4px;outline:none;flex:1}.ie-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent);width:14px;height:14px;box-shadow:0 0 6px var(--accent-glow), var(--neo-shadow-sm);cursor:pointer;border-radius:50%;transition:transform .1s}.ie-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.ie-slider-val{font-size:11px;font-family:var(--font-mono);color:var(--text3);text-align:right;flex-shrink:0;width:36px}.ie-slider-val.changed{color:var(--accent);font-weight:600}.ie-reset-btn{color:var(--text3);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:14px;line-height:1;transition:color .15s}.ie-reset-btn:hover{color:var(--accent)}.ie-footer{box-shadow:0 -1px 0 var(--border);flex-shrink:0;justify-content:flex-end;align-items:center;gap:10px;padding:13px 18px;display:flex}.spoiler-badge{font-size:10px;font-family:var(--font-mono);color:var(--accent);background:#2da89a1a;border:1px solid #2da89a40;border-radius:4px;align-items:center;gap:4px;padding:2px 6px;display:inline-flex}.spoiler-wrap{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:10px;max-width:280px;display:block;position:relative;overflow:hidden}.spoiler-img{object-fit:cover;filter:blur(22px)brightness(.35);pointer-events:none;border-radius:10px;width:100%;max-width:280px;max-height:320px;transition:filter .35s,transform .35s;display:block;transform:scale(1.06)}.spoiler-wrap.revealed .spoiler-img{filter:none;cursor:zoom-in;pointer-events:auto;transform:scale(1)}.spoiler-overlay{border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:5px;transition:opacity .3s;display:flex;position:absolute;inset:0}.spoiler-wrap.revealed .spoiler-overlay{opacity:0;pointer-events:none}.spoiler-icon{font-size:26px}.spoiler-label{color:#fff;font-size:12px;font-weight:700;font-family:var(--font-mono);letter-spacing:.1em;text-shadow:0 1px 4px #000000b3}.spoiler-hint{color:#fff9;font-size:10px;font-family:var(--font-mono)}.messages-area[style*=backgroundImage] .bubble-own{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#1c403ee0}.messages-area[style*=backgroundImage] .bubble-other{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#15302fd6}[data-theme=light] .messages-area[style*=backgroundImage] .bubble-own{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#c2dbd8e0}[data-theme=light] .messages-area[style*=backgroundImage] .bubble-other{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#cde4e2e0}.wallpaper-modal{max-width:360px}.wallpaper-body{flex-direction:column;gap:10px;padding:4px 0;display:flex}.wallpaper-preview{background:var(--surface2);width:100%;height:180px;box-shadow:var(--neo-shadow-in);border:.5px solid var(--border);background-position:50%;background-size:cover;border-radius:12px;justify-content:center;align-items:center;display:flex;overflow:hidden}.wallpaper-preview-empty{color:var(--text3);font-size:13px}.wallpaper-hint{color:var(--text3);text-align:center;font-size:12px;font-style:italic}.lang-toggle{background:var(--surface2);box-shadow:var(--neo-shadow-btn);border:.5px solid var(--border);color:var(--text2);font-family:var(--font-mono);cursor:pointer;letter-spacing:.04em;white-space:nowrap;border-radius:8px;height:34px;padding:0 8px;font-size:11px;font-weight:600;transition:color .15s,border-color .15s,box-shadow .15s}.lang-toggle:hover{color:var(--accent);border-color:var(--accent);box-shadow:0 0 8px var(--accent-glow), var(--neo-shadow-btn)}.lang-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px;box-shadow:0 0 0 3px var(--accent-glow), var(--neo-shadow-btn)}.auth-lang-switcher{z-index:10;gap:6px;display:flex;position:absolute;top:20px;right:24px}.auth-lang-btn{background:var(--surface);box-shadow:var(--neo-shadow-btn);border:.5px solid var(--border2);color:var(--text2);font-family:var(--font-ui);cursor:pointer;letter-spacing:.04em;border-radius:20px;padding:6px 12px;font-size:12px;font-weight:500;transition:all .2s}.auth-lang-btn:hover{color:var(--text);border-color:var(--accent)}.auth-lang-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px;box-shadow:0 0 0 3px var(--accent-glow), var(--neo-shadow-btn)}.auth-lang-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 0 12px var(--accent-glow), var(--neo-shadow-btn);font-weight:700}.mie-modal{flex-direction:column;width:96vw;max-width:640px;max-height:90vh;display:flex}.mie-body{flex:1;min-height:160px;padding:12px 16px;overflow-y:auto}.mie-dropzone{border:2px dashed var(--border);cursor:pointer;color:var(--text3);text-align:center;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:8px;min-height:120px;padding:28px 20px;font-size:13px;transition:border-color .15s,background .15s;display:flex}.mie-dropzone:hover:not(.disabled){border-color:var(--accent);background:color-mix(in srgb, var(--accent) 6%, transparent);color:var(--accent)}.mie-dropzone.drag-over{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 10%, transparent);color:var(--accent)}.mie-dropzone.disabled{opacity:.45;cursor:not-allowed}.mie-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;display:grid}.mie-card{background:var(--surface2);aspect-ratio:1;box-shadow:var(--neo-shadow-sm);border:2px solid #0000;border-radius:10px;transition:border-color .15s;position:relative;overflow:hidden}.mie-card:hover{border-color:var(--accent)}.mie-card-preview{position:absolute;inset:0}.mie-card-preview img{object-fit:cover;width:100%;height:100%;display:block}.mie-card-preview.mie-card-spoiler img{filter:blur(8px)brightness(.7)}.mie-card-spoiler-overlay{color:#fff;pointer-events:none;flex-direction:column;justify-content:center;align-items:center;gap:3px;font-size:20px;display:flex;position:absolute;inset:0}.mie-card-spoiler-label{letter-spacing:.08em;text-transform:uppercase;font-size:10px;font-weight:700}.mie-card-controls{opacity:0;background:linear-gradient(#0000 0%,#000000a6 100%);justify-content:space-between;align-items:center;padding:4px 3px;transition:opacity .15s;display:flex;position:absolute;bottom:0;left:0;right:0}.mie-card:hover .mie-card-controls{opacity:1}.mie-card-btn{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff2e;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:13px;line-height:1;transition:background .12s;display:flex}.mie-card-btn:hover:not(:disabled){background:#ffffff59}.mie-card-btn:disabled{opacity:.3;cursor:default}.mie-spoiler-btn.active{background:#2da89ab3}.mie-remove-btn:hover:not(:disabled){background:#c0392bb3!important}.mie-card-badge{color:#fff;letter-spacing:.06em;text-transform:uppercase;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none;background:#0000008c;border-radius:4px;padding:2px 5px;font-size:9px;font-weight:700;position:absolute;top:5px;left:5px}.mie-card-index{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none;background:#0000008c;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:600;display:flex;position:absolute;top:5px;right:5px}.mie-caption-row{padding:0 16px 4px}.mie-caption{resize:none;border:.5px solid var(--border);background:var(--surface2);width:100%;box-shadow:var(--neo-shadow-in);color:var(--text);box-sizing:border-box;border-radius:10px;outline:none;padding:8px 12px;font-family:inherit;font-size:13px;transition:border-color .15s}.mie-caption:focus{border-color:var(--accent)}.mie-bulk-row{justify-content:space-between;align-items:center;padding:6px 16px 2px;display:flex}.mie-bulk-spoiler-btn{color:var(--text2);background:var(--surface2);box-shadow:var(--neo-shadow-sm);border:.5px solid var(--border);cursor:pointer;border-radius:8px;align-items:center;gap:5px;padding:4px 10px;font-size:12px;transition:all .15s;display:flex}.mie-bulk-spoiler-btn:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 8px var(--accent-glow), var(--neo-shadow-sm)}.mie-bulk-spoiler-btn.active{background:color-mix(in srgb, var(--accent) 12%, transparent);border-color:var(--accent);color:var(--accent)}.mie-bulk-spoiler-btn.partial{border-color:var(--warn);color:var(--warn)}.mie-counter{color:var(--text3);font-size:11px;font-family:var(--font-mono)}.album-grid{border-radius:10px;gap:2px;width:100%;max-width:320px;display:grid;overflow:hidden}.album-1{grid-template-columns:1fr}.album-1 .album-cell{aspect-ratio:4/3}.album-2{grid-template-columns:1fr 1fr}.album-2 .album-cell{aspect-ratio:1}.album-3{grid-template-rows:auto;grid-template-columns:2fr 1fr}.album-3>.album-cell{aspect-ratio:3/4}.album-col{flex-direction:column;gap:2px;display:flex}.album-col .album-cell{aspect-ratio:1;flex:1}.album-4{grid-template-columns:1fr 1fr}.album-4 .album-cell{aspect-ratio:1}.album-n{grid-template-columns:repeat(3,1fr)}.album-n .album-cell-wrap,.album-n .album-cell{aspect-ratio:1}.album-cell-wrap{position:relative}.album-cell{cursor:pointer;background:var(--surface2);position:relative;overflow:hidden}.album-cell img{object-fit:cover;width:100%;height:100%;transition:transform .18s;display:block}.album-cell:hover img{transform:scale(1.03)}.album-cell-hidden img{filter:blur(10px)brightness(.6)}.album-cell-spoiler{color:#fff;pointer-events:none;flex-direction:column;justify-content:center;align-items:center;gap:3px;font-size:18px;display:flex;position:absolute;inset:0}.album-cell-hint{text-transform:uppercase;letter-spacing:.06em;opacity:.8;font-size:9px;font-weight:600}.album-cell-badge{color:#fff;text-transform:uppercase;letter-spacing:.06em;pointer-events:none;background:#00000080;border-radius:3px;padding:2px 4px;font-size:8px;font-weight:700;position:absolute;top:4px;left:4px}.album-more-overlay{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000008c;justify-content:center;align-items:center;font-size:20px;font-weight:700;display:flex;position:absolute;inset:0}.album-caption{color:var(--text);word-break:break-word;margin:4px 0 0;font-size:13.5px;line-height:1.45}.album-lightbox{z-index:9999;background:#000000eb;outline:none;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.album-lb-close{color:#fff;cursor:pointer;z-index:2;background:#ffffff1f;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;transition:background .15s;display:flex;position:absolute;top:16px;right:16px}.album-lb-close:hover{background:#ffffff38}.album-lb-img-wrap{justify-content:center;align-items:center;max-width:90vw;max-height:80vh;display:flex}.album-lb-img-wrap img{object-fit:contain;-webkit-user-select:none;user-select:none;border-radius:6px;max-width:90vw;max-height:80vh}.album-lb-nav{color:#fff;cursor:pointer;z-index:2;background:#ffffff1f;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:28px;transition:background .15s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.album-lb-nav:hover{background:#ffffff40}.album-lb-prev{left:16px}.album-lb-next{right:16px}.album-lb-counter{color:#ffffffb3;pointer-events:none;font-size:13px;font-weight:500;position:absolute;top:18px;left:50%;transform:translate(-50%)}.album-lb-strip{gap:6px;max-width:90vw;padding:4px;display:flex;position:absolute;bottom:12px;left:50%;overflow-x:auto;transform:translate(-50%)}.album-lb-thumb{cursor:pointer;opacity:.55;border:2px solid #0000;border-radius:6px;flex-shrink:0;width:44px;height:44px;transition:opacity .12s,border-color .12s;overflow:hidden}.album-lb-thumb.active{opacity:1;border-color:#fff}.album-lb-thumb img{object-fit:cover;width:100%;height:100%}.mobile-banner-overlay{z-index:300;width:min(600px,100vw - 32px);animation:.45s cubic-bezier(.16,1,.3,1) both banner-slide-up;position:fixed;bottom:20px;left:50%;transform:translate(-50%)}@keyframes banner-slide-up{0%{opacity:0;transform:translate(-50%)translateY(32px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.mobile-banner{background:var(--surface);border:.5px solid var(--border2);box-shadow:var(--neo-shadow-out), 0 8px 40px #00000073;border-radius:16px;align-items:center;gap:14px;padding:14px 16px;display:flex}.mobile-banner-icon{background:linear-gradient(135deg, var(--accent-dark), var(--accent));color:#fff;width:44px;min-width:44px;height:44px;box-shadow:0 0 16px var(--accent-glow), var(--neo-shadow-btn);border-radius:12px;justify-content:center;align-items:center;display:flex}.mobile-banner-content{flex:1;min-width:0}.mobile-banner-title{color:var(--text);font-size:14px;font-weight:700;font-family:var(--font-brand);margin-bottom:2px}.mobile-banner-sub{color:var(--text2);font-size:12px;line-height:1.4}.mobile-banner-btn{white-space:nowrap;background:linear-gradient(135deg, var(--accent-light), var(--accent-dark));color:#fff;font-family:var(--font-ui);cursor:pointer;box-shadow:0 0 16px var(--accent-glow), var(--neo-shadow-btn);border:none;border-radius:10px;flex-shrink:0;align-items:center;gap:7px;padding:8px 14px;font-size:13px;font-weight:700;text-decoration:none;transition:opacity .2s,box-shadow .2s,transform .1s;display:flex}.mobile-banner-btn:hover{opacity:.9;box-shadow:0 0 28px var(--accent-glow), var(--neo-shadow-btn)}.mobile-banner-btn:active{transform:scale(.96)}.mobile-banner-close{color:var(--text3);cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;padding:6px;transition:color .15s,background .15s;display:flex}.mobile-banner-close:hover{color:var(--text);background:var(--surface3)}.settings-avatar-wrap{flex-direction:column;align-items:center;gap:8px;display:flex}.avatar-btn-group{align-items:center;gap:6px;display:flex}.avatar-change-btn{font-family:var(--font-ui);color:var(--accent);cursor:pointer;white-space:nowrap;background:#2da89a14;border:1px solid #2da89a40;border-radius:8px;padding:4px 10px;font-size:12px;font-weight:600;transition:background .15s,border-color .15s,box-shadow .15s}.avatar-change-btn:hover:not(:disabled){border-color:var(--accent);box-shadow:0 0 8px var(--accent-glow);background:#2da89a24}.avatar-change-btn:disabled{opacity:.4;cursor:not-allowed}.avatar-remove-btn{width:28px;height:28px;color:var(--danger);cursor:pointer;background:#c0392b14;border:1px solid #c0392b38;border-radius:8px;justify-content:center;align-items:center;transition:background .15s,box-shadow .15s;display:flex}.avatar-remove-btn:hover:not(:disabled){background:#c0392b26;box-shadow:0 0 8px #c0392b4d}.avatar-remove-btn:disabled{opacity:.4;cursor:not-allowed}.avatar-uploading-spinner{border:3px solid #fff3;border-top-color:#fff;border-radius:50%;width:28px;height:28px;animation:.75s linear infinite spin}.msg-link{color:var(--accent);text-underline-offset:2px;word-break:break-all;cursor:pointer;-webkit-text-decoration:underline #2da89a66;text-decoration:underline #2da89a66;transition:color .15s,text-decoration-color .15s}.msg-link:hover{color:var(--accent-light);-webkit-text-decoration-color:var(--accent);text-decoration-color:var(--accent)}.bubble-own .msg-link{color:var(--text2);text-decoration-color:#9cbdba73}.bubble-own .msg-link:hover{color:var(--text);text-decoration-color:#9cbdbae6}[data-theme=light] .bubble-own .msg-link{color:var(--text2);text-decoration-color:#2d606059}[data-theme=light] .bubble-own .msg-link:hover{color:var(--text)}.msg-mention{font-family:var(--font-mono);color:var(--accent);cursor:pointer;font-size:.92em;font-weight:600;line-height:inherit;background:0 0;border:none;border-radius:4px;margin:0;padding:0;transition:background .12s,color .12s;display:inline}.msg-mention:hover{color:var(--accent-light);background:#2da89a1f}.bubble-own .msg-mention{color:var(--text2)}.bubble-own .msg-mention:hover{color:var(--text);background:#ffffff1a}.bot-badge{font-size:10px;font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;color:var(--accent);pointer-events:none;-webkit-user-select:none;user-select:none;background:#2da89a1a;border:1px solid #2da89a40;border-radius:5px;align-self:flex-start;align-items:center;gap:4px;margin-bottom:3px;padding:2px 7px;font-weight:600;display:inline-flex}.bubble-wrap.own .bot-badge{align-self:flex-end}.bubble-sticker{box-shadow:none!important;background:0 0!important;border:none!important}.bubble-sticker:after{display:none!important}.msg-sticker-wrap{flex-direction:column;gap:4px;display:flex}.saved-messages-item{border-bottom:1px solid var(--border);margin-bottom:4px}.saved-messages-item .avatar.sm{border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex}.saved-pin-screen{background:var(--surface2);flex:1;justify-content:center;align-items:center;display:flex}.saved-pin-inner{flex-direction:column;align-items:center;gap:16px;width:100%;max-width:280px;padding:0 24px;display:flex}.saved-pin-icon{filter:drop-shadow(0 0 16px var(--accent-glow));font-size:48px}.saved-pin-inner h3{color:var(--text);text-align:center;margin:0;font-size:18px;font-weight:700}.pin-input{text-align:center;letter-spacing:.4em;background:var(--surface2);width:100%;box-shadow:var(--neo-shadow-in);border:.5px solid var(--border);color:var(--text);font-size:24px;font-family:var(--font-mono);box-sizing:border-box;border-radius:12px;outline:none;padding:12px 16px;transition:border-color .25s,box-shadow .25s}.pin-input:focus{border-color:var(--accent);box-shadow:var(--neo-shadow-in), 0 0 0 3px var(--accent-glow)}.forward-banner{color:var(--accent);opacity:.9;border-bottom:1px solid var(--border);font-size:11px;font-weight:600;font-family:var(--font-mono);letter-spacing:.02em;align-items:center;gap:5px;margin-bottom:5px;padding-bottom:5px;display:flex}.forward-banner svg{opacity:.8;flex-shrink:0}.forward-picker-modal{flex-direction:column;width:90vw;max-width:380px;max-height:70vh;display:flex}.forward-list{flex:1;padding:0 8px 12px;overflow-y:auto}.forward-item{cursor:pointer;border-radius:10px;align-items:center;gap:12px;padding:10px;transition:background .15s;display:flex}.forward-item:hover{background:var(--surface3)}.forward-item-sent{background:var(--surface3);pointer-events:none}.forward-item-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.forward-item-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.forward-item-type{color:var(--text3);font-size:11px;font-family:var(--font-mono)}.no-forwards-badge{color:var(--text3);background:var(--surface3);font-size:10px;font-weight:600;font-family:var(--font-mono);letter-spacing:.04em;border-radius:6px;align-items:center;gap:4px;padding:2px 6px;display:inline-flex}.bubble-wrap.own .bubble-and-reactions{flex-direction:row;justify-content:flex-end;align-items:flex-end;display:flex}.pro-badge{color:#000;font-size:9px;font-family:var(--font-brand);vertical-align:middle;letter-spacing:.06em;text-transform:uppercase;background:linear-gradient(135deg,gold,#f39c12);border-radius:6px;margin-left:6px;padding:2px 6px;font-weight:800;box-shadow:0 0 8px #ffd70066}.pro-card{box-shadow:var(--neo-shadow-in);background:linear-gradient(135deg,#ffd7000f,#f39c1205);border:1px solid #ffd7004d;border-radius:16px;padding:20px}.pro-header{align-items:center;gap:12px;margin-bottom:12px;display:flex}.pro-header h3{font-size:18px;font-family:var(--font-brand);color:var(--text);margin:0}.pro-desc{color:var(--text2);margin-bottom:16px;font-size:13px;line-height:1.5}.pro-balance-box{background:var(--surface);color:var(--text);box-shadow:var(--neo-shadow-btn);border:.5px solid var(--border);border-radius:12px;justify-content:center;align-items:center;gap:8px;margin-bottom:12px;padding:12px;font-size:18px;font-weight:700;display:flex}.streak-info-box{border:.5px solid var(--border);background:#0000001a;border-radius:12px;margin-bottom:16px;padding:12px}[data-theme=light] .streak-info-box{background:#fff6}.streak-badge{color:#fff;font-size:9px;font-family:var(--font-brand);vertical-align:middle;letter-spacing:.04em;background:linear-gradient(135deg,#e74c3c,#f39c12);border-radius:6px;margin-left:6px;padding:2px 6px;font-weight:800;box-shadow:0 0 8px #e74c3c66}
