*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #1e1f2e;--bg-secondary: #181926;--bg-tertiary: #252636;--bg-hover: rgba(255,255,255,.04);--bg-active: rgba(114,137,218,.2);--sidebar-w: 240px;--userlist-w: 200px;--text: #dcddde;--text-muted: #72767d;--text-dim: #b0b0c0;--accent: #7289da;--accent-hover: #677bc4;--online: #43b581;--danger: #f04747;--warn: #faa61a;--border: rgba(255,255,255,.06);--radius: 6px;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", Arial, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", "Consolas", monospace}html,body,#root{height:100%;overflow:hidden}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:15px;line-height:1.5}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;border:none;background:none;color:inherit;font:inherit}input,textarea{font:inherit;color:inherit;background:none;border:none;outline:none}.layout{display:grid;grid-template-columns:var(--sidebar-w) 1fr var(--userlist-w);grid-template-rows:100vh;height:100vh;overflow:hidden}.sidebar{background:var(--bg-secondary);display:flex;flex-direction:column;border-right:1px solid var(--border);overflow:hidden}.sidebar-header{padding:16px 16px 12px;font-weight:700;font-size:15px;border-bottom:1px solid var(--border)}.server-name{color:var(--text)}.sidebar-section-label{padding:16px 8px 4px 12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);display:flex;align-items:center;justify-content:space-between}.sidebar-add-btn{width:18px;height:18px;border-radius:50%;background:var(--bg-hover);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--text-muted);transition:background .15s,color .15s}.sidebar-add-btn:hover{background:var(--accent);color:#fff}.sidebar-join-form{padding:4px 8px}.sidebar-join-input{width:100%;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);padding:4px 8px;font-size:13px;color:var(--text)}.channel-list{flex:1;overflow-y:auto;padding:4px 0}.channel-item-wrapper{padding:1px 8px}.channel-item{width:100%;display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:var(--radius);font-size:14px;color:var(--text-muted);transition:background .1s,color .1s;text-align:left}.channel-item:hover{background:var(--bg-hover);color:var(--text-dim)}.channel-item.active{background:var(--bg-active);color:var(--text)}.channel-hash{font-size:16px;opacity:.6}.channel-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.channel-badge{background:var(--danger);color:#fff;font-size:10px;font-weight:700;padding:1px 5px;border-radius:10px;min-width:18px;text-align:center}.voice-row{display:flex;align-items:center;justify-content:space-between;padding:2px 8px 2px 22px;font-size:12px;color:var(--text-muted)}.voice-label{color:var(--online)}.voice-join-btn{font-size:11px;padding:2px 6px;background:var(--accent);color:#fff;border-radius:var(--radius);transition:background .1s}.voice-join-btn:hover{background:var(--accent-hover)}.sidebar-footer{border-top:1px solid var(--border);padding:10px 12px}.self-info{display:flex;align-items:center;justify-content:space-between}.self-nick{font-size:14px;font-weight:600;color:var(--text)}.main-area{display:flex;flex-direction:column;overflow:hidden}.channel-header{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0}.channel-header-name{font-weight:700;font-size:15px}.channel-header-topic{font-size:13px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.channel-header-actions{margin-left:auto;display:flex;gap:4px}.messages-and-voice{flex:1;display:flex;flex-direction:column;overflow:hidden}.empty-state{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:14px}.message-list{flex:1;overflow-y:auto;padding:16px 0;scroll-behavior:smooth}.message-list-empty{color:var(--text-muted);text-align:center;padding:32px;font-size:14px}.message-group{display:flex;gap:12px;padding:2px 16px;border-radius:var(--radius);position:relative;transition:background .1s}.message-group:hover{background:var(--bg-hover)}.message-group.history{opacity:.75}.message-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0;margin-top:2px}.message-body{flex:1;min-width:0}.message-header{display:flex;align-items:baseline;gap:8px;margin-bottom:2px}.message-author{font-weight:600;font-size:15px;color:var(--text)}.message-time{font-size:11px;color:var(--text-muted)}.message-line{position:relative}.message-line-time{font-size:10px;color:var(--text-muted);opacity:0;position:absolute;left:-52px;top:50%;transform:translateY(-50%);pointer-events:none}.message-line:hover .message-line-time{opacity:1}.message-content{font-size:15px;color:var(--text);word-break:break-word;white-space:pre-wrap}.message-actions{position:absolute;right:16px;top:4px;display:flex;gap:4px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);padding:2px 4px}.inline-image{max-width:400px;max-height:300px;border-radius:var(--radius);display:block;margin-top:4px;object-fit:contain}.inline-video{max-width:400px;max-height:300px;border-radius:var(--radius);display:block;margin-top:4px}.inline-audio{display:block;margin-top:4px}.attachment-link{display:inline-flex;align-items:center;gap:4px;background:var(--bg-tertiary);padding:4px 10px;border-radius:var(--radius);font-size:13px;margin-top:4px}.reaction-bar{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.reaction-pill{display:inline-flex;align-items:center;gap:4px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:12px;padding:2px 8px;font-size:13px;transition:background .1s,border-color .1s}.reaction-pill:hover,.reaction-pill.mine{background:var(--bg-active);border-color:var(--accent)}.emoji-picker{display:flex;flex-wrap:wrap;gap:4px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);padding:8px;position:absolute;z-index:100;max-width:220px;box-shadow:0 8px 24px #0006;top:calc(100% + 4px)}.emoji-option{font-size:20px;border-radius:4px;padding:2px;transition:background .1s}.emoji-option:hover{background:var(--bg-active)}.message-input-area{position:relative;padding:0 16px 16px;flex-shrink:0}.message-input-area.drag-over .input-row{border-color:var(--accent)}.input-row{display:flex;align-items:flex-end;gap:8px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:10px;padding:8px 12px;transition:border-color .15s}.input-row:focus-within{border-color:#7289da80}.message-textarea{flex:1;resize:none;min-height:24px;max-height:160px;overflow-y:auto;line-height:1.5;font-size:15px}.message-textarea::placeholder{color:var(--text-muted)}.upload-btn{font-size:18px;padding:2px;opacity:.7}.upload-btn:hover{opacity:1}.send-btn{padding:4px 14px;border-radius:var(--radius);font-size:14px;white-space:nowrap}.upload-error{background:#f0474726;border:1px solid var(--danger);border-radius:var(--radius);padding:6px 12px;font-size:13px;margin-bottom:8px;display:flex;justify-content:space-between}.drop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#7289da26;border:2px dashed var(--accent);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--accent);pointer-events:none}.user-list{background:var(--bg-secondary);border-left:1px solid var(--border);overflow-y:auto;padding:16px 0}.user-list-label{padding:12px 12px 4px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.user-row{display:flex;align-items:center;gap:8px;padding:4px 12px;border-radius:var(--radius);margin:0 4px;transition:background .1s}.user-row:hover{background:var(--bg-hover)}.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0;position:relative}.user-voice-dot{position:absolute;bottom:-2px;right:-2px;font-size:10px;background:var(--bg-secondary);border-radius:50%}.user-nick{font-size:13px;color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.voice-panel{background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;flex-direction:column;max-height:280px;flex-shrink:0}.voice-panel.maximized{flex:1;max-height:none;min-height:0}.voice-panel-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border);font-size:13px;font-weight:600;flex-shrink:0}.voice-panel-title{color:var(--online)}.voice-panel-header-actions{display:flex;gap:2px}.video-grid{flex:1;display:flex;flex-wrap:wrap;gap:4px;padding:8px;overflow-y:auto;min-height:0}.voice-panel.maximized .video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));align-content:start}.voice-panel.maximized .video-grid .video-tile{width:auto;height:auto;aspect-ratio:4 / 3}.video-tile{position:relative;width:160px;height:120px;border-radius:var(--radius);overflow:hidden;background:#111;flex-shrink:0}.video-tile video{width:100%;height:100%;object-fit:cover}.video-tile video.mirrored{transform:scaleX(-1)}.video-tile-avatar{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:700;background:var(--bg-tertiary);color:var(--text-muted)}.video-tile-label{position:absolute;bottom:4px;left:6px;font-size:11px;font-weight:600;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.8);pointer-events:none}.video-tile-pin-btn{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:var(--radius);background:#0009;display:flex;align-items:center;justify-content:center;font-size:11px;line-height:1;opacity:0;transition:opacity .15s,background .15s}.video-tile:hover .video-tile-pin-btn{opacity:1}.video-tile-pin-btn.pinned{opacity:1;background:var(--accent)}.voice-pinned-layout{flex:1;display:flex;gap:4px;padding:8px;overflow:hidden;min-height:0}.voice-pinned-main{flex:1;min-width:0;overflow:hidden;border-radius:var(--radius)}.voice-pinned-main .video-tile{width:100%;height:100%}.voice-thumbnails{width:140px;flex-shrink:0;display:flex;flex-direction:column;gap:4px;overflow-y:auto}.voice-thumbnails .video-tile{width:140px;height:100px;flex-shrink:0}.voice-thumbnails .video-tile-avatar{font-size:24px}.voice-controls{display:flex;gap:8px;padding:8px 12px;border-top:1px solid var(--border);justify-content:center;flex-shrink:0}.voice-ctrl-btn{width:36px;height:36px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:18px;transition:background .15s;border:1px solid var(--border)}.voice-ctrl-btn:hover{background:var(--bg-hover)}.voice-ctrl-btn.off{background:var(--danger);border-color:var(--danger)}.voice-ctrl-btn.active{background:var(--accent);border-color:var(--accent)}.voice-ctrl-btn.danger{background:var(--danger);border-color:var(--danger)}.connect-overlay{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.connect-form{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:36px 40px;width:380px;max-width:calc(100vw - 32px);display:flex;flex-direction:column;gap:18px;box-shadow:0 16px 48px #00000080}.connect-logo{text-align:center}.connect-logo-text{font-size:32px;font-weight:800;color:var(--accent);letter-spacing:-1px}.connect-tagline{text-align:center;font-size:13px;color:var(--text-muted);margin-top:-8px}.connect-error{background:#f047471a;border:1px solid var(--danger);color:var(--danger);padding:8px 12px;border-radius:var(--radius);font-size:13px}.form-label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:var(--text-dim)}.form-input{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);padding:8px 12px;font-size:15px;color:var(--text);transition:border-color .15s}.form-input:focus{border-color:var(--accent)}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius);padding:10px 20px;font-weight:600;font-size:15px;transition:background .15s,opacity .15s}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.link-button{background:transparent;border:none;color:var(--text-muted);font-size:13px;text-align:center;padding:6px;cursor:pointer;transition:color .15s}.link-button:hover:not(:disabled){color:var(--accent)}.link-button:disabled{opacity:.5;cursor:not-allowed}.server-subdomain-row{display:flex;align-items:stretch;border:1px solid var(--border, #2a2a2a);border-radius:var(--radius);overflow:hidden;background:var(--bg-input, #1a1a1a)}.server-subdomain-row:focus-within{border-color:var(--accent)}.server-subdomain-input{flex:1 1 auto;border:none;background:transparent;border-radius:0}.server-subdomain-input:focus{border:none}.server-subdomain-suffix{display:flex;align-items:center;padding:0 12px;color:var(--text-muted);font-size:14px;background:var(--bg-input-secondary, rgba(255,255,255,.04));border-left:1px solid var(--border, #2a2a2a);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;white-space:nowrap}.form-label-optional{font-weight:400;color:var(--text-muted);font-size:12px}.btn-icon{width:28px;height:28px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:16px;transition:background .1s;color:var(--text-muted)}.btn-icon:hover{background:var(--bg-hover);color:var(--text)}.btn-icon.active{color:var(--accent)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff2e}
