@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--bg-deepest: #06060b;--bg-primary: #0c0c14;--bg-secondary:#101018;--bg-tertiary: #16161f;--bg-hover: #1c1c2a;--bg-active: #222234;--bg-float: #1a1a26;--accent: #5865F2;--accent-hover: #4752C4;--accent-soft: rgba(88,101,242,.12);--accent-glow: rgba(88,101,242,.25);--accent-grad: linear-gradient(135deg,#5865F2 0%,#7289DA 100%);--text-bright: #ffffff;--text-primary: #dcddde;--text-secondary:#8e9297;--text-muted: #5d5f63;--success: #23a559;--danger: #ed4245;--warning: #fee75c;--offline: #747f8d;--border: rgba(255,255,255,.04);--border-hover:rgba(255,255,255,.08);--shadow-sm: 0 1px 4px rgba(0,0,0,.35);--shadow-md: 0 4px 14px rgba(0,0,0,.45);--shadow-lg: 0 8px 30px rgba(0,0,0,.55);--shadow-glow:0 0 24px var(--accent-glow);--sidebar-w: 260px;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 20px;--r-full: 9999px;--font: "Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%;-webkit-text-size-adjust:100%}body{height:100%;font-family:var(--font);font-size:14px;line-height:1.5;color:var(--text-primary);background:var(--bg-deepest);overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%}a{color:var(--accent);text-decoration:none}img{display:block;max-width:100%}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff26}.avatar{display:flex;align-items:center;justify-content:center;border-radius:var(--r-full);font-weight:600;color:#fff;flex-shrink:0;text-transform:uppercase;-webkit-user-select:none;user-select:none;letter-spacing:-.01em}.avatar--xs{width:28px;height:28px;font-size:11px}.avatar--sm{width:34px;height:34px;font-size:13px}.avatar--md{width:38px;height:38px;font-size:14px}.avatar--lg{width:48px;height:48px;font-size:18px}.avatar--xl{width:72px;height:72px;font-size:28px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:var(--r-md);font-family:var(--font);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease;outline:none;white-space:nowrap}.btn:focus-visible{box-shadow:0 0 0 3px var(--accent-soft)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important;filter:none!important}.btn--primary{background:var(--accent);color:#fff}.btn--primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn--accent{background:var(--accent-grad);color:#fff}.btn--accent:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px);box-shadow:var(--shadow-glow)}.btn--ghost{background:transparent;color:var(--text-secondary)}.btn--ghost:hover:not(:disabled){color:var(--text-primary);background:var(--bg-hover)}.btn--sm{padding:7px 14px;font-size:13px;border-radius:var(--r-sm)}.btn--lg{padding:14px 28px;font-size:15px;border-radius:var(--r-lg)}.btn--full{width:100%}.btn-arrow{margin-left:4px;font-size:18px;line-height:1}.field{margin-bottom:20px}.field-label{display:block;margin-bottom:8px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.field-input{width:100%;padding:12px 16px;background:var(--bg-tertiary);border:1.5px solid var(--border);border-radius:var(--r-md);color:var(--text-primary);font-family:var(--font);font-size:15px;transition:border-color .2s,box-shadow .2s;outline:none}.field-input::placeholder{color:var(--text-muted)}.field-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.field-input--sm{padding:9px 12px;font-size:13px}.field-hint{font-size:12px;color:var(--text-muted);margin-top:6px;line-height:1.5}.phrase-wrap{position:relative}.phrase-wrap .field-input{padding-right:44px}.phrase-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;align-items:center}.phrase-toggle:hover{color:var(--text-primary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes dotBounce{0%,80%,to{transform:scale(.5);opacity:.4}40%{transform:scale(1);opacity:1}}@keyframes glow{0%,to{box-shadow:0 0 8px var(--accent-glow)}50%{box-shadow:0 0 24px var(--accent-glow)}}@keyframes shimmer{to{background-position:200% center}}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:20px;animation:fadeIn .4s ease}.loading-lock{width:48px;height:48px;border:3px solid var(--accent);border-top-color:transparent;border-radius:var(--r-full);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--text-muted);font-size:13px;letter-spacing:.02em}.setup-screen{display:flex;align-items:center;justify-content:center;height:100%;padding:24px;background:radial-gradient(ellipse at 50% 30%,rgba(88,101,242,.06) 0%,transparent 65%);animation:fadeIn .5s ease}.setup-card{width:100%;max-width:400px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-xl);padding:40px 36px;box-shadow:var(--shadow-lg);animation:slideUp .5s ease}.setup-header{text-align:center;margin-bottom:32px}.brand-icon{margin-bottom:12px;display:flex;justify-content:center}.brand-title{font-size:28px;font-weight:700;color:var(--text-bright);letter-spacing:-.02em}.brand-title--sm{font-size:22px}.brand-subtitle{color:var(--text-muted);font-size:13px;margin-top:6px}.color-grid{display:flex;gap:10px;flex-wrap:wrap}.color-dot{width:36px;height:36px;border-radius:var(--r-full);border:3px solid transparent;cursor:pointer;transition:transform .15s,border-color .15s,box-shadow .15s}.color-dot:hover{transform:scale(1.15)}.color-dot.selected{border-color:#fff;box-shadow:0 0 0 2px var(--bg-secondary),0 0 12px #ffffff26;transform:scale(1.1)}.avatar-preview{display:flex;justify-content:center;margin:28px 0}.pairing-screen{display:flex;align-items:center;justify-content:center;height:100%;padding:24px;background:radial-gradient(ellipse at 50% 20%,rgba(88,101,242,.06) 0%,transparent 65%);animation:fadeIn .5s ease}.pairing-card{width:100%;max-width:440px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-xl);padding:36px 32px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:20px;animation:slideUp .5s ease}.pairing-header{text-align:center}.qr-section{display:flex;flex-direction:column;align-items:center;gap:12px}.qr-frame{position:relative;padding:16px;background:var(--bg-tertiary);border-radius:var(--r-lg);border:1px solid var(--border);animation:glow 3s ease-in-out infinite}.qr-image{width:228px;height:228px;image-rendering:pixelated}.qr-corner{position:absolute;width:20px;height:20px;border-color:var(--accent);border-style:solid}.qr-corner.tl{top:-2px;left:-2px;border-width:3px 0 0 3px;border-radius:6px 0 0}.qr-corner.tr{top:-2px;right:-2px;border-width:3px 3px 0 0;border-radius:0 6px 0 0}.qr-corner.bl{bottom:-2px;left:-2px;border-width:0 0 3px 3px;border-radius:0 0 0 6px}.qr-corner.br{bottom:-2px;right:-2px;border-width:0 3px 3px 0;border-radius:0 0 6px}.pair-actions{display:flex;flex-direction:column;gap:8px}.scanner-section{display:flex;flex-direction:column;gap:10px;align-items:center}.scanner-view{width:100%;max-width:320px;border-radius:var(--r-md);overflow:hidden}.scanner-view video{border-radius:var(--r-md)}.manual-section{animation:slideUp .25s ease}.manual-row{display:flex;gap:8px}.manual-row .field-input{flex:1}.toast{padding:10px 16px;border-radius:var(--r-md);font-size:13px;text-align:center;animation:slideUp .25s ease}.toast--error{background:#ed42451f;color:#f87171;border:1px solid rgba(237,66,69,.2)}.paired-section{display:flex;flex-direction:column;gap:8px}.section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.paired-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg-tertiary);border-radius:var(--r-md);animation:slideIn .3s ease}.paired-name{flex:1;font-size:14px;color:var(--text-primary)}.app-layout{display:flex;height:100%;animation:fadeIn .3s ease}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:16px 16px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-title{font-size:16px;font-weight:700;color:var(--text-bright);flex:1}.sidebar-divider{height:1px;background:var(--border);margin:0 12px;flex-shrink:0}.sidebar-section{flex:1;overflow-y:auto;padding:12px 10px}.sidebar-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:4px 8px 10px}.user-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--r-md);transition:background .15s;cursor:default}.user-item:hover{background:var(--bg-hover)}.user-meta{flex:1;min-width:0;display:flex;flex-direction:column}.user-name{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-tag{font-size:11px;color:var(--text-muted)}.status-dot{width:10px;height:10px;border-radius:var(--r-full);flex-shrink:0;border:2px solid var(--bg-secondary)}.status-dot--online{background:var(--success)}.status-dot--offline{background:var(--offline)}.conn-badge{font-size:10px;font-weight:600;padding:3px 8px;border-radius:var(--r-full);letter-spacing:.02em}.conn-badge--on{background:#23a55926;color:var(--success)}.conn-badge--off{background:#ed42451f;color:var(--danger);animation:pulse 2s infinite}.sidebar-invite{padding:10px 10px 8px;border-top:1px solid var(--border);flex-shrink:0}.sidebar-code-row{display:flex;gap:6px;align-items:center;margin-bottom:6px}.sidebar-code{flex:1;font-size:10px;color:var(--text-muted);font-family:monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background:var(--bg-tertiary);padding:5px 8px;border-radius:var(--r-sm)}.btn--xs{padding:4px 10px;font-size:11px;border-radius:var(--r-sm)}.sidebar-join{display:flex;gap:6px;margin-top:6px}.field-input--xs{padding:5px 8px;font-size:12px;border-radius:var(--r-sm)}.sidebar-error{font-size:11px;color:var(--danger);margin-top:4px}.sidebar-footer{padding:10px;border-top:1px solid var(--border);flex-shrink:0;display:flex;flex-direction:column;gap:8px}.sidebar-add-btn{justify-content:flex-start}.sidebar-user-strip{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg-tertiary);border-radius:var(--r-md)}.strip-info{flex:1;min-width:0;display:flex;flex-direction:column}.strip-name{font-size:12px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.strip-status{font-size:10px;color:var(--text-muted)}.chat-main{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--bg-primary)}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--bg-primary)}.chat-header-left{display:flex;align-items:center;gap:8px}.channel-hash{font-size:22px;font-weight:700;color:var(--text-muted)}.channel-name{font-size:16px;font-weight:700;color:var(--text-bright)}.header-divider{width:1px;height:20px;background:var(--border-hover);margin:0 4px}.header-desc{font-size:13px;color:var(--text-muted)}.chat-header-right{display:flex;align-items:center;gap:10px}.header-avatars{display:flex;gap:4px;align-items:center}.header-avatar-wrap{position:relative}.micro-dot{position:absolute;bottom:-1px;right:-1px;width:8px;height:8px;border-radius:var(--r-full);border:2px solid var(--bg-primary)}.micro-dot--on{background:var(--success)}.micro-dot--off{background:var(--offline)}.invite-header-btn{display:flex;align-items:center;gap:6px;background:var(--accent-soft);color:var(--accent);border:none;border-radius:var(--r-md);padding:6px 14px;font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.invite-header-btn:hover{background:var(--accent);color:#fff}.conn-pill{display:flex;align-items:center;gap:6px;padding:4px 12px;border-radius:var(--r-full);font-size:11px;font-weight:600}.conn-pill--on{background:#23a5591a;color:var(--success)}.conn-pill--off{background:#ed42451a;color:var(--danger);animation:pulse 2s infinite}.conn-pill-dot{width:7px;height:7px;border-radius:var(--r-full);background:currentColor}.messages-scroll{flex:1;overflow-y:auto;padding:0 20px 16px}.welcome-block{text-align:center;padding:32px 20px 20px}.welcome-title{font-size:14px;font-weight:600;color:var(--text-secondary);margin-bottom:4px}.welcome-desc{font-size:12px;color:var(--text-muted);line-height:1.5}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:60px 24px 40px;animation:slideUp .4s ease}.empty-icon{margin-bottom:16px}.empty-title{font-size:22px;font-weight:700;color:var(--text-bright);margin-bottom:8px}.empty-desc{font-size:14px;color:var(--text-muted);line-height:1.6;max-width:400px;margin-bottom:32px}.invite-content{width:100%;max-width:440px}.invite-box{margin-bottom:16px}.invite-label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:8px}.code-row{display:flex;gap:8px;align-items:stretch}.code-display{flex:1;padding:10px 14px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-primary);font-family:monospace;font-size:12px;word-break:break-all;line-height:1.4;max-height:60px;overflow-y:auto;-webkit-user-select:all;user-select:all}.invite-hint{font-size:12px;color:var(--text-muted);margin-top:6px}.join-row{display:flex;gap:8px}.join-row .field-input{flex:1}.invite-divider{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--text-muted);font-size:12px}.invite-divider:before,.invite-divider:after{content:"";flex:1;height:1px;background:var(--border)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;z-index:200;animation:fadeIn .15s ease}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:460px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-xl);padding:28px 24px;z-index:210;box-shadow:var(--shadow-lg);animation:slideUp .25s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-header h3{font-size:18px;font-weight:700;color:var(--text-bright)}.modal-close{background:none;border:none;color:var(--text-muted);font-size:24px;cursor:pointer;padding:4px 8px;line-height:1;border-radius:var(--r-sm);transition:all .15s}.modal-close:hover{color:var(--text-primary);background:var(--bg-hover)}.date-sep{display:flex;align-items:center;gap:12px;margin:20px 0 12px}.date-sep:before,.date-sep:after{content:"";flex:1;height:1px;background:var(--border)}.date-sep-text{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.msg-row{display:flex;gap:10px;padding:3px 0;max-width:85%;animation:slideUp .2s ease}.msg-row--sent{margin-left:auto;flex-direction:row-reverse}.msg-row--recv{margin-right:auto}.msg-row--grouped{padding-top:1px}.msg-avatar{flex-shrink:0;padding-top:2px}.msg-avatar-gap{width:34px;flex-shrink:0}.msg-body{display:flex;flex-direction:column;min-width:0}.msg-meta{display:flex;align-items:baseline;gap:8px;margin-bottom:3px;padding-left:2px}.msg-author{font-size:13px;font-weight:600}.msg-ts{font-size:11px;color:var(--text-muted)}.msg-bubble{display:inline-flex;align-items:flex-end;gap:10px;padding:10px 14px;border-radius:var(--r-lg);max-width:100%;word-break:break-word;line-height:1.45}.msg-bubble--sent{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.msg-bubble--recv{background:var(--bg-tertiary);color:var(--text-primary);border-bottom-left-radius:4px;border:1px solid var(--border)}.msg-text{flex:1;white-space:pre-wrap}.msg-time{font-size:10px;opacity:.55;flex-shrink:0;padding-top:2px;white-space:nowrap}.typing-row{display:flex;align-items:center;gap:8px;padding:8px 4px}.typing-dots{display:flex;gap:3px}.typing-dots span{width:7px;height:7px;border-radius:var(--r-full);background:var(--text-muted);animation:dotBounce 1.4s ease-in-out infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}.typing-label{font-size:12px;color:var(--text-muted)}.scroll-anchor{height:1px}.input-bar{padding:12px 20px 14px;flex-shrink:0;background:var(--bg-primary)}.input-wrap{display:flex;align-items:flex-end;gap:8px;background:var(--bg-tertiary);border:1.5px solid var(--border);border-radius:var(--r-lg);padding:6px 6px 6px 16px;transition:border-color .2s,box-shadow .2s}.input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.msg-input{flex:1;border:none;outline:none;resize:none;background:transparent;color:var(--text-primary);font-family:var(--font);font-size:14px;line-height:1.5;padding:6px 0;min-height:24px;max-height:120px}.msg-input::placeholder{color:var(--text-muted)}.send-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;border:none;border-radius:var(--r-md);cursor:pointer;flex-shrink:0;transition:background .15s,transform .15s}.send-btn:hover:not(:disabled){background:var(--accent-hover);transform:scale(1.05)}.send-btn:disabled{opacity:.35;cursor:not-allowed}.input-hint{display:flex;align-items:center;gap:5px;margin-top:6px;padding-left:4px;font-size:11px;color:var(--text-muted);opacity:.5}.url-box{display:flex;gap:8px;align-items:center;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--r-md);padding:10px 14px;margin-bottom:24px;max-width:400px;width:100%}.url-display{flex:1;font-family:monospace;font-size:13px;color:var(--accent);-webkit-user-select:all;user-select:all;word-break:break-all}.waiting-dots{display:flex;gap:5px;justify-content:center}.waiting-dots span{width:8px;height:8px;border-radius:var(--r-full);background:var(--text-muted);animation:dotBounce 1.4s ease-in-out infinite}.waiting-dots span:nth-child(2){animation-delay:.2s}.waiting-dots span:nth-child(3){animation-delay:.4s}.setup-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--text-muted);font-size:12px}.setup-divider:before,.setup-divider:after{content:"";flex:1;height:1px;background:var(--border)}.scan-section{display:flex;flex-direction:column;gap:14px}.scan-hint{font-size:13px;color:var(--text-secondary);text-align:center}.scanner-view{width:100%;max-width:320px;margin:0 auto;border-radius:var(--r-md);overflow:hidden}.link-device-content{text-align:center}.link-desc{font-size:13px;color:var(--text-secondary);line-height:1.5;margin-bottom:20px}.link-qr-wrap{display:inline-flex;padding:16px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--r-lg);margin-bottom:16px}.link-qr-img{width:248px;height:248px;image-rendering:pixelated}.link-warning{display:flex;align-items:center;justify-content:center;gap:6px;font-size:11px;color:var(--warning);opacity:.8}.mobile-menu-btn{display:none}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:90;animation:fadeIn .2s ease}@media (max-width: 768px){.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:100;transform:translate(-100%);transition:transform .25s ease}.sidebar.sidebar--open{transform:translate(0);box-shadow:4px 0 24px #00000080}.sidebar-backdrop{display:block}.mobile-menu-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;margin-right:4px}.invite-header-label{display:none}.invite-header-btn{padding:6px 8px}.messages-scroll{padding:0 10px 12px}.chat-header{padding:10px 12px}.input-bar{padding:8px 10px 10px}.header-divider,.header-avatars{display:none}.msg-row{max-width:92%}.setup-screen{padding:16px}.setup-card{padding:24px 18px;border-radius:var(--r-lg)}.brand-title{font-size:24px}.empty-state{padding:40px 16px 24px}.empty-title{font-size:18px}.code-display{font-size:10px}.modal{width:92%;padding:22px 18px}.conn-pill span:not(.conn-pill-dot){display:none}.conn-pill{padding:4px 8px}}@media (max-width: 380px){.setup-card{padding:20px 14px}.channel-name{font-size:14px}}::selection{background:var(--accent);color:#fff}
