*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{display:flex;flex-direction:column;height:100vh;background:#f5f5f5}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 2px 4px #0000000d}.app-header h1{font-size:1.5rem;font-weight:600;color:#333}.header-actions{display:flex;align-items:center;gap:1rem}.connection-status{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#666}.status-dot{width:8px;height:8px;border-radius:50%;background:#ccc}.status-dot.connected{background:#4caf50}.app-content{display:flex;flex:1;overflow:hidden}.sidebar{width:280px;background:#fff;border-right:1px solid #e0e0e0;overflow-y:auto}.sidebar-section{padding:1rem;border-bottom:1px solid #f0f0f0}.sidebar-section h3{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:#666;text-transform:uppercase;margin-bottom:.75rem}.channel-list,.directory-list{display:flex;flex-direction:column;gap:.25rem}.channel-item,.directory-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border-radius:6px;cursor:pointer;transition:background .2s}.channel-item:hover,.directory-item:hover{background:#f5f5f5}.channel-item.active{background:#e3f2fd}.channel-info,.directory-info{flex:1;display:flex;align-items:center;gap:8px}.channel-name,.directory-name{font-weight:500;color:#333;margin-bottom:.25rem}.channel-status{font-size:.75rem;color:#999;text-transform:capitalize}.channel-status.connected{color:#4caf50}.directory-status,.directory-count{font-size:.75rem;color:#999}.chat-main{flex:1;display:flex;flex-direction:column;background:#fff}.message-list{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.message{display:flex;max-width:70%}.message-user{align-self:flex-end}.message-assistant{align-self:flex-start}.message-content{padding:.75rem 1rem;border-radius:12px;background:#f0f0f0}.message-user .message-content{background:#2196f3;color:#fff}.message-text{white-space:pre-wrap;word-wrap:break-word;line-height:1.5}.message-time{font-size:.75rem;color:#999;margin-top:.25rem}.message-user .message-time{color:#ffffffb3}.message-input{display:flex;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #e0e0e0;background:#fff}.message-input textarea{flex:1;padding:.75rem;border:1px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:.875rem;resize:none;min-height:44px;max-height:120px}.message-input textarea:focus{outline:none;border-color:#2196f3}.message-input button{padding:.75rem 1rem;background:#2196f3;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center}.message-input button:hover:not(:disabled){background:#1976d2}.message-input button:disabled{background:#ccc;cursor:not-allowed}.app-loading,.app-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1rem}.spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #2196f3;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading{text-align:center;padding:2rem;color:#999}@media(max-width:768px){.sidebar{width:240px}.message{max-width:85%}}.message.streaming .message-content{position:relative}.streaming-indicator{display:inline-flex;gap:4px;margin-left:8px}.streaming-indicator .dot{width:6px;height:6px;border-radius:50%;background:#999;animation:pulse 1.4s infinite ease-in-out}.streaming-indicator .dot:nth-child(1){animation-delay:-.32s}.streaming-indicator .dot:nth-child(2){animation-delay:-.16s}@keyframes pulse{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.typing-indicator{display:flex;align-items:center;gap:8px;padding:8px 16px;color:#666;font-size:.875rem}.typing-dots{display:flex;gap:4px}.typing-dots .dot{width:6px;height:6px;border-radius:50%;background:#999;animation:bounce 1.4s infinite ease-in-out}.typing-dots .dot:nth-child(1){animation-delay:-.32s}.typing-dots .dot:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-8px)}}.message-status{display:inline-flex;align-items:center;margin-left:4px;color:#999}.message-status.sent{color:#999}.message-status.delivered{color:#4caf50}.message-status.read{color:#2196f3}.message-status.failed{color:#f44336}.message-status.sending{animation:spin 1s linear infinite}.unread-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:#f44336;color:#fff;border-radius:10px;font-size:.75rem;font-weight:600}.channel-item .unread-badge,.directory-item .unread-badge{margin-left:auto}.status-indicator{width:8px;height:8px;border-radius:50%;background:#ccc;margin-right:8px}.status-indicator.online{background:#4caf50}.status-indicator.away{background:#ff9800}.status-indicator.offline{background:#999}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.login-card{width:100%;max-width:420px;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;overflow:hidden}.login-header{padding:2rem;text-align:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.login-header h1{font-size:1.75rem;margin-bottom:.5rem}.login-header p{opacity:.9;font-size:.875rem}.login-mode-selector{display:flex;gap:.5rem;padding:1rem;background:#f5f5f5}.mode-button{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;background:#fff;border:2px solid transparent;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.mode-button:hover{border-color:#667eea}.mode-button.active{background:#667eea;color:#fff;border-color:#667eea}.login-form{padding:2rem}.form-group{margin-bottom:1.5rem}.form-group label{display:flex;align-items:center;gap:.5rem;font-weight:500;margin-bottom:.5rem;color:#333}.form-group input[type=text],.form-group input[type=password]{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:.875rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#667eea}.form-group small{display:block;margin-top:.5rem;color:#666;font-size:.75rem}.form-group.checkbox{display:flex;align-items:center}.form-group.checkbox label{margin:0;cursor:pointer;-webkit-user-select:none;user-select:none}.form-group.checkbox input{margin-right:.5rem;cursor:pointer}.error-message{padding:.75rem;background:#ffebee;border:1px solid #ef5350;border-radius:8px;color:#c62828;font-size:.875rem;margin-bottom:1rem}.login-button{width:100%;padding:.875rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-footer{padding:1rem 2rem 2rem;text-align:center;font-size:.875rem;color:#666}.login-footer a{color:#667eea;text-decoration:none}.login-footer a:hover{text-decoration:underline}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:transparent;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s}.user-menu-trigger:hover{background:#f5f5f5}.user-menu-backdrop{position:fixed;inset:0;z-index:999}.user-menu-dropdown{position:absolute;top:calc(100% + .5rem);right:0;min-width:240px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000}.user-menu-header{padding:1rem}.user-info strong{display:block;font-size:.875rem;color:#333}.user-info small{display:block;margin-top:.25rem;color:#666;font-size:.75rem}.user-menu-divider{height:1px;background:#e0e0e0;margin:.5rem 0}.user-menu-items{padding:.5rem}.user-menu-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem;background:transparent;border:none;border-radius:6px;text-align:left;cursor:pointer;transition:background .2s}.user-menu-item:hover{background:#f5f5f5}.user-menu-item.danger{color:#f44336}.user-menu-item.danger:hover{background:#ffebee}.user-menu-footer{padding:.75rem 1rem;background:#f5f5f5;font-size:.75rem;color:#666}.file-upload{padding:.75rem;border-bottom:1px solid #e0e0e0}.file-upload-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#f5f5f5;border:1px dashed #ccc;border-radius:6px;color:#666;cursor:pointer;transition:all .2s;font-size:.875rem}.file-upload-button:hover:not(:disabled){background:#e8e8e8;border-color:#999}.file-upload-button:disabled{opacity:.5;cursor:not-allowed}.file-upload-previews{display:flex;flex-direction:column;gap:.75rem}.file-upload-header{display:flex;justify-content:space-between;align-items:center}.file-upload-count{font-size:.75rem;color:#666}.file-upload-clear{padding:.25rem .5rem;background:transparent;border:none;color:#f44336;font-size:.75rem;cursor:pointer;transition:color .2s}.file-upload-clear:hover:not(:disabled){color:#d32f2f}.file-upload-list{display:flex;flex-direction:column;gap:.5rem}.file-upload-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:#f5f5f5;border-radius:6px}.file-upload-thumbnail{width:48px;height:48px;border-radius:4px;overflow:hidden;background:#e0e0e0;display:flex;align-items:center;justify-content:center;flex-shrink:0}.file-upload-thumbnail img{width:100%;height:100%;object-fit:cover}.file-upload-info{flex:1;min-width:0}.file-upload-name{font-size:.875rem;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-upload-size{font-size:.75rem;color:#999;margin-top:.25rem}.file-upload-remove{padding:.25rem;background:transparent;border:none;color:#999;cursor:pointer;transition:color .2s;display:flex;align-items:center;justify-content:center}.file-upload-remove:hover:not(:disabled){color:#f44336}.file-upload-add-more{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem;background:transparent;border:1px dashed #ccc;border-radius:6px;color:#666;cursor:pointer;transition:all .2s;font-size:.875rem}.file-upload-add-more:hover:not(:disabled){background:#f5f5f5;border-color:#999}.file-upload-errors{display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem}.file-upload-error{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#ffebee;border:1px solid #ef5350;border-radius:6px;color:#c62828;font-size:.75rem}.message-input-with-media{display:flex;flex-direction:column;border-top:1px solid #e0e0e0;background:#fff}.message-input-row{display:flex;gap:.75rem;padding:1rem 1.5rem}.message-input-row textarea{flex:1;padding:.75rem;border:1px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:.875rem;resize:none;min-height:44px;max-height:120px}.message-input-row textarea:focus{outline:none;border-color:#2196f3}.message-input-row button{padding:.75rem 1rem;background:#2196f3;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center}.message-input-row button:hover:not(:disabled){background:#1976d2}.message-input-row button:disabled{background:#ccc;cursor:not-allowed}.access-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;text-align:center;padding:2rem}.access-denied h2{color:#f44336;margin-bottom:1rem}.access-denied p{color:#666;margin-bottom:.5rem}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{width:100%;height:100vh}
