*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f5;color:#333}.search-bar{position:sticky;top:0;z-index:50;background:#fff;padding:.5rem 1rem;border-bottom:1px solid #eee;max-width:600px;margin:0 auto}.search-bar input{width:100%;padding:.5rem .75rem;border:1px solid #e0e0e0;border-radius:20px;font-size:.9rem;outline:none;background:#f5f5f5}.search-bar input:focus{border-color:#1a73e8;background:#fff}.search-results{position:absolute;left:1rem;right:1rem;top:100%;background:#fff;border:1px solid #eee;border-radius:8px;box-shadow:0 4px 12px #0000001a;max-height:300px;overflow-y:auto;z-index:60}.search-result-item{padding:.6rem .75rem;border-bottom:1px solid #f5f5f5;cursor:pointer}.search-result-item:hover{background:#f8f8f8}.search-result-item:last-child{border-bottom:none}.search-result-content{font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-time{font-size:.7rem;color:#999;margin-top:.15rem}.search-empty{padding:1rem;text-align:center;color:#999;font-size:.85rem}.login-page{display:flex;justify-content:center;align-items:center;min-height:100vh}.login-card{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 12px #0000001a;width:320px}.login-card h1{text-align:center;margin-bottom:1.5rem;color:#1a73e8}.login-card form{display:flex;flex-direction:column;gap:.75rem}.login-card input{padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;outline:none}.login-card input:focus{border-color:#1a73e8}.login-card button{padding:.75rem;background:#1a73e8;color:#fff;border:none;border-radius:8px;font-size:1rem;cursor:pointer}.login-card button:hover{background:#1557b0}.login-card .error{color:#d93025;font-size:.875rem}.login-card .switch{text-align:center;margin-top:1rem;color:#1a73e8;cursor:pointer;font-size:.875rem}.tab-page{max-width:600px;margin:0 auto;min-height:100vh;padding-bottom:60px;background:#fff}.page-header{padding:1rem;border-bottom:1px solid #eee;background:#fff}.page-header h2{font-size:1.2rem}.list{padding:0}.list-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-bottom:1px solid #f0f0f0;cursor:pointer}.list-item:hover{background:#f8f8f8}.list-item:active{background:#f0f0f0}.list-item-avatar{width:44px;height:44px;border-radius:50%;background:#1a73e8;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:600;flex-shrink:0}.list-item-info{flex:1;display:flex;flex-direction:column;gap:.15rem}.list-item-name{font-size:1rem;font-weight:500}.status-text{font-size:.75rem;color:#999}.status-text.online{color:#34a853}.unread-badge{background:#d93025;color:#fff;font-size:.75rem;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 6px;flex-shrink:0}.empty{text-align:center;color:#999;padding:3rem 1rem}.profile-card{display:flex;align-items:center;gap:1rem;padding:1.5rem 1rem;border-bottom:1px solid #eee}.profile-avatar{width:60px;height:60px;border-radius:50%;background:#1a73e8;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:600}.profile-info{display:flex;flex-direction:column;gap:.25rem}.profile-name{font-size:1.2rem;font-weight:600}.profile-id{font-size:.85rem;color:#999}.profile-actions{padding:1.5rem 1rem}.logout-btn{width:100%;padding:.75rem;background:#fff;color:#d93025;border:1px solid #d93025;border-radius:8px;font-size:1rem;cursor:pointer}.logout-btn:hover{background:#fce8e6}.tab-bar{position:fixed;bottom:0;left:0;right:0;height:56px;background:#fff;border-top:1px solid #eee;display:flex;justify-content:center;z-index:100}.tab-item{flex:1;max-width:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;color:#999;-webkit-tap-highlight-color:transparent}.tab-item.active{color:#1a73e8}.tab-icon-wrap{position:relative}.tab-icon{font-size:1.3rem}.tab-badge{position:absolute;top:-6px;right:-10px;background:#d93025;color:#fff;font-size:.6rem;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}.tab-label{font-size:.7rem}.chat-room{max-width:600px;margin:0 auto;height:calc(100vh - 101px);display:flex;flex-direction:column;background:#fff;overflow:hidden}.chat-header{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid #eee;background:#fff;flex-shrink:0}.chat-header button{background:none;border:none;font-size:1rem;cursor:pointer;color:#1a73e8}.chat-header-info{display:flex;flex-direction:column}.chat-header-name{font-weight:600;font-size:1rem}.chat-header-status{font-size:.75rem;color:#999}.message-list{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.message-bubble{max-width:75%;padding:.6rem .9rem;border-radius:12px;word-break:break-word;flex-shrink:0}.message-bubble.mine{align-self:flex-end;background:#1a73e8;color:#fff;border-bottom-right-radius:4px}.message-bubble.other{align-self:flex-start;background:#f0f0f0;border-bottom-left-radius:4px}.bubble-meta{display:flex;align-items:center;gap:.4rem;margin-top:.25rem}.bubble-time{font-size:.7rem;opacity:.7}.read-status{font-size:.65rem;opacity:.7}.date-separator{text-align:center;font-size:.75rem;color:#999;padding:.5rem 0;margin:.25rem 0}.bubble-image{max-width:200px;max-height:200px;border-radius:8px;cursor:pointer;display:block}.bubble-file{color:inherit;text-decoration:none;display:flex;align-items:center;gap:.3rem}.bubble-file:hover{text-decoration:underline}.loading-more,.no-more{text-align:center;font-size:.8rem;color:#999;padding:.5rem}.chat-input{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-top:1px solid #eee;background:#fff;flex-shrink:0}.chat-input textarea{flex:1;padding:.6rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;resize:none;outline:none;font-family:inherit}.chat-input textarea:focus{border-color:#1a73e8}.chat-input button{padding:.6rem 1.2rem;background:#1a73e8;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem}.chat-input button:hover{background:#1557b0}.attach-btn{width:36px;height:36px;border-radius:50%;background:#f0f0f0!important;color:#333!important;border:none;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0!important}.attach-btn:hover{background:#e0e0e0!important}.profile-edit{display:flex;flex-direction:column;gap:.5rem}.profile-edit input{padding:.5rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;outline:none}.profile-edit input:focus{border-color:#1a73e8}.profile-edit-actions{display:flex;gap:.5rem}.profile-edit-actions button{padding:.4rem .8rem;border:none;border-radius:6px;font-size:.85rem;cursor:pointer;background:#1a73e8;color:#fff}.profile-edit-actions .btn-cancel{background:#e0e0e0;color:#333}.edit-link{font-size:.8rem;color:#1a73e8;cursor:pointer;margin-left:.5rem}.chat-header-actions{margin-left:auto;display:flex;gap:.5rem}.call-header-btn{background:none!important;border:none;font-size:1.3rem;cursor:pointer;padding:.25rem;border-radius:50%}.call-header-btn:hover{background:#f0f0f0!important}.call-overlay{position:fixed;inset:0;z-index:1000;background:#000000f2;display:flex;align-items:center;justify-content:center}.call-screen{width:100%;max-width:600px;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;color:#fff}.call-video-remote{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.call-video-local{position:absolute;top:1rem;right:1rem;width:120px;height:160px;object-fit:cover;border-radius:12px;border:2px solid white;z-index:10}.call-info{display:flex;flex-direction:column;align-items:center;gap:.75rem;z-index:5}.call-avatar{width:80px;height:80px;border-radius:50%;background:#1a73e8;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:600}.call-name{font-size:1.5rem;font-weight:600}.call-status-text{font-size:1rem;opacity:.8}.call-controls{position:absolute;bottom:4rem;display:flex;gap:1.5rem;z-index:10}.call-btn{padding:.75rem 1.2rem;border:none;border-radius:25px;font-size:.9rem;cursor:pointer;background:#fff3;color:#fff;min-width:80px}.call-btn:hover{background:#ffffff4d}.call-btn-active{background:#ffffff80}.call-btn-reject{background:#d93025}.call-btn-reject:hover{background:#b71c1c}.call-btn-accept{background:#34a853}.call-btn-accept:hover{background:#2e7d32}@media(max-width:600px){.tab-page,.chat-room{max-width:100%}}
