:root,:root[data-theme=dark]{--bg-base: #08080d;--bg-raised: #0e0e15;--bg-surface: #14141d;--bg-overlay: #1c1c27;--bg-elevated: #232330;--bg-hover: rgba(255,255,255,.045);--bg-press: rgba(255,255,255,.025);--border: rgba(255,255,255,.06);--border-strong: rgba(255,255,255,.12);--border-accent: rgba(139,92,246,.28);--accent: #8b5cf6;--accent-2: #6366f1;--accent-3: #a78bfa;--accent-dim: rgba(139,92,246,.13);--accent-soft: rgba(139,92,246,.08);--accent-glow: rgba(139,92,246,.42);--accent-grad: linear-gradient(135deg, #a78bfa 0%, #7c3aed 45%, #4f46e5 100%);--accent-grad-soft: linear-gradient(135deg, rgba(167,139,250,.15) 0%, rgba(79,70,229,.15) 100%);--accent-shine: linear-gradient(135deg, #c4b5fd 0%, #8b5cf6 50%, #6366f1 100%);--text-1: #f4f4f8;--text-2: #b4b4c4;--text-3: #6c6c7e;--text-4: #3e3e4c;--green: #22c55e;--green-glow: rgba(34,197,94,.4);--red: #ef4444;--red-glow: rgba(239,68,68,.4);--amber: #f59e0b;--blue: #60a5fa;--r-xs: 4px;--r-sm: 8px;--r-md: 12px;--r-lg: 18px;--r-xl: 26px;--r-2xl: 32px;--r-full: 9999px;--ease-spring: cubic-bezier(.22,1,.36,1);--ease-smooth: cubic-bezier(.4,0,.2,1);--ease-overshoot: cubic-bezier(.34,1.56,.64,1);--shadow-sm: 0 1px 2px rgba(0,0,0,.4), 0 1px 4px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.45), 0 2px 6px rgba(0,0,0,.3);--shadow-lg: 0 12px 32px rgba(0,0,0,.55), 0 4px 12px rgba(0,0,0,.35);--shadow-xl: 0 32px 64px rgba(0,0,0,.65), 0 12px 24px rgba(0,0,0,.4);--shadow-glow: 0 0 0 1px rgba(139,92,246,.25), 0 8px 32px rgba(139,92,246,.25);font-size:15px;-webkit-text-size-adjust:100%}:root[data-theme=light]{--bg-base: #f7f7fb;--bg-raised: #ffffff;--bg-surface: #f1f1f6;--bg-overlay: #e8e8f0;--bg-elevated: #ffffff;--bg-hover: rgba(0,0,0,.045);--bg-press: rgba(0,0,0,.025);--border: rgba(15,15,30,.09);--border-strong: rgba(15,15,30,.18);--border-accent: rgba(139,92,246,.32);--text-1: #15151c;--text-2: #4b4b5c;--text-3: #7a7a8c;--text-4: #b6b6c4;--shadow-sm: 0 1px 2px rgba(15,15,30,.06), 0 1px 4px rgba(15,15,30,.04);--shadow-md: 0 4px 12px rgba(15,15,30,.08), 0 2px 6px rgba(15,15,30,.04);--shadow-lg: 0 12px 32px rgba(15,15,30,.1), 0 4px 12px rgba(15,15,30,.05);--shadow-xl: 0 32px 64px rgba(15,15,30,.14), 0 12px 24px rgba(15,15,30,.07)}:root[data-accent=violet]{--accent: #8b5cf6;--accent-2: #6366f1;--accent-3: #a78bfa;--accent-dim: rgba(139,92,246,.13);--accent-soft: rgba(139,92,246,.08);--accent-glow: rgba(139,92,246,.42);--accent-grad: linear-gradient(135deg, #a78bfa 0%, #7c3aed 45%, #4f46e5 100%);--accent-grad-soft: linear-gradient(135deg, rgba(167,139,250,.15) 0%, rgba(79,70,229,.15) 100%);--accent-shine: linear-gradient(135deg, #c4b5fd 0%, #8b5cf6 50%, #6366f1 100%)}:root[data-accent=blue]{--accent: #3b82f6;--accent-2: #2563eb;--accent-3: #60a5fa;--accent-dim: rgba(59,130,246,.13);--accent-soft: rgba(59,130,246,.08);--accent-glow: rgba(59,130,246,.42);--accent-grad: linear-gradient(135deg, #60a5fa 0%, #2563eb 45%, #1d4ed8 100%);--accent-grad-soft: linear-gradient(135deg, rgba(96,165,250,.15) 0%, rgba(29,78,216,.15) 100%);--accent-shine: linear-gradient(135deg, #93c5fd 0%, #3b82f6 50%, #2563eb 100%)}:root[data-accent=emerald]{--accent: #10b981;--accent-2: #059669;--accent-3: #34d399;--accent-dim: rgba(16,185,129,.13);--accent-soft: rgba(16,185,129,.08);--accent-glow: rgba(16,185,129,.42);--accent-grad: linear-gradient(135deg, #34d399 0%, #059669 45%, #047857 100%);--accent-grad-soft: linear-gradient(135deg, rgba(52,211,153,.15) 0%, rgba(4,120,87,.15) 100%);--accent-shine: linear-gradient(135deg, #6ee7b7 0%, #10b981 50%, #059669 100%)}:root[data-accent=rose]{--accent: #f43f5e;--accent-2: #e11d48;--accent-3: #fb7185;--accent-dim: rgba(244,63,94,.13);--accent-soft: rgba(244,63,94,.08);--accent-glow: rgba(244,63,94,.42);--accent-grad: linear-gradient(135deg, #fb7185 0%, #e11d48 45%, #be123c 100%);--accent-grad-soft: linear-gradient(135deg, rgba(251,113,133,.15) 0%, rgba(190,18,60,.15) 100%);--accent-shine: linear-gradient(135deg, #fda4af 0%, #f43f5e 50%, #e11d48 100%)}:root[data-accent=amber]{--accent: #f59e0b;--accent-2: #d97706;--accent-3: #fbbf24;--accent-dim: rgba(245,158,11,.13);--accent-soft: rgba(245,158,11,.08);--accent-glow: rgba(245,158,11,.42);--accent-grad: linear-gradient(135deg, #fbbf24 0%, #d97706 45%, #b45309 100%);--accent-grad-soft: linear-gradient(135deg, rgba(251,191,36,.15) 0%, rgba(180,83,9,.15) 100%);--accent-shine: linear-gradient(135deg, #fcd34d 0%, #f59e0b 50%, #d97706 100%)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-feature-settings:"cv11","ss01","ss03","calt";background:var(--bg-base);color:var(--text-1);height:100dvh;overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;background:radial-gradient(ellipse 70% 50% at 20% 0%,rgba(124,58,237,.1),transparent 60%),radial-gradient(ellipse 50% 60% at 80% 100%,rgba(79,70,229,.08),transparent 55%),radial-gradient(ellipse 40% 40% at 100% 30%,rgba(167,139,250,.05),transparent 60%)}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:9998;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23g)' opacity='1'/%3E%3C/svg%3E");opacity:.025;mix-blend-mode:screen}#root{height:100dvh;display:flex;position:relative;z-index:0}::selection{background:var(--accent-dim);color:var(--text-1)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--r-sm)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--r-full);border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:#fff3;background-clip:padding-box;border:2px solid transparent}.splash{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px}.splash p{color:var(--text-3);font-size:13px;letter-spacing:.08em;text-transform:uppercase;font-weight:500}.onboarding{flex:1;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:24px}.onboarding:before{content:"";position:absolute;width:900px;height:900px;top:-350px;left:-250px;background:radial-gradient(circle,rgba(124,58,237,.18) 0%,transparent 65%);pointer-events:none;animation:drift1 20s ease-in-out infinite alternate;filter:blur(20px)}.onboarding:after{content:"";position:absolute;width:700px;height:700px;bottom:-250px;right:-150px;background:radial-gradient(circle,rgba(79,70,229,.15) 0%,transparent 65%);pointer-events:none;animation:drift2 24s ease-in-out infinite alternate;filter:blur(20px)}@keyframes drift1{0%{transform:translate(0) scale(1) rotate(0)}to{transform:translate(80px,50px) scale(1.12) rotate(8deg)}}@keyframes drift2{0%{transform:translate(0) scale(1) rotate(0)}to{transform:translate(-60px,-40px) scale(1.1) rotate(-6deg)}}.onboarding-card{position:relative;z-index:1;background:linear-gradient(180deg,#14141dd9,#0e0e15d9);backdrop-filter:blur(40px) saturate(140%);-webkit-backdrop-filter:blur(40px) saturate(140%);border:1px solid var(--border-strong);border-radius:var(--r-2xl);padding:56px 52px 48px;max-width:460px;width:100%;display:flex;flex-direction:column;align-items:center;gap:22px;box-shadow:0 0 0 1px #ffffff0a,var(--shadow-xl),inset 0 1px #ffffff14;animation:cardRise .6s var(--ease-spring)}@keyframes cardRise{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.onboarding-logo{width:68px;height:68px;background:var(--accent-grad);border-radius:22px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 12px 40px var(--accent-glow),0 0 0 1px #ffffff1f,inset 0 1px #ffffff40;margin-bottom:6px;position:relative;animation:logoPulse 4s ease-in-out infinite}.onboarding-logo:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:26px;background:var(--accent-grad);opacity:.35;z-index:-1;filter:blur(16px);animation:logoPulse 4s ease-in-out infinite}@keyframes logoPulse{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}.onboarding-card h1{font-size:30px;font-weight:800;letter-spacing:-.8px;background:linear-gradient(160deg,#fff 20%,#9898aa);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1.1}.subtitle{color:var(--text-2);text-align:center;line-height:1.65;font-size:14.5px;max-width:340px}.features{width:100%;display:flex;flex-direction:column;gap:13px;padding:22px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.feature{display:flex;align-items:center;gap:13px;color:var(--text-2);font-size:14px;font-weight:500;transition:color .2s}.feature:hover{color:var(--text-1)}.feature-check{width:22px;height:22px;flex-shrink:0;background:linear-gradient(135deg,#22c55e2e,#22c55e0f);border:1px solid rgba(34,197,94,.32);border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;color:var(--green);box-shadow:inset 0 1px #ffffff0d}.info-box{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);padding:16px 18px;font-size:13px;color:var(--text-2);line-height:1.65;display:flex;flex-direction:column;gap:8px;width:100%}.info-box strong{color:var(--text-1);font-weight:600}.import-identity-form{width:100%;display:flex;flex-direction:column;gap:12px;padding-top:8px}.import-desc{font-size:13px;color:var(--text-2);line-height:1.55}.import-textarea{min-height:100px;resize:vertical;font-family:JetBrains Mono,monospace;font-size:12px}.app-shell{flex:1;display:flex;overflow:hidden}.sidebar{width:72px;flex-shrink:0;background:linear-gradient(180deg,var(--bg-raised) 0%,#0a0a10 100%);border-right:1px solid var(--border);display:flex;flex-direction:column;align-items:center;padding:18px 0 20px;gap:6px;position:relative}.sidebar:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(139,92,246,.5),transparent)}.sidebar:after{content:"";position:absolute;top:0;right:-1px;bottom:0;width:1px;background:linear-gradient(180deg,transparent,rgba(139,92,246,.15),transparent)}.sidebar-logo{width:42px;height:42px;background:var(--accent-grad);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:22px;flex-shrink:0;box-shadow:0 6px 24px var(--accent-glow),0 0 0 1px #ffffff14,inset 0 1px #fff3;position:relative}.sidebar-logo:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:calc(var(--r-md) + 2px);background:var(--accent-grad);opacity:.3;z-index:-1;filter:blur(8px)}.nav-item{position:relative;width:56px;height:58px;border:none;background:transparent;border-radius:var(--r-md);cursor:pointer;color:var(--text-3);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;transition:color .2s var(--ease-smooth),background .2s var(--ease-smooth)}.nav-item:hover{color:var(--text-1);background:var(--bg-hover)}.nav-item.active{color:var(--accent-3);background:var(--accent-soft)}.nav-item.active:before{content:"";position:absolute;left:-1px;top:14px;bottom:14px;width:3px;border-radius:0 3px 3px 0;background:var(--accent-grad);box-shadow:0 0 12px var(--accent-glow)}.nav-label{font-size:10px;font-weight:600;letter-spacing:.04em}.nav-spacer{flex:1}.nav-item-inner{position:relative;display:flex;align-items:center;justify-content:center}.nav-badge{position:absolute;top:-8px;right:-10px;min-width:18px;height:18px;padding:0 5px;background:var(--red);color:#fff;font-size:10px;font-weight:700;line-height:18px;border-radius:var(--r-full);text-align:center;box-shadow:0 0 0 2px var(--bg-raised),0 4px 12px var(--red-glow);animation:badgePop .25s var(--ease-overshoot)}@keyframes badgePop{0%{transform:scale(0)}to{transform:scale(1)}}.main-content{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-base)}.chat-empty{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 32px;position:relative;overflow:auto}.chat-empty:before{content:"";position:absolute;width:600px;height:600px;top:-200px;left:50%;transform:translate(-50%);background:radial-gradient(circle,rgba(124,58,237,.08) 0%,transparent 60%);pointer-events:none;filter:blur(40px)}.chat-empty-inner{position:relative;max-width:480px;width:100%;display:flex;flex-direction:column;align-items:center;gap:24px;text-align:center}.chat-empty-icon{width:72px;height:72px;background:linear-gradient(135deg,var(--accent-dim),var(--accent-soft));border:1px solid var(--border-accent);border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;color:var(--accent);box-shadow:0 8px 32px #8b5cf62e,inset 0 1px #ffffff14}.chat-empty-inner h2{font-size:24px;font-weight:700;letter-spacing:-.4px;background:linear-gradient(160deg,#fff 30%,#9898aa);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.chat-empty-inner>p{color:var(--text-2);font-size:14px;line-height:1.65;max-width:340px}.input-row{display:flex;gap:10px;width:100%}.contact-list{width:100%;display:flex;flex-direction:column;gap:2px;text-align:left;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--r-lg);padding:8px;box-shadow:var(--shadow-sm)}.contact-list-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);padding:8px 10px 10px}.contact-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;border:none;cursor:pointer;background:transparent;border-radius:var(--r-md);transition:background .15s var(--ease-smooth);text-align:left}.contact-item:hover{background:var(--bg-hover)}.contact-avatar{flex-shrink:0;width:42px;height:42px;border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;color:#fff;letter-spacing:-.5px;box-shadow:var(--shadow-sm),inset 0 1px #ffffff2e;position:relative}.contact-info{flex:1;min-width:0}.contact-name{font-size:13.5px;font-weight:600;color:var(--text-1);display:flex;align-items:center;gap:8px}.contact-id-sub{font-size:11px;font-weight:400;color:var(--text-3);font-family:JetBrains Mono,monospace;letter-spacing:.02em}.contact-preview{font-size:12.5px;color:var(--text-3);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.contact-preview--unread{color:var(--text-2);font-weight:500}.contact-unread-badge{flex-shrink:0;min-width:22px;height:22px;padding:0 7px;background:var(--accent-grad);color:#fff;font-size:11px;font-weight:700;line-height:22px;border-radius:var(--r-full);text-align:center;box-shadow:0 4px 12px var(--accent-glow);animation:badgePop .25s var(--ease-overshoot)}.your-id-box{background:linear-gradient(180deg,var(--bg-raised),var(--bg-base));border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 20px;width:100%;display:flex;flex-direction:column;gap:10px;transition:border-color .25s,box-shadow .25s;position:relative;overflow:hidden}.your-id-box:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--border-accent),transparent)}.your-id-box:hover{border-color:var(--border-accent);box-shadow:0 0 0 1px var(--accent-soft),0 8px 24px #8b5cf614}.your-id-box .label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3)}.user-id-row{display:flex;align-items:center;gap:10px}.user-id-row .user-id{font-family:JetBrains Mono,Fira Code,SF Mono,monospace;font-size:12px;color:var(--accent-3);word-break:break-all;flex:1;font-weight:500}.chat-view{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-header{display:flex;align-items:center;gap:10px;padding:12px 18px;border-bottom:1px solid var(--border);background:#0e0e15b3;backdrop-filter:blur(24px) saturate(140%);-webkit-backdrop-filter:blur(24px) saturate(140%);flex-shrink:0;min-height:64px;position:relative;z-index:10}.btn-back{background:none;border:none;color:var(--text-2);cursor:pointer;padding:8px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s;flex-shrink:0}.btn-back:hover{color:var(--text-1);background:var(--bg-hover)}.chat-recipient{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.recipient-avatar{width:38px;height:38px;border-radius:var(--r-full);flex-shrink:0;background:var(--accent-grad);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;letter-spacing:-.5px;box-shadow:0 4px 16px var(--accent-glow),inset 0 1px #ffffff2e}.recipient-info{display:flex;flex-direction:column;gap:3px;min-width:0}.recipient-name{font-size:14.5px;font-weight:600;color:var(--text-1);line-height:1}.recipient-id-sub{font-family:JetBrains Mono,Fira Code,monospace;font-size:11px;color:var(--text-3);line-height:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-header-actions{display:flex;gap:4px}.btn-icon{background:none;border:none;cursor:pointer;color:var(--text-2);padding:8px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s}.btn-icon:hover:not(:disabled){color:var(--text-1);background:var(--bg-hover)}.btn-icon:disabled{opacity:.4;cursor:not-allowed}.btn-icon--danger{color:var(--red)!important}.btn-icon--active{color:var(--accent)!important;background:var(--accent-soft)!important}.messages-list{flex:1;overflow-y:auto;padding:24px 24px 16px;display:flex;flex-direction:column;gap:4px;scroll-behavior:smooth}.messages-list::-webkit-scrollbar{width:6px}.messages-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-3);gap:14px;text-align:center}.messages-empty-icon{width:56px;height:56px;border-radius:var(--r-full);background:var(--bg-surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-3);box-shadow:var(--shadow-sm)}.messages-empty p{font-size:13px}.message{display:flex;animation:msgIn .3s var(--ease-spring)}@keyframes msgIn{0%{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.message-sent{justify-content:flex-end}.message-received{justify-content:flex-start}.message-bubble{max-width:70%;padding:10px 16px 9px;border-radius:20px;display:flex;flex-direction:column;gap:4px;word-break:break-word;position:relative;transition:transform .15s var(--ease-smooth)}.message-sent .message-bubble{background:var(--accent-grad);border-bottom-right-radius:6px;color:#fff;box-shadow:0 6px 20px #4f46e552,0 1px 3px #0000004d,inset 0 1px #ffffff2e}.message-received .message-bubble{background:linear-gradient(180deg,var(--bg-elevated),var(--bg-overlay));border:1px solid var(--border-strong);border-bottom-left-radius:6px;box-shadow:var(--shadow-sm),inset 0 1px #ffffff0a}.message-text{line-height:1.5;font-size:14.5px}.message-meta{display:flex;align-items:center;gap:5px;align-self:flex-end;margin-top:2px}.message-time{font-size:10.5px;opacity:.55;line-height:1;font-variant-numeric:tabular-nums}.msg-status{font-size:11px;line-height:1;font-style:normal;transition:color .3s}.msg-status--sending{opacity:.35}.msg-status--sent{opacity:.55}.msg-status--delivered{opacity:.85}.msg-status--seen{color:#93c5fd;opacity:1}.typing-message{min-height:0;margin-bottom:4px}.typing-bubble{display:flex;align-items:center;gap:5px;padding:12px 16px!important;min-width:56px}.typing-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--text-3);animation:dotBounce 1.2s ease-in-out infinite}.typing-dot:nth-child(2){animation-delay:.15s}.typing-dot:nth-child(3){animation-delay:.3s}.compose-bar{display:flex;align-items:center;gap:10px;padding:12px 18px 16px;border-top:1px solid var(--border);background:#0e0e15d9;backdrop-filter:blur(24px) saturate(140%);-webkit-backdrop-filter:blur(24px) saturate(140%);flex-shrink:0}.compose-input{flex:1;background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--r-full);padding:11px 20px;color:var(--text-1);font-size:14.5px;outline:none;font-family:inherit;transition:border-color .2s,box-shadow .2s,background .2s}.compose-input:hover{border-color:#fff3}.compose-input:focus{border-color:var(--accent);background:var(--bg-overlay);box-shadow:0 0 0 4px var(--accent-soft)}.compose-input::placeholder{color:var(--text-3)}.btn-send{width:42px;height:42px;flex-shrink:0;border:none;border-radius:var(--r-full);background:var(--accent-grad);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .15s,transform .12s var(--ease-overshoot),box-shadow .15s;box-shadow:0 4px 16px var(--accent-glow),inset 0 1px #fff3}.btn-send:hover:not(:disabled){transform:scale(1.05);box-shadow:0 6px 24px var(--accent-glow),inset 0 1px #ffffff40}.btn-send:active:not(:disabled){transform:scale(.95)}.btn-send:disabled{opacity:.35;cursor:not-allowed;box-shadow:none}.error-banner{background:linear-gradient(180deg,#ef44441f,#ef44440f);border-bottom:1px solid rgba(239,68,68,.25);color:#fca5a5;padding:11px 18px;font-size:13px;display:flex;align-items:center;justify-content:space-between;gap:8px;cursor:pointer;flex-shrink:0;animation:slideDown .25s var(--ease-spring)}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dismiss{opacity:.55;display:flex}.call-banner{background:linear-gradient(180deg,#22c55e1a,#22c55e0a);border-bottom:1px solid rgba(34,197,94,.2);color:#86efac;padding:11px 18px;font-size:13px;display:flex;align-items:center;justify-content:space-between;gap:8px;flex-shrink:0;animation:slideDown .25s var(--ease-spring)}.call-banner--dialing{background:linear-gradient(180deg,#f59e0b1a,#f59e0b0a);border-bottom-color:#f59e0b33;color:#fcd34d}.call-id{font-family:JetBrains Mono,monospace;font-size:11px;opacity:.85}.call-hint{opacity:.65;font-size:12px}.btn-hangup{background:#ef444433;color:#fca5a5;border:1px solid rgba(239,68,68,.32);border-radius:var(--r-sm);padding:5px 14px;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s,transform .12s}.btn-hangup:hover{background:#ef444452;transform:scale(1.03)}.settings{flex:1;min-height:0;overflow-y:auto;padding:40px 32px 56px;max-width:720px;width:100%;margin:0 auto}.settings-header{margin-bottom:36px}.settings-title{font-size:32px;font-weight:800;letter-spacing:-.8px;margin-bottom:6px;background:linear-gradient(160deg,#fff 20%,#a8a8b8);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.settings-subtitle{color:var(--text-2);font-size:14.5px}.settings-group{display:flex;flex-direction:column;gap:6px;margin-bottom:28px}.settings-group:last-child{margin-bottom:0}.settings-section{background:linear-gradient(180deg,var(--bg-raised),var(--bg-base));border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;flex-shrink:0;box-shadow:var(--shadow-sm)}.settings-section-header{display:flex;align-items:center;padding:12px 18px;font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);border-bottom:1px solid var(--border);background:#ffffff05}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 18px;border-bottom:1px solid var(--border);transition:background .15s;min-height:50px}.settings-row:last-child{border-bottom:none}.settings-row.clickable{cursor:pointer}.settings-row.clickable:hover{background:var(--bg-hover)}.settings-label{color:var(--text-2);font-size:14px;flex-shrink:0;font-weight:500}.settings-value{font-size:14px;color:var(--text-1);text-align:right;display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.settings-value.code{font-family:JetBrains Mono,Fira Code,monospace;font-size:12px;color:var(--accent-3)}.truncate{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.settings-loading{color:var(--text-3);font-size:14px;padding:14px 18px}.settings-hint{color:var(--text-3);font-size:12px;padding:8px 18px 14px;line-height:1.5}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:var(--r-full);font-size:11.5px;font-weight:700;letter-spacing:.02em}.badge-premium{background:var(--accent-grad-soft);color:#c4b5fd;border:1px solid var(--border-accent);box-shadow:0 0 12px #8b5cf61f}.badge-free{background:var(--bg-surface);color:var(--text-2);border:1px solid var(--border)}.danger-zone{border-color:#ef444438}.danger-zone .settings-section-header{color:#ef4444d9;border-bottom-color:#ef444426;background:#ef44440a}.danger-warning{font-size:13px;color:var(--text-2);line-height:1.65;padding:14px 18px;background:#ef44440f;border-bottom:1px solid rgba(239,68,68,.12)}.key-backup-panel{padding:18px 20px;display:flex;flex-direction:column;gap:16px}.backup-tabs{display:flex;gap:4px;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--r-md);padding:4px}.backup-tab{flex:1;padding:8px 14px;border:none;border-radius:calc(var(--r-md) - 4px);background:none;color:var(--text-2);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s var(--ease-smooth);font-family:inherit}.backup-tab.active{background:var(--bg-elevated);color:var(--text-1);box-shadow:0 2px 8px #0000004d,inset 0 1px #ffffff0d}.backup-tab:hover:not(.active){background:var(--bg-hover);color:var(--text-1)}.backup-form{display:flex;flex-direction:column;gap:10px}.backup-desc{font-size:13px;color:var(--text-2);line-height:1.6;margin:0}.backup-input{background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--r-md);padding:11px 14px;color:var(--text-1);font-size:14px;outline:none;font-family:inherit;transition:border-color .2s,box-shadow .2s;width:100%;box-sizing:border-box}.backup-input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.backup-input::placeholder{color:var(--text-3)}.backup-error{font-size:13px;color:#fca5a5;margin:0;padding:10px 14px;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--r-md)}.backup-qr{display:flex;flex-direction:column;align-items:center;gap:12px;padding:18px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md)}.backup-qr-label{font-size:12px;color:var(--text-2);text-align:center;line-height:1.55;margin:0}.backup-qr-img{width:200px;height:200px;border-radius:var(--r-sm)}.backup-divider{text-align:center;font-size:11px;color:var(--text-3);position:relative;text-transform:uppercase;letter-spacing:.1em;font-weight:600}.backup-divider:before,.backup-divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:var(--border)}.backup-divider:before{left:0}.backup-divider:after{right:0}.backup-file-label{display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.backup-file-label input[type=file]{display:none}.btn{padding:11px 22px;border:none;border-radius:var(--r-md);font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s,transform .12s var(--ease-overshoot),box-shadow .2s;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;letter-spacing:-.005em}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--accent-grad);color:#fff;position:relative;overflow:hidden;box-shadow:0 4px 18px var(--accent-glow),inset 0 1px #fff3}.btn-primary:after{content:"";position:absolute;top:-50%;left:-80%;width:50%;height:200%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);transform:skew(-20deg);transition:left .65s var(--ease-smooth)}.btn-primary:hover:not(:disabled):after{left:130%}.btn-primary:hover:not(:disabled){box-shadow:0 8px 28px var(--accent-glow),inset 0 1px #ffffff40}.btn-large{padding:15px 30px;font-size:15px;width:100%;border-radius:var(--r-md)}.btn-sm{padding:6px 14px;font-size:12px;border-radius:var(--r-sm)}.btn-secondary{background:var(--bg-surface);color:var(--text-1);border:1px solid var(--border-strong)}.btn-secondary:hover:not(:disabled){background:var(--bg-overlay);border-color:var(--border-accent)}.btn-danger{background:#ef44441f;color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.btn-danger:hover:not(:disabled){background:#ef444433;border-color:#ef444473}.btn-link{background:none;border:none;color:var(--text-3);cursor:pointer;font-size:13px;padding:6px 10px;border-radius:var(--r-sm);transition:color .15s;font-family:inherit}.btn-link:hover{color:var(--accent-3)}.input{flex:1;background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--r-md);padding:11px 16px;color:var(--text-1);font-size:14px;outline:none;font-family:inherit;transition:border-color .2s,box-shadow .2s,background .2s}.input:hover{border-color:#fff3}.input:focus{border-color:var(--accent);background:var(--bg-overlay);box-shadow:0 0 0 4px var(--accent-soft)}.input::placeholder{color:var(--text-3)}.copy-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--r-sm);background:var(--bg-surface);border:1px solid var(--border);color:var(--text-3);cursor:pointer;flex-shrink:0;transition:all .15s var(--ease-smooth)}.copy-btn:hover{color:var(--text-1);background:var(--bg-elevated);border-color:var(--border-strong)}.copy-btn.copied{color:var(--green);border-color:#22c55e66;background:#22c55e1a}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:spin .65s linear infinite;display:inline-block}.spinner-small{width:14px;height:14px;border:2px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:spin .65s linear infinite;display:inline-block}.spinner-large{width:48px;height:48px;border:3px solid var(--border);border-top-color:var(--accent);border-right-color:var(--accent-2);border-radius:50%;animation:spin .9s linear infinite;filter:drop-shadow(0 0 12px var(--accent-glow))}.call-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;background:#03030a;display:flex;align-items:center;justify-content:center;overflow:hidden}.call-video-remote{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;background:#08080f}.call-video-local{position:absolute;bottom:100px;right:22px;width:168px;height:96px;object-fit:cover;border-radius:var(--r-md);z-index:2;border:2px solid rgba(255,255,255,.18);background:#111;box-shadow:0 8px 32px #000000b3;transition:opacity .3s}.call-video-local--hidden{opacity:0;pointer-events:none}.call-minimize-btn{position:absolute;top:14px;right:14px;z-index:5;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border:none;cursor:pointer;border-radius:50%;background:#00000073;color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:background .15s}.call-minimize-btn:hover{background:#000000b3}.call-pill{position:fixed;top:12px;left:50%;transform:translate(-50%);z-index:9100;display:inline-flex;align-items:center;gap:10px;padding:8px 8px 8px 14px;border:none;cursor:pointer;border-radius:999px;font:inherit;font-size:13px;font-weight:600;color:#fff;background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 6px 24px #16a34a73,0 0 0 1px #ffffff1a inset;animation:call-pill-pulse 2.4s ease-in-out infinite}.call-pill:hover{filter:brightness(1.08)}.call-pill-dot{width:8px;height:8px;border-radius:50%;background:#fff;box-shadow:0 0 #ffffffb3;animation:call-pill-dot 1.6s ease-in-out infinite}.call-pill-label{white-space:nowrap}.call-pill-hangup{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:#00000040;color:#fff;transition:background .15s}.call-pill-hangup:hover{background:#dc2626e6}@keyframes call-pill-pulse{0%,to{box-shadow:0 6px 24px #16a34a73,0 0 0 1px #ffffff1a inset}50%{box-shadow:0 6px 32px #16a34ab3,0 0 0 1px #ffffff26 inset}}@keyframes call-pill-dot{0%,to{box-shadow:0 0 #ffffffb3}50%{box-shadow:0 0 0 6px #fff0}}.call-hidden-media{position:fixed;width:1px;height:1px;left:-9999px;top:-9999px;overflow:hidden;pointer-events:none}.call-overlay--minimised{opacity:0;pointer-events:none}.call-status-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;background:#03030ad1;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.call-status-avatar{width:92px;height:92px;border-radius:var(--r-full);background:var(--accent-grad);display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:700;color:#fff;animation:ringPulse 2s ease-in-out infinite;box-shadow:inset 0 1px #fff3}@keyframes ringPulse{0%,to{box-shadow:0 0 0 12px #8b5cf629,0 0 0 26px #8b5cf612,inset 0 1px #fff3}50%{box-shadow:0 0 0 18px #8b5cf61f,0 0 0 36px #8b5cf60a,inset 0 1px #fff3}}.call-status-text{color:#ffffffc7;font-size:1.1rem;font-weight:500;letter-spacing:.02em}.call-status-dots{display:flex;gap:6px}.call-status-dots span{width:6px;height:6px;background:#fff6;border-radius:var(--r-full);animation:dotBounce 1.4s ease-in-out infinite}.call-status-dots span:nth-child(2){animation-delay:.2s}.call-status-dots span:nth-child(3){animation-delay:.4s}@keyframes dotBounce{0%,80%,to{transform:scale(.7);opacity:.4}40%{transform:scale(1);opacity:1}}.call-controls{position:absolute;bottom:0;left:0;right:0;height:88px;z-index:4;display:flex;align-items:center;justify-content:center;gap:14px;padding:0 24px;background:linear-gradient(transparent,#000000bf)}.call-ctrl-btn{background:#ffffff21;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-full);color:#fff;width:46px;height:46px;cursor:pointer;padding:0;transition:background .18s,transform .12s var(--ease-overshoot),border-color .18s;display:flex;align-items:center;justify-content:center}.call-ctrl-btn span{font-size:0}.call-ctrl-btn:hover{background:#ffffff38;transform:scale(1.06);border-color:#ffffff2e}.call-ctrl-btn--off{background:#ef444452;border-color:#ef444466}.call-ctrl-btn--off:hover{background:#ef444473}.call-ctrl-btn--hangup{background:var(--red);width:52px;height:52px;box-shadow:0 6px 24px var(--red-glow);border-color:#ef44444d}.call-ctrl-btn--hangup:hover{background:#dc2626;box-shadow:0 8px 32px var(--red-glow)}.call-peer-badge{position:absolute;top:22px;left:22px;z-index:4;color:#ffffffd9;font-size:.82rem;display:flex;align-items:center;gap:9px;background:#0000008c;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:7px 16px;border-radius:var(--r-full);border:1px solid rgba(255,255,255,.1);font-family:JetBrains Mono,monospace}.call-live-dot{width:7px;height:7px;background:var(--green);border-radius:var(--r-full);box-shadow:0 0 8px var(--green);animation:blink 2s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.4}}.call-stage{position:absolute;top:0;right:0;bottom:0;left:0;transition:right .28s var(--ease-smooth)}.call-overlay--with-chat .call-stage{right:360px}.call-overlay--with-chat .call-video-local{right:382px}@media (max-width: 720px){.call-overlay--with-chat .call-stage{right:0;bottom:50%}.call-overlay--with-chat .call-video-local{right:22px;bottom:calc(50% + 16px)}}.call-ctrl-group{position:relative;display:flex;align-items:center;gap:4px}.call-ctrl-chevron{background:#ffffff21;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-full);color:#ffffffd9;width:20px;height:20px;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;transition:background .18s,transform .12s var(--ease-overshoot)}.call-ctrl-chevron:hover{background:#ffffff3d;transform:scale(1.1)}.call-ctrl-btn--active{background:#8b5cf666;border-color:#8b5cf68c}.call-device-popover{position:absolute;bottom:calc(100% + 14px);left:50%;transform:translate(-50%);min-width:240px;max-width:320px;background:#141220f5;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-md);box-shadow:var(--shadow-xl);padding:6px;z-index:10;animation:popIn .14s var(--ease-overshoot)}@keyframes popIn{0%{opacity:0;transform:translate(-50%) translateY(4px) scale(.96)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.call-device-popover-title{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:#ffffff73;padding:8px 10px 4px}.call-device-popover-empty{padding:10px;color:#ffffff8c;font-size:.85rem;text-align:center}.call-device-popover-item{display:block;width:100%;background:transparent;border:none;color:#ffffffe0;text-align:left;padding:8px 10px;border-radius:var(--r-sm);font-size:.87rem;cursor:pointer;transition:background .14s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.call-device-popover-item:hover{background:#ffffff14}.call-device-popover-item.is-active{background:#8b5cf638;color:#fff;font-weight:500}.call-device-popover-item.is-active:before{content:"✓ ";color:var(--accent)}.call-chat{position:absolute;top:0;right:0;bottom:0;width:360px;background:#0f0e1af0;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-left:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;z-index:5;animation:slideInChat .28s var(--ease-smooth)}@keyframes slideInChat{0%{transform:translate(100%)}to{transform:translate(0)}}@media (max-width: 720px){.call-chat{width:100%;height:50%;top:auto;bottom:0;border-left:none;border-top:1px solid rgba(255,255,255,.08)}}.call-chat-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.06);font-weight:600;color:#fff;font-size:.95rem}.call-chat-close{background:transparent;border:none;color:#ffffffb3;cursor:pointer;padding:4px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;transition:background .14s,color .14s}.call-chat-close:hover{background:#ffffff14;color:#fff}.call-chat-messages{flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:8px}.call-chat-empty{text-align:center;color:#fff6;font-size:.85rem;margin-top:24px}.call-chat-msg{max-width:80%;padding:8px 12px;border-radius:14px;font-size:.9rem;line-height:1.35;word-wrap:break-word}.call-chat-msg--in{align-self:flex-start;background:#ffffff14;color:#ffffffeb;border-bottom-left-radius:4px}.call-chat-msg--out{align-self:flex-end;background:var(--accent-grad);color:#fff;border-bottom-right-radius:4px;box-shadow:0 4px 14px #8b5cf640}.call-chat-input{display:flex;gap:8px;padding:12px;border-top:1px solid rgba(255,255,255,.06);background:#0000002e}.call-chat-input input{flex:1;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);color:#fff;padding:9px 12px;border-radius:var(--r-md);font-size:.9rem;outline:none;transition:border-color .14s,background .14s}.call-chat-input input:focus{border-color:var(--accent);background:#ffffff1a}.call-chat-input button{background:var(--accent-grad);color:#fff;border:none;cursor:pointer;width:40px;height:40px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;transition:transform .12s var(--ease-overshoot),opacity .14s}.call-chat-input button:hover:not(:disabled){transform:scale(1.05)}.call-chat-input button:disabled{opacity:.4;cursor:not-allowed}.call-quality-bars{display:inline-flex;align-items:flex-end;gap:2px;height:14px}.call-quality-bar{width:3px;background:#fff3;border-radius:1px;transition:background .4s}.call-quality-bar:nth-child(1){height:5px}.call-quality-bar:nth-child(2){height:8px}.call-quality-bar:nth-child(3){height:11px}.call-quality-bar:nth-child(4){height:14px}.call-quality-bar--active{background:var(--q-color, var(--green))}.call-incoming{position:relative;z-index:5;background:linear-gradient(180deg,#14141deb,#0e0e15eb);border:1px solid var(--border-strong);border-radius:var(--r-2xl);padding:48px 56px;text-align:center;backdrop-filter:blur(28px) saturate(140%);-webkit-backdrop-filter:blur(28px) saturate(140%);box-shadow:0 40px 120px #000000bf,0 0 0 1px #ffffff0d,inset 0 1px #ffffff0f;animation:callSlideIn .45s var(--ease-spring)}@keyframes callSlideIn{0%{opacity:0;transform:scale(.86) translateY(28px)}to{opacity:1;transform:scale(1) translateY(0)}}.call-ring-avatar{width:80px;height:80px;margin:0 auto 22px;background:var(--accent-grad);border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;color:#fff;animation:ringPulse 1.8s ease-in-out infinite}.call-incoming h2{font-size:1.4rem;color:#fff;margin-bottom:8px;font-weight:700;letter-spacing:-.4px}.call-peer-id{color:#ffffff80;font-family:JetBrains Mono,monospace;font-size:.85rem;margin-bottom:38px;letter-spacing:.03em}.call-incoming-actions{display:flex;gap:24px;justify-content:center}.call-btn-wrap{display:flex;flex-direction:column;align-items:center;gap:10px}.call-btn-label{font-size:12px;color:#ffffff8c;letter-spacing:.04em;font-weight:500;text-transform:uppercase}.call-btn{width:68px;height:68px;border:none;border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .12s var(--ease-overshoot),opacity .15s,box-shadow .2s;border:1px solid rgba(255,255,255,.06)}.call-btn:hover{transform:scale(1.1)}.call-btn--accept{background:var(--green);color:#fff;box-shadow:0 8px 28px var(--green-glow),inset 0 1px #fff3}.call-btn--accept:hover{box-shadow:0 12px 36px var(--green-glow),inset 0 1px #ffffff40}.call-btn--reject{background:var(--red);color:#fff;box-shadow:0 8px 28px var(--red-glow),inset 0 1px #fff3}.call-btn--reject:hover{box-shadow:0 12px 36px var(--red-glow),inset 0 1px #ffffff40}.group-screen{display:flex;flex-direction:column;height:100%;overflow:hidden}.group-list-header{display:flex;align-items:center;justify-content:space-between;padding:24px 24px 14px;border-bottom:1px solid var(--border);background:#0e0e15b3;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.group-list-header h2{font-size:1.15rem;font-weight:700;color:var(--text-1);margin:0;letter-spacing:-.3px}.group-list-subtitle{margin-top:6px;font-size:12.5px;color:var(--text-3)}.group-panel-switcher{display:flex;gap:8px;padding:16px 24px 12px;border-bottom:1px solid var(--border)}.group-panel-tab{border:1px solid var(--border-strong);background:var(--bg-surface);color:var(--text-2);border-radius:var(--r-full);padding:9px 16px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;font-family:inherit;transition:all .18s var(--ease-smooth)}.group-panel-tab:hover{color:var(--text-1);border-color:var(--border-accent);background:var(--bg-elevated)}.group-panel-tab.active{background:var(--accent-grad-soft);color:#fff;border-color:var(--border-accent);box-shadow:0 8px 24px #4f46e533}.group-list{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1}.group-list-item{display:flex;align-items:center;gap:14px;padding:16px 24px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .15s}.group-list-item:hover{background:var(--bg-hover)}.group-avatar{width:44px;height:44px;border-radius:var(--r-md);background:var(--accent-grad);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--shadow-sm),inset 0 1px #ffffff2e}.group-info{display:flex;flex-direction:column;gap:2px}.group-name{font-size:14.5px;font-weight:600;color:var(--text-1)}.group-meta{font-size:12px;color:var(--text-3)}.empty-hint{color:var(--text-3);font-size:14px;padding:32px 24px;text-align:center}.group-finance-shell{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:20px}.group-finance-hero{position:relative;overflow:hidden;padding:26px;border-radius:var(--r-xl);border:1px solid var(--border-accent);background:radial-gradient(circle at top right,rgba(139,92,246,.22),transparent 38%),linear-gradient(180deg,#ffffff08,#ffffff03),var(--bg-raised);box-shadow:var(--shadow-md)}.group-finance-hero h3{font-size:26px;letter-spacing:-.5px;font-weight:700;margin:16px 0 10px;color:var(--text-1)}.group-finance-hero p{max-width:54ch;color:var(--text-2);font-size:14px;line-height:1.65}.group-finance-badge{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:var(--r-full);background:var(--accent-grad-soft);color:#c4b5fd;border:1px solid var(--border-accent);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.group-finance-stats{margin-top:20px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.group-finance-stat{padding:16px 18px;border-radius:var(--r-md);background:#08080d80;border:1px solid var(--border);display:flex;flex-direction:column;gap:6px}.group-finance-stat-label{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);font-weight:600}.group-finance-stat strong{font-size:16px;color:var(--text-1);font-weight:700;font-variant-numeric:tabular-nums}.group-finance-grid{display:grid;gap:16px;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr)}.group-finance-card{border-radius:var(--r-lg);border:1px solid var(--border);background:var(--bg-raised);overflow:hidden;box-shadow:var(--shadow-sm)}.group-finance-card-head{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);background:#ffffff05}.group-finance-muted{color:var(--text-3);font-size:11px}.group-finance-actions{padding:14px;display:flex;flex-direction:column;gap:10px}.group-finance-action{width:100%;padding:14px 16px;border-radius:var(--r-md);background:var(--bg-surface);border:1px solid var(--border-strong);color:var(--text-2);display:flex;align-items:center;gap:10px;font:inherit;text-align:left;transition:all .15s}.group-finance-action:not(:disabled):hover{background:var(--bg-elevated);border-color:var(--border-accent);color:var(--text-1)}.group-finance-action:disabled{opacity:.78}.group-finance-list{display:flex;flex-direction:column}.group-finance-item{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:18px;border-bottom:1px solid var(--border);transition:background .15s}.group-finance-item:hover{background:var(--bg-hover)}.group-finance-item:last-child{border-bottom:none}.group-finance-item strong{display:block;font-size:14.5px;color:var(--text-1);margin-bottom:4px;font-weight:600}.group-finance-item p{color:var(--text-2);font-size:13px;line-height:1.55}.group-finance-item-meta{display:flex;flex-direction:column;align-items:flex-end;gap:8px;min-width:110px}.group-finance-status{padding:4px 10px;border-radius:var(--r-full);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.group-finance-status--settled{background:#22c55e1f;color:#86efac;border:1px solid rgba(34,197,94,.22)}.group-finance-status--pending{background:#f59e0b1f;color:#fcd34d;border:1px solid rgba(245,158,11,.22)}.group-finance-status--streaming{background:#60a5fa1f;color:#93c5fd;border:1px solid rgba(96,165,250,.22)}.group-finance-amount{font-family:JetBrains Mono,Fira Code,monospace;font-size:13.5px;color:var(--text-1);font-weight:600;font-variant-numeric:tabular-nums}@media (max-width: 900px){.group-finance-grid{grid-template-columns:1fr}}@media (max-width: 640px){.sidebar{width:64px}.group-list-header{align-items:flex-start;padding:18px 16px 12px}.group-finance-shell{padding:16px}.group-finance-hero{padding:20px}.group-finance-item{flex-direction:column}.group-finance-item-meta{align-items:flex-start;min-width:0}.settings{padding:24px 18px 40px}.settings-title{font-size:26px}.messages-list{padding:18px 16px 12px}.compose-bar{padding:10px 14px 14px}.message-bubble{max-width:82%}.onboarding-card{padding:40px 28px 36px}}.group-sender-hash{display:block;font-size:10.5px;font-family:JetBrains Mono,monospace;color:var(--accent-3);margin-bottom:4px;font-weight:500;letter-spacing:.02em}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:8000;background:#000000a6;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:fadeIn .25s var(--ease-smooth)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-box{background:linear-gradient(180deg,#14141deb,#0e0e15eb);border:1px solid var(--border-strong);border-radius:var(--r-xl);padding:32px 36px;width:min(520px,92vw);box-shadow:var(--shadow-xl),inset 0 1px #ffffff0f;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(28px) saturate(140%);backdrop-filter:blur(28px) saturate(140%);animation:cardRise .35s var(--ease-spring)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}.modal-header h2{font-size:1.15rem;font-weight:700;color:var(--text-1);margin:0;letter-spacing:-.3px}.field-label{font-size:12px;color:var(--text-2);margin-bottom:6px;display:block;font-weight:500}.input-field{width:100%;padding:10px 14px;font-size:14px;background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--r-md);color:var(--text-1);font-family:inherit;box-sizing:border-box;outline:none;transition:border-color .2s,box-shadow .2s}.input-field:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.send-btn{padding:10px 14px;background:var(--accent-grad);color:#fff;border:none;border-radius:var(--r-md);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:opacity .15s,box-shadow .15s;box-shadow:0 4px 16px #4f46e552}.send-btn:hover:not(:disabled){opacity:.9;box-shadow:0 6px 20px #4f46e573}.send-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.member-list{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:5px}.member-list li{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);font-size:12px;font-family:JetBrains Mono,monospace;color:var(--text-2)}.icon-btn{background:none;border:none;cursor:pointer;color:var(--text-3);padding:5px;border-radius:var(--r-sm);display:inline-flex;align-items:center;justify-content:center;transition:color .12s,background .12s}.icon-btn:hover{color:var(--text-1);background:var(--bg-hover)}.icon-btn.btn-icon--active{color:var(--accent)}.error-text{color:var(--red);font-size:13px;margin-top:6px}.primary-btn{padding:11px 22px;background:var(--accent-grad);color:#fff;border:none;border-radius:var(--r-md);cursor:pointer;font-size:14px;font-weight:600;font-family:inherit;transition:opacity .15s,transform .12s,box-shadow .15s;box-shadow:0 4px 18px var(--accent-glow),inset 0 1px #ffffff2e}.primary-btn:hover:not(:disabled){box-shadow:0 6px 24px var(--accent-glow),inset 0 1px #ffffff38}.primary-btn:active:not(:disabled){transform:scale(.97)}.primary-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.chat-header-info{display:flex;flex-direction:column;gap:3px}.chat-header-info .chat-peer-name{font-size:14.5px;font-weight:600;color:var(--text-1)}.chat-header-info .chat-peer-sub{font-size:11px;color:var(--text-3)}.disappear-timer-wrapper{position:relative}.timer-menu{position:absolute;top:calc(100% + 8px);right:0;background:linear-gradient(180deg,var(--bg-elevated),var(--bg-overlay));border:1px solid var(--border-strong);border-radius:var(--r-md);padding:6px;min-width:200px;z-index:500;box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);animation:menuPop .2s var(--ease-overshoot)}@keyframes menuPop{0%{opacity:0;transform:translateY(-6px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.timer-menu-label{font-size:11px;font-weight:700;color:var(--text-3);padding:6px 10px 8px;text-transform:uppercase;letter-spacing:.08em}.timer-option{display:block;width:100%;text-align:left;padding:9px 12px;background:none;border:none;border-radius:var(--r-sm);cursor:pointer;font-size:13px;color:var(--text-2);font-family:inherit;transition:background .12s,color .12s}.timer-option:hover{background:var(--bg-hover);color:var(--text-1)}.timer-option--active{color:var(--accent-3);font-weight:600}.disappear-badge{display:inline-flex;align-items:center;color:var(--accent);margin-left:2px}.attachment-bubble{display:flex;align-items:center;gap:10px;padding:4px 0}.attachment-icon{color:currentColor;opacity:.85;flex-shrink:0}.attachment-name{font-weight:600;font-size:13.5px;flex:1}.attachment-size{font-size:11px;opacity:.65;font-variant-numeric:tabular-nums}.btn-attach{flex-shrink:0;color:var(--text-3);background:none;border:none;cursor:pointer;padding:8px;border-radius:var(--r-sm);display:inline-flex;align-items:center;transition:color .15s,background .15s}.btn-attach:hover{color:var(--accent);background:var(--bg-hover)}.attachment-sentinel{display:flex;align-items:center;gap:6px;color:var(--text-2);font-size:13px}.reply-quote{display:block;border-left:3px solid var(--accent);background:#00000014;padding:4px 8px;margin-bottom:6px;border-radius:4px;font-size:12px;opacity:.85;max-width:100%}.message-sent .reply-quote{background:#ffffff2e}.reply-quote-preview{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.message-bubble{position:relative}.message-actions{position:absolute;top:-14px;display:flex;gap:2px;background:var(--bg-1, #fff);border:1px solid var(--border, rgba(0,0,0,.08));border-radius:16px;padding:2px;box-shadow:0 2px 6px #00000014;opacity:0;transition:opacity .12s;pointer-events:none}.message-sent .message-actions{right:8px}.message-received .message-actions{left:8px}.message-bubble:hover .message-actions{opacity:1;pointer-events:auto}.message-action-btn{background:transparent;border:0;cursor:pointer;padding:2px 6px;font-size:14px;line-height:1;border-radius:12px}.message-action-btn:hover{background:var(--bg-hover, rgba(0,0,0,.06))}.reaction-picker{position:absolute;bottom:-42px;display:flex;gap:2px;background:var(--bg-1, #fff);border:1px solid var(--border, rgba(0,0,0,.08));border-radius:20px;padding:4px 6px;box-shadow:0 4px 12px #0000001f;z-index:10}.message-sent .reaction-picker{right:0}.message-received .reaction-picker{left:0}.reaction-picker-btn{background:none;border:0;cursor:pointer;padding:4px 6px;font-size:18px;line-height:1;border-radius:50%;transition:transform .1s,background .1s}.reaction-picker-btn:hover{transform:scale(1.25);background:var(--bg-hover, rgba(0,0,0,.06))}.reaction-picker-btn--active{background:var(--accent-soft, rgba(0,122,255,.15))}.reaction-row{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}.message-sent .reaction-row{justify-content:flex-end}.message-received .reaction-row{justify-content:flex-start}.reaction-badge{display:inline-flex;align-items:center;gap:3px;background:var(--bg-2, rgba(0,0,0,.05));border:1px solid var(--border, rgba(0,0,0,.08));border-radius:12px;padding:2px 7px;font-size:13px;cursor:pointer;transition:background .12s,border-color .12s}.reaction-badge:hover{background:var(--bg-hover, rgba(0,0,0,.08))}.reaction-badge--mine{background:var(--accent-soft, rgba(0,122,255,.15));border-color:var(--accent, #007aff)}.reaction-badge-count{font-size:11px;font-variant-numeric:tabular-nums;opacity:.8}.reply-preview{display:flex;align-items:center;gap:8px;background:var(--bg-2, rgba(0,0,0,.04));border-left:3px solid var(--accent, #007aff);padding:6px 10px;margin:0 12px;border-radius:4px;font-size:13px}.reply-preview-label{font-weight:600;color:var(--accent, #007aff);flex-shrink:0}.reply-preview-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;opacity:.8}.reply-preview-cancel{background:none;border:0;cursor:pointer;padding:2px;display:inline-flex;align-items:center;border-radius:50%;color:var(--text-3)}.reply-preview-cancel:hover{background:var(--bg-hover, rgba(0,0,0,.08))}.messages-list--dragover{outline:2px dashed var(--accent, #007aff);outline-offset:-8px}.dropzone-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:#007aff14;pointer-events:none;z-index:5;font-size:14px;font-weight:600;color:var(--accent, #007aff)}.messages-list{position:relative}.attachment-bubble--image{flex-direction:column;align-items:stretch;gap:4px;padding:0}.attachment-image{display:block;max-width:280px;max-height:320px;border-radius:8px;cursor:pointer;object-fit:cover}.attachment-image-placeholder{width:200px;height:140px;background:var(--bg-2, rgba(0,0,0,.05));border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:12px;opacity:.6}.attachment-image-meta{display:flex;gap:8px;align-items:baseline;padding:0 4px;font-size:11px}.search-panel{border-bottom:1px solid var(--border, rgba(255,255,255,.08));background:var(--bg-raised, rgba(255,255,255,.02));padding:10px 16px;display:flex;flex-direction:column;gap:8px}.search-input-wrap{display:flex;align-items:center;gap:8px;background:var(--bg-surface, rgba(255,255,255,.04));border:1px solid var(--border, rgba(255,255,255,.08));border-radius:8px;padding:6px 10px}.search-input-wrap svg{opacity:.5;flex-shrink:0}.search-input{flex:1;background:transparent;border:0;outline:0;color:var(--text-1, #fff);font-size:14px}.search-clear{background:transparent;border:0;color:var(--text-3, #888);cursor:pointer;padding:2px;display:flex;align-items:center}.search-clear:hover{color:var(--text-1, #fff)}.search-results{max-height:280px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.search-result{text-align:left;background:transparent;border:0;color:var(--text-2, #ccc);padding:8px 10px;border-radius:6px;cursor:pointer;display:flex;flex-direction:column;gap:2px;font:inherit}.search-result:hover{background:var(--bg-overlay, rgba(255,255,255,.05))}.search-result-time{font-size:11px;opacity:.6}.search-result-text{font-size:13px;color:var(--text-1, #fff);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-empty{padding:12px;text-align:center;color:var(--text-3, #888);font-size:13px}.message--highlight .message-bubble{animation:msgHighlight 1.5s ease-out}@keyframes msgHighlight{0%{box-shadow:0 0 0 3px #8b5cf68c}to{box-shadow:0 0 #8b5cf600}}.message-menu{position:absolute;top:100%;right:4px;margin-top:4px;background:var(--bg-elevated, #1c1c22);border:1px solid var(--border, rgba(255,255,255,.08));border-radius:8px;box-shadow:0 8px 24px #00000059;padding:4px;display:flex;flex-direction:column;min-width:130px;z-index:10}.message-menu-item{display:flex;align-items:center;gap:8px;background:transparent;border:0;color:var(--text-1, #fff);padding:8px 10px;border-radius:6px;font-size:13px;cursor:pointer;text-align:left}.message-menu-item:hover{background:var(--bg-overlay, rgba(255,255,255,.06))}.message-menu-item--danger{color:#ef4444}.message-menu-item--danger:hover{background:#ef44441f}.message-edit{display:flex;flex-direction:column;gap:6px;min-width:220px}.message-edit-input{background:#00000040;color:inherit;border:1px solid rgba(255,255,255,.15);border-radius:6px;padding:6px 8px;font:inherit;outline:0}.message-edit-input:focus{border-color:#8b5cf699}.message-edit-actions{display:flex;justify-content:flex-end;gap:6px}.btn-link{background:transparent;border:0;color:var(--text-2, #ccc);font-size:12px;cursor:pointer;padding:2px 6px;border-radius:4px}.btn-link:hover{color:var(--text-1, #fff);background:#ffffff0f}.btn-link--accent{color:#a78bfa;font-weight:600}.btn-link--accent:hover{color:#c4b5fd}.message-edited{font-size:10px;opacity:.55;font-style:italic;margin-left:4px}.message-text--deleted{display:inline-flex;align-items:center;gap:6px;font-style:italic;opacity:.55}.message--deleted .message-bubble{background:#ffffff0a!important;border:1px dashed rgba(255,255,255,.1)}.theme-mode-group{display:inline-flex;background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;padding:3px;gap:2px}.theme-mode-btn{background:transparent;border:0;color:var(--text-3);padding:6px 14px;border-radius:7px;font:inherit;font-size:13px;cursor:pointer;transition:color .15s ease,background .15s ease}.theme-mode-btn:hover{color:var(--text-1)}.theme-mode-btn--active{color:#fff;background:var(--accent-grad);box-shadow:0 2px 8px var(--accent-glow)}.accent-swatches{display:inline-flex;gap:8px}.accent-swatch{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:transform .15s ease,border-color .15s ease;padding:0}.accent-swatch:hover{transform:scale(1.08)}.accent-swatch--active{border-color:var(--text-1);box-shadow:0 0 0 3px var(--bg-base)}.recipient-presence{font-size:12px;color:var(--text-3);display:flex;align-items:center;gap:6px;margin-top:1px}.recipient-presence--online{color:#22c55e;font-weight:500}.presence-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 6px #22c55e99;display:inline-block}.switch{position:relative;display:inline-block;width:42px;height:24px;flex-shrink:0;cursor:pointer}.switch input{opacity:0;width:0;height:0;position:absolute}.switch-track{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--bg-overlay);border:1px solid var(--border-strong);border-radius:999px;transition:background .2s ease,border-color .2s ease}.switch-thumb{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:var(--text-2);transition:transform .2s var(--ease-spring),background .2s ease}.switch input:checked+.switch-track{background:var(--accent);border-color:var(--accent)}.switch input:checked+.switch-track .switch-thumb{transform:translate(18px);background:#fff}.switch input:disabled+.switch-track{opacity:.5;cursor:not-allowed}.backup-meta{display:flex;flex-direction:column;gap:4px;background:var(--bg-overlay);border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-size:13px;color:var(--text-1)}.backup-meta-row{display:block}.backup-meta-row--muted{font-size:12px;color:var(--text-3)}
