*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,system-ui,sans-serif;background:#313338;color:#f2f3f5;min-height:100vh;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}#root{min-height:100vh}a{color:#00a8fc;text-decoration:none}a:hover{text-decoration:underline}input,button,textarea{font:inherit}.app-layout{display:flex;height:100vh;overflow:hidden;position:relative}.skip-link{position:absolute;top:0;left:0;z-index:100;padding:8px 16px;background:#5865f2;color:#fff;font-size:14px;text-decoration:none;border-radius:0 0 4px;transform:translateY(-100%);transition:transform .15s}.skip-link:focus{transform:translateY(0);outline:2px solid #fff;outline-offset:2px}.servers-bar{width:72px;background:#1e1f22;display:flex;flex-direction:column;align-items:center;padding-top:12px;gap:8px}.servers-bar .server-icon{width:48px;height:48px;border-radius:50%;background:#313338;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#23a559;font-weight:700;transition:border-radius .2s}.servers-bar .server-icon:hover,.servers-bar .server-icon.active{border-radius:16px;background:#5865f2;color:#fff}.channels-panel{width:240px;background:#2b2d31;display:flex;flex-direction:column;overflow:hidden}.channels-panel .server-name{padding:16px;font-weight:600;border-bottom:1px solid #1e1f22;color:#f2f3f5}.channels-panel .channels-list{flex:1;overflow-y:auto;padding:8px 0}.channel-item{padding:6px 12px;margin:0 8px;border-radius:4px;cursor:pointer;display:flex;align-items:center;gap:8px;color:#b5bac1}.channel-item:hover{background:#383a40;color:#f2f3f5}.channel-item.active{background:#404249;color:#f2f3f5}.channel-item .icon{font-size:1.1rem}.chat-panel{flex:1;display:flex;flex-direction:column;background:#313338;min-width:0}.chat-header{padding:12px 16px;border-bottom:1px solid #1e1f22;display:flex;align-items:center;gap:8px}.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:4px}.chat-input-area{padding:16px;border-top:1px solid #1e1f22}.chat-input-area textarea{width:100%;min-height:44px;max-height:200px;padding:12px 16px;border-radius:8px;background:#383a40;border:none;color:#f2f3f5;resize:none}.chat-input-area textarea::placeholder{color:#949ba4}.members-panel{width:240px;background:#2b2d31;overflow-y:auto;padding:12px}.member-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:4px;color:#b5bac1}.member-row .avatar{width:32px;height:32px;border-radius:50%;background:#5865f2;display:flex;align-items:center;justify-content:center;font-size:14px}.message-row{display:flex;gap:16px;padding:4px 0}.message-row.message-highlight{background:#5865f226;border-radius:4px;margin:0 8px;padding:4px 8px;animation:message-highlight-fade 2s ease-out}@keyframes message-highlight-fade{0%{background:#5865f259}to{background:transparent}}.message-row .avatar{width:40px;height:40px;border-radius:50%;background:#5865f2;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:600}.message-row .body .author{font-weight:600;margin-right:8px}.message-row .body .time{font-size:12px;color:#949ba4}.message-row .body .content{margin-top:2px;white-space:pre-wrap;word-break:break-word}.message-row .body .attachments{margin-top:8px;display:flex;flex-wrap:wrap;gap:8px}.message-row .body .attachments img{max-width:400px;max-height:300px;border-radius:4px}.message-row .body .attachments video{max-width:100%;max-height:320px;border-radius:4px}.link-preview-card:hover{background:#2b2d31;border-color:#404249}.pinned-banner{background:#2b2d31;padding:8px 16px;margin:0 16px 8px;border-radius:4px;display:flex;align-items:center;gap:8px;cursor:pointer;color:#b5bac1}.pinned-banner:hover{color:#f2f3f5}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#313338}.login-box{width:100%;max-width:400px;padding:32px;background:#2b2d31;border-radius:8px;box-shadow:0 8px 16px #0000004d}.login-box h1{margin:0 0 24px;text-align:center;font-size:1.5rem}.login-box input{width:100%;padding:12px;margin-bottom:12px;border-radius:4px;border:none;background:#1e1f22;color:#f2f3f5}.login-box button{width:100%;padding:12px;border:none;border-radius:4px;background:#5865f2;color:#fff;font-weight:600;cursor:pointer}.login-box button:hover{background:#4752c4}.login-box .toggle{margin-top:12px;text-align:center;color:#b5bac1;font-size:14px}.btn-secondary{background:#4e5058!important}.btn-secondary:hover{background:#5d5f66!important}.voice-panel{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:#2b2d31;border-top:1px solid #1e1f22;gap:16px;flex-wrap:wrap}.voice-panel-left{display:flex;align-items:center;gap:12px}.voice-channel-name{font-weight:600;color:#f2f3f5}.voice-participants{display:flex;flex-direction:column;gap:6px;max-height:120px;overflow-y:auto;min-width:180px}.voice-participant-card{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:6px;background:#383a40;border-left:3px solid transparent;transition:background .15s,border-color .15s}.voice-participant-card.speaking{background:#3f4248;border-left-color:#23a559;box-shadow:0 0 0 1px #23a55940}.voice-participant-avatar{width:24px;height:24px;border-radius:50%;background:#5865f2;color:#fff;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0}.voice-participant-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.voice-participant-name{font-size:12px;color:#f2f3f5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.voice-participant-screen{margin-left:2px;opacity:.9}.voice-volume-bar{height:4px;background:#2b2d31;border-radius:2px;overflow:hidden;width:100%;max-width:80px}.voice-volume-fill{height:100%;background:#4e5058;border-radius:2px;transition:width .1s ease-out}.voice-volume-fill[data-speaking]{background:#23a559}.voice-deafen-hint{font-size:11px;color:#f23f42;margin-top:4px}.voice-btn-unlock{background:#23a559;color:#fff;font-size:12px;padding:6px 10px}.voice-btn-unlock:hover{background:#2dc96e}.voice-settings-link{display:inline-block;font-size:11px;color:#949ba4;margin-top:6px;text-decoration:none}.voice-settings-link:hover{color:#00a8fc}.voice-solo-hint{font-size:11px;color:#80848e;margin:6px 0 0}.voice-participants-floating{min-width:200px;max-width:260px;background:#2b2d3199;border-radius:8px;border:2px solid rgba(35,165,89,.5);box-shadow:0 4px 24px #0006,0 0 0 1px #23a55933;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.voice-participants-floating-header{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#23a55933;border-radius:6px 6px 0 0;cursor:grab;border-bottom:1px solid rgba(35,165,89,.3)}.voice-participants-floating-header:active{cursor:grabbing}.voice-participants-floating-drag-handle{font-size:10px;color:#23a559cc;letter-spacing:-1px;-webkit-user-select:none;user-select:none}.voice-participants-floating-title{font-size:13px;font-weight:600;color:#f2f3f5}.voice-participants-floating-hint{font-size:11px;color:#23a559}.voice-participants-floating-list-wrap{overflow:hidden;transition:max-height .2s ease-out,opacity .15s ease-out}.voice-participants-floating-list{padding:8px;max-height:240px;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.voice-participants-floating-list .voice-participant-card{padding:6px 10px}.voice-participants-floating-collapsed{min-width:0;max-width:72px}.voice-participants-floating-collapsed .voice-participants-floating-header{padding:6px 8px;flex-wrap:nowrap}.voice-participants-floating-collapsed .voice-participants-floating-title{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.voice-participants-floating-toggle{margin-left:auto;padding:2px 6px;border:none;background:#ffffff1a;border-radius:4px;color:#b5bac1;cursor:pointer;font-size:10px;line-height:1}.voice-participants-floating-toggle:hover{background:#fff3;color:#f2f3f5}.voice-participants-floating-toggle:focus-visible{outline:2px solid #23a559;outline-offset:2px}.voice-participants-floating-menu{padding:4px;background:#2b2d31;border:1px solid #383a40;border-radius:6px;box-shadow:0 4px 12px #0000004d;display:flex;flex-direction:column;gap:2px;min-width:140px}.voice-participants-floating-menu button{padding:6px 12px;text-align:left;border:none;background:transparent;color:#f2f3f5;font-size:13px;cursor:pointer;border-radius:4px}.voice-participants-floating-menu button:hover{background:#383a40}.voice-participants-floating-menu button:focus-visible{outline:2px solid #23a559;outline-offset:2px}.voice-error-banner{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#f23f4226;border:1px solid rgba(242,63,66,.4);border-radius:6px;width:100%;flex-basis:100%;margin-bottom:4px}.voice-error-text{flex:1;font-size:12px;color:#f23f42}.voice-btn-retry{background:#f23f42;color:#fff;flex-shrink:0}.voice-btn-retry:hover{background:#f25558}.voice-restore-stream-banner{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#23a5591f;border:1px solid rgba(35,165,89,.35);border-radius:6px;margin-bottom:6px;font-size:12px;color:#b5bac1}.voice-restore-stream-banner span{flex:1}.voice-btn-restore-stream{flex-shrink:0;background:#23a559;color:#fff}.voice-btn-restore-stream:hover{background:#2dc96b}.voice-participant-streaming-label{font-size:11px;color:#949ba4;margin-left:4px}.voice-btn-watch{margin-top:4px;padding:4px 10px;font-size:12px;background:#23a559;color:#fff}.voice-btn-watch:hover{background:#2dc96b}.voice-screen-share-error{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#f23f421f;border-radius:6px;font-size:12px;color:#f23f42;margin-top:4px}.voice-screen-share-error span{flex:1}.voice-btn-dismiss{padding:2px 8px;border:none;border-radius:4px;background:transparent;color:#f23f42;cursor:pointer;font-size:18px;line-height:1}.voice-btn-dismiss:hover{background:#f23f4233}.voice-panel-controls{display:flex;align-items:center;gap:8px}.voice-btn{padding:8px 12px;border:none;border-radius:4px;background:#404249;color:#b5bac1;cursor:pointer;font-size:13px}.voice-btn:hover{background:#4e5058;color:#f2f3f5}.voice-btn:focus-visible{outline:2px solid #23a559;outline-offset:2px}.voice-btn.muted{background:#f23f42;color:#fff}.voice-btn.ptt-active{background:#23a559;color:#fff}.voice-ptt-hint{font-size:11px;color:#949ba4;margin-left:2px}.voice-btn.disconnect{background:#f23f42;color:#fff}.voice-btn.sharing{background:#23a559}.voice-quality-picker{display:flex;gap:4px}.voice-quality-picker button{padding:6px 10px;font-size:12px;border:none;border-radius:4px;background:#383a40;color:#b5bac1;cursor:pointer}.voice-quality-picker button.active{background:#5865f2;color:#fff}.voice-quality-picker button:focus-visible{outline:2px solid #23a559;outline-offset:2px}.voice-screen-preview{display:flex;align-items:center;gap:8px;font-size:12px;color:#949ba4}.voice-video-area{margin-top:8px;margin-bottom:8px;display:flex;flex-direction:column;gap:8px}.voice-video-main{position:relative;background:#000;border-radius:8px;overflow:hidden;min-height:220px;display:flex;align-items:center;justify-content:center}.voice-video-main-video{width:100%;height:100%;object-fit:contain;background:#000}.voice-video-main-overlay{position:absolute;left:8px;right:8px;bottom:8px;display:flex;align-items:center;justify-content:space-between;pointer-events:none}.voice-video-main-title{font-size:13px;color:#f2f3f5;padding:4px 8px;border-radius:4px;background:#0009}.voice-video-fullscreen-btn{pointer-events:auto}.voice-video-strip{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px}.voice-video-thumb{display:flex;flex-direction:column;align-items:center;gap:2px;padding:2px;border-radius:6px;border:1px solid transparent;background:transparent;cursor:pointer;min-width:120px}.voice-video-thumb.active{border-color:#5865f2;background:#5865f21f}.voice-video-thumb-video{width:140px;max-height:90px;border-radius:4px;background:#1e1f22}.voice-video-thumb-name{font-size:11px;color:#b5bac1}
