*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;overflow:hidden}body{display:block;min-height:100vh;place-items:unset}a{color:inherit;text-decoration:none}button{font-family:inherit}:root{--bg-primary: #0a0e1a;--bg-secondary: #0f1423;--bg-tertiary: #151b2e;--bg-hover: #1a2238;--bg-active: #1f2942;--bg-floating: #0c1019;--bg-message-hover: rgba(6, 182, 212, .03);--glass-bg: rgba(15, 20, 35, .85);--glass-border: rgba(6, 182, 212, .1);--text-primary: #e2e8f0;--text-secondary: #94a3b8;--text-muted: #475569;--accent: #06b6d4;--accent-hover: #22d3ee;--accent-glow: rgba(6, 182, 212, .3);--accent-subtle: rgba(6, 182, 212, .08);--accent-gradient: linear-gradient(135deg, #06b6d4, #0ea5e9);--amber: #f59e0b;--amber-glow: rgba(245, 158, 11, .25);--success: #10b981;--success-light: #34d399;--success-glow: rgba(16, 185, 129, .3);--danger: #ef4444;--danger-glow: rgba(239, 68, 68, .2);--warning: #f59e0b;--border: rgba(148, 163, 184, .08);--border-strong: rgba(148, 163, 184, .14);--border-glow: rgba(6, 182, 212, .15);--radius: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-low: 0 1px 2px rgba(0, 0, 0, .4);--shadow-med: 0 4px 16px rgba(0, 0, 0, .35);--shadow-high: 0 8px 32px rgba(0, 0, 0, .45);--shadow-glow: 0 0 20px rgba(6, 182, 212, .08);--sidebar-width: 240px;--server-bar-width: 56px;--member-sidebar-width: 200px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);overflow:hidden;height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100vh;max-width:none;margin:0;padding:0;text-align:left}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar-drawer{display:flex;flex-shrink:0}.mobile-menu-btn{display:none;background:none;border:none;color:var(--text-secondary);font-size:1.1rem;padding:.3rem;cursor:pointer;transition:color .15s}.mobile-menu-btn:hover{color:var(--text-primary)}.mobile-menu-btn-empty{position:absolute;top:1rem;left:1rem;z-index:2}.mobile-sidebar-backdrop{display:none}.auth-container{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg-primary);background-image:radial-gradient(ellipse at 15% 80%,rgba(6,182,212,.12) 0%,transparent 50%),radial-gradient(ellipse at 85% 20%,rgba(245,158,11,.06) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(14,165,233,.04) 0%,transparent 60%);position:relative;overflow:hidden}.auth-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:conic-gradient(from 0deg at 50% 50%,transparent 0deg,rgba(6,182,212,.03) 60deg,transparent 120deg,rgba(245,158,11,.02) 180deg,transparent 240deg,rgba(14,165,233,.03) 300deg,transparent 360deg);animation:auroraRotate 30s linear infinite;pointer-events:none}@keyframes auroraRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auth-card{background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:2.5rem;width:100%;max-width:420px;box-shadow:var(--shadow-high),var(--shadow-glow);position:relative;z-index:1}.auth-logo{text-align:center;margin-bottom:2rem}.logo-icon{font-size:3rem;display:block;margin-bottom:.5rem;color:var(--accent);filter:drop-shadow(0 0 12px var(--accent-glow))}.auth-logo h1{font-size:2.2rem;font-weight:700;background:linear-gradient(135deg,var(--accent),var(--amber));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-subtitle{color:var(--text-secondary);font-size:.9rem;margin-top:.25rem}.auth-buttons{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.auth-note{text-align:center;color:var(--text-muted);font-size:.8rem;line-height:1.6}.auth-note i{color:var(--accent)}.btn-back{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:.9rem;margin-bottom:1.5rem;padding:0;transition:color .15s;display:flex;align-items:center;gap:.35rem}.btn-back:hover{color:var(--accent)}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.7rem;color:var(--text-secondary);margin-bottom:.5rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.form-group input,.form-group textarea{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius);padding:.7rem .85rem;color:var(--text-primary);font-size:.95rem;font-family:inherit;outline:none;transition:border-color .25s,box-shadow .25s}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow),0 0 16px #06b6d414}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.form-select{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius);padding:.7rem 2rem .7rem .85rem;color:var(--text-primary);font-size:.95rem;font-family:inherit;outline:none;transition:border-color .25s,box-shadow .25s;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2394a3b8' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center}.form-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow),0 0 16px #06b6d414}.form-select option{background:var(--bg-secondary);color:var(--text-primary)}.error-msg{background:#ef444414;border:1px solid rgba(239,68,68,.18);color:var(--danger);padding:.6rem .85rem;border-radius:var(--radius);font-size:.85rem;margin-bottom:1rem;display:flex;align-items:center;gap:.4rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.65rem 1.1rem;border-radius:var(--radius);font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:all .2s ease;font-family:inherit;position:relative;overflow:hidden}.btn-fa-icon{font-size:.85em}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:0 2px 8px #06b6d433}.btn-primary:hover{box-shadow:0 4px 16px #06b6d459;transform:translateY(-1px);filter:brightness(1.1)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-strong)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-glow)}.btn-small{padding:.4rem .75rem;font-size:.8rem}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text-secondary)}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-hover);border-color:var(--border-strong)}.btn-icon{background:transparent;border:none;border-radius:var(--radius);color:var(--text-muted);width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;transition:all .2s}.btn-icon:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-icon.muted,.btn-icon.btn-danger{color:var(--danger)}.btn-icon.btn-danger:hover{background:var(--danger-glow)}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.modal{background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:1.75rem;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-high),var(--shadow-glow)}.modal h2,.modal h3{margin-bottom:1rem;font-weight:600;color:var(--text-primary)}.modal h3 i{color:var(--accent);margin-right:.35rem}.seed-warning{background:#f59e0b0f;border:1px solid rgba(245,158,11,.15);color:var(--warning);padding:.85rem 1rem;border-radius:var(--radius);font-size:.85rem;margin-bottom:1.25rem;line-height:1.5}.seed-display{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.1rem;margin-bottom:1rem}.seed-identity{text-align:center;font-size:1rem;font-weight:600;color:var(--accent);margin-bottom:.85rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.seed-words{display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem}.seed-word{background:var(--bg-hover);padding:.4rem .65rem;border-radius:6px;font-size:.82rem;font-weight:500;border:1px solid var(--border)}.seed-index{color:var(--text-muted);font-size:.68rem;margin-right:.4rem}.seed-confirm{display:flex;align-items:center;gap:.5rem;margin:1rem 0;font-size:.85rem;color:var(--text-secondary);cursor:pointer}.seed-confirm input[type=checkbox]{accent-color:var(--accent)}.server-bar{width:var(--server-bar-width);min-width:var(--server-bar-width);background:var(--bg-floating);display:flex;flex-direction:column;align-items:center;padding:.5rem 0;gap:.35rem;height:100vh;overflow-y:auto;overflow-x:hidden;border-right:1px solid var(--border);flex-shrink:0}.server-icon{width:42px;height:42px;border-radius:50%;background:var(--bg-tertiary);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;font-weight:700;font-size:1rem;transition:all .2s ease;position:relative;flex-shrink:0;border:2px solid transparent}.server-icon:hover{background:var(--bg-active);color:var(--text-primary);border-radius:35%;border-color:var(--border-glow)}.server-icon.active{background:var(--accent-gradient);color:#fff;border-radius:35%;box-shadow:0 2px 10px #06b6d44d}.server-icon:before{content:"";position:absolute;left:-10px;width:3px;border-radius:0 4px 4px 0;background:var(--accent);transition:height .2s ease,opacity .2s ease;height:0;opacity:0}.server-icon:hover:before{height:8px;opacity:.5}.server-icon.active:before{height:70%;opacity:1;box-shadow:0 0 8px var(--accent-glow)}.server-icon.dm-icon{background:var(--bg-tertiary);color:var(--accent);font-size:1.1rem}.server-icon.dm-icon.active{background:var(--accent-gradient);color:#fff}.server-icon.add-server{color:var(--success)}.server-icon.add-server:hover{background:#10b9811a;border-color:#10b98133;color:var(--success-light)}.server-icon.discover-server{color:var(--amber)}.server-icon.discover-server:hover{background:#f59e0b1a;border-color:#f59e0b33;color:var(--amber)}.server-icon.join-invite{color:var(--text-muted)}.server-icon.join-invite:hover{color:var(--accent)}.server-separator{width:28px;height:2px;background:var(--border-strong);border-radius:1px;margin:.15rem 0;flex-shrink:0}.channel-sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--bg-secondary);display:flex;flex-direction:column;height:100vh;border-right:1px solid var(--border);position:relative}.channel-sidebar:after{content:"";position:absolute;right:0;top:0;width:1px;height:100%;background:linear-gradient(180deg,transparent 0%,rgba(6,182,212,.15) 30%,rgba(245,158,11,.08) 60%,rgba(6,182,212,.1) 80%,transparent 100%)}.sidebar-header{height:52px;padding:0 1rem;display:flex;align-items:center;justify-content:space-between;gap:.6rem;flex-shrink:0;border-bottom:1px solid var(--border)}.server-name-header{font-weight:700;font-size:1rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.logo-icon-sm{font-size:1.2rem;color:var(--accent);filter:drop-shadow(0 0 6px var(--accent-glow))}.app-name{font-weight:700;font-size:1.1rem;background:linear-gradient(135deg,var(--accent),var(--amber));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-content{flex:1;overflow-y:auto;padding-top:.5rem}.channel-section{margin-bottom:.15rem}.channel-section-header{padding:1rem .75rem .35rem .85rem;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);cursor:default;transition:color .15s;display:flex;align-items:center;gap:.3rem}.channel-section-header:hover{color:var(--text-secondary)}.section-arrow{font-size:.5rem;transition:transform .2s}.channel-list{padding:0 .5rem}.channel-item{display:flex;align-items:center;gap:.45rem;padding:.4rem .6rem;border-radius:var(--radius);cursor:pointer;transition:all .15s ease;margin-bottom:1px;color:var(--text-muted);position:relative}.channel-item:hover{background:var(--bg-hover);color:var(--text-secondary)}.channel-item.active{background:var(--accent-subtle);color:var(--text-primary)}.channel-item.voice-active{color:var(--success-light);background:#10b9810f}.channel-item:before{content:"";position:absolute;left:-8px;width:3px;border-radius:0 4px 4px 0;background:var(--accent);transition:height .2s ease,opacity .2s ease;height:0;opacity:0}.channel-item:hover:before{height:8px;opacity:.4}.channel-item.active:before{height:70%;opacity:1;box-shadow:0 0 8px var(--accent-glow)}.channel-icon{color:var(--text-muted);font-size:.95rem;width:20px;text-align:center;flex-shrink:0;transition:color .15s}.channel-item.active .channel-icon{color:var(--accent)}.channel-item:hover .channel-icon{color:var(--text-secondary)}.channel-item.voice-active .channel-icon{color:var(--success-light)}.channel-name{font-size:.88rem;font-weight:500;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-actions{padding:.5rem;display:flex;flex-direction:column;gap:.2rem;border-top:1px solid var(--border);margin-top:.25rem}.sidebar-actions .btn{background:transparent;color:var(--text-muted);font-size:.78rem;padding:.4rem .65rem;justify-content:flex-start;border-radius:var(--radius);border:none;gap:.4rem}.sidebar-actions .btn:hover{background:var(--bg-hover);color:var(--accent)}.create-room-form{padding:.25rem .5rem .5rem;display:flex;gap:.35rem}.create-room-form input{flex:1;background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius);padding:.375rem .65rem;color:var(--text-primary);font-size:.85rem;outline:none;font-family:inherit;transition:border-color .25s,box-shadow .25s}.create-room-form input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}.create-room-form input::placeholder{color:var(--text-muted)}.sidebar-footer{padding:.55rem .65rem;background:var(--bg-floating);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;border-top:1px solid var(--border)}.user-info{display:flex;align-items:center;gap:.5rem;min-width:0;flex:1}.user-avatar-wrapper{position:relative;flex-shrink:0}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-gradient);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.82rem;box-shadow:0 2px 6px #06b6d433}.status-dot{position:absolute;bottom:-1px;right:-1px;width:10px;height:10px;border-radius:50%;border:2.5px solid var(--bg-floating);background:var(--text-muted)}.status-dot.online{background:var(--success);box-shadow:0 0 6px var(--success-glow)}.user-details{display:flex;flex-direction:column;min-width:0}.user-name{font-size:.82rem;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-tag{font-size:.68rem;color:var(--text-muted)}.dm-search{padding-bottom:.25rem;border-bottom:1px solid var(--border);margin-bottom:.25rem}.dm-search-results{padding:.25rem .5rem .5rem;display:flex;flex-direction:column;gap:.2rem;max-height:200px;overflow-y:auto}.dm-search-result-item{display:flex;align-items:center;gap:.5rem;padding:.4rem .6rem;border-radius:var(--radius);cursor:pointer;font-size:.85rem;color:var(--text-secondary);transition:all .15s}.dm-search-result-item:hover{background:var(--bg-hover);color:var(--text-primary)}.dm-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-gradient);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.82rem;flex-shrink:0}.dm-avatar-small{width:24px;height:24px;border-radius:50%;background:var(--bg-active);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.62rem;flex-shrink:0}.dm-tag{font-size:.68rem;color:var(--text-muted);margin-left:auto;flex-shrink:0}.member-sidebar{width:var(--member-sidebar-width);min-width:var(--member-sidebar-width);background:var(--bg-secondary);display:flex;flex-direction:column;height:100vh;border-left:1px solid var(--border);flex-shrink:0}.member-sidebar-header{height:52px;padding:0 .85rem;display:flex;align-items:center;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);flex-shrink:0;border-bottom:1px solid var(--border)}.member-sidebar-content{flex:1;overflow-y:auto;padding:.5rem 0}.member-section-header{padding:.75rem .75rem .35rem .85rem;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted)}.member-item{display:flex;align-items:center;gap:.5rem;padding:.35rem .65rem;margin:0 .35rem;border-radius:var(--radius);cursor:pointer;transition:all .15s ease}.member-item:hover{background:var(--bg-hover)}.member-avatar{width:28px;height:28px;border-radius:50%;background:var(--bg-active);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.68rem;flex-shrink:0}.member-info{display:flex;flex-direction:column;min-width:0;flex:1}.member-name{font-size:.82rem;font-weight:500;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-name.owner{color:var(--amber)}.member-tag{font-size:.62rem;color:var(--text-muted)}.voice-section{margin-top:.15rem}.voice-channel-item{display:flex;align-items:center;gap:.45rem;padding:.4rem .6rem;margin:0 .5rem;border-radius:var(--radius);cursor:pointer;transition:all .15s ease;font-size:.88rem;font-weight:500;color:var(--text-muted)}.voice-channel-item:hover{background:var(--bg-hover);color:var(--text-secondary)}.voice-channel-item.active{color:var(--success-light);background:#10b9810f;cursor:default}.voice-channel-icon{font-size:1.05rem;width:20px;text-align:center;flex-shrink:0}.voice-channel-name{flex:1}.voice-pulse-sm{width:8px;height:8px;border-radius:50%;background:var(--success);animation:voicePulse 1.5s ease-in-out infinite;box-shadow:0 0 4px var(--success-glow)}@keyframes voicePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.7)}}.voice-users-list{padding:.15rem 0 .15rem 1.6rem}.voice-user-item{display:flex;align-items:center;gap:.4rem;padding:.2rem .45rem;border-radius:6px;font-size:.8rem;color:var(--text-muted);transition:all .15s ease}.voice-user-item:hover{background:var(--bg-hover);color:var(--text-secondary)}.voice-user-item.speaking{color:var(--success-light)}.voice-user-avatar{width:24px;height:24px;border-radius:50%;background:var(--bg-active);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.6rem;flex-shrink:0;border:2px solid transparent;transition:border-color .3s,box-shadow .3s}.voice-user-avatar.speaking{border-color:var(--success);box-shadow:0 0 10px var(--success-glow)}.voice-user-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.voice-user-dot{width:7px;height:7px;border-radius:50%;background:var(--text-muted);flex-shrink:0;transition:all .3s ease}.voice-user-dot.speaking{background:var(--success);box-shadow:0 0 8px var(--success-glow);animation:speakGlow .7s ease-in-out infinite alternate}@keyframes speakGlow{0%{box-shadow:0 0 4px #10b9814d;transform:scale(1)}to{box-shadow:0 0 12px #10b981b3;transform:scale(1.2)}}.voice-user-muted-icon{font-size:.65rem;color:var(--danger);opacity:.7;flex-shrink:0}.voice-status-panel{padding:.5rem .65rem;background:#10b9810f;border-top:1px solid rgba(16,185,129,.12);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:.5rem}.voice-status-info{display:flex;flex-direction:column;gap:.1rem;min-width:0;flex:1}.voice-connected-label{font-size:.78rem;font-weight:600;color:var(--success-light);display:flex;align-items:center;gap:.35rem}.voice-connected-icon{font-size:.72rem;animation:voicePulse 1.5s ease-in-out infinite}.voice-status-channel{font-size:.7rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.voice-controls-sidebar{display:flex;align-items:center;gap:.3rem}.btn-icon-sm{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.82rem;transition:all .2s ease}.btn-icon-sm:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-strong);transform:translateY(-1px)}.btn-icon-sm.muted{color:var(--danger);border-color:#ef444440;background:#ef44440f}.btn-icon-sm.muted:hover{background:#ef44441f}.btn-icon-sm.danger{color:var(--danger)}.btn-icon-sm.danger:hover{background:#ef44441a;border-color:#ef444440}.invite-create-section{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:1rem}.invite-create-section .form-group{margin-bottom:.5rem}.invite-code-display{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.65rem .85rem;background:#10b9810f;border:1px solid rgba(16,185,129,.15);border-radius:var(--radius);margin-bottom:1rem}.invite-code{font-size:1.1rem;font-weight:700;color:var(--success-light);font-family:Fira Code,Cascadia Code,monospace;letter-spacing:.05em}.invite-list{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.5rem}.invite-list-item{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem .65rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);transition:all .15s}.invite-list-item:hover{border-color:var(--border-strong)}.invite-item-info{display:flex;flex-direction:column;gap:.1rem;min-width:0;flex:1}.invite-item-code{font-size:.85rem;font-weight:600;color:var(--text-primary);font-family:Fira Code,Cascadia Code,monospace}.invite-item-meta{font-size:.68rem;color:var(--text-muted)}.chat-container{flex:1;display:flex;flex-direction:column;height:100vh;background:var(--bg-primary);min-width:0}.chat-empty{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);background-image:radial-gradient(ellipse at 40% 60%,rgba(6,182,212,.04) 0%,transparent 50%),radial-gradient(ellipse at 70% 30%,rgba(245,158,11,.02) 0%,transparent 50%)}.chat-empty-content{text-align:center;color:var(--text-secondary)}.empty-icon{font-size:3.5rem;display:block;margin-bottom:1rem;color:var(--accent);filter:drop-shadow(0 0 16px var(--accent-glow))}.chat-empty-content h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.chat-empty-content p{color:var(--text-muted);font-size:.9rem;max-width:360px;line-height:1.5}.chat-header{height:52px;padding:0 1.25rem;display:flex;align-items:center;justify-content:space-between;background:var(--bg-primary);border-bottom:1px solid var(--border);z-index:1;flex-shrink:0}.chat-header-info{display:flex;align-items:center;gap:.5rem}.room-icon-large{color:var(--text-muted);font-size:1.1rem}.chat-header h3{font-size:1rem;font-weight:600;color:var(--text-primary)}.member-badge{font-size:.72rem;color:var(--text-muted);padding-left:.75rem;border-left:1px solid var(--border-strong);margin-left:.25rem;display:flex;align-items:center;gap:.3rem}.chat-header-right{display:flex;align-items:center;gap:.5rem}.encryption-badge{font-size:.68rem;color:var(--success);background:#10b9810f;border:1px solid rgba(16,185,129,.12);padding:.2rem .6rem;border-radius:999px;font-weight:600;cursor:help;display:flex;align-items:center;gap:.3rem;transition:all .2s}.encryption-badge:hover{background:#10b9811a;box-shadow:0 0 10px #10b9811a}.chat-messages{flex:1;overflow-y:auto;padding:1rem 0;display:flex;flex-direction:column}.loading-spinner,.no-messages{display:flex;align-items:center;justify-content:center;gap:.5rem;height:100%;color:var(--text-muted);font-size:.9rem}.message{padding:.15rem 1.25rem;transition:background-color .1s}.message:hover{background:var(--bg-message-hover)}.message.with-header{margin-top:1rem;padding-top:.15rem}.message-header{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.1rem}.message-author{font-weight:600;font-size:.9rem;color:var(--text-primary)}.message-author.me{color:var(--accent)}.message-time{font-size:.68rem;color:var(--text-muted)}.message-body{display:flex;align-items:flex-start;gap:.5rem}.message-content{font-size:.9rem;line-height:1.45;color:var(--text-secondary);word-break:break-word;flex:1}.message-actions{opacity:0;display:flex;align-items:center;gap:.2rem;transition:opacity .15s;flex-shrink:0}.message:hover .message-actions{opacity:1}.reply-btn{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.75rem;transition:all .15s}.reply-btn:hover{background:var(--bg-hover);color:var(--accent);border-color:var(--accent)}.replied-message-preview{display:flex;align-items:center;gap:.4rem;padding:.3rem .6rem;margin-bottom:.3rem;border-left:2px solid var(--accent);background:var(--accent-subtle);border-radius:0 var(--radius) var(--radius) 0;font-size:.78rem;cursor:pointer;transition:background .15s;max-width:400px;overflow:hidden}.replied-message-preview:hover{background:#06b6d41f}.replied-sender{color:var(--accent);font-weight:600;white-space:nowrap;flex-shrink:0}.replied-text{color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.message.highlight{animation:msgHighlight 1.5s ease-out}@keyframes msgHighlight{0%{background:#06b6d426}to{background:transparent}}.reply-preview-bar{display:flex;align-items:center;justify-content:space-between;padding:.45rem .75rem;margin-bottom:.4rem;background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius);border-left:3px solid var(--accent);animation:slideDown .15s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.reply-preview-content{display:flex;align-items:center;gap:.4rem;min-width:0;flex:1;font-size:.8rem;color:var(--text-muted)}.reply-preview-content>i{color:var(--accent);flex-shrink:0}.reply-preview-sender{color:var(--accent);font-weight:600;white-space:nowrap;flex-shrink:0}.reply-preview-text{color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reply-preview-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.2rem;font-size:.85rem;transition:color .15s;flex-shrink:0}.reply-preview-close:hover{color:var(--text-primary)}.image-message{cursor:pointer;border-radius:var(--radius);overflow:hidden;max-width:300px;background:var(--bg-tertiary);border:1px solid var(--border);transition:border-color .15s}.image-message:hover{border-color:var(--accent)}.image-message img{display:block;border-radius:var(--radius) var(--radius) 0 0;object-fit:cover}.image-caption{padding:.4rem .5rem .15rem;font-size:.85rem;color:var(--text-secondary);line-height:1.4;word-break:break-word}.image-meta{padding:.25rem .5rem;font-size:.68rem;color:var(--text-muted)}.image-loading{width:200px;height:120px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:1.2rem}.image-preview-bar{display:flex;align-items:center;gap:.6rem;padding:.45rem .75rem;margin-bottom:.4rem;background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius);animation:slideDown .15s ease-out}.image-preview-thumb{width:40px;height:40px;border-radius:6px;object-fit:cover;flex-shrink:0}.image-preview-info{display:flex;flex-direction:column;min-width:0;flex:1}.image-preview-name{font-size:.8rem;color:var(--text-primary);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.image-preview-size{font-size:.68rem;color:var(--text-muted)}.image-preview-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.2rem;font-size:.85rem;transition:color .15s;flex-shrink:0}.image-preview-close:hover{color:var(--danger)}.lightbox-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:200;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);cursor:pointer}.lightbox-content{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:var(--radius-lg);box-shadow:var(--shadow-high);cursor:default}.lightbox-close{position:fixed;top:1rem;right:1rem;background:#ffffff1a;border:none;color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem;transition:background .15s;z-index:201}.lightbox-close:hover{background:#fff3}.chat-input-wrapper{padding:0 1rem .75rem;flex-shrink:0}.chat-input-bar{display:flex;align-items:flex-end;gap:0;background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius-xl);padding:.35rem;transition:border-color .3s,box-shadow .3s,background .3s}.chat-input-bar:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #06b6d41a,0 4px 20px #06b6d40f;background:var(--bg-hover)}.chat-input-bar.has-text{border-color:#06b6d433}.input-action-btn{width:36px;height:36px;border-radius:50%;border:none;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0;transition:all .2s}.input-action-btn:hover{background:var(--bg-active);color:var(--text-primary)}.input-action-btn:active{transform:scale(.9)}.input-action-btn.emoji-toggle.active{color:var(--accent);background:var(--accent-subtle)}.chat-input-bar textarea{flex:1;background:transparent;border:none;padding:.5rem .4rem;color:var(--text-primary);font-size:.9rem;font-family:inherit;outline:none;resize:none;max-height:160px;min-height:22px;line-height:1.4}.chat-input-bar textarea::placeholder{color:var(--text-muted)}.input-actions-right{display:flex;align-items:flex-end;gap:.15rem;flex-shrink:0}.char-counter{font-size:.65rem;font-weight:600;padding:.15rem .35rem;border-radius:6px;align-self:center;font-variant-numeric:tabular-nums;transition:all .2s}.char-counter.warn{color:var(--warning);background:#f59e0b14}.char-counter.danger{color:var(--danger);background:#ef444414;animation:counterPulse .8s ease-in-out infinite alternate}@keyframes counterPulse{0%{opacity:.7}to{opacity:1}}.send-btn{width:36px;height:36px;border-radius:50%;border:none;background:var(--accent-gradient);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0;transition:all .3s cubic-bezier(.34,1.56,.64,1);transform:scale(0) rotate(-45deg);opacity:0;width:0;padding:0;margin:0;overflow:hidden;box-shadow:0 2px 8px #06b6d440}.send-btn.visible{transform:scale(1) rotate(0);opacity:1;width:36px;margin-left:.15rem}.send-btn:hover{box-shadow:0 4px 16px #06b6d466;transform:scale(1.08) rotate(0);filter:brightness(1.15)}.send-btn:active{transform:scale(.92) rotate(0)}.input-hint{display:flex;gap:.75rem;padding:.3rem .6rem 0;font-size:.62rem;color:var(--text-muted);opacity:.5}.input-hint kbd{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:3px;padding:0 .3rem;font-family:inherit;font-size:.6rem;margin-right:.15rem}.emoji-picker-wrapper{position:relative}.emoji-picker{position:absolute;bottom:calc(100% + 8px);right:0;width:320px;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-high),0 0 30px #06b6d40d;overflow:hidden;animation:emojiSlideUp .2s ease-out;z-index:50}@keyframes emojiSlideUp{0%{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.emoji-tabs{display:flex;gap:0;padding:.35rem .35rem 0;border-bottom:1px solid var(--border)}.emoji-tab{flex:1;background:none;border:none;border-bottom:2px solid transparent;padding:.4rem .2rem;font-size:1.1rem;cursor:pointer;border-radius:6px 6px 0 0;transition:all .15s;display:flex;align-items:center;justify-content:center}.emoji-tab:hover{background:var(--bg-hover)}.emoji-tab.active{border-bottom-color:var(--accent);background:var(--accent-subtle)}.emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:0;padding:.5rem .35rem;max-height:200px;overflow-y:auto}.emoji-item{background:none;border:none;font-size:1.25rem;padding:.3rem;cursor:pointer;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;transition:all .1s}.emoji-item:hover{background:var(--bg-hover);transform:scale(1.2)}.emoji-item:active{transform:scale(.95)}.emoji-footer{padding:.3rem .6rem;font-size:.65rem;color:var(--text-muted);border-top:1px solid var(--border);text-transform:uppercase;letter-spacing:.04em;font-weight:600}.room-browse-list{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem;max-height:300px;overflow-y:auto}.room-browse-item{display:flex;align-items:center;justify-content:space-between;padding:.65rem .85rem;background:var(--bg-tertiary);border-radius:var(--radius);border:1px solid var(--border);transition:all .15s}.room-browse-item:hover{background:var(--bg-hover);border-color:var(--border-glow)}.member-count{font-size:.72rem;color:var(--text-muted)}.empty-text{text-align:center;color:var(--text-muted);padding:2rem;font-size:.85rem}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-active);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}*{scrollbar-width:thin;scrollbar-color:var(--bg-active) transparent}::selection{background:#06b6d440;color:var(--text-primary)}.auth-card{animation:fadeInUp .4s ease-out}.modal{animation:fadeInScale .25s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media(max-width:1024px){.member-sidebar{display:none}}@media(max-width:768px){.mobile-menu-btn{display:flex;align-items:center;justify-content:center}.sidebar-drawer{position:fixed;left:0;top:0;height:100vh;z-index:90;transform:translate(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);box-shadow:none}.app-layout.sidebar-open .sidebar-drawer{transform:translate(0);box-shadow:4px 0 24px #00000080}.app-layout.sidebar-open .mobile-sidebar-backdrop{display:block;position:fixed;inset:0;background:#0000008c;z-index:89;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.channel-sidebar{width:220px;min-width:220px}.member-sidebar{display:none}.chat-container{width:100%}.chat-header{padding:0 .75rem}.message{padding:.15rem .75rem}.chat-input-wrapper{padding:0 .5rem .5rem}.input-hint{display:none}.emoji-picker{position:fixed;bottom:0;left:0;right:0;width:100%;border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:50vh;animation:emojiSlideUpMobile .25s ease-out}@keyframes emojiSlideUpMobile{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.auth-card{margin:1rem;padding:1.5rem}.modal{width:95%;max-height:85vh;padding:1.25rem}.image-message{max-width:240px}.lightbox-content{max-width:95vw;max-height:85vh}.replied-message-preview{max-width:100%}.seed-words{grid-template-columns:repeat(2,1fr)}.server-bar{width:48px;min-width:48px}.server-icon{width:36px;height:36px;font-size:.9rem}.server-icon:before{left:-7px}.server-separator{width:24px}.chat-empty-content h2{font-size:1.2rem}.chat-empty-content p{font-size:.82rem;padding:0 1rem}.empty-icon{font-size:2.5rem}}@media(max-width:480px){.chat-header h3{font-size:.88rem}.encryption-badge{font-size:.6rem;padding:.15rem .45rem}.chat-input-bar textarea,.message-content,.message-author{font-size:.85rem}.auth-card{padding:1.25rem}.auth-logo h1{font-size:1.8rem}.logo-icon{font-size:2.5rem}}@media(hover:none)and (pointer:coarse){.message-actions{opacity:.7}.channel-item{padding:.55rem .6rem}.member-item{padding:.5rem .65rem}.voice-user-item{padding:.3rem .45rem}.dm-search-result-item{padding:.55rem .6rem}.btn-primary:hover,.btn-icon-sm:hover{transform:none}.reply-btn{width:32px;height:32px;font-size:.85rem}}
