:root{--bg:#0d0d0f;--panel:#151518;--panel-2:#1c1c20;--border:#25252b;--hover:#232329;--text:#ececef;--muted:#8a8a93;--accent:#6366f1;--accent-hover:#7c7ef3;--danger:#ef4444;--success:#22c55e;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{background:var(--bg);height:100%;color:var(--text);overflow:hidden}button{color:inherit;cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea{color:inherit;background:0 0;border:none;outline:none;font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--hover)}.login-page{background:radial-gradient(circle at 20% 20%, #6366f11f, transparent 40%), radial-gradient(circle at 80% 80%, #8b5cf614, transparent 40%), var(--bg);justify-content:center;align-items:center;width:100%;height:100%;padding:24px;display:flex}.login-card{background:var(--panel);border:1px solid var(--border);text-align:center;border-radius:16px;width:100%;max-width:380px;padding:36px 32px;box-shadow:0 20px 60px #0006}.login-logo{justify-content:center;margin-bottom:20px;display:flex}.login-logo-mark{background:linear-gradient(135deg, var(--accent), #8b5cf6);letter-spacing:-.5px;color:#fff;border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;font-size:24px;font-weight:700;display:flex;box-shadow:0 8px 20px #6366f159}.login-card h1{letter-spacing:-.3px;margin-bottom:6px;font-size:22px;font-weight:600}.login-sub{color:var(--muted);margin-bottom:24px;font-size:14px}.login-card form{flex-direction:column;gap:10px;display:flex}.login-card input{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;width:100%;padding:12px 14px;font-size:14px;transition:border-color .18s,background .18s}.login-card input:focus{border-color:var(--accent);background:var(--panel-2)}.login-card input.invalid{border-color:var(--danger)}.login-card button[type=submit]{background:var(--accent);color:#fff;border-radius:10px;width:100%;padding:12px 14px;font-size:14px;font-weight:600;transition:background .18s,opacity .18s}.login-card button[type=submit]:hover:not(:disabled){background:var(--accent-hover)}.login-card button[type=submit]:disabled{opacity:.5;cursor:not-allowed}.login-footer{color:var(--muted);margin-top:18px;font-size:12px}.server-sidebar{background:var(--bg);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;align-items:center;width:72px;padding:12px 0;display:flex}.server-list{flex-direction:column;flex:1;align-items:center;gap:8px;width:100%;padding-bottom:12px;display:flex;overflow-y:auto}.server-icon{color:#fff;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:16px;font-weight:600;transition:border-radius .2s,box-shadow .2s;display:flex;position:relative}.server-icon.active{box-shadow:0 0 0 2px var(--accent), 0 8px 16px #0006;border-radius:12px}.server-icon.active:before{content:"";background:var(--text);border-radius:0 4px 4px 0;width:4px;height:28px;position:absolute;top:50%;left:-16px;transform:translateY(-50%)}.server-icon.add-server{background:var(--panel);color:var(--success);border:1px dashed var(--border);font-size:22px;font-weight:300}.server-icon.add-server:hover{background:var(--hover);border-style:solid;border-color:var(--success)}.server-tooltip{color:#fff;white-space:nowrap;opacity:0;pointer-events:none;z-index:50;background:#000;border-radius:6px;padding:6px 10px;font-size:12px;font-weight:500;transition:opacity .18s,transform .18s;position:absolute;top:50%;left:calc(100% + 14px);transform:translateY(-50%)translate(-4px)}.server-icon:hover .server-tooltip{opacity:1;transform:translateY(-50%)translate(0)}.server-bottom{border-top:1px solid var(--border);justify-content:center;width:100%;padding-top:12px;display:flex}.user-icon{font-size:14px}.channel-sidebar{background:var(--panel);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:240px;display:flex;position:relative}.channel-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 14px 14px 18px;display:flex}.channel-header h2{letter-spacing:-.2px;white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:600;overflow:hidden}.channel-invite{width:28px;height:28px;color:var(--muted);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:background .18s,color .18s;display:flex}.channel-invite:hover{background:var(--hover);color:var(--text)}.channel-section{flex-direction:column;flex:1;gap:8px;padding:10px 8px;display:flex;overflow-y:auto}.channel-group+.channel-group{margin-top:4px}.channel-section-header{color:var(--muted);text-transform:uppercase;letter-spacing:.6px;justify-content:space-between;align-items:center;padding:8px 10px 6px;font-size:11px;font-weight:600;display:flex}.channel-add{width:18px;height:18px;color:var(--muted);border-radius:4px;justify-content:center;align-items:center;font-size:14px;transition:background .15s,color .15s;display:flex}.channel-add:hover{background:var(--hover);color:var(--text)}.channel-list{flex-direction:column;gap:2px;display:flex}.channel-item{width:100%;color:var(--muted);text-align:left;border-radius:6px;align-items:center;gap:6px;padding:7px 10px;font-size:14px;transition:background .15s,color .15s;display:flex}.channel-item:hover{background:var(--hover);color:var(--text)}.channel-item.active{background:var(--panel-2);color:var(--text)}.channel-prefix{color:var(--muted);justify-content:center;align-items:center;width:16px;font-size:16px;display:inline-flex}.channel-item.active .channel-prefix{color:var(--accent)}.channel-item.voice .channel-prefix{font-size:14px}.channel-name{text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:500;overflow:hidden}.channel-status{justify-content:center;align-items:center;margin-left:auto;display:flex}.channel-status.connecting{color:var(--accent)}.channel-status.connected .dot{background:var(--success);border-radius:50%;width:7px;height:7px;animation:1.6s ease-in-out infinite ch-pulse;box-shadow:0 0 0 3px #22c55e2e}@keyframes ch-pulse{0%,to{box-shadow:0 0 0 3px #22c55e2e}50%{box-shadow:0 0 0 5px #22c55e00}}@keyframes spin{to{transform:rotate(360deg)}}.channel-voice-block{flex-direction:column;display:flex}.presence-row{color:var(--muted);border-radius:6px;align-items:center;gap:10px;padding:5px 10px 5px 30px;font-size:13px;display:flex;overflow:hidden}.presence-row.self{color:var(--text);background:#6366f114}.presence-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;font-weight:700;display:flex;position:relative}.presence-row.self .presence-avatar{box-shadow:0 0 0 2px var(--accent)}.presence-avatar.muted{filter:saturate(.6)}.presence-mic{background:var(--danger);border:2px solid var(--panel);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;display:flex;position:absolute;bottom:-3px;right:-3px}.presence-name{white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:6px;font-weight:500;display:flex;overflow:hidden}.presence-row.self .presence-name{font-weight:600}.presence-you{text-transform:uppercase;color:var(--accent);letter-spacing:.4px;background:#6366f126;border-radius:3px;padding:1px 5px;font-size:9px;font-weight:700}.voice-status-panel{border-top:1px solid var(--border);background:var(--panel-2);flex-direction:column;gap:8px;padding:10px 12px 12px;display:flex}.vsp-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.vsp-status{text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:6px;font-size:11px;font-weight:700;display:flex}.vsp-status.connecting{color:var(--accent)}.vsp-status.connected{color:var(--success)}.vsp-dot{background:var(--success);border-radius:50%;width:7px;height:7px;animation:1.6s ease-in-out infinite ch-pulse;box-shadow:0 0 0 3px #22c55e33}.vsp-channel{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:4px;min-width:0;font-size:12px;display:flex;overflow:hidden}.vsp-user{align-items:center;gap:10px;padding:4px 0 2px;display:flex}.vsp-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:12px;font-weight:700;display:flex}.vsp-name{text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;overflow:hidden}.vsp-controls{gap:6px;display:flex}.vsp-btn{background:var(--panel);height:34px;color:var(--text);border-radius:8px;flex:1;justify-content:center;align-items:center;transition:background .18s,color .18s;display:flex}.vsp-btn:hover{background:var(--hover)}.vsp-btn.danger{color:var(--danger);background:#ef444426}.vsp-btn.danger:hover{background:#ef444438}.vsp-btn.leave{background:var(--danger);color:#fff}.vsp-btn.leave:hover{background:#dc2626}.chat-view{background:var(--bg);flex-direction:column;flex:1;min-width:0;display:flex}.chat-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 18px;display:flex}.chat-title{letter-spacing:-.2px;align-items:center;gap:6px;font-size:15px;font-weight:600;display:flex}.chat-title .hash{color:var(--muted);font-size:18px}.share-button{color:var(--muted);border:1px solid var(--border);border-radius:8px;align-items:center;gap:8px;padding:8px 12px;font-size:13px;font-weight:500;transition:background .18s,color .18s,border-color .18s;display:flex}.share-button:hover{color:var(--text);background:var(--hover)}.share-button.active{color:var(--accent);border-color:var(--accent);background:#6366f114}.share-wrap{border-bottom:1px solid var(--border);overflow:hidden}.chat-messages{flex-direction:column;flex:1;gap:12px;padding:18px 18px 8px;display:flex;overflow-y:auto}.chat-empty{text-align:center;max-width:380px;margin:auto;padding:40px 20px}.chat-empty-mark{background:var(--panel);border:1px solid var(--border);width:56px;height:56px;color:var(--muted);border-radius:16px;justify-content:center;align-items:center;margin:0 auto 14px;font-size:24px;display:flex}.chat-empty h3{letter-spacing:-.3px;margin-bottom:6px;font-size:18px;font-weight:600}.chat-empty p{color:var(--muted);font-size:14px}.msg{border-radius:8px;gap:12px;padding:6px 8px;transition:background .15s;display:flex}.msg:hover{background:var(--panel)}.msg-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:600;display:flex}.msg-body{flex:1;min-width:0}.msg-meta{align-items:baseline;gap:8px;margin-bottom:2px;display:flex}.msg-author{font-size:14px;font-weight:600}.msg-ts{color:var(--muted);font-size:11px}.msg-content{word-wrap:break-word;white-space:pre-wrap;font-size:14px;line-height:1.5}.chat-input{flex-shrink:0;gap:8px;padding:12px 18px 18px;display:flex}.chat-input input{background:var(--panel);border:1px solid var(--border);border-radius:10px;flex:1;padding:12px 14px;font-size:14px;transition:border-color .18s}.chat-input input:focus{border-color:var(--accent)}.chat-input button{background:var(--accent);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:42px;height:42px;transition:background .18s,opacity .18s;display:flex}.chat-input button:hover:not(:disabled){background:var(--accent-hover)}.chat-input button:disabled{opacity:.4;cursor:not-allowed}.quality-wrap{display:inline-flex;position:relative}.quality-pop{background:var(--panel);border:1px solid var(--border);z-index:50;border-radius:12px;width:260px;padding:10px;position:absolute;bottom:calc(100% + 8px);right:0;box-shadow:0 14px 40px #00000080}.quality-pop-title{text-transform:uppercase;letter-spacing:.6px;color:var(--muted);padding:4px 8px 8px;font-size:11px;font-weight:700}.quality-pop-list{flex-direction:column;gap:2px;display:flex}.quality-opt{text-align:left;cursor:pointer;border-radius:8px;align-items:center;gap:10px;width:100%;padding:8px 10px;transition:background .15s;display:flex}.quality-opt:hover{background:var(--hover)}.quality-opt.active{background:#6366f11f}.quality-opt-radio{border:2px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:14px;height:14px;transition:border-color .15s;display:flex}.quality-opt.active .quality-opt-radio{border-color:var(--accent)}.quality-opt-radio .dot{background:var(--accent);border-radius:50%;width:6px;height:6px}.quality-opt-text{flex-direction:column;display:flex}.quality-opt-label{font-size:13px;font-weight:600}.quality-opt-hint{color:var(--muted);font-size:11px}.quality-pop-foot{color:var(--muted);border-top:1px solid var(--border);margin-top:8px;padding:8px 8px 4px;font-size:11px;line-height:1.4}.voice-room{background:var(--bg);flex-direction:column;flex:1;min-width:0;display:flex;position:relative}.voice-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 18px;display:flex}.voice-title{letter-spacing:-.2px;align-items:center;gap:8px;font-size:15px;font-weight:600;display:flex}.voice-title svg{color:var(--muted)}.voice-count{color:var(--muted);background:var(--panel);border:1px solid var(--border);border-radius:999px;margin-left:4px;padding:2px 8px;font-size:11px;font-weight:600}.voice-status{border-radius:6px;align-items:center;gap:8px;padding:5px 10px;font-size:12px;font-weight:500;display:flex}.voice-status.connecting{color:var(--accent);background:#6366f11a}.voice-status.connected{color:var(--success);background:#22c55e1a}.voice-status .dot{background:var(--success);border-radius:50%;width:7px;height:7px;animation:1.6s ease-in-out infinite voice-pulse;box-shadow:0 0 0 4px #22c55e2e}@keyframes voice-pulse{0%,to{box-shadow:0 0 0 4px #22c55e2e}50%{box-shadow:0 0 0 6px #22c55e00}}.spinner{animation:.9s linear infinite spin}.voice-body{flex-direction:column;flex:1;gap:18px;padding:22px 18px 100px;display:flex;overflow-y:auto}.voice-share{border:1px solid var(--border);aspect-ratio:16/9;background:#000;border-radius:12px;width:100%;max-height:60vh;position:relative;overflow:hidden}.voice-share video{object-fit:contain;background:#000;width:100%;height:100%}.voice-share-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;background:#0009;border-radius:8px;align-items:center;gap:8px;padding:6px 10px;font-size:12px;font-weight:600;display:flex;position:absolute;top:12px;left:12px}.voice-share-badge .dot{background:var(--danger);border-radius:50%;width:7px;height:7px;animation:1.4s ease-in-out infinite rec-pulse}.voice-share-volume{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;background:#0009;border-radius:8px;align-items:center;gap:8px;padding:6px 10px;display:flex;position:absolute;bottom:12px;right:12px}.voice-share-volume input[type=range]{width:110px}@keyframes rec-pulse{0%,to{opacity:1}50%{opacity:.4}}.voice-empty{text-align:center;max-width:380px;color:var(--muted);flex-direction:column;align-items:center;margin:auto;padding:40px 24px;display:flex}.voice-empty svg{margin-bottom:12px}.voice-empty h3{color:var(--text);letter-spacing:-.3px;margin-bottom:6px;font-size:17px;font-weight:600}.voice-empty p{margin-bottom:18px;font-size:13px;line-height:1.5}.voice-join-big{background:var(--accent);color:#fff;border-radius:10px;padding:11px 22px;font-size:14px;font-weight:600;transition:background .18s}.voice-join-big:hover{background:var(--accent-hover)}.voice-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;display:grid}.voice-grid.compact{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.voice-grid.compact .voice-tile{padding:14px 8px}.voice-grid.compact .voice-tile-avatar{width:44px;height:44px;font-size:16px}.voice-tile{background:var(--panel);border:1px solid var(--border);border-radius:12px;flex-direction:column;align-items:center;gap:10px;padding:22px 12px;display:flex;position:relative}.voice-tile.self{border-color:var(--accent);box-shadow:0 0 0 1px #6366f166}.voice-tile-avatar{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:18px;font-weight:600;display:flex;position:relative}.voice-tile-avatar.muted{filter:saturate(.6)}.voice-tile-pulse{border:2px solid var(--success);opacity:0;border-radius:50%;animation:2.2s ease-in-out infinite tile-pulse;position:absolute;inset:-4px}@keyframes tile-pulse{0%{opacity:0;transform:scale(.95)}50%{opacity:.5;transform:scale(1.08)}to{opacity:0;transform:scale(1.15)}}.voice-tile-badge{background:var(--danger);border:2px solid var(--bg);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;display:flex;position:absolute;bottom:-2px;right:-2px}.voice-tile-name{text-align:center;word-break:break-word;align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.voice-tile-you{text-transform:uppercase;color:var(--accent);letter-spacing:.4px;background:#6366f11f;border-radius:4px;padding:1px 6px;font-size:10px;font-weight:700}.voice-tile-volume{width:100%;color:var(--muted);align-items:center;gap:6px;padding:0 4px;display:flex}.voice-tile-volume svg{flex-shrink:0}.voice-tile-volume input[type=range]{flex:1;min-width:0}.voice-tile-state{letter-spacing:.4px;text-transform:uppercase;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:600}.voice-tile-state.connecting{color:var(--accent);background:#6366f11f}.voice-tile-state.connected{color:var(--success);background:#22c55e1f}.voice-tile-state.failed{color:var(--danger);background:#ef44441f}input[type=range]{appearance:none;background:var(--border);border-radius:2px;outline:none;height:4px}input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--accent);cursor:pointer;border-radius:50%;width:12px;height:12px;transition:transform .12s}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}input[type=range]::-moz-range-thumb{background:var(--accent);cursor:pointer;border:none;border-radius:50%;width:12px;height:12px}.voice-mic-error{color:var(--danger);text-align:center;background:#ef44441a;border:1px solid #ef44444d;border-radius:10px;padding:10px 14px;font-size:13px}@media (width<=768px){.voice-bar{border-radius:14px;gap:6px;padding:6px;bottom:12px}.ctl{border-radius:10px;width:40px;height:40px}.voice-leave{height:40px;padding:0 12px;font-size:12px}.voice-leave svg{width:14px;height:14px}.voice-bar-spacer{margin:0 2px}.voice-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px}.voice-grid.compact{grid-template-columns:repeat(auto-fill,minmax(90px,1fr))}.voice-tile{padding:14px 8px}.voice-share-volume{padding:4px 8px;bottom:8px;right:8px}.voice-share-volume input[type=range]{width:80px}.voice-body{padding:14px 12px 90px}.quality-pop{width:240px}}.voice-bar{left:50%;bottom:max(18px, env(safe-area-inset-bottom));background:var(--panel);border:1px solid var(--border);z-index:5;border-radius:16px;align-items:center;gap:8px;max-width:calc(100% - 36px);padding:8px;display:flex;position:absolute;transform:translate(-50%);box-shadow:0 12px 32px #00000080}.voice-bar.idle{padding:6px}.voice-bar-spacer{background:var(--border);width:1px;height:28px;margin:0 4px}.ctl{background:var(--panel-2);width:44px;height:44px;color:var(--text);border:1px solid #0000;border-radius:12px;justify-content:center;align-items:center;transition:background .18s,color .18s,transform .18s;display:flex}.ctl:hover{background:var(--hover)}.ctl.off{color:var(--muted)}.ctl.danger{color:var(--danger);background:#ef444426;border-color:#ef44444d}.ctl.danger:hover{background:#ef444438}.ctl.accent{color:var(--accent);background:#6366f12e;border-color:#6366f166}.ctl.accent:hover{background:#6366f140}.voice-leave{background:var(--danger);color:#fff;border-radius:12px;align-items:center;gap:8px;height:44px;padding:0 16px;font-size:13px;font-weight:600;transition:background .18s;display:flex}.voice-leave:hover{background:#dc2626}.voice-join-bar{background:var(--accent);color:#fff;border-radius:12px;padding:12px 24px;font-size:14px;font-weight:600;transition:background .18s}.voice-join-bar:hover{background:var(--accent-hover)}.voice-error{color:var(--danger);background:#ef444426;border:1px solid #ef44444d;border-radius:10px;padding:8px 14px;font-size:13px;font-weight:500;position:absolute;bottom:90px;left:50%;transform:translate(-50%)}.empty-state{background:var(--bg);flex:1;justify-content:center;align-items:center;padding:40px;display:flex}.empty-content{text-align:center;max-width:380px}.empty-content h2{letter-spacing:-.3px;margin-bottom:8px;font-size:22px;font-weight:600}.empty-content p{color:var(--muted);margin-bottom:22px;font-size:14px;line-height:1.5}.empty-action{background:var(--accent);color:#fff;border-radius:10px;padding:10px 18px;font-size:14px;font-weight:600;transition:background .18s}.empty-action:hover{background:var(--accent-hover)}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0000008c;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{background:var(--panel);border:1px solid var(--border);border-radius:14px;width:100%;max-width:380px;padding:24px;box-shadow:0 20px 60px #00000080}.modal h3{letter-spacing:-.2px;margin-bottom:14px;font-size:16px;font-weight:600}.modal input{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;width:100%;margin-bottom:18px;padding:11px 14px;font-size:14px;transition:border-color .18s}.modal input:focus{border-color:var(--accent)}.modal-actions{justify-content:flex-end;gap:8px;display:flex}.modal-actions button{border-radius:8px;padding:9px 16px;font-size:14px;font-weight:600;transition:background .18s,opacity .18s}.modal-cancel{color:var(--muted)}.modal-cancel:hover{background:var(--hover);color:var(--text)}.modal-confirm{background:var(--accent);color:#fff}.modal-confirm:hover:not(:disabled){background:var(--accent-hover)}.modal-confirm:disabled{opacity:.4;cursor:not-allowed}@media (width<=480px){.modal-backdrop{padding:16px}.modal{padding:18px}.modal h3{font-size:15px}.modal input{padding:10px 12px;font-size:13px}}.create-channel-modal{max-width:420px}.cc-types{flex-direction:column;gap:8px;margin-bottom:18px;display:flex}.cc-type{border:1px solid var(--border);background:var(--panel-2);text-align:left;cursor:pointer;border-radius:10px;align-items:center;gap:12px;padding:12px 14px;transition:border-color .18s,background .18s;display:flex}.cc-type:hover{border-color:var(--hover)}.cc-type.active{border-color:var(--accent);background:#6366f114}.cc-type-icon{background:var(--panel);width:32px;height:32px;color:var(--muted);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.cc-type.active .cc-type-icon{color:var(--accent);background:#6366f126}.cc-type-text{flex-direction:column;flex:1;min-width:0;display:flex}.cc-type-label{font-size:14px;font-weight:600}.cc-type-hint{color:var(--muted);font-size:12px}.cc-type-dot{border:2px solid var(--border);border-radius:50%;flex-shrink:0;width:16px;height:16px;transition:all .18s}.cc-type-dot.on{border-color:var(--accent);background:var(--accent);box-shadow:inset 0 0 0 3px var(--panel)}.invite-modal{max-width:460px}.invite-hint{color:var(--muted);margin-bottom:16px;font-size:13px;line-height:1.5}.invite-link{gap:8px;margin-bottom:14px;display:flex}.invite-link input{background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:10px;flex:1;padding:10px 12px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}.invite-copy{background:var(--accent);color:#fff;white-space:nowrap;border-radius:10px;padding:10px 14px;font-size:13px;font-weight:600;transition:background .18s}.invite-copy:hover{background:var(--accent-hover)}.invite-note{color:var(--muted);background:var(--panel-2);border:1px dashed var(--border);border-radius:8px;margin-bottom:18px;padding:10px 12px;font-size:12px;line-height:1.5}.join-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:200;background:#000000a6;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.join-card{background:var(--panel);border:1px solid var(--border);text-align:center;border-radius:16px;width:100%;max-width:400px;padding:32px 28px;box-shadow:0 20px 60px #00000080}.join-icon{color:#fff;border-radius:18px;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 18px;font-size:28px;font-weight:700;display:flex}.join-card h2{color:var(--muted);letter-spacing:.4px;text-transform:uppercase;margin-bottom:6px;font-size:13px;font-weight:500}.join-card h1{letter-spacing:-.4px;margin-bottom:6px;font-size:22px;font-weight:700}.join-meta{color:var(--muted);margin-bottom:22px;font-size:13px}.join-actions{flex-direction:column;gap:8px;display:flex}.join-accept{background:var(--accent);color:#fff;border-radius:10px;padding:12px;font-size:14px;font-weight:600;transition:background .18s}.join-accept:hover{background:var(--accent-hover)}.join-decline{color:var(--muted);border-radius:8px;padding:8px;font-size:13px;transition:color .18s}.join-decline:hover{color:var(--text)}.workspace{width:100%;height:100%;display:flex;position:relative}.workspace-main,.channel-pane{flex:1;min-width:0;height:100%;display:flex}.mobile-hamburger{background:var(--panel);border:1px solid var(--border);width:40px;height:40px;color:var(--text);z-index:60;border-radius:10px;justify-content:center;align-items:center;display:none;position:fixed;top:12px;left:12px;box-shadow:0 6px 16px #0006}.mobile-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:30;opacity:0;pointer-events:none;background:#00000080;transition:opacity .2s;display:none;position:fixed;inset:0}@media (width<=768px){.mobile-hamburger{display:flex}.workspace .server-sidebar,.workspace .channel-sidebar{z-index:40;transition:transform .28s cubic-bezier(.22,1,.36,1);position:fixed;top:0;bottom:0}.workspace .server-sidebar{left:0;transform:translate(-100%)}.workspace .channel-sidebar{width:calc(100vw - 64px);max-width:280px;left:64px;transform:translate(calc(-100% - 64px))}.workspace.mobile-sidebar-open .server-sidebar,.workspace.mobile-sidebar-open .channel-sidebar{transform:translate(0)}.workspace.mobile-sidebar-open .mobile-backdrop{opacity:1;pointer-events:auto;display:block}.workspace .server-sidebar{width:64px}.workspace .workspace-main{width:100%}.chat-header,.voice-header{padding-left:64px}}
