:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:#f8f9fa}h1,h2,h3,h4,h5,h6{margin:0}button,input{font-family:inherit}#root{margin:0;padding:0;height:100vh;font-family:Inter,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{display:flex;height:100vh;background:#f8f9fa;overflow:hidden}.sidebar{width:260px;background:#2c2f33;color:#fff;display:flex;flex-direction:column;border-right:1px solid #202225}.sidebar-header{padding:1rem;border-bottom:1px solid #202225;display:flex;justify-content:space-between;align-items:center}.sidebar-header h2{margin:0;font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#b9bbbe}.add-channel-btn{background:#36393f;border:none;color:#b9bbbe;width:32px;height:32px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:all .2s ease}.add-channel-btn:hover{background:#40444b;color:#fff;transform:scale(1.05)}.channels-list{flex:1;padding:.5rem 0;overflow-y:auto}.channel-item{padding:.6rem 1rem;cursor:pointer;display:flex;align-items:center;transition:all .2s ease;border-radius:6px;margin:0 .5rem;position:relative}.channel-item:hover{background:#36393f}.channel-item.active{background:#5865f2;color:#fff}.channel-item.active .channel-hash{color:#fffc}.channel-hash{color:#72767d;margin-right:.5rem;font-weight:700}.channel-name{font-weight:500}.create-channel-form{padding:1rem;border-bottom:1px solid #202225;background:#36393f}.create-channel-form input{width:100%;padding:.5rem;border:1px solid #202225;border-radius:4px;background:#202225;color:#fff;margin-bottom:.5rem}.create-channel-form input::placeholder{color:#72767d}.form-actions{display:flex;gap:.5rem}.small-btn{padding:.4rem .8rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500}.small-btn.secondary{background:#72767d;color:#fff}.small-btn.secondary:hover{background:#5c5e66}.main-content{flex:1;display:flex;flex-direction:column;background:#fff}.chat-header{background:#fff;padding:1rem 1.5rem;border-bottom:1px solid #e3e5e8;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 3px #0000001a}.chat-header h1{margin:0;color:#2f3136;display:flex;align-items:center;font-size:1.2rem}.chat-header h1 .channel-hash{color:#5865f2;margin-right:.5rem}.user-info{color:#72767d;font-size:.9rem}.chat-container{flex:1;display:flex;flex-direction:column}.messages{flex:1;overflow-y:auto;padding:1rem 1.5rem;max-height:calc(100vh - 140px)}.message{margin-bottom:1rem;padding:.75rem 1rem;background:#fff;border-radius:12px 12px 12px 4px;box-shadow:0 2px 8px #0000001a;border-left:4px solid #5865f2;max-width:70%}.message.own{margin-left:auto;border-left-color:#27ae60;background:#dcf8c6;border-radius:12px 12px 4px}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.message-author{color:#2f3136;font-weight:600;font-size:.9rem}.message-time{color:#72767d;font-size:.75rem}.message-body{color:#2f3136;line-height:1.4}.message-form{padding:1rem 1.5rem;background:#fff;border-top:1px solid #e3e5e8;display:flex;gap:1rem;align-items:center}.message-form input{flex:1;padding:.75rem 1rem;border:1px solid #ddd;border-radius:20px;font-size:1rem;outline:none;transition:border-color .2s}.message-form input:focus{border-color:#404eed}.message-form button{padding:.75rem 1.5rem;background:#5865f2;color:#fff;border:none;border-radius:20px;cursor:pointer;font-weight:500;transition:all .2s ease}.message-form button:hover:not(:disabled){background:#4752c4;transform:translateY(-1px);box-shadow:0 4px 12px #5865f24d}.message-form button:disabled{background:#ccc;cursor:not-allowed}.login-container{display:flex;justify-content:center;align-items:center;height:100vh;background:#f8f9fa}.login-card{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 20px #0000001a;text-align:center;max-width:400px;width:90%}.login-card h1{margin:0 0 .5rem;color:#2f3136;font-size:2rem}.login-card p{color:#72767d;margin-bottom:2rem}.login-form{display:flex;flex-direction:column;gap:1rem}.login-form input{padding:.75rem 1rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;outline:none}.login-form input:focus{border-color:#404eed}.primary-btn{padding:.75rem 1.5rem;background:#5865f2;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;font-size:1rem;transition:all .2s ease}.primary-btn:hover{background:#4752c4;transform:translateY(-1px);box-shadow:0 4px 12px #5865f24d}.mobile-modal{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.mobile-modal-content{background:#36393f;color:#fff;padding:2rem;border-radius:12px;width:90%;max-width:400px;box-shadow:0 8px 24px #0000004d}.mobile-modal h3{margin:0 0 1rem;color:#fff}.mobile-modal .create-channel-form{display:block!important}.mobile-modal .form-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem}@media(max-width:768px){.sidebar{width:70px}.sidebar-header h2{display:none}.channel-item{flex-direction:column;justify-content:center;align-items:center;padding:.75rem .5rem;position:relative;min-height:60px}.channel-hash{margin:0 0 .25rem;font-size:1.2rem}.channel-name{display:block;font-size:.65rem;text-align:center;line-height:1.1;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.9;padding:0 2px}.chat-header{padding:.75rem 1rem}.chat-header h1{font-size:1.1rem}.messages,.message-form{padding:.75rem 1rem}.message{max-width:85%}.create-channel-form{display:none}}
