*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:15px;color:#e2e2e2;background:#0f1117}.app{display:flex;flex-direction:column;height:100%;max-width:860px;margin:0 auto}.header{display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:52px;background:#1a1d27;border-bottom:1px solid #2a2d3a;flex-shrink:0}.header-title{font-size:1.1rem;font-weight:600;color:#fff}.header-right{display:flex;align-items:center;gap:10px}.username-label{font-size:.9rem;color:#a0a8c0}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.status-dot--connected{background:#4caf7d}.status-dot--disconnected{background:#e05c5c}.messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.messages-empty{color:#555870;text-align:center;margin-top:40px;font-style:italic}.message{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;column-gap:8px;row-gap:2px}.message-author{font-weight:600;font-size:.88rem;color:#7eb8f7}.message-time{font-size:.78rem;color:#555870;align-self:center}.message-content{grid-column:1 / -1;font-size:.95rem;line-height:1.5;color:#dce0f0;word-break:break-word;white-space:pre-wrap}.input-bar{display:flex;gap:8px;padding:12px 16px;background:#1a1d27;border-top:1px solid #2a2d3a;flex-shrink:0}.message-input{flex:1;padding:10px 14px;border-radius:8px;border:1px solid #2a2d3a;background:#0f1117;color:#e2e2e2;font-size:.95rem;outline:none;transition:border-color .15s}.message-input:focus{border-color:#4a7fc1}.message-input:disabled{opacity:.4;cursor:not-allowed}.btn{padding:10px 18px;border-radius:8px;border:none;cursor:pointer;font-size:.9rem;font-weight:500;transition:background .15s,opacity .15s}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:#4a7fc1;color:#fff}.btn-primary:not(:disabled):hover{background:#5a90d4}.btn-ghost{background:transparent;color:#a0a8c0;padding:6px 10px}.btn-ghost:hover{background:#2a2d3a;color:#e2e2e2}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;padding:16px}.modal{background:#1a1d27;border:1px solid #2a2d3a;border-radius:12px;padding:32px;width:100%;max-width:400px;display:flex;flex-direction:column;gap:16px}.modal h2{font-size:1.3rem;color:#fff}.modal p{color:#a0a8c0;font-size:.9rem}.modal form{display:flex;flex-direction:column;gap:10px}.modal-input{padding:10px 14px;border-radius:8px;border:1px solid #2a2d3a;background:#0f1117;color:#e2e2e2;font-size:.95rem;outline:none;transition:border-color .15s}.modal-input:focus{border-color:#4a7fc1}.modal-error{color:#e05c5c;font-size:.85rem}.emoji-picker-wrapper{position:relative}.emoji-picker-popup{position:absolute;bottom:calc(100% + 8px);right:0;z-index:100}.emoji-btn{font-size:1.2rem;padding:6px 10px}.reply-bar{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:6px 16px;background:#1e2235;border-top:1px solid #2a2d3a;flex-shrink:0}.reply-bar-inner{display:flex;flex-direction:column;gap:1px;overflow:hidden}.reply-bar-author{font-size:.8rem;font-weight:600;color:#7eb8f7}.reply-bar-text{font-size:.8rem;color:#a0a8c0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reply-bar-close{background:none;border:none;color:#a0a8c0;font-size:1.2rem;cursor:pointer;padding:0 4px;line-height:1;flex-shrink:0}.reply-bar-close:hover{color:#e2e2e2}.reply-quote{grid-column:1 / -1;display:flex;flex-direction:column;gap:1px;padding:4px 8px;border-left:3px solid #4a7fc1;background:#1a1d27;border-radius:4px;margin-bottom:4px}.reply-quote-author{font-size:.78rem;font-weight:600;color:#7eb8f7}.reply-quote-text{font-size:.78rem;color:#a0a8c0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.message-reply-btn{grid-column:1 / -1;align-self:start;background:none;border:1px solid #2a2d3a;border-radius:6px;color:#a0a8c0;font-size:.78rem;padding:2px 8px;cursor:pointer;width:fit-content;margin-top:2px}.message-reply-btn:hover{background:#2a2d3a;color:#e2e2e2}.message-content a{color:#7eb8f7;text-decoration:underline}.message-content a:hover{color:#a8d4ff}.message-image{grid-column:1 / -1;max-width:100%;max-height:400px;border-radius:6px;margin-top:4px;object-fit:contain;display:block}.image-preview{display:flex;align-items:flex-start;gap:8px;padding:8px 16px;background:#1e2235;border-top:1px solid #2a2d3a;flex-shrink:0}.image-preview-img{max-height:80px;max-width:120px;border-radius:4px;object-fit:contain}.image-preview-remove{background:none;border:none;color:#a0a8c0;font-size:1.2rem;cursor:pointer;padding:0 4px;line-height:1}.image-preview-remove:hover{color:#e2e2e2}.image-error{padding:4px 16px;font-size:.82rem;color:#e05c5c;background:#1e2235;border-top:1px solid #2a2d3a;flex-shrink:0}@media (max-width: 480px){.header{padding:0 10px}.messages{padding:12px 10px}.input-bar{padding:10px}.modal{padding:24px 20px}.btn{padding:10px 14px}}
