@import"https://fonts.googleapis.com/css2?family=Noto+Sans+SC:wght@400;500;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-0: #0e0f12;--bg-1: #17191e;--bg-2: #1e2028;--bg-3: #2b2d35;--bg-4: #36383f;--fg-0: #f2f3f5;--fg-1: #b5bac1;--fg-2: #72767d;--accent: #5865f2;--accent-hover: #4752c4;--green: #57f287;--red: #ed4245;--yellow: #fee75c;--border: rgba(255, 255, 255, .06);--r: 8px;--font: "Noto Sans SC", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif}html,body,#root{height:100%;overflow:hidden}body{font-family:var(--font);background:var(--bg-0);color:var(--fg-0);-webkit-font-smoothing:antialiased}.app{display:flex;height:100vh;overflow:hidden}.rail{width:70px;background:var(--bg-0);display:flex;flex-direction:column;align-items:center;padding:10px 0;gap:6px;border-right:1px solid var(--border);flex-shrink:0;overflow-y:auto;scrollbar-width:none}.rail::-webkit-scrollbar{display:none}.rail-logo{font-size:26px;margin-bottom:4px;position:relative}.rail-total{position:absolute;top:-4px;right:-10px;background:var(--red);color:#fff;font-size:9px;font-weight:700;padding:1px 5px;border-radius:10px;min-width:16px;text-align:center;letter-spacing:.3px}.rail-acc{width:46px;height:46px;border-radius:50%;cursor:pointer;position:relative;display:flex;align-items:center;justify-content:center;transition:border-radius .18s,background .18s;font-size:18px;font-weight:600;background:var(--bg-3);color:var(--fg-1);overflow:hidden}.rail-acc img{width:100%;height:100%;object-fit:cover}.rail-acc:hover{border-radius:14px}.rail-acc.active{border-radius:14px;outline:2px solid var(--accent)}.rail-all{font-size:20px}.rail-dot{position:absolute;bottom:0;right:0;width:12px;height:12px;border-radius:50%;border:2px solid var(--bg-0)}.rail-add{color:var(--green);font-size:26px;font-weight:300}.rail-add:hover{background:var(--green);color:#000}.sidebar{width:275px;background:var(--bg-1);display:flex;flex-direction:column;border-right:1px solid var(--border);flex-shrink:0}.sidebar-head{padding:14px 12px 10px;border-bottom:1px solid var(--border)}.sidebar-title{font-weight:700;font-size:14px;margin-bottom:10px}.search-wrap{position:relative}.search-wrap input{width:100%;background:var(--bg-3);border:none;outline:none;padding:7px 28px 7px 10px;border-radius:var(--r);color:var(--fg-0);font-size:13px;font-family:var(--font)}.search-wrap input::placeholder{color:var(--fg-2)}.search-clear{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--fg-2);cursor:pointer;font-size:12px;padding:4px 6px}.conv-list{flex:1;overflow-y:auto;padding:4px;scrollbar-width:thin;scrollbar-color:var(--bg-4) transparent}.conv-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r);cursor:pointer;transition:background .12s}.conv-item:hover,.conv-item.active{background:var(--bg-3)}.conv-info{flex:1;min-width:0}.conv-row1{display:flex;justify-content:space-between;align-items:center;margin-bottom:3px}.conv-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conv-time{font-size:11px;color:var(--fg-2);flex-shrink:0;margin-left:6px}.conv-row2{display:flex;align-items:center;gap:5px}.conv-preview{font-size:12px;color:var(--fg-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.unread-badge{background:var(--accent);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px;flex-shrink:0}.acc-tag{font-size:10px;font-weight:700;padding:1px 6px;border-radius:4px;border:1px solid;white-space:nowrap;flex-shrink:0;letter-spacing:.2px}.search-item{padding:10px;border-radius:var(--r);cursor:pointer;transition:background .12s}.search-item:hover{background:var(--bg-3)}.search-meta{display:flex;align-items:center;gap:6px;margin-bottom:4px}.search-partner{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-time{font-size:11px;color:var(--fg-2);margin-left:auto}.search-content{font-size:13px;color:var(--fg-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-footer{padding:8px 12px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:4px;max-height:120px;overflow-y:auto}.foot-row{display:flex;align-items:center;gap:6px;font-size:12px}.foot-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.foot-label{color:var(--fg-1);font-weight:600}.foot-user{color:var(--fg-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat{flex:1;display:flex;flex-direction:column;background:var(--bg-2);min-width:0}.chat-head{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--border)}.chat-partner{font-weight:700;font-size:16px}.messages{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:2px;scrollbar-width:thin;scrollbar-color:var(--bg-4) transparent}.msg-wrap{display:flex;align-items:flex-end;gap:8px;margin:1px 0}.msg-wrap.out{flex-direction:row-reverse}.msg-col{display:flex;flex-direction:column;max-width:64%}.msg-wrap.out .msg-col{align-items:flex-end}.msg-sname{font-size:11px;color:var(--fg-2);margin-bottom:3px;padding-left:3px}.bubble{padding:8px 14px;border-radius:18px;font-size:14px;line-height:1.55;word-break:break-word;white-space:pre-wrap}.msg-wrap.in .bubble{background:var(--bg-3);color:var(--fg-0);border-bottom-left-radius:4px}.msg-wrap.out .bubble{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.msg-time{font-size:10px;color:var(--fg-2);margin-top:3px;padding:0 3px}.input-bar{display:flex;align-items:center;gap:10px;padding:12px 20px;border-top:1px solid var(--border)}.msg-input{flex:1;background:var(--bg-3);border:none;outline:none;border-radius:22px;padding:11px 18px;color:var(--fg-0);font-size:14px;font-family:var(--font);transition:box-shadow .18s}.msg-input:focus{box-shadow:0 0 0 2px var(--accent)}.msg-input::placeholder{color:var(--fg-2)}.send-btn{border-radius:20px!important;padding:10px 20px!important}.welcome{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;color:var(--fg-2);text-align:center;padding:40px}.welcome-icon{font-size:64px}.welcome h2{color:var(--fg-0);font-size:22px}.welcome p{font-size:14px;line-height:1.6;max-width:320px}.empty{text-align:center;color:var(--fg-2);font-size:13px;padding:40px 16px}.empty-chat{flex:1;display:flex;align-items:center;justify-content:center;color:var(--fg-2);font-size:14px}.loading{text-align:center;color:var(--fg-2);padding:30px;font-size:13px}.btn{border:none;border-radius:var(--r);padding:10px 20px;font-weight:600;font-size:14px;cursor:pointer;font-family:var(--font);transition:background .15s,transform .1s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:scale(1.02)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--fg-1);border:1px solid var(--border)}.btn-ghost:hover{background:var(--bg-3)}.avatar{border-radius:50%;object-fit:cover;flex-shrink:0;display:flex;align-items:center;justify-content:center}.avatar-fallback{background:var(--bg-4);color:var(--fg-1);font-weight:700}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-2);border:1px solid var(--border);border-radius:14px;padding:28px;width:420px;max-width:90vw;display:flex;flex-direction:column;gap:14px;animation:slideUp .2s}@keyframes slideUp{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.modal h2{font-size:18px;color:var(--fg-0)}.modal-hint{font-size:12px;color:var(--fg-2);line-height:1.6}.modal-hint code{background:var(--bg-3);padding:1px 6px;border-radius:4px;font-family:monospace;color:var(--fg-1)}.modal-label{font-size:11px;font-weight:700;color:var(--fg-2);text-transform:uppercase;letter-spacing:.5px;margin-top:4px}.modal-input{background:var(--bg-3);border:1px solid var(--border);outline:none;border-radius:var(--r);padding:10px 12px;color:var(--fg-0);font-size:14px;font-family:var(--font);width:100%;transition:border-color .2s}.modal-input:focus{border-color:var(--accent)}.modal-err{background:#ed424526;border:1px solid var(--red);color:var(--red);padding:8px 12px;border-radius:var(--r);font-size:13px}.modal-warn{font-size:12px;color:var(--yellow);padding:8px 12px;background:#fee75c12;border:1px solid rgba(254,231,92,.2);border-radius:var(--r);line-height:1.5}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:4px}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at top,#1e2028,#0e0f12 70%);padding:20px}.auth-card{background:var(--bg-2);border:1px solid var(--border);border-radius:14px;padding:36px 32px;width:380px;max-width:100%;display:flex;flex-direction:column;gap:8px;box-shadow:0 16px 48px #00000080}.auth-logo{font-size:48px;text-align:center;margin-bottom:4px}.auth-title{font-size:20px;text-align:center;margin:0}.auth-sub{text-align:center;font-size:13px;color:var(--fg-2);margin-bottom:12px}.auth-label{font-size:11px;font-weight:700;color:var(--fg-2);text-transform:uppercase;letter-spacing:.5px;margin-top:8px}.auth-input{background:var(--bg-3);border:1px solid var(--border);outline:none;border-radius:var(--r);padding:10px 12px;color:var(--fg-0);font-size:14px;font-family:var(--font);transition:border-color .2s}.auth-input:focus{border-color:var(--accent)}.auth-err{background:#ed424526;border:1px solid var(--red);color:var(--red);padding:8px 12px;border-radius:var(--r);font-size:13px;margin-top:8px}.auth-btn{margin-top:16px;width:100%}.auth-switch{text-align:center;font-size:13px;color:var(--fg-2);margin-top:4px}.auth-switch a{color:var(--accent);cursor:pointer;margin-left:4px;text-decoration:none}.auth-switch a:hover{text-decoration:underline}.auth-warn{font-size:11px;color:var(--yellow);text-align:center;margin-top:12px;line-height:1.5;opacity:.8}.rail-logout{background:transparent;color:var(--fg-2);font-size:22px;margin-top:auto}.rail-logout:hover{background:var(--red);color:#fff}
