:root{--sab:env(safe-area-inset-bottom, 0px)}.chatbox-container{position:fixed;bottom:0;right:0;z-index:9999;pointer-events:none}.chatbox{position:fixed;bottom:0;width:320px;height:420px;background-color:var(--base-color);border-radius:.75rem .75rem 0 0;box-shadow:0 0 16px rgba(0,0,0,.12),0 4px 24px rgba(0,0,0,.08);border:0 solid rgba(0,0,0,.08);border-bottom:none;display:flex;flex-direction:column;transition:height .2s ease,opacity .2s ease;pointer-events:auto;z-index:100}.chatbox.focused{z-index:101;box-shadow:0 0 20px rgba(0,0,0,.15),0 8px 32px rgba(0,0,0,.1)}.chatbox.minimized{height:48px}.chatbox-header{padding:.75rem 1rem;background:linear-gradient(135deg,var(--chat-header-color-start) 0,var(--chat-header-color-end) 100%);color:#fff;border-radius:.75rem .75rem 0 0;display:flex;justify-content:space-between;align-items:center;cursor:pointer;flex-shrink:0;user-select:none;transition:background .15s ease}.chatbox-header:hover{background:linear-gradient(135deg,#ffa545 0,var(--highlight-color) 100%)}.chatbox-header-info{display:flex;align-items:center;gap:.625rem;flex:1;min-width:0}.chatbox-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0;background-color:rgba(255,255,255,.2)}.chatbox-title{font-weight:600;font-size:.9em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:.25rem}.chatbox-muted-indicator{color:rgba(255,255,255,.6);flex-shrink:0}.chatbox-muted-indicator.hide{display:none}.chatbox-header-actions{display:flex;gap:.25rem;flex-shrink:0}.chatbox-btn{width:28px;height:28px;border-radius:50%;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .15s ease;padding:0;background:0 0;box-shadow:none}.chatbox-btn:hover{box-shadow:none;background:0 0}.chatbox-btn:hover svg{transform:scale(1.2)}.chatbox-btn:active{box-shadow:none;background:0 0}.chatbox-btn svg{display:block;transition:opacity .15s ease}.chatbox-request-indicator{background:linear-gradient(135deg,#fbbf24 0,#f59e0b 100%);color:#78350f;padding:.5rem 1rem;font-size:.8rem;font-weight:600;display:flex;align-items:center;gap:.5rem;border-bottom:1px solid rgba(0,0,0,.1);flex-shrink:0}.chatbox-request-indicator svg{width:16px;height:16px;flex-shrink:0}.chatbox-decline-request-btn{margin-left:auto;padding:.25rem .75rem;border-radius:6px;border:none;background-color:rgba(0,0,0,.1);color:#78350f;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s ease}.chatbox-decline-request-btn:hover{background-color:#ef4444;color:#fff}.chatbox-body{flex:1;overflow:hidden;display:flex;flex-direction:column;background-color:var(--main-content-bg-color)}.chatbox.minimized .chatbox-body{display:none}.chatbox-messages{flex:1;overflow-y:auto;padding:1em 1em .5em;display:flex;flex-direction:column;gap:0}.chatbox-messages::-webkit-scrollbar{width:6px}.chatbox-messages::-webkit-scrollbar-track{background:0 0}.chatbox-messages::-webkit-scrollbar-thumb{background-color:rgba(0,0,0,.2);border-radius:3px}.chatbox-messages::-webkit-scrollbar-thumb:hover{background-color:rgba(0,0,0,.3)}.chatbox-message.chatbox-typing-indicator{display:none}.chatbox-typing-indicator.visible{display:flex}.chatbox-typing-indicator .chatbox-message-text{padding:.3em .5em;white-space:normal}.chatbox-typing-indicator .typing-dots{display:flex;align-items:center;gap:.25rem;padding:.3em}.chatbox-typing-indicator .typing-dots .dot{width:6px;height:6px;border-radius:50%;background-color:#999;animation:typing-dot-pulse 1.4s infinite}.chatbox-typing-indicator .typing-dots .dot:first-child{animation-delay:0s}.chatbox-typing-indicator .typing-dots .dot:nth-child(2){animation-delay:.2s}.chatbox-typing-indicator .typing-dots .dot:nth-child(3){animation-delay:.4s}@keyframes typing-dot-pulse{0%,100%,60%{opacity:.3;transform:scale(.8)}30%{opacity:1;transform:scale(1)}}.chatbox-message{display:flex;gap:.5rem;align-items:flex-end;max-width:75%;margin-bottom:.75rem}.chatbox-message-own{align-self:flex-end;flex-direction:row-reverse}.chatbox-message-other{align-self:flex-start}.chatbox-message-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0;margin-top:8px}.chatbox-message-avatar.gradient-avatar{width:28px;height:28px;min-width:28px;min-height:28px}.chatbox-message-avatar.gradient-avatar .gradient-avatar-initials{font-size:11px}.cluster-end .chatbox-message-avatar,.cluster-single .chatbox-message-avatar{margin-top:0;margin-bottom:16px}.chatbox-message-avatar-spacer{width:28px;height:28px;flex-shrink:0}.chatbox-message-content{display:flex;flex-direction:column;gap:.25rem}.chatbox-message-text{padding:.625rem .875rem;border-radius:1.125rem;font-size:.9375rem;line-height:1.4;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word}.chatbox-message-other .chatbox-message-text{background-color:var(--base-muted-color);color:var(--primary-text-color);border-bottom-left-radius:.25rem}.chatbox-message-own .chatbox-message-text{background-color:var(--primary-color);color:#fff;border-bottom-right-radius:.25rem}.chatbox-message-text a{text-decoration:underline;word-break:break-all}.chatbox-message-other .chatbox-message-text a{color:var(--primary-color)}.chatbox-message-own .chatbox-message-text a{color:#fff}.chatbox-message-time{font-size:.75rem;color:var(--primary-light-text-color);display:flex;align-items:center;gap:.25rem}.chatbox-message-own .chatbox-message-time{text-align:right;justify-content:flex-end}.chatbox-bubble-row{display:inline-flex;align-items:center;position:relative}.chatbox-message-other .chatbox-bubble-row{align-self:flex-start}.chatbox-message-own .chatbox-bubble-row{align-self:flex-end;flex-direction:row-reverse}.chatbox-bubble-inner{position:relative}.reaction-add-btn{position:absolute;top:50%;transform:translateY(-50%);width:28px;height:28px;border-radius:50%;border:1px solid var(--block-border-color);background-color:var(--main-content-bg-color);color:var(--primary-light-text-color);cursor:pointer;display:none;align-items:center;justify-content:center;padding:0;transition:all .15s ease;z-index:3}.chatbox-message-other .reaction-add-btn{left:100%;margin-left:4px}.chatbox-message-own .reaction-add-btn{right:100%;margin-right:4px}.chatbox-message:hover .reaction-add-btn{display:flex}.reaction-add-btn::before{content:'';position:absolute;top:-4px;bottom:-4px}.chatbox-message-other .reaction-add-btn::before{right:100%;width:12px}.chatbox-message-own .reaction-add-btn::before{left:100%;width:12px}.reaction-add-btn:hover{background-color:var(--list-hover-color);color:var(--primary-text-color)}.chatbox-bubble-row>.reaction-add-btn:hover{transform:translateY(-50%) scale(1.1)}.message-action-buttons .reaction-add-btn:hover{transform:scale(1.1)}.reactions-row{position:absolute;bottom:-10px;right:-8px;display:flex;align-items:center;z-index:2}.reactions-row.reactions-own{right:auto;left:8px}.reaction-circle{position:relative;width:22px;height:22px;border-radius:50%;border:none;background-color:var(--main-content-bg-color);font-size:12px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;margin-left:-4px;transition:transform .1s ease}.reaction-circle:first-child{margin-left:0}.reaction-circle:hover{transform:scale(1.15);z-index:1}.reaction-circle.active{outline:1.5px solid var(--primary-color);outline-offset:-1.5px}.reaction-overflow{font-size:9px;font-weight:600;color:var(--primary-light-text-color);margin-left:2px}.reaction-picker{position:absolute;display:flex;gap:2px;padding:6px 8px;background-color:var(--main-content-bg-color);border:1px solid var(--block-border-color);border-radius:24px;box-shadow:0 4px 12px rgba(0,0,0,.12);z-index:100;animation:reaction-picker-in .15s ease}.chatbox-message-other .reaction-picker{left:0}.chatbox-message-own .reaction-picker{right:0}@keyframes reaction-picker-in{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.reaction-picker-emoji{width:32px;height:32px;border:none;background:0 0;border-radius:50%;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s ease,background-color .1s ease;padding:0;box-shadow:none}.reaction-picker-emoji:hover{transform:scale(1.25);background-color:var(--list-hover-color);box-shadow:none}.chatbox-message.message-failed .chatbox-message-text{opacity:.5}.chatbox-message.message-failed .chatbox-message-time{display:none}.chatbox-message.message-sending .chatbox-message-time{color:var(--secondary-text-color)}.chatbox-message-status{font-size:.65rem;margin-top:.25rem}.chatbox-message-status.failed{color:var(--red-color)}.chatbox-read-receipt{font-size:.75rem;font-weight:500;display:inline-block;margin-left:.125rem;transition:color .2s ease,transform .2s ease;white-space:nowrap}.chatbox-read-receipt.sent{color:var(--primary-light-text-color);font-weight:400;opacity:.8}.chatbox-read-receipt.seen{color:var(--primary-color);font-weight:600}.chatbox-message-own .chatbox-read-receipt{font-size:.8125rem;letter-spacing:-.5px}.chatbox-read-receipt:hover{opacity:.85;cursor:help}@keyframes seenPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.12)}}.chatbox-read-receipt.seen{animation:seenPulse .4s ease-out}.chatbox-message-sender{font-size:.75rem;font-weight:600;color:var(--primary-text-color);margin-bottom:.25rem;display:flex;align-items:center;gap:.25rem}.chat-badge-icon{display:inline-block;width:16px;height:16px;border-radius:1em;object-fit:contain;flex-shrink:0;vertical-align:middle;background:#fff;margin-left:.25rem}.chat-name .chat-badge-icon,.chatbox-title .chat-badge-icon,.user-list-name .chat-badge-icon{width:16px;height:16px}.chatbox-message-sender .chat-badge-icon{width:16px;height:16px}.chatbox-message.cluster-middle,.chatbox-message.cluster-start{margin-bottom:.125rem}.chatbox-message.cluster-end,.chatbox-message.cluster-single{margin-bottom:.75rem}.chatbox-message-other.cluster-start .chatbox-message-text{border-bottom-left-radius:.25rem;border-top-left-radius:1.125rem}.chatbox-message-other.cluster-middle .chatbox-message-text{border-bottom-left-radius:.25rem;border-top-left-radius:.25rem}.chatbox-message-other.cluster-end .chatbox-message-text{border-bottom-left-radius:.25rem;border-top-left-radius:.25rem}.chatbox-message-other.cluster-single .chatbox-message-text{border-bottom-left-radius:.25rem;border-top-left-radius:1.125rem}.chatbox-message-own.cluster-start .chatbox-message-text{border-bottom-right-radius:.25rem;border-top-right-radius:1.125rem}.chatbox-message-own.cluster-middle .chatbox-message-text{border-bottom-right-radius:.25rem;border-top-right-radius:.25rem}.chatbox-message-own.cluster-end .chatbox-message-text{border-bottom-right-radius:.25rem;border-top-right-radius:.25rem}.chatbox-message-own.cluster-single .chatbox-message-text{border-bottom-right-radius:.25rem;border-top-right-radius:1.125rem}.chatbox-group-info{display:flex;align-items:center;gap:.5rem;padding:.625rem .875rem;background:var(--card-alt-background-color);border-bottom:1px solid var(--block-border-color);font-size:.8125rem;color:var(--primary-text-color);margin:-1rem -1rem .75rem -1rem;border-radius:0;flex-shrink:0}.chatbox-group-info svg{width:14px;height:14px;flex-shrink:0;opacity:.5;color:var(--primary-light-text-color)}.chatbox-group-info strong{font-weight:600;color:var(--primary-text-color)}.chatbox-load-more{padding:.5em .5em 0;text-align:center;margin:-1rem -1rem .75rem -1rem}.chatbox-load-more-btn{padding:.5rem 1rem;background:var(--base-color);border:1px solid rgba(0,0,0,.12);border-radius:1.25rem;cursor:pointer;font-size:.8125rem;font-weight:500;color:var(--primary-text-color);transition:all .15s ease;display:inline-block}.chatbox-load-more-btn:hover{background:var(--base-muted-color);border-color:rgba(0,0,0,.18);transform:translateY(-1px);box-shadow:0 2px 4px rgba(0,0,0,.08);color:var(--primary-color)}.chatbox-load-more-btn:active{transform:translateY(0);box-shadow:none}.chatbox-load-more .loading-spinner{width:20px;height:20px;border:2px solid rgba(0,0,0,.1);border-top:2px solid var(--primary-color);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}.chatbox-empty,.chatbox-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;gap:.75rem;color:var(--primary-light-text-color);height:100%}.chatbox-loading .loading-spinner{width:24px;height:24px;border:2px solid rgba(0,0,0,.1);border-top:2px solid var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}.chatbox-empty p,.chatbox-loading span{font-size:.875rem;font-weight:500;margin:0}.chatbox-empty span{font-size:.8125rem;color:var(--primary-lightest-text-color)}.chatbox-footer{padding:.6em;padding-bottom:.8em;background-color:var(--main-content-bg-color);border-top:1px solid rgba(0,0,0,.08);display:flex;gap:.25rem;align-items:center;flex-shrink:0;position:relative}.chatbox-attach-wrapper{position:relative;flex-shrink:0}.chatbox-attach-btn{transition:color .15s ease,background-color .15s ease,transform .2s ease}.chatbox-attach-btn.active{color:var(--primary-color);transform:rotate(45deg)}.chatbox-attach-menu{position:absolute;bottom:calc(100% + .5rem);left:0;background:var(--base-color);border:1px solid var(--block-border-color);border-radius:.75rem;padding:.35rem;display:flex;flex-direction:column;gap:.15rem;box-shadow:0 4px 12px rgba(0,0,0,.12);z-index:10;opacity:1;visibility:visible;transition:opacity .15s ease,visibility .15s ease;white-space:nowrap}.chatbox-attach-menu.hide{opacity:0;visibility:hidden;pointer-events:none}.chatbox-attach-option{display:flex;align-items:center;justify-content:flex-start;gap:.5rem;padding:.45rem .65rem;border-radius:.5rem;background:0 0;border:none;cursor:pointer;color:var(--primary-light-text-color);font-size:.8rem;font-weight:500;transition:color .15s ease,background-color .15s ease;width:100%;text-align:left;box-shadow:none}.chatbox-attach-option:hover{color:var(--primary-text-color);background-color:var(--list-hover-color);transform:none;box-shadow:none}.chatbox-attach-option svg{flex-shrink:0}.chatbox.minimized .chatbox-footer{display:none}.chatbox-input{flex:1;border:1px solid var(--block-border-color);border-radius:1.25rem;padding:.5rem .875rem;font-size:.9375rem;font-family:inherit;resize:none;max-height:100px;min-height:36px;line-height:1.4;transition:border-color .15s ease;outline:0;background:var(--base-color);scrollbar-width:thin;scrollbar-color:rgba(0,0,0,0.2) transparent}.chatbox-input::-webkit-scrollbar{width:4px}.chatbox-input::-webkit-scrollbar-track{background:0 0;margin:1rem 0}.chatbox-input::-webkit-scrollbar-thumb{background:rgba(0,0,0,.2);border-radius:4px}.chatbox-input::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.35)}.chatbox-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px rgba(var(--primary-color-rgb,5,111,240),.1)}.chatbox-input::placeholder{color:var(--primary-light-text-color)}.chatbox-send-btn svg{left:-1px;position:relative;top:1px}.chatbox-footer .sticker-picker{position:absolute;bottom:100%;left:0;right:0;background-color:var(--base-color);border:1px solid rgba(0,0,0,.08);border-radius:.75rem .75rem 0 0;box-shadow:0 -4px 16px rgba(0,0,0,.1);max-height:200px;height:200px;display:flex;flex-direction:column;z-index:10;overflow:hidden;transform:translateY(10px);opacity:0;visibility:hidden;transition:transform .2s ease,opacity .2s ease,visibility .2s}.chatbox-footer .sticker-picker:not(.hide){transform:translateY(0);opacity:1;visibility:visible}.sticker-picker-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;border-bottom:1px solid rgba(0,0,0,.08);flex-shrink:0}.sticker-picker-title{font-weight:600;font-size:.875rem;color:var(--primary-text-color)}.sticker-picker-close:hover{color:var(--primary-text-color)}.sticker-picker-content{flex:1;overflow-y:auto;padding:.5rem}.sticker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:.375rem}.sticker-item{aspect-ratio:1;padding:.25rem;background:0 0;border:none;cursor:pointer;border-radius:.375rem;transition:background-color .15s ease;display:flex;align-items:center;justify-content:center;box-shadow:none}.sticker-item:hover{background-color:rgba(0,0,0,.05);box-shadow:none;transform:none}.sticker-item lottie-player{width:100%;height:100%;max-width:48px;max-height:48px}.sticker-picker-error,.sticker-picker-loading{text-align:center;padding:1.5rem .75rem;color:var(--primary-light-text-color);font-size:.8rem}[data-theme=dark] .sticker-picker{border-color:rgba(255,255,255,.08);box-shadow:0 -4px 16px rgba(0,0,0,.3)}[data-theme=dark] .sticker-picker-header{border-bottom-color:rgba(255,255,255,.08)}[data-theme=dark] .sticker-picker-close:hover{background-color:rgba(255,255,255,.05)}[data-theme=dark] .sticker-item:hover{background-color:rgba(255,255,255,.05)}[data-theme=dark] .reaction-add-btn{background-color:var(--main-content-bg-color);border-color:rgba(255,255,255,.1)}[data-theme=dark] .reaction-add-btn:hover{background-color:rgba(255,255,255,.1)}[data-theme=dark] .reaction-picker{background-color:var(--main-content-bg-color);border-color:rgba(255,255,255,.1);box-shadow:0 4px 12px rgba(0,0,0,.3)}[data-theme=dark] .reaction-picker-emoji:hover{background-color:rgba(255,255,255,.08)}@media (hover:none){.reaction-add-btn{display:flex;opacity:.5;width:24px;height:24px}.reaction-add-btn svg{width:14px;height:14px}}.message-action-buttons{position:absolute;top:50%;transform:translateY(-50%);display:none;align-items:center;gap:2px;z-index:3}.chatbox-message-other .message-action-buttons{left:100%;margin-left:4px}.chatbox-message-own .message-action-buttons{right:100%;margin-right:4px;flex-direction:row-reverse}.chatbox-message:hover .message-action-buttons{display:flex}.message-action-buttons .reaction-add-btn{position:static;transform:none;display:flex;margin:0}.message-action-buttons .reaction-add-btn::before{display:none}.message-reply-btn{width:28px;height:28px;border-radius:50%;border:1px solid rgba(0,0,0,.08);background-color:var(--main-content-bg-color);color:var(--primary-light-text-color);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .15s ease;box-shadow:none}.message-reply-btn:hover{background-color:var(--list-hover-color);color:var(--primary-text-color);transform:scale(1.1);box-shadow:none}.message-reply-btn svg{width:14px;height:14px}.message-action-buttons::before{content:'';position:absolute;top:-4px;bottom:-4px}.chatbox-message-other .message-action-buttons::before{right:100%;width:12px}.chatbox-message-own .message-action-buttons::before{left:100%;width:12px}[data-theme=dark] .message-reply-btn{background-color:var(--main-content-bg-color);border-color:rgba(255,255,255,.1)}[data-theme=dark] .message-reply-btn:hover{background-color:rgba(255,255,255,.1)}@media (hover:none){.message-action-buttons{display:flex;opacity:.5}.message-action-buttons .reaction-add-btn,.message-reply-btn{width:24px;height:24px}.message-action-buttons .reaction-add-btn svg,.message-reply-btn svg{width:14px;height:14px}}.reply-quote{border-radius:1rem;padding:.3rem .65rem;margin-bottom:-.4rem;max-width:min(200px,80%);overflow:hidden;cursor:pointer;transition:background-color .15s ease;background-color:var(--base-muted-color);align-self:flex-start}.chatbox-message-own .reply-quote{align-self:flex-end}.reply-quote:hover{background-color:rgba(0,0,0,.1)}.reply-quote-content{font-size:.75rem;color:var(--primary-light-text-color);overflow:hidden;text-overflow:ellipsis;line-height:1.3;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical}[data-theme=dark] .reply-quote{background-color:rgba(255,255,255,.08)}[data-theme=dark] .reply-quote:hover{background-color:rgba(255,255,255,.12)}.reply-compose-bar{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background-color:var(--base-muted-color);border-radius:.5rem;margin-bottom:.5rem;width:100%;flex-basis:100%;animation:reply-bar-in .15s ease}.chatbox-footer:has(.reply-compose-bar),.message-input-footer:has(.reply-compose-bar){flex-wrap:wrap}@keyframes reply-bar-in{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.reply-compose-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.reply-compose-label{font-size:.75rem;color:var(--primary-color);font-weight:500}.reply-compose-label strong{font-weight:600}.reply-compose-preview{font-size:.8rem;color:var(--primary-light-text-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.reply-compose-close{flex-shrink:0}[data-theme=dark] .reply-compose-bar{background-color:rgba(255,255,255,.06)}@media (prefers-reduced-motion:reduce){.chatbox,.chatbox-btn,.chatbox-btn svg,.chatbox-header,.chatbox-input,.chatbox-read-receipt,.chatbox-send-btn{transition:none;animation:none}.chatbox-loading .loading-spinner{animation:none;border-top-color:var(--primary-color)}.chatbox-read-receipt.seen{animation:none!important}.reply-compose-bar{animation:none}}.chatbox-btn:focus-visible,.chatbox-send-btn:focus-visible{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}@media (max-width:768px){.chatbox{width:calc(100vw - 2rem);max-width:400px;height:100vh;height:100dvh;max-height:calc(100vh - 1rem);max-height:calc(100dvh - 1rem);right:1rem;padding-bottom:env(safe-area-inset-bottom,0)}.chatbox-container{right:0}.chatbox-read-receipt{font-size:.7rem}.chatbox-message-own .chatbox-read-receipt{font-size:.75rem}.chatbox-group-info{font-size:.75rem;padding:.5rem .75rem}}@media (max-width:1024px) and (min-width:769px){.chatbox{width:300px;height:420px}}@media (min-width:1600px){.chatbox{width:340px;height:480px}}.chat-image-message{position:relative;border-radius:12px;overflow:hidden;max-width:100%;max-height:300px}.chat-image-blurred{cursor:pointer}.chat-image{display:block;width:100%;height:auto;max-height:300px;object-fit:cover;border-radius:8px;border:1px solid rgba(0,0,0,.1);cursor:pointer;transition:border-color .15s}.chat-image:hover{border-color:rgba(0,0,0,.25)}.chat-image-blurred .chat-image{filter:blur(20px);transform:scale(1.1)}.chat-image-blur-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem;background:rgba(0,0,0,.45);cursor:pointer;border-radius:12px;padding:1rem;transition:background .2s}.chat-image-blur-overlay:hover{background:rgba(0,0,0,.55)}.chat-image-blur-text{color:#fff;font-size:.8rem;font-weight:500;text-align:center;line-height:1.3;text-shadow:0 1px 3px rgba(0,0,0,.5)}.chat-image-blur-action{color:#fff;font-size:.75rem;opacity:.85;text-decoration:underline;text-align:center;text-shadow:0 1px 3px rgba(0,0,0,.5)}.chat-image-upload-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:rgba(0,0,0,.3);border-radius:12px}.chat-image-upload-spinner{width:28px;height:28px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:chatImageSpin .8s linear infinite}@keyframes chatImageSpin{to{transform:rotate(360deg)}}.chat-image-lightbox{position:fixed;inset:0;z-index:100000;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.9);cursor:zoom-out;animation:chatLightboxFadeIn .2s ease}.chat-image-lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:4px;box-shadow:0 4px 24px rgba(0,0,0,.5)}.chat-image-lightbox-close{position:absolute;top:1rem;right:1rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.15);border:none;border-radius:50%;color:#fff;font-size:1.25rem;cursor:pointer;transition:background .15s}.chat-image-lightbox-close:hover{background:rgba(255,255,255,.3)}@keyframes chatLightboxFadeIn{from{opacity:0}to{opacity:1}}.chat-image-preview{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background-color:var(--secondary-color);border-top:1px solid rgba(0,0,0,.08)}.chat-image-preview.hide{display:none}.chat-image-preview-thumb{width:40px;height:40px;object-fit:cover;border-radius:6px}.chat-image-preview-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}.chat-image-preview-name{font-size:.8rem;font-weight:500;color:var(--primary-text-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-image-preview-size{font-size:.7rem;color:var(--primary-light-text-color)}.chat-voice-message{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .875rem;border-radius:1.125rem;background:var(--base-muted-color);cursor:pointer;user-select:none;transition:opacity .15s ease;position:relative;overflow:hidden}.chat-voice-message .chat-voice-progress{position:absolute;left:0;top:0;bottom:0;width:0%;border-radius:1.125rem;pointer-events:none;transition:width .3s linear}.chatbox-message-other .chat-voice-message .chat-voice-progress{background:rgba(0,0,0,.08)}.chatbox-message-own .chat-voice-message .chat-voice-progress{background:rgba(255,255,255,.15)}.chat-voice-message .chat-voice-duration,.chat-voice-message .chat-voice-mic-icon{position:relative;z-index:1}.chatbox-message-own .chat-voice-message{background:var(--primary-color);justify-content:flex-end}.chat-voice-message:active{opacity:.8}.chat-voice-message.uploading{opacity:.7;cursor:default}.chat-voice-mic-icon{flex-shrink:0;color:var(--primary-light-text-color)}.chat-voice-message.mine .chat-voice-mic-icon{color:rgba(255,255,255,.7)}.chat-voice-duration{font-size:.8rem;font-weight:500;color:var(--primary-text-color);font-variant-numeric:tabular-nums;white-space:nowrap}.chat-voice-message.mine .chat-voice-duration{color:rgba(255,255,255,.9)}@keyframes voiceMicPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.9)}}.chat-voice-message.playing .chat-voice-mic-icon{color:var(--primary-color);animation:voiceMicPulse 1.5s ease-in-out infinite}.chat-voice-message.mine.playing .chat-voice-mic-icon{color:#fff}.chat-voice-recorder{display:flex;align-items:center;width:100%}.chat-voice-recorder.hide{display:none}.chat-voice-recording-state{display:flex;align-items:center;gap:.5rem;width:100%}.chat-voice-recording-state.hide{display:none}.chat-voice-preview-state{display:flex;align-items:center;gap:.5rem;width:100%}.chat-voice-preview-state.hide{display:none}.chat-voice-recording-pill{flex:1;display:flex;align-items:center;gap:.375rem;background:var(--base-muted-color);border-radius:1.25rem;padding:.375rem .75rem .375rem .375rem;min-width:0;height:36px}.chat-voice-stop{width:28px;height:28px;border-radius:50%;border:none;background:#ef4444;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0;transition:opacity .15s ease;box-shadow:none}.chat-voice-stop:hover{opacity:.85;box-shadow:none;transform:none}.chat-voice-recording-indicator{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.chat-voice-red-dot{width:8px;height:8px;border-radius:50%;background:#ef4444;animation:voicePulse 1s ease-in-out infinite}@keyframes voicePulse{0%,100%{opacity:1}50%{opacity:.3}}.chat-voice-timer{font-size:.7rem;font-variant-numeric:tabular-nums;color:var(--primary-light-text-color);min-width:2rem;text-align:right;white-space:nowrap}.chat-voice-timer.warning{color:#ef4444}.chat-voice-live-waveform{flex:1;display:flex;align-items:center;gap:1.5px;height:22px;min-width:0;overflow:hidden}.chat-voice-live-waveform .chat-voice-bar{flex:1;min-width:1.5px;max-width:none;height:3px;border-radius:2px;background:var(--primary-light-text-color);opacity:.5;transition:height .12s ease}@keyframes voiceIdleWave{0%,100%{height:3px}50%{height:7px}}.chat-voice-live-waveform.idle .chat-voice-bar{animation:voiceIdleWave 2s ease-in-out infinite}@keyframes voiceActiveWave{0%,100%{height:4px}50%{height:20px}}.chat-voice-live-waveform.active .chat-voice-bar{animation:voiceActiveWave .6s ease-in-out infinite}.chat-voice-preview-pill{flex:1;display:flex;align-items:center;gap:.5rem;background:var(--base-muted-color);border-radius:1.25rem;padding:.375rem .875rem .375rem .375rem;min-width:0;height:36px}.chat-voice-preview-play{width:28px;height:28px;border-radius:50%;border:none;background:var(--primary-color);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0;transition:opacity .15s ease;box-shadow:none}.chat-voice-preview-play:hover{opacity:.85;box-shadow:none;transform:none}.chat-voice-preview-duration{font-size:.8rem;font-weight:500;color:var(--primary-text-color);font-variant-numeric:tabular-nums;flex-shrink:0;white-space:nowrap}.chat-voice-discard{padding:.4rem;border-radius:50%;border:none;background:0 0;color:var(--primary-light-text-color);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .15s ease,background-color .15s ease;box-shadow:none}.chat-voice-discard:hover{color:#ef4444;background:rgba(239,68,68,.08);box-shadow:none}