*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base: #0E1015;--bg-surface: #1C1E26;--bg-elevated: #252730;--bg-hover: #2E3140;--accent-cyan: #00E5FF;--accent-purple:#B958FF;--accent-green: #00FF9C;--text-primary: #E8EAF0;--text-secondary:#8B9BB4;--text-muted: #4A526A;--border: #2A2D3A;--danger: #FF4E6A;--online: #00FF9C;--offline: #4A526A;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--font-ui: "Inter", sans-serif;--font-display: "Space Grotesk", sans-serif}html,body,#root{height:100%;background:#0e1015;color:#e8eaf0;font-family:Inter,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:var(--radius-md);font-family:var(--font-ui);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease;text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--accent-cyan),var(--accent-purple));color:#0e1015;font-weight:600}.btn-primary:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px)}.btn-ghost{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--bg-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){filter:brightness(1.1)}.btn-sm{padding:6px 12px;font-size:12px}.btn-icon{padding:8px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all .15s}.btn-icon:hover{background:var(--bg-hover);color:var(--text-primary)}.input{width:100%;padding:11px 14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-ui);font-size:14px;outline:none;transition:border-color .15s}.input::placeholder{color:var(--text-muted)}.input:focus{border-color:var(--accent-cyan)}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:12px;font-weight:500;color:var(--text-secondary);letter-spacing:.05em;text-transform:uppercase}.form-error{font-size:12px;color:var(--danger)}.divider{display:flex;align-items:center;gap:12px;color:var(--text-muted);font-size:12px}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border)}.status-dot{width:9px;height:9px;border-radius:50%;border:2px solid var(--bg-surface);flex-shrink:0}.status-dot.online{background:var(--online)}.status-dot.offline{background:var(--offline)}.avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--accent-purple),var(--accent-cyan));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;color:var(--bg-base);flex-shrink:0;position:relative}.avatar.lg{width:48px;height:48px;font-size:18px}.avatar.sm{width:32px;height:32px;font-size:12px}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent-cyan);border-radius:50%;animation:spin .7s linear infinite}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--accent-purple);color:#fff;font-size:11px;font-weight:600;flex-shrink:0}.auth-page{height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:#0d0b1e}.auth-bg-image{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center center;z-index:0;display:block}.auth-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#08061485;z-index:1;pointer-events:none}.auth-panel-right{position:relative;z-index:2;width:100%;display:flex;align-items:center;justify-content:center;padding:24px 16px;overflow-y:auto;max-height:100vh}.auth-inner{width:100%;max-width:420px;display:flex;flex-direction:column;gap:20px;background:#0e0b1eb8;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:36px 32px;backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);box-shadow:0 2px #ffffff0a inset,0 24px 64px #0000008c}.auth-logo{display:flex;align-items:center;gap:11px;justify-content:center}.auth-logo img{width:40px;height:40px;object-fit:contain}.auth-logo-wordmark h1{font-family:var(--font-display);font-size:17px;font-weight:700;letter-spacing:5px;color:#ede8ff;line-height:1}.auth-logo-wordmark p{font-size:10.5px;color:#ffffff47;letter-spacing:.05em;margin-top:3px}.auth-heading{text-align:center}.auth-heading h2{font-family:var(--font-display);font-size:21px;font-weight:700;color:#ede8ff;margin-bottom:6px;letter-spacing:.01em}.auth-heading h2 span{background:linear-gradient(90deg,#a78bfa,#818cf8);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.auth-heading p{font-size:13px;color:#ffffff52}.auth-form{display:flex;flex-direction:column;gap:11px}.input-icon-wrap{position:relative}.input-icon-wrap .input-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:#ffffff38;width:15px;height:15px;pointer-events:none}.input-icon-wrap .input{width:100%;padding:12px 14px 12px 42px;font-size:13.5px;background:#ffffff0d;border:1px solid rgba(255,255,255,.09);border-radius:9px;color:#ddd8f8;outline:none;font-family:var(--font-ui);transition:border-color .15s,background .15s}.input-icon-wrap .input::placeholder{color:#fff3}.input-icon-wrap .input:focus{border-color:#7289da8c;background:#ffffff12}.input-icon-wrap .input-icon-right{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:#ffffff38;cursor:pointer;background:none;border:none;padding:0;display:flex;align-items:center;transition:color .15s}.input-icon-wrap .input-icon-right:hover{color:#ffffff8c}.input-icon-wrap .input-with-right-icon{padding-right:42px}.auth-row{display:flex;align-items:center;justify-content:space-between;font-size:12.5px}.auth-checkbox{display:flex;align-items:center;gap:7px;color:#ffffff52;cursor:pointer;-webkit-user-select:none;user-select:none}.auth-checkbox input[type=checkbox]{accent-color:#7289da;width:14px;height:14px}.btn-auth{width:100%;padding:13px;border:none;border-radius:9px;background:#5865f2;color:#fff;font-family:var(--font-ui);font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .15s,transform .12s;letter-spacing:.01em}.btn-auth:hover:not(:disabled){background:#4752c4;transform:translateY(-1px)}.btn-auth:active:not(:disabled){transform:translateY(0)}.btn-auth:disabled{opacity:.38;cursor:not-allowed}.auth-divider{display:flex;align-items:center;gap:10px;color:#ffffff2e;font-size:11px;letter-spacing:.04em}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#ffffff12}.auth-alt-btns{display:grid;grid-template-columns:1fr 1fr;gap:9px}.btn-alt{padding:10px 8px;border:1px solid rgba(255,255,255,.08);border-radius:9px;background:#ffffff0a;color:#ffffff61;font-family:var(--font-ui);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;transition:background .15s,border-color .15s,color .15s}.btn-alt:hover{background:#ffffff14;border-color:#ffffff26;color:#ffffffa6}.auth-footer{text-align:center;font-size:12.5px;color:#ffffff47}.auth-link{color:#7289da;font-weight:600;text-decoration:none;transition:color .15s}.auth-link:hover{color:#a78bfa}.form-error{font-size:12px;color:#f87171;text-align:center;padding:9px 12px;background:#f8717114;border:1px solid rgba(248,113,113,.16);border-radius:8px}.otp-inputs{display:flex;gap:10px;justify-content:center}.otp-input{width:50px;height:58px;text-align:center;font-size:24px;font-weight:700;font-family:var(--font-display);background:#ffffff0d;border:1px solid rgba(255,255,255,.09);border-radius:9px;color:#ddd8f8;outline:none;transition:border-color .15s}.otp-input:focus{border-color:#7289da8c}@media (max-width: 500px){.auth-inner{padding:28px 20px;border-radius:14px;margin:12px}}.chat-area{display:flex;flex-direction:column;height:100%;overflow:hidden}.chat-header{padding:14px 20px;border-bottom:1px solid var(--border);background:var(--bg-surface);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.messages-container{flex:1;overflow-y:auto;padding:20px 20px 8px;display:flex;flex-direction:column;gap:4px}.messages-loading,.messages-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:14px}.date-divider{display:flex;align-items:center;gap:12px;margin:16px 0 8px;color:var(--text-muted);font-size:11px;letter-spacing:.06em;text-transform:uppercase}.date-divider:before,.date-divider:after{content:"";flex:1;height:1px;background:var(--border)}.message-row{display:flex;align-items:flex-end;gap:8px;margin-bottom:2px}.message-row.mine{flex-direction:row-reverse}.message-bubble{max-width:65%;padding:9px 13px;border-radius:16px;display:flex;flex-direction:column;gap:3px;word-break:break-word}.message-bubble.mine{background:linear-gradient(135deg,#00e5ff2e,#b958ff2e);border:1px solid rgba(0,229,255,.2);border-bottom-right-radius:4px;align-items:flex-end}.message-bubble.theirs{background:var(--bg-surface);border:1px solid var(--border);border-bottom-left-radius:4px;align-items:flex-start}.message-text{font-size:14px;line-height:1.5;color:var(--text-primary);white-space:pre-wrap}.message-time{font-size:10px;color:var(--text-muted);flex-shrink:0}.chat-input-bar{padding:12px 16px;border-top:1px solid var(--border);background:var(--bg-surface);display:flex;align-items:flex-end;gap:10px;flex-shrink:0}.chat-textarea{flex:1;padding:10px 14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:22px;color:var(--text-primary);font-family:var(--font-ui);font-size:14px;outline:none;resize:none;line-height:1.5;max-height:120px;overflow-y:auto;transition:border-color .15s}.chat-textarea::placeholder{color:var(--text-muted)}.chat-textarea:focus{border-color:#00e5ff66}.send-btn{width:40px;height:40px;border-radius:50%;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.send-btn.active{background:linear-gradient(135deg,var(--accent-cyan),var(--accent-purple));border-color:transparent;color:var(--bg-base)}.send-btn:disabled{cursor:not-allowed;opacity:.5}.send-btn.active:hover{filter:brightness(1.1);transform:scale(1.05)}.chat-search-bar{display:flex;align-items:center;gap:8px;padding:8px 16px;border-bottom:1px solid var(--border);background:var(--bg-elevated);flex-shrink:0}.chat-search-input{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:13px;font-family:var(--font-ui)}.chat-search-input::placeholder{color:var(--text-muted)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.btn-icon.active{background:#00e5ff1a;color:var(--accent-cyan)}.feed-layout{display:flex;flex-direction:column;height:100%;overflow:hidden}.feed-header{padding:20px 28px 16px;border-bottom:1px solid rgba(255,255,255,.05);flex-shrink:0}.feed-title{font-size:17px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.feed-scroll{flex:1;overflow-y:auto;padding:24px 28px;max-width:680px;width:100%}.compose-card{display:flex;gap:14px;padding:18px;background:#1c1e28;border:1px solid rgba(255,255,255,.07);border-radius:14px;margin-bottom:24px}.compose-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#3d4870,#5a6490);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--text-primary);flex-shrink:0}.compose-body{flex:1;min-width:0}.compose-input{width:100%;background:transparent;border:none;outline:none;color:var(--text-primary);font-family:var(--font-ui);font-size:14px;line-height:1.6;resize:none;padding:0;placeholder-color:var(--text-muted)}.compose-input::placeholder{color:var(--text-muted)}.compose-footer{display:flex;align-items:center;justify-content:space-between;margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.05)}.compose-hint{font-size:11px;color:var(--text-muted)}.compose-btn{padding:7px 18px;border-radius:8px;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-muted);font-size:13px;font-weight:600;font-family:var(--font-ui);cursor:pointer;transition:all .15s}.compose-btn.ready{background:var(--text-primary);border-color:transparent;color:var(--bg-base)}.compose-btn:disabled{cursor:not-allowed;opacity:.5}.compose-btn.ready:hover{opacity:.88}.feed-divider{display:flex;align-items:center;gap:12px;margin-bottom:20px;color:var(--text-muted);font-size:11px;letter-spacing:.06em;text-transform:uppercase}.feed-divider:before,.feed-divider:after{content:"";flex:1;height:1px;background:#ffffff0d}.posts-list{display:flex;flex-direction:column;gap:2px}.post-card{display:flex;gap:14px;padding:18px;border-radius:12px;background:transparent;border:1px solid transparent;transition:all .15s;cursor:pointer}.post-card:hover{background:#ffffff05;border-color:#ffffff0a}.post-author-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#3d4870,#5a6490);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--text-primary);flex-shrink:0}.post-body{flex:1;min-width:0}.post-header{display:flex;align-items:baseline;gap:6px;margin-bottom:8px;flex-wrap:wrap}.post-author-name{font-size:13px;font-weight:700;color:var(--text-primary)}.post-author-handle,.post-dot,.post-time{font-size:12px;color:var(--text-muted)}.post-content{font-size:14px;line-height:1.65;color:var(--text-primary);margin-bottom:14px;white-space:pre-wrap;word-break:break-word}.post-actions{display:flex;gap:20px}.post-action{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-muted);font-size:12px;font-family:var(--font-ui);cursor:pointer;padding:4px 0;transition:color .12s;font-weight:500}.post-action:hover{color:var(--text-secondary)}.post-action.liked{color:#e85455}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0c12bf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal-card{background:var(--bg-surface);border:1px solid rgba(255,255,255,.08);border-radius:16px;width:100%;max-width:420px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:modal-pop .15s ease}@keyframes modal-pop{0%{opacity:0;transform:scale(.97) translateY(4px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 18px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.modal-title{font-size:15px;font-weight:700;color:var(--text-primary)}.modal-close{width:28px;height:28px;border-radius:7px;background:transparent;border:1px solid var(--border);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.modal-close:hover{background:var(--bg-elevated);color:var(--text-primary)}.modal-body{padding:16px 18px;overflow-y:auto;display:flex;flex-direction:column;gap:4px;flex:1}.field-label{font-size:12px;font-weight:600;color:var(--text-secondary);margin-top:12px;margin-bottom:6px}.field-label:first-child{margin-top:0}.field-optional{font-weight:400;color:var(--text-muted)}.modal-input{margin-bottom:0}.modal-error{font-size:12px;color:var(--danger);margin-top:10px}.modal-error-footer{padding:0 18px;margin:-4px 0 0}.visibility-options{display:flex;flex-direction:column;gap:8px;margin-top:2px}.visibility-card{display:flex;align-items:center;gap:12px;padding:12px;border-radius:10px;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;text-align:left;transition:all .15s;width:100%}.visibility-card:hover{border-color:#ffffff2e}.visibility-card.active{border-color:var(--accent-cyan);background:#00e5ff0f;color:var(--text-primary)}.visibility-icon{width:34px;height:34px;border-radius:9px;background:var(--bg-hover);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:inherit}.visibility-card.active .visibility-icon{background:#00e5ff26;color:var(--accent-cyan)}.visibility-text{display:flex;flex-direction:column;gap:2px}.visibility-name{font-size:13px;font-weight:600;color:var(--text-primary)}.visibility-desc{font-size:11.5px;color:var(--text-muted)}.invite-list{display:flex;flex-direction:column;gap:2px;margin-top:10px;max-height:280px;overflow-y:auto}.invite-row{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;background:transparent;border:none;cursor:pointer;width:100%;text-align:left;transition:background .12s}.invite-row:hover{background:#ffffff0a}.invite-row.checked{background:#00e5ff0d}.invite-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#3d4870,#5a6490);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--text-primary);flex-shrink:0}.invite-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.invite-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.invite-sub{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.invite-check{width:19px;height:19px;border-radius:5px;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#0e1015;transition:all .15s}.invite-check.checked{background:var(--accent-cyan);border-color:var(--accent-cyan)}.invite-count{font-size:11.5px;color:var(--text-muted);margin-top:8px;text-align:right}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 18px;border-top:1px solid var(--border);flex-shrink:0}.modal-submit{min-width:110px}.btn-danger-outline{background:#ff4e6a1a;border:1px solid rgba(255,78,106,.3);color:var(--danger)}.btn-danger-outline:hover:not(:disabled){background:#ff4e6a2e}.room-title-trigger{display:flex;align-items:center;gap:6px;background:transparent;border:none;cursor:pointer;padding:4px 6px;margin:-4px -6px;border-radius:7px;transition:background .12s}.room-menu-wrap{position:relative}.room-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:220px;background:#1c1e28;border:1px solid rgba(255,255,255,.08);border-radius:12px;box-shadow:0 12px 32px #00000073;padding:6px;z-index:200;animation:room-menu-pop .12s ease}.member-list{display:flex;flex-direction:column;gap:2px;margin-top:8px;max-height:200px;overflow-y:auto}.member-row{display:flex;align-items:center;gap:10px;padding:7px 4px}.member-row .invite-avatar{width:30px;height:30px;font-size:10.5px}.member-role{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:2px 7px;border-radius:5px;background:var(--bg-elevated);border:1px solid var(--border)}.danger-zone{margin-top:18px;padding-top:14px;border-top:1px solid var(--border)}.danger-zone-title{font-size:12px;font-weight:600;color:var(--danger);margin-bottom:8px}.delete-confirm-box{background:#ff4e6a0f;border:1px solid rgba(255,78,106,.25);border-radius:10px;padding:12px;margin-top:8px}.delete-confirm-text{font-size:12.5px;color:var(--text-secondary);line-height:1.5;margin-bottom:10px}.delete-confirm-actions{display:flex;gap:8px;justify-content:flex-end}.room-layout{display:flex;flex-direction:row;height:100%;overflow:hidden}.room-channels-sidebar{width:220px;min-width:200px;max-width:240px;flex-shrink:0;display:flex;flex-direction:column;background:var(--bg-surface);border-right:1px solid rgba(255,255,255,.05);overflow:hidden}.room-channels-header{padding:14px 14px 12px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0;position:relative}.room-channels-title{font-size:14px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.channels-section{flex:1;overflow-y:auto;padding:8px 6px 12px;display:flex;flex-direction:column;gap:1px}.channels-label{display:flex;align-items:center;justify-content:space-between;padding:6px 8px 4px;font-size:10.5px;font-weight:700;letter-spacing:.06em;color:var(--text-muted);text-transform:uppercase}.category-group{margin-top:10px}.category-group:first-child{margin-top:0}.category-header{display:flex;align-items:center;gap:5px;width:100%;padding:6px 8px;background:transparent;border:none;cursor:pointer;text-align:left;border-radius:6px;transition:background .12s,color .12s}.category-header:hover{background:#ffffff0d}.category-chevron{color:var(--text-muted);transition:transform .15s;flex-shrink:0}.category-header.collapsed .category-chevron{transform:rotate(-90deg)}.category-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.category-delete-btn{opacity:0}.category-header:hover .category-delete-btn{opacity:.5}.category-channels{display:flex;flex-direction:column;gap:1px;margin-top:1px}.category-empty-hint{font-size:11.5px;color:var(--text-muted);padding:4px 10px 6px;font-style:italic}.add-channel-select{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:7px;padding:7px 10px;font-size:12.5px;color:var(--text-primary);font-family:var(--font-ui);outline:none;width:100%;cursor:pointer}.add-channel-select:focus{border-color:#fff3}.add-category-form{padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:8px}.add-channel-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:2px 4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .12s}.add-channel-btn:hover{color:var(--text-primary);background:#ffffff0f}.channel-item{display:flex;align-items:center;gap:6px;width:100%;padding:6px 8px;border-radius:7px;background:transparent;border:none;color:var(--text-muted);font-size:13.5px;font-family:var(--font-ui);cursor:pointer;text-align:left;transition:background .1s,color .1s;position:relative}.channel-item:hover{background:#ffffff0d;color:var(--text-secondary)}.channel-item.active{background:#ffffff14;color:var(--text-primary);font-weight:600}.channel-hash{font-size:16px;line-height:1;flex-shrink:0;color:inherit;opacity:.7}.channel-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.channel-delete-btn{opacity:0;padding:2px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:opacity .12s,background .12s;flex-shrink:0}.channel-item:hover .channel-delete-btn{opacity:.5}.channel-delete-btn:hover{opacity:1!important;background:#ff4e6a33;color:var(--danger)}.channels-loading{display:flex;justify-content:center;padding:20px 0}.add-channel-form{margin:4px 2px;display:flex;flex-direction:column;gap:6px}.add-channel-input{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:7px;padding:7px 10px;font-size:13px;color:var(--text-primary);font-family:var(--font-ui);outline:none;width:100%}.add-channel-input:focus{border-color:#fff3}.add-channel-input::placeholder{color:var(--text-muted)}.add-channel-actions{display:flex;gap:6px}.add-channel-confirm{flex:1;padding:6px 10px;border-radius:6px;background:var(--accent-cyan);border:none;color:#0e1015;font-size:12px;font-weight:700;cursor:pointer;font-family:var(--font-ui);transition:opacity .12s;display:flex;align-items:center;justify-content:center}.add-channel-confirm:disabled{opacity:.4;cursor:not-allowed}.add-channel-cancel{flex:1;padding:6px 10px;border-radius:6px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);color:var(--text-muted);font-size:12px;font-weight:500;cursor:pointer;font-family:var(--font-ui);transition:all .12s}.add-channel-cancel:hover{color:var(--text-primary)}.room-chat-area{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.channel-empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--text-muted)}.channel-empty-icon{width:64px;height:64px;border-radius:16px;background:var(--bg-elevated);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;margin-bottom:6px}.channel-empty-state p{font-size:14px;font-weight:600;color:var(--text-secondary)}.channel-empty-state span{font-size:12px}.room-header{padding:14px 24px;border-bottom:1px solid rgba(255,255,255,.05);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--bg-base)}.room-header-left{display:flex;align-items:center;gap:12px}.room-header-icon{width:34px;height:34px;border-radius:9px;background:#ffffff0d;border:1px solid rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);flex-shrink:0}.room-header-name{font-size:15px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.room-header-desc{font-size:12px;color:var(--text-muted);margin-top:1px}.room-header-right{display:flex;align-items:center;gap:10px}.member-count{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-muted);padding:5px 10px;border-radius:6px;background:var(--bg-elevated);border:1px solid var(--border)}.room-messages{flex:1;overflow-y:auto;padding:20px 24px 8px;display:flex;flex-direction:column;gap:0}.room-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--text-muted);padding:60px 0}.room-empty-icon{width:52px;height:52px;border-radius:13px;background:var(--bg-elevated);border:1px solid var(--border);display:flex;align-items:center;justify-content:center}.room-empty p{font-size:13px}.room-msg{display:flex;gap:14px;padding:3px 6px;border-radius:8px;margin-bottom:1px;transition:background .1s}.room-msg:hover{background:#ffffff05}.room-msg.grouped{margin-top:0}.room-msg-avatar{width:38px;flex-shrink:0;display:flex;align-items:flex-start;justify-content:center;padding-top:2px}.msg-avatar-circle{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#3d4870,#5a6490);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--text-primary)}.msg-time-hover{font-size:10px;color:transparent;white-space:nowrap;margin-top:6px}.room-msg:hover .msg-time-hover{color:var(--text-muted)}.room-msg-content{flex:1;min-width:0}.room-msg-meta{display:flex;align-items:baseline;gap:8px;margin-bottom:3px}.msg-author{font-size:13px;font-weight:700;color:var(--text-primary)}.msg-author.me{color:var(--accent-cyan)}.msg-time{font-size:11px;color:var(--text-muted)}.room-msg-text{font-size:14px;line-height:1.55;color:var(--text-primary);word-break:break-word;white-space:pre-wrap}.room-input-wrap{padding:12px 24px 16px;background:var(--bg-base);flex-shrink:0}.room-input-bar{display:flex;align-items:flex-end;gap:10px;background:#1c1e28;border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:10px 14px;transition:border-color .15s}.room-input-bar:focus-within{border-color:#ffffff21}.room-textarea{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);font-family:var(--font-ui);font-size:14px;line-height:1.5;resize:none;max-height:120px;overflow-y:auto}.room-textarea::placeholder{color:var(--text-muted)}.room-send-btn{width:32px;height:32px;border-radius:8px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.room-send-btn.active{color:var(--text-primary)}.room-send-btn.active:hover{color:var(--accent-cyan)}.room-send-btn:disabled{cursor:not-allowed;opacity:.3}.spinner-sm{width:14px;height:14px;border:2px solid rgba(255,255,255,.12);border-top-color:var(--text-muted);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.room-title-trigger{display:flex;align-items:center;gap:6px;background:transparent;border:none;cursor:pointer;padding:4px 6px;margin:-4px -6px;border-radius:7px;transition:background .12s;width:calc(100% + 12px)}.room-title-trigger:hover{background:#ffffff0d}.room-title-trigger.open{background:#ffffff12}.room-title-chevron{color:var(--text-muted);transition:transform .15s;flex-shrink:0}.room-title-trigger.open .room-title-chevron{transform:rotate(180deg)}.room-menu{position:absolute;top:calc(100% + 4px);left:6px;right:6px;min-width:180px;background:#1c1e28;border:1px solid rgba(255,255,255,.08);border-radius:12px;box-shadow:0 12px 32px #00000073;padding:6px;z-index:200;animation:room-menu-pop .12s ease}@keyframes room-menu-pop{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.room-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 10px;border-radius:8px;background:transparent;border:none;color:var(--text-secondary);font-size:13px;font-weight:500;font-family:var(--font-ui);cursor:pointer;text-align:left;transition:background .12s,color .12s}.room-menu-item svg{flex-shrink:0;color:inherit}.room-menu-item:hover{background:#ffffff0f;color:var(--text-primary)}.room-menu-item.danger{color:var(--danger)}.room-menu-item.danger:hover{background:#ff4e6a1a;color:var(--danger)}.room-menu-divider{height:1px;background:var(--border);margin:5px 2px}.app-layout{display:flex;height:100vh;overflow:hidden;background:var(--bg-base)}.nav-rail{width:68px;flex-shrink:0;background:#141620;border-right:1px solid rgba(255,255,255,.04);display:flex;flex-direction:column;align-items:center;padding:14px 0 16px;gap:4px}.rail-logo{width:38px;height:38px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.rail-logo-img{width:38px;height:38px;object-fit:contain;border-radius:8px}.rail-items{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;width:100%}.rail-item{position:relative;width:48px;height:48px;border-radius:12px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;transition:all .15s;padding:0}.rail-item:hover{background:#ffffff0d;color:var(--text-secondary)}.rail-item.active{background:#ffffff12;color:var(--text-primary)}.rail-item.active:before{content:"";position:absolute;left:-1px;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--accent-cyan);border-radius:0 2px 2px 0}.rail-label{font-size:9px;letter-spacing:.04em;font-weight:500}.rail-badge{position:absolute;top:6px;right:6px;min-width:16px;height:16px;background:#e85455;color:#fff;font-size:9px;font-weight:700;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px}.rail-bottom{display:flex;flex-direction:column;align-items:center;gap:8px;padding-top:12px;border-top:1px solid rgba(255,255,255,.04);width:100%}.rail-user-wrap{position:relative}.rail-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#3d4870,#5a6490);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--text-primary);cursor:pointer;transition:all .15s;border:2px solid transparent}.rail-avatar:hover{border-color:#ffffff26}.rail-avatar.open{border-color:#ffffff40}.rail-avatar span{line-height:1}.user-menu{position:absolute;bottom:0;left:calc(100% + 10px);width:210px;background:#1e2130;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:6px;box-shadow:0 8px 32px #00000080;z-index:200;animation:menu-pop .12s ease-out}@keyframes menu-pop{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:translate(0)}}.user-menu-header{display:flex;align-items:center;gap:10px;padding:10px}.user-menu-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#3d4870,#5a6490);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--text-primary);flex-shrink:0}.user-menu-name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-menu-handle{font-size:11px;color:var(--text-muted)}.user-menu-divider{height:1px;background:#ffffff0f;margin:4px 0}.user-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 10px;border-radius:8px;background:transparent;border:none;color:var(--text-secondary);font-size:13px;font-family:var(--font-ui);font-weight:500;cursor:pointer;transition:all .12s;text-align:left}.user-menu-item:hover{background:#ffffff0d;color:var(--text-primary)}.user-menu-item.danger{color:#e85455}.user-menu-item.danger:hover{background:#e854551a;color:#e85455}.sidebar-panel{width:260px;flex-shrink:0;background:#171923;border-right:1px solid rgba(255,255,255,.05);display:flex;flex-direction:column;overflow:hidden}.panel-section{display:flex;flex-direction:column;flex:1;overflow:hidden}.panel-header{padding:20px 16px 12px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.panel-title{font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary)}.panel-action{width:28px;height:28px;border-radius:7px;background:transparent;border:1px solid var(--border);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.panel-action:hover{background:var(--bg-elevated);color:var(--text-primary)}.panel-search{flex-shrink:0;padding:0 12px 8px}.panel-input{width:100%;padding:9px 12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-family:var(--font-ui);font-size:13px;outline:none;transition:border-color .15s;margin-bottom:4px}.panel-input::placeholder{color:var(--text-muted)}.panel-input:focus{border-color:#ffffff26}.panel-body{flex:1;overflow-y:auto;padding:8px 12px 16px;display:flex;flex-direction:column;gap:2px}.panel-hint{font-size:12px;color:var(--text-muted);line-height:1.6;padding:4px 2px 10px}.panel-section-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:4px 2px 10px}.filter-group{display:flex;gap:6px;flex-wrap:wrap;padding-top:4px}.filter-chip{padding:5px 12px;border-radius:20px;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;font-family:var(--font-ui)}.filter-chip:hover{border-color:#ffffff26;color:var(--text-primary)}.filter-chip.active{background:#ffffff12;border-color:#ffffff26;color:var(--text-primary)}.room-list{display:flex;flex-direction:column;gap:1px}.room-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;background:transparent;border:none;cursor:pointer;color:var(--text-secondary);text-align:left;transition:all .12s;width:100%}.room-row:hover{background:#ffffff0a;color:var(--text-primary)}.room-row.active{background:#ffffff0f;color:var(--text-primary)}.room-icon{width:28px;height:28px;border-radius:7px;background:var(--bg-elevated);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0}.room-row.active .room-icon{background:#ffffff14;border-color:#ffffff1a}.room-info{display:flex;flex-direction:column;gap:1px}.room-name{font-size:13px;font-weight:500}.room-meta{font-size:11px;color:var(--text-muted)}.room-row-search{cursor:default}.room-join-btn{flex-shrink:0;padding:5px 12px;border-radius:7px;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);font-size:11.5px;font-weight:600;font-family:var(--font-ui);cursor:pointer;transition:all .15s}.room-join-btn:hover:not(:disabled){border-color:var(--accent-cyan);color:var(--accent-cyan)}.room-join-btn:disabled{opacity:.6;cursor:default}.room-join-btn.joined{background:transparent;border-color:var(--border);color:var(--text-secondary)}.friend-row{display:flex;align-items:center;gap:10px;padding:7px 8px;border-radius:8px;background:transparent;border:none;cursor:pointer;width:100%;text-align:left;transition:background .12s}.friend-row:hover{background:#ffffff0a}.friend-row.active{background:#ffffff0f}.friend-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#3d4870,#5a6490);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--text-primary);flex-shrink:0;position:relative}.status-pip{position:absolute;bottom:0;right:0;width:9px;height:9px;border-radius:50%;border:2px solid #171923}.status-pip.on{background:#3dd68c}.status-pip.off{background:#4a526a}.friend-info-col{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.friend-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.friend-sub{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unread-dot{min-width:18px;height:18px;border-radius:9px;background:#e85455;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;flex-shrink:0}.user-row{display:flex;align-items:center;gap:10px;padding:8px 4px;border-bottom:1px solid rgba(255,255,255,.04)}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#3d4870,#5a6490);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--text-primary);flex-shrink:0}.user-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.user-name{font-size:13px;font-weight:500;color:var(--text-primary)}.user-sub{font-size:11px;color:var(--text-muted)}.add-btn,.accept-btn{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;font-family:var(--font-ui);cursor:pointer;transition:all .15s;flex-shrink:0}.add-btn{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary)}.add-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.accept-btn{background:#3dd68c1f;border:1px solid rgba(61,214,140,.25);color:#3dd68c}.accept-btn:hover{background:#3dd68c33}.main-content{flex:1;overflow:hidden;display:flex;flex-direction:column;background:var(--bg-base)}.empty-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-muted)}.empty-icon{width:56px;height:56px;border-radius:14px;background:var(--bg-elevated);border:1px solid var(--border);display:flex;align-items:center;justify-content:center}.empty-content p{font-size:14px}.call-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0c12cc;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000}.call-card{background:#1c1e2a;border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:36px 44px;text-align:center;min-width:280px}.call-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#3d4870,#5a6490);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:var(--text-primary);margin:0 auto 16px}.call-name{font-size:17px;font-weight:700;margin-bottom:4px}.call-sub{font-size:13px;color:var(--text-muted);margin-bottom:28px}.call-actions{display:flex;gap:12px;justify-content:center}.call-btn{padding:10px 24px;border-radius:10px;font-size:13px;font-weight:600;font-family:var(--font-ui);cursor:pointer;border:none;transition:all .15s}.call-btn.decline{background:#e8545526;border:1px solid rgba(232,84,85,.3);color:#e85455}.call-btn.decline:hover{background:#e8545540}.call-btn.accept{background:#3dd68c26;border:1px solid rgba(61,214,140,.3);color:#3dd68c}.call-btn.accept:hover{background:#3dd68c40}.settings-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-base);padding:40px 24px}.settings-card{width:100%;max-width:560px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px 36px;display:flex;flex-direction:column;gap:24px}.settings-title{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--text-primary);letter-spacing:1px}.settings-section{display:flex;flex-direction:column;gap:16px}.settings-section h3{font-size:12px;font-weight:600;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase}
