@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Space+Grotesk:wght@500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg:#050505;--bg2:#0a0a0a;--surface:#111;--elevated:#1a1a1a;--accent:#22c55e;--accent2:#28d847;--glow:rgba(0,255,65,.12);--text:#f0f0f0;--muted:#999;--dim:#555;--border:rgba(255,255,255,.06);--danger:#f85149;--success:#3fb950;--warning:#d29922;--msg-out:#0b3d0b;--msg-in:#1a1a1a;--font:"Inter",-apple-system,BlinkMacSystemFont,sans-serif;--logo:"Space Grotesk",sans-serif;--mono:"JetBrains Mono",monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overflow:hidden;letter-spacing:-.01em}#app{height:100%;display:flex;flex-direction:column}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:2px}::-webkit-scrollbar-thumb:hover{background:#ffffff26}::selection{background:#00ff4140}.auth-screen{display:flex;align-items:center;justify-content:center;height:100%;position:relative}.auth-card{background:var(--surface);border-radius:14px;padding:48px 40px;width:100%;max-width:420px;box-shadow:0 10px 40px #0006;z-index:1}.auth-logo{text-align:center;margin-bottom:36px}.auth-logo h1{font-family:var(--logo);font-size:32px;font-weight:700;letter-spacing:2px;background:linear-gradient(135deg,#00ff41,#28c840);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.auth-logo .tagline{font-size:13px;color:var(--dim);margin-top:8px}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:13px;font-weight:500;color:var(--muted);margin-bottom:8px}.form-input{width:100%;padding:14px 16px;background:var(--bg);border:1px solid var(--border);border-radius:12px;color:var(--text);font-family:var(--font);font-size:16px;outline:none;transition:border .2s}.form-input::placeholder{color:var(--dim)}.form-input:focus{border-color:#00ff4166;box-shadow:0 0 0 3px #00ff4114}.btn{width:100%;padding:12px 20px;border:none;border-radius:12px;font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.btn:active{transform:scale(.97)}.btn-primary{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;box-shadow:0 2px 8px #22c55e4d}.btn-primary:hover{box-shadow:0 4px 12px #22c55e66}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:#ffffff0f;color:#e0e0e0;border:1px solid rgba(255,255,255,.1)}.btn-ghost:hover{background:#ffffff1a}.auth-switch{text-align:center;margin-top:20px;font-size:14px;color:var(--muted)}.auth-switch a{color:var(--accent);text-decoration:none;cursor:pointer;font-weight:500}.app-layout{display:flex;height:100%}.sidebar{width:340px;height:100%;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.sidebar-header{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between;min-height:52px;background:#0a0a0ad9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.sidebar-header h2{font-family:var(--logo);font-size:18px;font-weight:700;letter-spacing:1px;background:linear-gradient(135deg,#00ff41,#28c840);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.sidebar-search{padding:8px 12px}.sidebar-search input{width:100%;padding:10px 16px;background:#ffffff0d;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.06);border-radius:20px;color:var(--text);font-size:15px;outline:none;transition:all .2s}.sidebar-search input:focus{border-color:#22c55e4d;background:#ffffff14}.sidebar-search input::placeholder{color:#ffffff4d}.conversations-list{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.conversation-item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;transition:background .12s;position:relative;min-height:64px;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.conversation-item:hover{background:#ffffff0a}.conversation-item.active{background:var(--elevated);border-left:3px solid var(--accent)}.conversation-avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#0c3,#092);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;flex-shrink:0;color:#fff;position:relative;box-shadow:0 2px 8px #0003}.conversation-info{flex:1;min-width:0}.conversation-name{font-weight:600;font-size:16px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.conversation-preview{font-size:14px;color:#ffffff73;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.conversation-meta{text-align:right;flex-shrink:0}.conversation-time{font-size:12px;color:#ffffff59;white-space:nowrap}.unread-badge{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;font-size:12px;font-weight:700;min-width:22px;height:22px;padding:0 6px;border-radius:11px;margin-top:4px;box-shadow:0 2px 6px #22c55e4d}.chat-panel{flex:1;display:flex;flex-direction:column;background:var(--bg)}.chat-header{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:10px;background:#0a0a0ad9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);min-height:52px;position:sticky;top:0;z-index:100}.chat-header-info h3{font-size:16px;font-weight:600;color:#fff}.chat-header-actions{margin-left:auto;display:flex;gap:4px}.chat-header-actions button,.icon-btn{background:none;border:none;color:#fff9;width:40px;height:40px;border-radius:50%;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;padding:0}.icon-btn:hover{color:#fff;background:#ffffff14}.icon-btn:active{transform:scale(.9);background:#ffffff1f}.messages-container{flex:1;overflow-y:auto;padding:8px 12px;display:flex;flex-direction:column;gap:3px;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;position:relative}.messages-container:before{content:"";position:fixed;inset:0;opacity:.05;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 5L35 15L25 15Z' fill='%2322c55e'/%3E%3Ccircle cx='10' cy='40' r='3' fill='%2322c55e'/%3E%3Crect x='45' y='35' width='8' height='8' rx='1' fill='%2322c55e'/%3E%3Cpath d='M15 55L20 50L10 50Z' fill='%2322c55e'/%3E%3Ccircle cx='50' cy='15' r='2' fill='%2322c55e'/%3E%3C/svg%3E");background-size:60px 60px}.message{max-width:75%;padding:8px 12px 6px;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;border-radius:18px;font-size:15px;line-height:1.5;position:relative;word-break:break-word;transition:opacity .2s,transform .2s}.message-sent{align-self:flex-end;background:linear-gradient(135deg,#1a6b37,#155d30);color:#fff;border-bottom-right-radius:6px;box-shadow:0 1px 3px #0003,inset 0 1px #ffffff0d}.message-sent+.message-sent{margin-top:-1px;border-top-right-radius:6px;border-bottom-right-radius:6px}.message-received{align-self:flex-start;background:linear-gradient(135deg,#1e2530,#1a2028);color:#e8eaed;border-bottom-left-radius:6px;box-shadow:0 1px 3px #00000026,inset 0 1px #ffffff08}.message-received+.message-received{margin-top:-1px;border-top-left-radius:6px;border-bottom-left-radius:6px}.message-time{font-size:11px;color:#ffffff73;margin-top:2px;text-align:right;display:flex;align-items:center;justify-content:flex-end;gap:4px}.msg-ticks{margin-left:3px;vertical-align:middle;flex-shrink:0;opacity:.7}.ctx-overlay{position:fixed;inset:0;z-index:9999}.ctx-backdrop{position:fixed;inset:0;background:#00000080;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.ctx-menu{position:fixed;background:#1c2028f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:16px;overflow:hidden;min-width:220px;max-width:240px;padding:6px;box-shadow:0 8px 32px #00000080,0 0 1px #ffffff1a;animation:ctxAppear .15s cubic-bezier(.2,0,.13,1.5);z-index:10000}.ctx-reactions{display:flex;gap:2px;padding:8px 6px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:4px}.ctx-react-btn{background:none;border:none;font-size:22px;width:40px;height:40px;border-radius:50%;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.ctx-react-btn:hover{background:#ffffff1a;transform:scale(1.15)}.ctx-react-btn:active{transform:scale(.9)}.ctx-items{padding:4px 0}.ctx-item{display:flex;align-items:center;gap:12px;width:100%;padding:11px 14px;border-radius:10px;font-size:14px;background:none;border:none;color:#e0e0e0;cursor:pointer;transition:background .12s;text-align:left}.ctx-item:hover{background:#ffffff14}.ctx-item:active{background:#ffffff1f;transform:scale(.98)}.ctx-icon{width:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.7}.ctx-icon svg{stroke:currentColor}.ctx-danger{color:#f87171!important}.ctx-danger .ctx-icon svg{stroke:#f87171}.ctx-danger:hover{background:#ef44441a!important}.ctx-muted{color:#fff6;font-size:13px}.ctx-muted .ctx-icon svg{stroke:#fff6}.ctx-sep{height:1px;background:#ffffff0f;margin:4px 8px}@keyframes ctxIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes ctxAppear{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes msgSend{0%{opacity:0;transform:translateY(8px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes msgReceive{0%{opacity:0;transform:translate(-8px) scale(.97)}to{opacity:1;transform:translate(0) scale(1)}}.msg-spoiler{background:#ffffff26;color:transparent;border-radius:4px;padding:0 4px;cursor:pointer;transition:all .3s;user-select:none;-webkit-user-select:none}.msg-spoiler.revealed{color:inherit;background:transparent}.msg-quote{border-left:3px solid var(--accent);padding:4px 8px;margin:4px 0;background:#22c55e14;border-radius:0 6px 6px 0;font-size:13px;color:#ffffffb3}.msg-reply-card{border-left:2px solid var(--accent);background:#ffffff0a;border-radius:0 8px 8px 0;padding:6px 10px;margin-bottom:4px;cursor:pointer;max-width:100%;overflow:hidden}.msg-reply-sender{font-size:12px;font-weight:600;color:var(--accent);margin-bottom:1px}.msg-reply-text{font-size:13px;color:#ffffff80;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msg-forwarded{font-size:11px;color:#ffffff80;margin-bottom:3px;display:flex;align-items:center;gap:4px;font-style:italic}.msg-forwarded svg{opacity:.5}.reply-preview{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#22c55e0f;border-left:3px solid var(--accent);border-radius:0 8px 8px 0;margin:0 12px}.reply-preview-bar{width:3px;height:32px;background:var(--accent);border-radius:2px;flex-shrink:0}.reply-preview-content{flex:1;overflow:hidden}.reply-preview-name{font-size:12px;font-weight:600;color:var(--accent)}.reply-preview-text{font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pinned-bar{display:flex;align-items:center;gap:10px;padding:8px 14px;background:linear-gradient(135deg,#22c55e0f,#22c55e05);border-bottom:1px solid rgba(34,197,94,.12);cursor:pointer;transition:background .15s}.pinned-bar:active{background:#22c55e1a}.pinned-icon{width:32px;height:32px;border-radius:50%;background:#22c55e1f;display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}.pinned-content{flex:1;overflow:hidden;min-width:0}.pinned-label{font-size:11px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.5px}.pinned-msg-text{font-size:13px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:1px}.pinned-unpin-btn{flex-shrink:0;font-size:11px;font-weight:500;padding:5px 12px;border-radius:8px;border:none;background:#ffffff14;color:var(--text-muted);cursor:pointer;transition:all .15s}.pinned-unpin-btn:hover{background:#ff464626;color:#ff4545}.msg-highlight{animation:msgHighlight 2s ease-out}@keyframes msgHighlight{0%,30%{background:#22c55e26}to{background:transparent}}.tab-badge{position:absolute;top:2px;right:50%;transform:translate(14px);min-width:16px;height:16px;border-radius:8px;background:var(--accent);color:#000;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px}.profile-card{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#12161afa;backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border-radius:20px;padding:28px 20px 20px;width:min(320px,88vw);text-align:center;z-index:10001;animation:modalAppear .25s cubic-bezier(.34,1.56,.64,1);border:1px solid rgba(255,255,255,.06);box-shadow:0 20px 60px #0009}.profile-avatar{width:72px;height:72px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:600;color:#fff;margin:0 auto 10px}.profile-name{font-size:18px;font-weight:600;color:#fff;margin:0}.profile-status{font-size:12px;color:var(--accent);margin-top:3px}.profile-id{font-size:10px;color:#ffffff26;margin-top:2px;font-family:var(--mono)}.profile-actions{display:flex;justify-content:space-around;margin:16px 0;padding:14px 0;border-top:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.05)}.profile-action-btn{display:flex;flex-direction:column;align-items:center;gap:5px;background:none;border:none;color:#fff9;cursor:pointer;font-size:10px;padding:6px 4px;min-width:48px;transition:color .15s}.profile-action-btn:active{opacity:.5}.profile-action-btn svg{opacity:.7}.profile-section{text-align:left;margin-top:12px;padding:10px 12px;background:#ffffff08;border-radius:10px;border:1px solid rgba(255,255,255,.04)}.profile-section-title{font-size:11px;font-weight:600;color:var(--accent);margin-bottom:3px;text-transform:uppercase;letter-spacing:.3px}.profile-section-text{font-size:12px;color:var(--text-muted);line-height:1.4}.profile-photo-btn{position:absolute;bottom:-2px;right:-2px;width:26px;height:26px;border-radius:50%;background:var(--accent);border:2px solid rgba(18,22,26,.98);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s}.profile-photo-btn:active{transform:scale(.9)}.select-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg2);border-bottom:1px solid var(--border)}.select-bar-btn{width:40px;height:40px;border-radius:50%;border:none;background:none;color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.select-bar-btn:active{background:#ffffff1a}.select-bar-delete{color:var(--danger)}.select-bar-delete svg{stroke:var(--danger)}.select-bar-count{font-size:15px;font-weight:500;color:var(--text);margin-left:4px}.message.selectable{cursor:pointer;transition:background .15s;position:relative;margin-left:32px}.message.selectable:before{content:"";position:absolute;left:-32px;top:50%;transform:translateY(-50%);width:22px;height:22px;border:2px solid rgba(255,255,255,.25);border-radius:50%;transition:all .15s}.message.selected:before{background:var(--accent);border-color:var(--accent)}.message.selected:after{content:"✓";position:absolute;left:-27px;top:50%;transform:translateY(-50%);color:#000;font-size:12px;font-weight:700;z-index:1}.message.selected{background:#22c55e0f}.message-status{font-size:10px;color:var(--accent);margin-left:4px}.e2e-badge{display:flex;align-items:center;justify-content:center;gap:6px;padding:6px;font-size:11px;color:var(--dim);margin-bottom:8px;opacity:.6}.system-message{display:flex;align-items:center;justify-content:center;gap:6px;padding:6px 14px;font-size:12px;color:var(--muted);margin:8px auto;background:#ffffff0a;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:16px;max-width:fit-content}.system-message b{color:var(--accent)}.msg-timer{font-family:var(--mono);font-size:10px;color:var(--warning);margin-left:2px}.compose-bar{padding:8px 12px 14px;display:flex;align-items:flex-end;gap:8px;background:#0a0a0ae6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid rgba(255,255,255,.06);max-width:600px;margin:0 auto;width:100%}.compose-circle-btn{width:42px;height:42px;border-radius:50%;border:none;background:var(--surface);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.compose-circle-btn:active{transform:scale(.9);background:var(--elevated)}.compose-circle-btn.sending{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;box-shadow:0 2px 8px #22c55e4d}.compose-input-wrap{flex:1;position:relative;display:flex;align-items:flex-end;background:#ffffff0f;border-radius:22px;border:1px solid rgba(255,255,255,.08);overflow:hidden;transition:border-color .2s}.compose-input-wrap:focus-within{border-color:#22c55e66}.compose-input{flex:1;padding:10px 38px 10px 16px;background:transparent;border:none;color:var(--text);font-family:var(--font);font-size:15px;outline:none;resize:none;max-height:120px;min-height:36px;line-height:1.4}.compose-input:focus{outline:none}.compose-emoji-btn{position:absolute;right:8px;bottom:7px;width:28px;height:28px;background:none;border:none;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .15s}.compose-emoji-btn:active{background:#ffffff1a}.compose-actions{display:flex;gap:0}.compose-actions button{width:36px;height:36px;border-radius:50%;padding:0;display:flex;align-items:center;justify-content:center}.empty-chat{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--dim)}.typing-indicator{display:flex;gap:5px;padding:10px 16px;align-self:flex-start;background:linear-gradient(135deg,#1e2530,#1a2028);border-radius:18px 18px 18px 6px;box-shadow:0 1px 3px #00000026}.typing-indicator span{width:8px;height:8px;background:var(--accent);border-radius:50%;animation:typing 1.2s ease-in-out infinite;opacity:.6}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,to{transform:translateY(0);opacity:.4}50%{transform:translateY(-4px);opacity:1}}.scan-line{position:fixed;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);animation:scan 4s linear infinite;opacity:.15;z-index:9999;pointer-events:none}@keyframes scan{0%{top:0}to{top:100%}}.modal-overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;animation:fadeIn .2s}.modal{background:#14161cfa;backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:24px;width:min(400px,90vw);max-height:85vh;overflow-y:auto;box-shadow:0 16px 48px #00000080;animation:modalAppear .25s cubic-bezier(.34,1.56,.64,1)}.modal h3{font-size:18px;font-weight:600;margin-bottom:16px;color:#fff}.modal .form-group label{color:#ffffff80;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.modal .form-input{background:#0006;border:1px solid rgba(255,255,255,.1)}.modal .form-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #22c55e1f}.modal .btn-primary{border-radius:10px}.modal .btn-ghost{border-radius:10px;border:1px solid rgba(255,255,255,.08)}.settings-panel{padding:24px}.settings-group{margin-bottom:16px;background:var(--surface);border-radius:12px;border:1px solid var(--border);overflow:hidden}.settings-group h4{font-size:12px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:6px;padding-left:16px}.settings-group>.settings-item:last-child{border-bottom:none}.settings-group.collapsible>.settings-header{cursor:pointer;display:flex;align-items:center;justify-content:space-between;padding:10px 16px;margin-bottom:0;-webkit-user-select:none;user-select:none}.settings-group.collapsible>.settings-header:after{content:"";width:8px;height:8px;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);transform:rotate(45deg);transition:transform .2s;flex-shrink:0}.settings-group.collapsible>.settings-item,.settings-group.collapsible>div:not(.settings-header){max-height:500px;overflow:hidden;transition:max-height .25s ease,opacity .2s;opacity:1}.settings-group.collapsible.collapsed>.settings-item,.settings-group.collapsible.collapsed>div:not(.settings-header){max-height:0;opacity:0;padding-top:0;padding-bottom:0;border:none;margin:0}.settings-item{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;background:transparent;border-bottom:.5px solid rgba(255,255,255,.04);font-size:14px;transition:background .15s}.settings-item[style*="cursor:pointer"]:active{background:var(--elevated)}.settings-item:first-child{border-radius:12px 12px 0 0}.settings-item:last-child{border-radius:0 0 12px 12px;border-bottom:none}.settings-item:only-child{border-radius:12px}.msg-bold{font-weight:600}.msg-italic{font-style:italic}.msg-code{font-family:var(--mono);font-size:13px;background:var(--bg);padding:2px 6px;border-radius:4px}.msg-quote{border-left:3px solid var(--accent);padding-left:10px;color:var(--muted);font-style:italic}.msg-link{color:var(--accent);text-decoration:underline;cursor:pointer}.reactions-bar{display:flex;gap:4px;margin-top:6px;flex-wrap:wrap}.reaction-chip{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:14px;font-size:13px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);cursor:pointer;transition:all .15s}.reaction-chip:hover{background:#ffffff1a;transform:scale(1.05)}.reaction-chip:active{transform:scale(.95)}.reaction-chip.mine{border-color:#22c55e66;background:#22c55e1f;color:var(--accent)}.quick-reactions{display:flex;gap:4px;padding:6px 10px;background:var(--elevated);border:1px solid var(--border);border-radius:24px;box-shadow:0 8px 30px #00000080;position:absolute;bottom:100%;animation:fadeInUp .15s ease-out}.quick-reactions button{font-size:20px;padding:4px 6px;background:none;border:none;cursor:pointer;border-radius:8px}.quick-reactions button:hover{transform:scale(1.3)}.format-toolbar{display:flex;gap:2px;padding:4px 8px;border-top:1px solid var(--border);background:var(--elevated)}.format-toolbar button{font-size:13px;padding:4px 8px;background:none;border:none;color:var(--dim);cursor:pointer;border-radius:4px;font-family:var(--mono)}.format-toolbar button:hover{color:var(--accent);background:var(--elevated)}.chat-search{padding:8px 16px;background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}.chat-search input{flex:1;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:20px;color:var(--text);font-size:13px;outline:none}.message-burn{border:1px solid rgba(248,81,73,.3);background:#f851490d;position:relative}.message-burn:before{content:"🔥";position:absolute;top:-8px;right:-8px;font-size:14px}.presence-dot{width:12px;height:12px;border-radius:50%;border:2.5px solid var(--bg);position:absolute;bottom:0;right:0}.presence-online{background:var(--success)}.presence-offline{background:var(--dim)}.screen-protected{-webkit-user-select:none;user-select:none}body.blur-on-inactive #app{filter:blur(30px);transition:filter .15s}.screen-lock-overlay{position:fixed;inset:0;z-index:10000;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center}.mesh-bg{position:fixed;inset:0;background-image:linear-gradient(rgba(0,255,65,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(0,255,65,.02) 1px,transparent 1px);background-size:48px 48px;pointer-events:none;z-index:0}.toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);padding:10px 20px;background:#1c2028f2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:12px;font-size:13px;z-index:9999;animation:fadeInUp .2s;box-shadow:0 4px 16px #0000004d}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes modalAppear{0%{opacity:0;transform:scale(.9) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes loading{0%{transform:translate(-100%)}50%{transform:translate(0)}to{transform:translate(200%)}}@keyframes splashPulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.06);opacity:1}}.loading-dots span{animation:dotPulse 1.2s ease-in-out infinite}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes dotPulse{0%,80%,to{opacity:0}40%{opacity:1}}.bottom-tabs{display:flex;border-top:1px solid rgba(255,255,255,.06);background:#050505f2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:6px 0 10px;gap:0}.tab-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 0;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:10px;transition:all .2s;position:relative}.tab-btn.active{color:var(--accent)}.tab-btn.active:after{content:"";position:absolute;top:-6px;left:50%;transform:translate(-50%);width:24px;height:2px;background:var(--accent);border-radius:1px}.tab-btn svg{transition:stroke .2s}.tab-btn.active svg{stroke:var(--accent)}.sidebar-content{flex:1;overflow-y:auto;overflow-x:hidden}.conversation-item{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.conv-online-dot{position:absolute;bottom:0;right:0;width:13px;height:13px;border-radius:50%;background:var(--accent);border:2.5px solid var(--bg2);display:none;z-index:2}.tab-page{display:none;height:100%;overflow-y:auto}.date-separator{display:flex;align-items:center;justify-content:center;padding:12px 0;margin:4px 0}.date-separator span{background:#ffffff0f;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff6;font-size:12px;font-weight:500;padding:4px 14px;border-radius:20px}.scroll-bottom-btn{position:absolute;bottom:80px;right:16px;width:40px;height:40px;border-radius:50%;background:#1c2028e6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);color:#ffffffb3;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #0006;z-index:10;transition:all .2s}.scroll-bottom-btn:hover{background:#22c55e26;border-color:#22c55e4d;color:var(--accent)}.scroll-bottom-btn:active{transform:scale(.9)}@media(max-width:768px){.sidebar{width:100%}.chat-panel,.app-layout.chat-open .sidebar{display:none}.app-layout.chat-open .chat-panel{display:flex;flex-direction:column}.back-btn{display:block!important}}@media(min-width:769px){.back-btn{display:none!important}}@media(max-width:480px){.message{max-width:82%}.chat-header{padding:8px 10px;gap:6px}.conversation-avatar{width:46px;height:46px;font-size:16px}.compose-bar{padding:6px 10px 14px}}[data-theme=matrix]{--bg:#000;--bg2:#020;--surface:#031;--elevated:#042;--accent:#0f0;--accent2:#0f0;--glow:rgba(0,255,0,.15);--text:#0f0;--muted:#090;--dim:#060;--border:rgba(0,255,0,.1);--danger:#f00;--success:#0f0;--warning:#ff0;--msg-out:#020;--msg-in:#010}[data-theme=midnight]{--bg:#080820;--bg2:#0a0a2e;--surface:#101040;--elevated:#181860;--accent:#4488ff;--accent2:#5599ff;--glow:rgba(68,136,255,.12);--text:#c8d8ff;--muted:#6688bb;--dim:#445588;--border:rgba(68,136,255,.1);--danger:#ff4466;--success:#44cc88;--warning:#ffaa22;--msg-out:#182050;--msg-in:#101040}[data-theme=amber]{--bg:#0a0800;--bg2:#100c00;--surface:#181200;--elevated:#201a00;--accent:#ffaa00;--accent2:#ffcc00;--glow:rgba(255,170,0,.12);--text:#ffcc66;--muted:#aa8833;--dim:#665522;--border:rgba(255,170,0,.1);--danger:#ff4400;--success:#88cc00;--warning:#ffaa00;--msg-out:#1a1400;--msg-in:#181200}.voice-waveform{display:flex;align-items:center;gap:2px;height:32px;padding:0 4px}.voice-waveform .wf-bar{width:3px;min-height:4px;background:var(--accent);border-radius:2px;transition:height .1s}.voice-waveform.playing .wf-bar{background:var(--accent2)}.voice-msg{display:flex;align-items:center;gap:10px;min-width:200px;padding:4px 0}.voice-msg .vm-play{width:32px;height:32px;border-radius:50%;background:var(--accent);border:none;color:#000;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px}.voice-msg .vm-play:active{transform:scale(.9)}.voice-msg .vm-dur{font-size:11px;color:var(--muted);font-family:var(--mono);flex-shrink:0}.rec-waveform{display:flex;align-items:center;gap:2px;flex:1;height:28px;overflow:hidden}.rec-waveform .wf-bar{width:3px;min-height:3px;background:var(--danger);border-radius:2px;opacity:.8}@keyframes pulse-ring{0%,to{opacity:1}50%{opacity:.3}}.waveform-container{display:flex;align-items:center;gap:8px;padding:4px 8px;background:#22c55e0f;border-radius:12px;min-width:160px;flex:1}.waveform-bars{display:flex;align-items:center;gap:2px;height:32px;flex:1}.waveform-bar{width:3px;border-radius:2px;transition:height .1s ease,background .15s ease;min-height:3px}.waveform-bar.played{background:var(--accent);opacity:1}.waveform-bar.unplayed{background:#22c55e4d}.waveform-time{font-family:var(--mono);font-size:12px;color:var(--muted);min-width:36px;text-align:right}.vo-audio-container{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px;max-width:320px}.vo-audio-icon{font-size:48px;animation:voAudioPulse 1.5s ease-in-out infinite}@keyframes voAudioPulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.15);opacity:1}}.vo-audio-label{font-size:16px;font-weight:500;color:var(--text)}.vo-audio-waveform{display:flex;align-items:center;gap:2px;height:36px;width:100%}.vo-wf-bar{width:3px;border-radius:2px;background:#22c55e4d;min-height:3px;transition:background .15s ease}.vo-audio-time{font-family:var(--mono);font-size:14px;color:var(--text-muted)}.vo-file-container{background:var(--surface);border-radius:16px;max-width:90vw;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;position:relative}.vo-file-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);font-size:14px;font-weight:500;color:var(--text)}.vo-file-timer{font-family:var(--mono);font-size:13px;color:var(--accent);background:#22c55e1a;padding:4px 10px;border-radius:8px}.vo-file-content{padding:20px;overflow-y:auto;max-height:60vh;font-size:13px;line-height:1.6;color:var(--text);white-space:pre-wrap;word-break:break-word;-webkit-user-select:none;user-select:none}.locked-chat-overlay{position:fixed;inset:0;z-index:200;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}.locked-chat-overlay h3{font-size:18px;color:var(--text)}.pin-input{display:flex;gap:8px}.pin-input input{width:44px;height:52px;text-align:center;font-size:22px;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text);outline:none;font-family:var(--mono)}.pin-input input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #22c55e26}.storage-bar{height:8px;background:var(--surface);border-radius:4px;overflow:hidden;margin:8px 16px}.storage-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:4px;transition:width .3s}.theme-pick{padding:12px;border-radius:10px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .15s}.theme-pick:hover{opacity:.8}.theme-pick.active{border-color:var(--accent)!important;box-shadow:0 0 0 1px var(--accent)}[data-wallpaper=none] .messages-container:before{display:none}[data-wallpaper=grid] .messages-container:before{background-image:linear-gradient(rgba(34,197,94,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(34,197,94,.08) 1px,transparent 1px)!important;background-size:24px 24px!important;opacity:.12!important}[data-wallpaper=dots] .messages-container:before{background-image:radial-gradient(circle,rgba(34,197,94,.2) 1px,transparent 1px)!important;background-size:20px 20px!important;opacity:.12!important}.message-sticker{background:none!important;border:none!important;box-shadow:none!important;padding:4px!important}.message-sticker .message-time{background:#0006;border-radius:8px;padding:2px 6px;margin-top:4px;display:inline-block}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.animated-emoji{font-size:64px;line-height:1;animation:emojiPop .4s cubic-bezier(.175,.885,.32,1.275);cursor:pointer;user-select:none;-webkit-user-select:none;will-change:transform}.animated-emoji.anim-loop{animation-iteration-count:infinite;animation-direction:alternate}.animated-emoji:active{transform:scale(1.15)}.message-emoji-only{background:transparent!important;border:none!important;box-shadow:none!important}.message:has(.animated-emoji){background:transparent!important;border:none!important;box-shadow:none!important}[data-emoji=❤️],[data-emoji=❤]{animation-name:emojiHeart!important;animation-duration:.6s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=🔥]{animation-name:emojiFire!important;animation-duration:.5s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=👍]{animation-name:emojiThumb!important;animation-duration:.4s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=😂]{animation-name:emojiLaugh!important;animation-duration:.5s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=👎]{animation-name:emojiThumb!important;animation-duration:.4s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=💀]{animation-name:emojiShake!important;animation-duration:.5s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=🎉]{animation-name:emojiParty!important;animation-duration:.6s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=⭐]{animation-name:emojiSpin!important;animation-duration:.6s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=💯]{animation-name:emojiBounce!important;animation-duration:.5s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=😍],[data-emoji=🥰]{animation-name:emojiHeart!important;animation-duration:.7s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=😘]{animation-name:emojiKiss!important;animation-duration:.8s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=🤔]{animation-name:emojiThink!important;animation-duration:1.2s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=😱],[data-emoji=😨]{animation-name:emojiShake!important;animation-duration:.4s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=🤣]{animation-name:emojiRoll!important;animation-duration:.6s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=😭]{animation-name:emojiCry!important;animation-duration:.8s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=🙏]{animation-name:emojiPray!important;animation-duration:.9s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=👋]{animation-name:emojiWave!important;animation-duration:.6s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=💪]{animation-name:emojiFlex!important;animation-duration:.7s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=🎊],[data-emoji=🎉]{animation-name:emojiParty!important;animation-duration:.6s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=💃],[data-emoji=🕺]{animation-name:emojiDance!important;animation-duration:.5s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=🚀]{animation-name:emojiRocket!important;animation-duration:.8s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=💣],[data-emoji=💥]{animation-name:emojiExplode!important;animation-duration:.5s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=🎵],[data-emoji=🎶]{animation-name:emojiMusic!important;animation-duration:.7s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=💤]{animation-name:emojiFloat!important;animation-duration:1.5s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=✨],[data-emoji=🌟]{animation-name:emojiSparkle!important;animation-duration:.8s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=🤮],[data-emoji=🤢]{animation-name:emojiShake!important;animation-duration:.3s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=😈],[data-emoji=👿]{animation-name:emojiDevil!important;animation-duration:.8s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=🌈]{animation-name:emojiRainbow!important;animation-duration:1.2s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=❄️],[data-emoji=🥶]{animation-name:emojiFreeze!important;animation-duration:1s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=🔔]{animation-name:emojiBell!important;animation-duration:.5s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=💔]{animation-name:emojiBreak!important;animation-duration:.8s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=👀]{animation-name:emojiEyes!important;animation-duration:1s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}[data-emoji=🫡]{animation-name:emojiSalute!important;animation-duration:.6s!important;animation-iteration-count:infinite!important;animation-direction:alternate!important}@keyframes emojiPop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.3)}to{transform:scale(1);opacity:1}}@keyframes emojiHeart{0%{transform:scale(0)}25%{transform:scale(1.4)}50%{transform:scale(.9)}75%{transform:scale(1.2)}to{transform:scale(1)}}@keyframes emojiFire{0%{transform:scale(0) rotate(-10deg);opacity:0}50%{transform:scale(1.3) rotate(5deg)}to{transform:scale(1) rotate(0);opacity:1}}@keyframes emojiThumb{0%{transform:scale(0) rotate(-30deg)}60%{transform:scale(1.2) rotate(10deg)}to{transform:scale(1) rotate(0)}}@keyframes emojiLaugh{0%,to{transform:rotate(0)}20%{transform:rotate(-5deg) scale(1.1)}40%{transform:rotate(5deg) scale(1.2)}60%{transform:rotate(-3deg) scale(1.1)}80%{transform:rotate(2deg)}}@keyframes emojiShake{0%,to{transform:translate(0)}15%{transform:translate(-6px) rotate(-5deg)}30%{transform:translate(5px) rotate(4deg)}45%{transform:translate(-4px) rotate(-3deg)}60%{transform:translate(3px) rotate(2deg)}75%{transform:translate(-2px)}}@keyframes emojiParty{0%{transform:scale(0) rotate(-20deg);opacity:0}40%{transform:scale(1.3) rotate(10deg)}60%{transform:scale(.95) rotate(-5deg)}80%{transform:scale(1.1) rotate(2deg)}to{transform:scale(1) rotate(0);opacity:1}}@keyframes emojiSpin{0%{transform:scale(0) rotate(-180deg);opacity:0}60%{transform:scale(1.2) rotate(20deg)}to{transform:scale(1) rotate(0);opacity:1}}@keyframes emojiBounce{0%{transform:scale(0) translateY(20px);opacity:0}40%{transform:scale(1.2) translateY(-10px)}60%{transform:scale(.95) translateY(5px)}80%{transform:scale(1.05) translateY(-3px)}to{transform:scale(1) translateY(0);opacity:1}}@keyframes emojiKiss{0%,to{transform:scale(1)}30%{transform:scale(1.15) rotate(-5deg)}60%{transform:scale(.95) rotate(3deg)}}@keyframes emojiThink{0%,to{transform:rotate(0) translateY(0)}50%{transform:rotate(-8deg) translateY(-3px)}}@keyframes emojiRoll{0%,to{transform:rotate(0) scale(1)}25%{transform:rotate(-15deg) scale(1.1)}50%{transform:rotate(15deg) scale(1.15)}75%{transform:rotate(-8deg) scale(1.05)}}@keyframes emojiCry{0%,to{transform:translateY(0) scale(1)}30%{transform:translateY(-4px) scale(1.05)}60%{transform:translateY(2px) scale(.98)}}@keyframes emojiPray{0%,to{transform:scale(1) translateY(0)}50%{transform:scale(1.1) translateY(-5px)}}@keyframes emojiWave{0%,to{transform:rotate(0)}25%{transform:rotate(20deg)}50%{transform:rotate(-15deg)}75%{transform:rotate(10deg)}}@keyframes emojiFlex{0%,to{transform:scale(1) rotate(0)}50%{transform:scale(1.2) rotate(-10deg)}}@keyframes emojiDance{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(-5px) rotate(-8deg)}50%{transform:translate(5px) rotate(8deg)}75%{transform:translate(-3px) rotate(-4deg)}}@keyframes emojiRocket{0%,to{transform:translateY(0) rotate(-45deg) scale(1)}50%{transform:translateY(-15px) rotate(-45deg) scale(1.15)}}@keyframes emojiExplode{0%,to{transform:scale(1)}25%{transform:scale(1.3)}50%{transform:scale(.9)}75%{transform:scale(1.15)}}@keyframes emojiMusic{0%,to{transform:rotate(0) translateY(0)}25%{transform:rotate(-8deg) translateY(-3px)}50%{transform:rotate(8deg) translateY(-5px)}75%{transform:rotate(-4deg) translateY(-2px)}}@keyframes emojiFloat{0%,to{transform:translateY(0);opacity:1}50%{transform:translateY(-10px);opacity:.7}}@keyframes emojiSparkle{0%,to{transform:scale(1) rotate(0);opacity:1}25%{transform:scale(1.2) rotate(15deg);opacity:.8}50%{transform:scale(.9) rotate(-10deg);opacity:1}75%{transform:scale(1.15) rotate(5deg);opacity:.85}}@keyframes emojiDevil{0%,to{transform:scale(1) rotate(0)}30%{transform:scale(1.15) rotate(-5deg)}60%{transform:scale(1.05) rotate(5deg)}}@keyframes emojiRainbow{0%,to{transform:scale(1) rotate(0);filter:brightness(1)}50%{transform:scale(1.1) rotate(5deg);filter:brightness(1.3)}}@keyframes emojiFreeze{0%,to{transform:scale(1);filter:brightness(1)}50%{transform:scale(1.05);filter:brightness(1.3) hue-rotate(20deg)}}@keyframes emojiBell{0%,to{transform:rotate(0)}15%{transform:rotate(15deg)}30%{transform:rotate(-12deg)}45%{transform:rotate(8deg)}60%{transform:rotate(-5deg)}75%{transform:rotate(3deg)}}@keyframes emojiBreak{0%,to{transform:scale(1)}25%{transform:scale(1.1) rotate(-3deg)}50%{transform:scale(.95) rotate(2deg)}75%{transform:scale(1.05)}}@keyframes emojiEyes{0%,40%,to{transform:translate(0)}10%{transform:translate(-3px)}25%{transform:translate(3px)}55%{transform:translate(-2px)}70%{transform:translate(2px)}}@keyframes emojiSalute{0%,to{transform:rotate(0) scale(1)}30%{transform:rotate(-10deg) scale(1.05)}60%{transform:rotate(5deg) scale(1.1)}}.msg-translation{margin-top:6px;padding-top:6px;border-top:1px solid rgba(255,255,255,.08);font-size:14px;line-height:1.45;color:#ffffffd9}.translate-badge{display:flex;align-items:center;gap:8px;font-size:10px;color:var(--accent);opacity:.7;margin-top:4px;font-weight:500;letter-spacing:.3px}.translate-toggle{background:none;border:none;color:var(--accent);font-size:11px;cursor:pointer;padding:2px 8px;border-left:1px solid rgba(34,197,94,.3);margin-left:4px;opacity:.7;transition:opacity .15s;font-family:var(--font)}.translate-toggle:hover{opacity:1;text-decoration:underline}.translate-shimmer{position:relative;overflow:hidden;height:16px;border-radius:4px;background:#ffffff0f;margin-top:6px}.translate-shimmer:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);animation:shimmer 1.5s ease-in-out infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.media-panel{background:#0a0a0af2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.08);animation:mediaPanelSlideUp .25s cubic-bezier(.4,0,.2,1)}@keyframes mediaPanelSlideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.media-tabs{display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:0;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.media-tab{flex:1;padding:10px 8px;text-align:center;font-size:13px;font-weight:500;background:none;border:none;color:var(--muted);cursor:pointer;transition:all .2s ease;border-bottom:2px solid transparent;position:relative;flex-shrink:0;white-space:nowrap}.media-tab.active{color:var(--accent);border-bottom-color:var(--accent);transform:scale(1.02)}.media-tab:hover:not(.active){color:var(--text);background:#ffffff08}.media-content{max-height:280px;overflow-y:auto;padding:8px;scroll-behavior:smooth}.media-content::-webkit-scrollbar{width:3px}.media-content::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.media-content .emoji-categories{position:sticky;top:-8px;z-index:2;background:#0a0a0af2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);margin:-8px -8px 0;padding:6px 8px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;overflow-x:auto;gap:2px;scrollbar-width:none;-ms-overflow-style:none}.media-content .emoji-categories::-webkit-scrollbar{display:none}.media-content .emoji-grid{max-height:none;padding:8px 0 0}.emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:2px;padding:8px}.emoji-grid button{font-size:24px;padding:6px;background:none;border:none;cursor:pointer;border-radius:8px;transition:transform .12s ease,background .12s ease}.emoji-grid button:hover{background:#ffffff0f;transform:scale(1.2)}.emoji-grid button:active{transform:scale(.9)}.emoji-categories{display:flex;gap:2px;padding:4px 8px;border-bottom:1px solid var(--border)}.emoji-categories button{font-size:18px;padding:6px 10px;background:none;border:none;cursor:pointer;border-radius:8px;opacity:.45;transition:all .15s ease;flex-shrink:0}.emoji-categories button.active{opacity:1;background:#22c55e1f}.emoji-categories button:hover:not(.active){opacity:.75;background:#ffffff0a}.gif-category-chips{display:flex;gap:6px;padding:4px 4px 8px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.gif-category-chips::-webkit-scrollbar{display:none}.gif-chip{padding:6px 14px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);border-radius:20px;color:var(--muted);font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .15s ease;flex-shrink:0}.gif-chip:hover{background:#ffffff1a;color:var(--text)}.gif-chip.active{background:#22c55e26;border-color:var(--accent);color:var(--accent)}.gif-search-bar{display:flex;gap:6px;padding:0 4px}.gif-search-bar input{flex:1;padding:8px 14px;background:#ffffff0a;backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.08);border-radius:12px;color:var(--text);font-size:13px;outline:none;transition:border-color .2s}.gif-search-bar input:focus{border-color:#22c55e66}.gif-search-bar input::placeholder{color:var(--dim)}#gif-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;max-height:280px;overflow-y:auto;padding:4px}#gif-grid::-webkit-scrollbar{width:3px}#gif-grid::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}#gif-grid button{background:none;border:1px solid rgba(255,255,255,.04);border-radius:12px;padding:0;cursor:pointer;overflow:hidden;aspect-ratio:4/3;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}#gif-grid button:hover{transform:scale(1.03);border-color:#22c55e4d;box-shadow:0 4px 12px #0000004d}#gif-grid button img{width:100%;height:100%;object-fit:cover}.gif-skeleton{background:#ffffff0a;border-radius:12px;aspect-ratio:4/3;position:relative;overflow:hidden}.gif-skeleton:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent);animation:shimmer 1.5s ease-in-out infinite}.animated-emoji-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;padding:8px}.animated-emoji-grid button{font-size:32px;padding:8px;background:none;border:1px solid rgba(255,255,255,.04);cursor:pointer;border-radius:12px;transition:all .2s ease;animation:emojiPulse 2s ease-in-out infinite;animation-play-state:paused}.animated-emoji-grid button:hover{background:#22c55e14;border-color:#22c55e33;transform:scale(1.15);animation-play-state:running}.animated-emoji-grid button:active{transform:scale(.9)}@keyframes emojiPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.ai-cursor{animation:blink 1s step-end infinite}.ai-header-glow{box-shadow:0 0 12px #22c55e4d;border:1.5px solid rgba(34,197,94,.4)}.ai-model-dropdown{position:absolute;top:100%;right:0;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:8px;min-width:280px;box-shadow:0 8px 32px #0006;z-index:1000;animation:fadeInUp .2s ease-out}.ai-model-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:8px;cursor:pointer;transition:background .15s}.ai-model-item:hover{background:#22c55e14}.ai-model-item.selected{background:#22c55e1f;border:1px solid rgba(34,197,94,.3)}.ai-agents-panel{position:fixed;top:0;right:0;bottom:0;width:min(400px,90vw);background:var(--bg);border-left:1px solid var(--border);z-index:10000;display:flex;flex-direction:column;animation:slideInRight .25s ease-out;box-shadow:-4px 0 24px #0000004d}.ai-agent-card{padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:12px;cursor:pointer;transition:all .2s}.ai-agent-card:hover{border-color:var(--accent);background:#22c55e0a}.ai-template-card{display:flex;align-items:center;gap:12px;padding:12px;background:#22c55e0a;border:1px solid rgba(34,197,94,.12);border-radius:10px;cursor:pointer;transition:all .2s}.ai-template-card:hover{border-color:var(--accent);background:#22c55e14}.ai-suggestion-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:16px 20px}.ai-suggestion-card{display:flex;align-items:center;gap:10px;padding:12px 14px;background:#22c55e0a;border:1px solid rgba(34,197,94,.12);border-radius:12px;color:var(--text);font-size:13px;cursor:pointer;transition:all .2s}.ai-suggestion-card:hover{border-color:var(--accent);background:#22c55e1a;box-shadow:0 0 8px #22c55e26}@media(max-width:480px){.ai-suggestion-grid{grid-template-columns:1fr}}.username-input-wrap{display:flex;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:border-color .2s}.username-input-wrap:focus-within{border-color:var(--accent)}.username-prefix{padding:10px 0 10px 12px;color:var(--text-muted);font-size:14px;font-weight:500;user-select:none}.username-input{flex:1;padding:10px 12px 10px 2px;background:none;border:none;color:var(--text-primary);font-size:14px;outline:none}.username-status{padding:4px 12px;font-size:12px;margin-top:4px}.username-status.available{color:var(--accent)}.username-status.taken{color:var(--danger)}.username-status.invalid{color:var(--warning)}.username-search-results{max-height:200px;overflow-y:auto;border:1px solid var(--border);border-radius:10px;margin-top:4px;background:var(--bg-elevated)}.username-search-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .15s}.username-search-item:hover{background:#22c55e14}.view-once-bubble{background:linear-gradient(135deg,#22c55e26,#22c55e0d);border:1px solid rgba(34,197,94,.2);border-radius:16px;padding:16px;cursor:pointer;transition:all .2s;text-align:center;min-width:180px}.view-once-bubble:hover{border-color:#22c55e66;background:linear-gradient(135deg,#22c55e33,#22c55e14)}.view-once-bubble:active{transform:scale(.97)}.view-once-lock{animation:viewOncePulse 2s ease-in-out infinite}@keyframes viewOncePulse{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.view-once-opened{color:var(--muted);font-style:italic;font-size:13px;padding:4px 0}.view-once-viewer{position:fixed;inset:0;z-index:99999;background:#000000f2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.view-once-countdown{font-size:48px;font-weight:700;color:var(--accent);font-family:var(--mono);text-shadow:0 0 20px rgba(34,197,94,.5)}.view-once-progress{position:absolute;bottom:0;left:0;height:3px;background:var(--accent);transition:width 1s linear;border-radius:0 2px 2px 0}.message img,.message video,.message-emoji-only img{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.message .animated-emoji{-webkit-touch-callout:none}.unread-separator{display:flex;align-items:center;gap:12px;padding:10px 20px;margin:6px 0}.unread-separator:before,.unread-separator:after{content:"";flex:1;height:1px;background:var(--accent)}.unread-separator span{font-size:12px;color:var(--accent);font-weight:600;white-space:nowrap}.device-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:linear-gradient(135deg,#22c55e0a,#22c55e03);border:1px solid rgba(255,255,255,.06);border-radius:14px;margin-bottom:8px;transition:all .2s;position:relative;overflow:hidden}.device-card:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:var(--accent);border-radius:0 3px 3px 0}.device-card:hover{border-color:#22c55e33;background:#22c55e0f}.device-card.current{border-color:#22c55e4d;background:#22c55e14}.device-card.current:before{background:linear-gradient(180deg,#22c55e,#16a34a);width:4px}.device-icon{width:44px;height:44px;border-radius:12px;background:#22c55e1a;display:flex;align-items:center;justify-content:center;flex-shrink:0}.device-info{flex:1;min-width:0}.device-name{font-size:14px;font-weight:600;color:var(--text-primary)}.device-meta{font-size:12px;color:var(--text-muted);margin-top:2px}.device-status{width:8px;height:8px;border-radius:50%;flex-shrink:0}.device-status.online{background:#22c55e;box-shadow:0 0 6px #22c55e80}.device-status.offline{background:#fff3}.device-unlink{background:none;border:1px solid rgba(239,68,68,.2);color:var(--danger);padding:6px 12px;border-radius:8px;font-size:12px;cursor:pointer;transition:all .2s}.device-unlink:hover{background:#ef44441a;border-color:#ef444466}.link-code-display{text-align:center;padding:24px;background:linear-gradient(135deg,#22c55e14,#22c55e05);border:1px solid rgba(34,197,94,.15);border-radius:16px;margin:16px 0}.link-code-digits{font-family:var(--font-mono);font-size:36px;font-weight:700;letter-spacing:12px;color:var(--accent);text-shadow:0 0 20px rgba(34,197,94,.3);margin:12px 0}.link-code-timer{font-size:13px;color:var(--text-muted)}.unread-badge-pwa{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;border-radius:9px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 2px 6px #ef444466;animation:badgePop .3s cubic-bezier(.175,.885,.32,1.275)}@keyframes badgePop{0%{transform:scale(0)}70%{transform:scale(1.2)}to{transform:scale(1)}}.remote-panel{position:fixed;top:0;right:0;bottom:0;width:min(420px,92vw);background:var(--bg);border-left:1px solid rgba(255,255,255,.06);z-index:10000;display:flex;flex-direction:column;animation:slideInRight .25s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 32px #0006}.remote-device-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--surface);border:1px solid rgba(255,255,255,.06);border-radius:14px;cursor:pointer;transition:all .2s;margin-bottom:8px}.remote-device-card:hover{border-color:var(--accent);transform:translate(2px)}.remote-device-card .platform-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px}.remote-device-card .platform-icon.macos{background:linear-gradient(135deg,#9ca3af26,#9ca3af0d)}.remote-device-card .platform-icon.windows{background:linear-gradient(135deg,#3b82f626,#3b82f60d)}.remote-device-card .platform-icon.linux{background:linear-gradient(135deg,#fbbf2426,#fbbf240d)}.remote-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:12px 0}.remote-metric{padding:10px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:10px;text-align:center}.remote-metric-value{font-size:18px;font-weight:700;color:var(--accent);font-family:var(--font-mono)}.remote-metric-label{font-size:10px;color:var(--text-muted);margin-top:2px;text-transform:uppercase;letter-spacing:.5px}.remote-terminal{background:#0a0a0a;border:1px solid rgba(34,197,94,.15);border-radius:12px;padding:12px;font-family:var(--font-mono);font-size:13px;color:#22c55e;max-height:200px;overflow-y:auto;white-space:pre-wrap;word-break:break-all}.remote-terminal .prompt{color:var(--accent);user-select:none}.remote-terminal .output{color:#fffc}.remote-terminal .error{color:#ef4444}.remote-cmd-input{display:flex;gap:8px;margin-top:8px}.remote-cmd-input input{flex:1;padding:10px 14px;background:#0000004d;border:1px solid rgba(34,197,94,.2);border-radius:10px;color:#22c55e;font-family:var(--font-mono);font-size:13px;outline:none}.remote-cmd-input input:focus{border-color:var(--accent);box-shadow:0 0 8px #22c55e26}.remote-cmd-input button{padding:10px 16px;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:10px;color:#fff;font-weight:600;font-size:13px;cursor:pointer}.code-output{background:#0d1117;border:1px solid rgba(34,197,94,.1);border-radius:10px;padding:12px;font-family:var(--font-mono);font-size:12px;color:#e6edf3;max-height:300px;overflow-y:auto;margin-top:8px;position:relative}.code-output:before{content:"Output";position:absolute;top:4px;right:8px;font-size:9px;color:#ffffff4d;font-family:var(--font);text-transform:uppercase;letter-spacing:1px}.code-output .success{color:#22c55e}.code-output .error{color:#ef4444}.code-output .warning{color:#eab308}.incoming-call-overlay{position:fixed;inset:0;z-index:99998;background:#000000eb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;flex-direction:column;align-items:center;justify-content:center;animation:fadeIn .3s ease-out}.call-avatar-ring{width:120px;height:120px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative}.call-avatar-ring:before,.call-avatar-ring:after{content:"";position:absolute;inset:-8px;border-radius:50%;border:2px solid rgba(34,197,94,.4);animation:callRing 2s ease-out infinite}.call-avatar-ring:after{animation-delay:.5s}@keyframes callRing{0%{transform:scale(1);opacity:1}to{transform:scale(1.5);opacity:0}}.call-btn{width:64px;height:64px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:24px;transition:transform .15s}.call-btn:active{transform:scale(.9)}.call-btn.accept{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 4px 16px #22c55e66}.call-btn.decline{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 16px #ef444466}.call-history-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .15s}.call-history-item:hover{background:#ffffff0a}.call-history-item .call-type-icon{font-size:16px}.call-history-item .call-status.missed{color:var(--danger)}.call-history-item .call-status.completed{color:var(--accent)}.call-overlay-premium{position:fixed;inset:0;z-index:99998;background:linear-gradient(180deg,#000000f7,#00140af7,#000000f7);display:flex;flex-direction:column;align-items:center;justify-content:center;animation:fadeIn .3s ease-out}.call-overlay-premium .call-e2e-badge{position:absolute;top:16px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:6px;padding:6px 14px;background:#22c55e1a;border:1px solid rgba(34,197,94,.2);border-radius:20px;font-size:11px;color:#22c55ecc;letter-spacing:.5px}.call-overlay-premium .call-quality{position:absolute;top:16px;right:16px;display:flex;align-items:flex-end;gap:2px;height:16px}.call-overlay-premium .call-quality-bar{width:3px;background:var(--accent);border-radius:1px;transition:height .3s,background .3s}.call-controls{position:absolute;bottom:40px;left:50%;transform:translate(-50%);display:flex;gap:16px;z-index:2}.call-control-btn{width:56px;height:56px;border-radius:50%;border:1px solid rgba(255,255,255,.15);background:#ffffff1a;color:#fff;font-size:20px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;transition:all .2s;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.call-control-btn:hover{background:#fff3}.call-control-btn.active{background:var(--danger);border-color:var(--danger)}.call-control-btn.hangup{width:64px;height:64px;background:linear-gradient(135deg,#ef4444,#dc2626);border-color:transparent;box-shadow:0 4px 16px #ef444466}.call-control-btn-label{font-size:9px;opacity:.7;margin-top:2px}@keyframes callingDot{0%,80%,to{opacity:.3}40%{opacity:1}}.calling-dots span{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);margin:0 3px;animation:callingDot 1.4s ease-in-out infinite}.calling-dots span:nth-child(2){animation-delay:.2s}.calling-dots span:nth-child(3){animation-delay:.4s}@keyframes outgoingCallPulse{0%{box-shadow:0 0 #22c55e66}50%{box-shadow:0 0 0 20px #22c55e00}to{box-shadow:0 0 #22c55e00}}.call-avatar-pulse{animation:outgoingCallPulse 2s ease-in-out infinite;border-radius:50%}.view-once-bubble{background:linear-gradient(135deg,#22c55e1f,#22c55e08);border:1px solid rgba(34,197,94,.2);border-radius:16px;padding:16px 18px;cursor:pointer;transition:all .25s;position:relative;overflow:hidden}.view-once-bubble:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(34,197,94,.05),transparent);pointer-events:none}.view-once-bubble:hover{border-color:#22c55e66;box-shadow:0 0 16px #22c55e1a;transform:scale(1.01)}.view-once-bubble:active{transform:scale(.98)}.view-once-lock{font-size:22px;animation:viewOncePulse 2s ease-in-out infinite}@keyframes viewOncePulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.15)}}.view-once-type-icon{font-size:24px;opacity:.8}.view-once-label{font-size:14px;font-weight:600;color:var(--text-primary)}.view-once-hint{font-size:12px;color:var(--text-muted);margin-top:2px}.view-once-opened{display:flex;align-items:center;gap:6px;color:var(--text-muted);font-style:italic;font-size:13px;padding:8px 0}.view-once-viewer{position:fixed;inset:0;z-index:99999;background:#000000f5;display:flex;flex-direction:column;align-items:center;justify-content:center;animation:fadeIn .2s;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.view-once-countdown{font-size:56px;font-weight:800;color:var(--accent);font-family:var(--font-mono);text-shadow:0 0 30px rgba(34,197,94,.4);position:absolute;top:24px}.view-once-progress{position:absolute;bottom:0;left:0;height:4px;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:0 2px 0 0;transition:width linear;box-shadow:0 0 8px #22c55e80}.view-once-audio-player{display:flex;flex-direction:column;align-items:center;gap:16px}.view-once-audio-wave{display:flex;align-items:center;gap:3px;height:40px}.view-once-audio-bar{width:4px;border-radius:2px;background:var(--accent);animation:voViewOnceBar .5s ease infinite alternate}@keyframes voViewOnceBar{0%{height:8px;opacity:.4}to{height:36px;opacity:1}}.waveform-container{display:flex;align-items:center;gap:10px;padding:8px 14px;background:#22c55e0a;border-radius:14px;min-width:200px}.waveform-play-btn{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .15s;box-shadow:0 2px 8px #22c55e4d}.waveform-play-btn:active{transform:scale(.9)}.waveform-bars{display:flex;align-items:center;gap:2px;height:28px;flex:1}.waveform-bar{width:3px;border-radius:1.5px;min-height:3px;transition:height .08s ease,background .15s}.waveform-bar.played{background:var(--accent)}.waveform-bar.unplayed{background:#22c55e40}.waveform-time{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);min-width:36px;text-align:right}.voice-record-indicator{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#ef444414;border:1px solid rgba(239,68,68,.15);border-radius:12px}.voice-record-dot{width:10px;height:10px;border-radius:50%;background:#ef4444;animation:recordPulse 1s ease infinite}@keyframes recordPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.voice-record-wave{display:flex;align-items:center;gap:2px;height:24px}.voice-record-bar{width:3px;border-radius:1.5px;background:#ef4444}.hosting-panel{position:fixed;top:0;right:0;bottom:0;width:min(440px,94vw);background:var(--bg);border-left:1px solid rgba(255,255,255,.06);z-index:10000;display:flex;flex-direction:column;animation:slideInRight .25s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 32px #00000080}.hosting-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.06)}.hosting-header h3{font-size:17px;font-weight:700;display:flex;align-items:center;gap:8px}.site-card{padding:14px 16px;background:linear-gradient(135deg,#22c55e0a,#22c55e03);border:1px solid rgba(255,255,255,.06);border-radius:14px;margin-bottom:10px;cursor:pointer;transition:all .2s;position:relative}.site-card:hover{border-color:#22c55e40;transform:translate(2px)}.site-card-name{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.site-card-url{font-size:12px;color:var(--accent);font-family:var(--font-mono)}.site-card-meta{display:flex;gap:12px;margin-top:8px;font-size:11px;color:var(--text-muted)}.site-card-status{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:2px 8px;border-radius:6px;font-weight:600}.site-card-status.active{background:#22c55e1a;color:var(--accent)}.site-card-status.paused{background:#fbbf241a;color:#fbbf24}.site-deploy-btn{width:100%;padding:14px;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:12px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:opacity .2s;box-shadow:0 4px 16px #22c55e4d}.site-deploy-btn:hover{opacity:.9}.site-editor{background:#0d1117;border:1px solid rgba(34,197,94,.1);border-radius:12px;overflow:hidden}.site-editor-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.06)}.site-editor-tab{padding:8px 16px;font-size:12px;font-weight:600;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;font-family:var(--font-mono)}.site-editor-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.site-editor textarea{width:100%;min-height:200px;background:transparent;border:none;color:#e6edf3;font-family:var(--font-mono);font-size:13px;padding:12px;resize:vertical;outline:none}.site-preview-frame{border:1px solid rgba(255,255,255,.06);border-radius:12px;overflow:hidden;background:#fff}.site-preview-frame iframe{width:100%;height:300px;border:none}.twofa-qr-container{display:flex;justify-content:center;padding:20px;background:#fff;border-radius:16px;margin:16px 0;box-shadow:0 4px 16px #0003}.twofa-secret-display{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:10px;font-family:var(--mono);font-size:14px;letter-spacing:2px;color:var(--accent);margin:12px 0}.twofa-code-input{display:flex;gap:8px;justify-content:center;margin:20px 0}.twofa-digit{width:48px;height:56px;text-align:center;font-size:24px;font-weight:700;font-family:var(--mono);background:var(--surface);border:2px solid var(--border);border-radius:12px;color:var(--text);outline:none;transition:border-color .2s,box-shadow .2s;caret-color:var(--accent)}.twofa-digit:focus{border-color:var(--accent);box-shadow:0 0 0 3px #22c55e26}.twofa-digit.error{border-color:var(--danger);animation:shakeInput .4s}@keyframes shakeInput{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.twofa-backup-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:12px;font-family:var(--mono);font-size:14px;color:var(--text)}.twofa-backup-code{padding:6px 10px;background:#22c55e0f;border-radius:6px;text-align:center;letter-spacing:1px}.twofa-success{text-align:center;padding:20px}.twofa-success-icon{width:64px;height:64px;border-radius:50%;background:#22c55e1a;border:2px solid rgba(34,197,94,.3);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:28px;color:var(--success);animation:successPop .4s cubic-bezier(.175,.885,.32,1.275)}@keyframes successPop{0%{transform:scale(0)}70%{transform:scale(1.2)}to{transform:scale(1)}}.photo-viewer{position:fixed;inset:0;z-index:99998;background:#000000f2;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s}.photo-viewer img{max-width:95%;max-height:90vh;object-fit:contain;border-radius:4px;touch-action:pinch-zoom;user-select:none;-webkit-user-select:none}.photo-viewer-controls{position:absolute;top:16px;left:0;right:0;display:flex;justify-content:space-between;padding:0 16px;z-index:2}.photo-viewer-btn{width:40px;height:40px;border-radius:50%;background:#ffffff1a;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:none;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.photo-viewer-btn:hover{background:#fff3}.photo-viewer-btn:active{transform:scale(.9)}.pdf-preview{display:flex;align-items:center;gap:12px;padding:12px 14px;background:#ef44440f;border:1px solid rgba(239,68,68,.12);border-radius:12px;cursor:pointer;transition:all .2s;min-width:200px}.pdf-preview:hover{border-color:#ef444440}.pdf-preview:active{transform:scale(.98)}.pdf-icon{width:42px;height:42px;border-radius:10px;background:#ef44441f;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pdf-info{flex:1;min-width:0}.pdf-name{font-size:14px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.pdf-size{font-size:11px;color:var(--text-muted);margin-top:2px}.pdf-viewer{position:fixed;inset:0;z-index:99998;background:var(--bg);display:flex;flex-direction:column;animation:fadeIn .2s}.pdf-viewer-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--surface)}.pdf-viewer iframe{flex:1;border:none;background:#fff}.audio-player-card{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#22c55e0a;border:1px solid rgba(34,197,94,.1);border-radius:14px;min-width:220px}.audio-play-btn{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px #22c55e4d;transition:transform .15s}.audio-play-btn:active{transform:scale(.9)}.audio-info{flex:1;min-width:0}.audio-name{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.audio-progress{height:4px;background:#22c55e26;border-radius:2px;margin:6px 0 4px;cursor:pointer;position:relative}.audio-progress-bar{height:100%;background:var(--accent);border-radius:2px;width:0%;transition:width .1s linear}.audio-time{font-size:11px;color:var(--text-muted);font-family:var(--mono)}.video-container{position:relative;border-radius:12px;overflow:hidden;max-width:280px}.video-container video{width:100%;display:block;border-radius:12px}.video-play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0000004d;cursor:pointer;transition:opacity .2s}.video-play-overlay.hidden{opacity:0;pointer-events:none}.video-play-circle{width:56px;height:56px;border-radius:50%;background:#ffffffe6;display:flex;align-items:center;justify-content:center;font-size:24px;color:#000;box-shadow:0 4px 16px #0000004d}.channel-icon{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#3b82f633,#3b82f60d);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.channel-post{padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.04)}.channel-post-content{font-size:15px;line-height:1.55;color:var(--text-primary);margin:8px 0;word-break:break-word}.channel-post-meta{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--text-muted)}.channel-post-views{display:flex;align-items:center;gap:4px}.channel-reactions{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}.channel-reaction{display:flex;align-items:center;gap:4px;padding:4px 10px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:20px;font-size:13px;cursor:pointer;transition:all .15s}.channel-reaction:hover{border-color:#3b82f64d;background:#3b82f614}.channel-reaction.active{border-color:#3b82f666;background:#3b82f61f;color:#3b82f6}.channel-create-modal .form-group{margin-bottom:16px}.channel-create-modal label{display:block;font-size:13px;color:var(--text-muted);margin-bottom:6px}.channel-discover-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:14px;margin-bottom:8px;cursor:pointer;transition:all .2s}.channel-discover-card:hover{border-color:#3b82f64d}.channel-discover-join{padding:6px 16px;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;flex-shrink:0}.channel-info-panel{position:fixed;top:0;right:0;bottom:0;width:min(400px,90vw);background:var(--bg);border-left:1px solid var(--border);z-index:10000;display:flex;flex-direction:column;animation:slideInRight .25s ease-out;box-shadow:-4px 0 24px #0000004d}.channel-compose{display:flex;align-items:center;gap:8px;padding:10px 16px;border-top:1px solid rgba(255,255,255,.06);background:#0000004d}.channel-compose textarea,.channel-compose-input{flex:1;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:12px;color:var(--text-primary);font-size:14px;resize:none;outline:none;max-height:100px;font-family:inherit}.channel-compose textarea:focus,.channel-compose-input:focus{border-color:var(--accent)}.channel-pinned-post{padding:10px 16px;background:#3b82f60f;border-left:3px solid #3b82f6;font-size:13px;cursor:pointer}.public-toggle{display:flex;align-items:center;justify-content:space-between;padding:12px 0}.toggle-switch{width:44px;height:24px;border-radius:12px;background:#ffffff26;position:relative;cursor:pointer;transition:background .2s}.toggle-switch.active{background:var(--accent)}.toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s}.toggle-switch.active:after{transform:translate(20px)}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.community-icon{width:52px;height:52px;border-radius:16px;background:linear-gradient(135deg,#a855f733,#a855f70d);display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0;border:2px solid rgba(168,85,247,.2)}.community-icon-sm{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#a855f726,#a855f70d);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.community-badge{font-size:9px;padding:1px 5px;border-radius:4px;background:#a855f726;color:#a855f7;font-weight:700}.community-view{display:flex;flex-direction:column;height:100%}.community-header{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border)}.community-announcements{margin:12px 16px;padding:14px 16px;background:linear-gradient(135deg,#3b82f614,#3b82f605);border:1px solid rgba(59,130,246,.15);border-radius:14px;cursor:pointer;transition:all .2s}.community-announcements:hover{border-color:#3b82f64d}.community-section-title{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1px;padding:12px 16px 6px}.community-group-card{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .15s;position:relative}.community-group-card:hover{background:#ffffff08}.community-group-icon{width:44px;height:44px;border-radius:12px;background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:20px}.community-group-info{flex:1;min-width:0}.community-group-name{font-size:14px;font-weight:600}.community-group-preview{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.community-group-meta{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:6px}.community-joined-badge{font-size:10px;padding:2px 8px;border-radius:6px;background:#22c55e1a;color:var(--accent);font-weight:600}.community-join-btn{padding:6px 14px;background:linear-gradient(135deg,#a855f7,#9333ea);border:none;border-radius:8px;color:#fff;font-size:12px;font-weight:600;cursor:pointer}.community-create-modal .emoji-grid-mini{display:grid;grid-template-columns:repeat(8,1fr);gap:4px;max-height:120px;overflow-y:auto;margin:8px 0}.community-create-modal .emoji-grid-mini button{font-size:24px;padding:6px;background:none;border:1px solid transparent;border-radius:8px;cursor:pointer;transition:all .15s}.community-create-modal .emoji-grid-mini button:hover{background:#a855f71a;border-color:#a855f74d}.community-create-modal .emoji-grid-mini button.selected{background:#a855f726;border-color:#a855f7}.community-discover-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:14px;margin:8px 16px;transition:all .2s;cursor:pointer}.community-discover-card:hover{border-color:#a855f74d}.community-info-panel{position:fixed;top:0;right:0;bottom:0;width:min(400px,90vw);background:var(--bg);border-left:1px solid var(--border);z-index:10000;display:flex;flex-direction:column;animation:slideInRight .25s ease-out;box-shadow:-4px 0 24px #0000004d;overflow-y:auto}.community-invite-link{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#a855f70f;border:1px solid rgba(168,85,247,.15);border-radius:10px;font-family:var(--font-mono);font-size:13px;color:#a855f7}.community-stat{display:flex;gap:20px;justify-content:center;margin:12px 0}.community-stat-item{text-align:center}.community-stat-value{font-size:20px;font-weight:700;color:#a855f7}.community-stat-label{font-size:11px;color:var(--muted)}.community-add-group-btn{display:flex;align-items:center;gap:8px;padding:12px 16px;color:#a855f7;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s}.community-add-group-btn:hover{background:#a855f70f}.sidebar-header h2{text-shadow:0 0 20px rgba(34,197,94,.4),0 0 40px rgba(34,197,94,.15);filter:drop-shadow(0 0 8px rgba(34,197,94,.2))}.sidebar-header .icon-btn,.sidebar-header button{width:38px;height:38px;border-radius:50%;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);color:#fff9;transition:all .2s cubic-bezier(.4,0,.2,1);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.sidebar-header .icon-btn:hover,.sidebar-header button:hover{background:#22c55e1a;border-color:#22c55e33;color:var(--accent);transform:scale(1.05)}.sidebar-header .icon-btn:active,.sidebar-header button:active{transform:scale(.92)}.sidebar-search{padding:8px 14px 10px}.sidebar-search input{padding:11px 18px;background:#ffffff0a;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.06);border-radius:22px;font-size:15px;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0000001a}.sidebar-search input:focus{border-color:#22c55e66;background:#ffffff12;box-shadow:0 0 0 3px #22c55e1a,0 2px 8px #00000026;transform:scaleX(1.01)}.sidebar-search input::placeholder{color:#ffffff40;font-weight:400}.stories-bar,.status-bar{display:flex;gap:14px;padding:12px 16px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;border-bottom:1px solid rgba(255,255,255,.04);background:linear-gradient(180deg,rgba(255,255,255,.01),transparent)}.stories-bar::-webkit-scrollbar,.status-bar::-webkit-scrollbar{display:none}.story-circle,.status-circle{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s}.story-circle:active,.status-circle:active{transform:scale(.92)}.story-avatar,.status-avatar{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;color:#fff;position:relative;background:linear-gradient(135deg,#1a1a2e,#16213e);box-shadow:0 2px 10px #00000040}.story-circle:not(.seen) .story-avatar,.status-circle:not(.seen) .status-avatar,.story-avatar.unseen,.status-avatar.unseen{border:2.5px solid transparent;background-clip:padding-box;outline:2.5px solid transparent;outline-offset:1px;box-shadow:0 0 0 2.5px #22c55e,0 0 0 3.5px #22c55e4d,0 2px 10px #00000040}.story-circle.seen .story-avatar,.status-circle.seen .status-avatar,.story-avatar.seen,.status-avatar.seen{box-shadow:0 0 0 2px #ffffff26,0 2px 8px #0003}.story-circle.my-story .story-avatar:after,.status-circle.my-status .status-avatar:after,.story-add-badge,.status-add-badge{content:"+";position:absolute;bottom:-2px;right:-2px;width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg2);box-shadow:0 2px 6px #22c55e66}.story-name,.status-name{font-size:11px;color:#ffffff80;font-weight:500;max-width:60px;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conversation-item{border-bottom:.5px solid rgba(255,255,255,.03)}.conversation-item:last-child{border-bottom:none}.conversation-preview .typing-text,.conversation-preview[data-typing=true],.conv-typing{color:var(--accent);animation:typingPreviewPulse 1.5s ease-in-out infinite}@keyframes typingPreviewPulse{0%,to{opacity:.6}50%{opacity:1}}.conversation-item.muted,.conversation-item[data-muted=true]{opacity:.55}.conversation-item.muted .conversation-name,.conversation-item[data-muted=true] .conversation-name{color:#ffffff80}.conversation-item.muted .unread-badge,.conversation-item[data-muted=true] .unread-badge{background:#ffffff26;color:#ffffff80;box-shadow:none}.bottom-tabs{display:flex;align-items:center;justify-content:space-around;padding:6px 0 env(safe-area-inset-bottom,8px);background:#080808eb;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid rgba(255,255,255,.04);position:sticky;bottom:0;z-index:100;gap:0}.tab-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 16px;cursor:pointer;color:#fff6;font-size:10px;font-weight:500;transition:color .2s;position:relative;-webkit-tap-highlight-color:transparent;background:none;border:none}.tab-btn.active{color:#22c55e}.tab-btn.active:after{content:"";position:absolute;top:-6px;left:50%;transform:translate(-50%);width:24px;height:3px;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:0 0 3px 3px}.tab-btn svg{transition:transform .15s,stroke .2s}.tab-btn:active svg{transform:scale(.85)}.tab-btn.active svg{stroke:#22c55e;filter:drop-shadow(0 0 4px rgba(34,197,94,.3))}.tab-badge{position:absolute;top:0;right:50%;transform:translate(14px);min-width:18px;height:18px;border-radius:9px;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 2px 6px #22c55e4d}.settings-panel{padding:0 0 env(safe-area-inset-bottom,16px);overflow-y:auto;-webkit-overflow-scrolling:touch}.settings-group{margin:8px 12px;background:#ffffff05;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.04)}.settings-group h4{font-size:13px;font-weight:600;color:#ffffff80;padding:14px 16px 8px;text-transform:uppercase;letter-spacing:1px}.settings-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;font-size:15px;color:#e0e0e0;cursor:pointer;transition:background .12s;border-bottom:.5px solid rgba(255,255,255,.03)}.settings-item:hover{background:#ffffff0a}.settings-item:active{background:#ffffff0f}.settings-profile{text-align:center;padding:28px 16px 20px;background:linear-gradient(180deg,rgba(34,197,94,.06),transparent);border-bottom:1px solid rgba(255,255,255,.04)}.settings-profile-avatar,.settings-panel .profile-avatar{width:80px;height:80px;border-radius:50%;margin:0 auto 12px;border:3px solid rgba(34,197,94,.3);box-shadow:0 4px 20px #0000004d,0 0 20px #22c55e1a}.settings-profile-name,.settings-panel .profile-name{font-size:20px;font-weight:700;color:#fff}.settings-profile-bio{font-size:13px;color:var(--muted);margin-top:4px}.settings-group.collapsible>.settings-header{cursor:pointer;transition:background .12s;padding:12px 16px;display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#ffffffb3}.settings-group.collapsible>.settings-header:hover{background:#ffffff08}.settings-group.collapsible>.settings-header:after{content:"";margin-left:auto;width:8px;height:8px;border-right:2px solid rgba(255,255,255,.3);border-bottom:2px solid rgba(255,255,255,.3);transform:rotate(45deg);transition:transform .2s;flex-shrink:0}.settings-group.collapsible.collapsed>.settings-header:after{transform:rotate(-45deg)}.theme-pick{padding:12px;border-radius:12px;cursor:pointer;font-size:13px;font-weight:500;display:flex;align-items:center;gap:8px;transition:all .15s;border:1px solid transparent}.theme-pick:hover{transform:scale(1.02);background:#ffffff0a}.theme-pick.active{box-shadow:0 0 0 2px var(--accent);border-color:var(--accent)}.settings-danger,.settings-group.danger{background:#ef44440a;border-color:#ef44441a}.settings-danger .settings-item,.settings-group.danger .settings-item{color:#f87171}.settings-danger .settings-item:hover,.settings-group.danger .settings-item:hover{background:#ef44440f}.settings-toggle,.toggle-switch{position:relative;width:46px;height:26px;background:#ffffff1a;border-radius:13px;cursor:pointer;transition:background .25s;flex-shrink:0}.settings-toggle.active,.toggle-switch.active,.settings-toggle[data-active=true],.toggle-switch[data-active=true]{background:linear-gradient(135deg,#22c55e,#16a34a)}.settings-toggle:after,.toggle-switch:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .25s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 4px #0000004d}.settings-toggle.active:after,.toggle-switch.active:after,.settings-toggle[data-active=true]:after,.toggle-switch[data-active=true]:after{transform:translate(20px)}.contacts-list,.contacts-container{padding:8px 0}.contact-item{display:flex;align-items:center;gap:14px;padding:12px 16px;cursor:pointer;transition:background .12s;-webkit-tap-highlight-color:transparent}.contact-item:hover{background:#ffffff0a}.contact-item:active{background:#ffffff0f}.contact-avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0;box-shadow:0 2px 8px #0003;background:linear-gradient(135deg,#1a3a2a,#0f2920);color:#fff}.contact-name{font-size:16px;font-weight:500;color:#fff}.contact-username{font-size:13px;color:#fff6;margin-top:1px}.contact-actions{margin-left:auto;display:flex;gap:6px}.add-contact-fab{position:fixed;bottom:80px;right:20px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;color:#fff;font-size:24px;cursor:pointer;box-shadow:0 4px 20px #22c55e66,0 0 30px #22c55e26;display:flex;align-items:center;justify-content:center;transition:transform .15s,box-shadow .2s;z-index:50;-webkit-tap-highlight-color:transparent}.add-contact-fab:hover{box-shadow:0 6px 24px #22c55e80,0 0 40px #22c55e33;transform:scale(1.05)}.add-contact-fab:active{transform:scale(.9)}.contact-letter{padding:6px 16px;font-size:13px;font-weight:700;color:var(--accent);position:sticky;top:0;background:var(--bg);z-index:5;text-transform:uppercase;letter-spacing:.5px}.calls-list,.calls-container{padding:8px 0}.call-item,.call-history-item{display:flex;align-items:center;gap:14px;padding:12px 16px;cursor:pointer;transition:background .12s;-webkit-tap-highlight-color:transparent}.call-item:hover,.call-history-item:hover{background:#ffffff0a}.call-item:active,.call-history-item:active{background:#ffffff0f}.call-avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0;background:linear-gradient(135deg,#1a2a3a,#0f1f2f);color:#fff;box-shadow:0 2px 8px #0003}.call-info{flex:1;min-width:0}.call-name{font-size:16px;font-weight:500;color:#fff}.call-details{display:flex;align-items:center;gap:6px;font-size:13px;margin-top:2px;color:#fff6}.call-details.missed,.call-history-item .call-status.missed{color:#f87171}.call-details.completed,.call-history-item .call-status.completed{color:#fff6}.call-direction{font-size:14px}.call-time{font-size:12px;color:#ffffff59}.call-action-btn{width:40px;height:40px;border-radius:50%;border:none;background:#22c55e14;color:var(--accent);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;-webkit-tap-highlight-color:transparent}.call-action-btn:hover{background:#22c55e2e;box-shadow:0 0 12px #22c55e26}.call-action-btn:active{transform:scale(.9)}.calls-empty,.contacts-empty,.empty-tab-state{text-align:center;padding:60px 32px;color:#ffffff4d}.calls-empty-icon,.contacts-empty-icon,.empty-tab-icon{font-size:52px;margin-bottom:16px;opacity:.4;filter:grayscale(.3)}.calls-empty-text,.contacts-empty-text,.empty-tab-text{font-size:16px;font-weight:600;color:#fff6}.calls-empty-sub,.contacts-empty-sub,.empty-tab-sub{font-size:13px;margin-top:6px;color:#fff3;line-height:1.5}.form-input{width:100%;padding:13px 16px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:12px;color:#fff;font-size:15px;outline:none;transition:border-color .2s,box-shadow .2s,background .2s;font-family:var(--font)}.form-input:focus{border-color:#22c55e66;box-shadow:0 0 0 3px #22c55e1a,0 2px 8px #0000001a;background:#ffffff0f}.form-input::placeholder{color:#ffffff40}select.form-input{cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='rgba(255,255,255,0.4)' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}.tab-page{animation:tabPageIn .2s ease-out}.tab-page.active{display:block}@keyframes tabPageIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.conversation-item.active{background:linear-gradient(90deg,#22c55e14,#22c55e05);border-left:3px solid var(--accent);box-shadow:inset 4px 0 12px #22c55e0f}.conv-online-dot,.presence-online{box-shadow:0 0 #22c55e66;animation:onlinePulse 2s ease-in-out infinite}@keyframes onlinePulse{0%,to{box-shadow:0 0 #22c55e66}50%{box-shadow:0 0 0 4px #22c55e00}}.unread-badge{animation:badgeGlow 2s ease-in-out infinite}@keyframes badgeGlow{0%,to{box-shadow:0 2px 6px #22c55e4d}50%{box-shadow:0 2px 12px #22c55e80,0 0 20px #22c55e26}}.sidebar-content{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.06) transparent}.sidebar-content::-webkit-scrollbar{width:3px}.sidebar-content::-webkit-scrollbar-thumb{background:#ffffff0f;border-radius:3px}.auth-card{background:#111111f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.06);box-shadow:0 20px 60px #00000080,0 0 40px #22c55e0d}.auth-logo h1{text-shadow:0 0 30px rgba(34,197,94,.3)}.modal{border:1px solid rgba(255,255,255,.06);box-shadow:0 20px 60px #0009,0 0 1px #ffffff1a}.toast{background:#14181ef2;border:1px solid rgba(255,255,255,.06);box-shadow:0 8px 32px #0006,0 0 1px #ffffff14}.screen-lock-overlay{background:#050505fa;backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px)}.pin-input input{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:12px;transition:all .2s}.pin-input input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #22c55e1f;background:#ffffff0f}.date-separator span{background:#ffffff0d;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.04);color:#ffffff59;font-size:12px;font-weight:500;padding:5px 16px;border-radius:20px;box-shadow:0 1px 4px #00000026}.scroll-bottom-btn{background:#14181ee6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.06);box-shadow:0 4px 20px #0006;transition:all .2s cubic-bezier(.4,0,.2,1)}.scroll-bottom-btn:hover{background:#22c55e1f;border-color:#22c55e40;color:var(--accent);box-shadow:0 4px 20px #0006,0 0 12px #22c55e1a}
