:root{font-family: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}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.unique-sidebar{width:290px;background:var(--sidebar-bg);color:var(--text-primary);display:flex;flex-direction:column;height:100vh;padding:0;box-shadow:2px 0 8px #00000014;transition:border-color .3s}.unique-profile{padding:24px 0 12px;display:flex;flex-direction:column;align-items:center;border-bottom:1px solid var(--border-color)}.unique-avatar-ring{border:3px solid var(--accent-color);border-radius:50%;padding:4px;margin-bottom:8px;transition:all .3s ease}.unique-avatar-ring:hover{transform:scale(1.05);box-shadow:0 6px 20px #4f8cff4d}.unique-avatar-ring img,.unique-avatar-ring svg{width:56px;height:56px;border-radius:50%;background:var(--bg-tertiary)}.unique-username{font-weight:700;font-size:1.1em;margin-top:8px;color:var(--text-primary)}.unique-mood{font-size:1.2em;margin-top:4px;cursor:pointer;color:var(--accent-color);display:flex;flex-direction:column;align-items:center}.unique-mood-set{font-size:.8em;color:var(--text-secondary)}.unique-mood-picker{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:8px;margin-top:6px;display:flex;flex-wrap:wrap;justify-content:center}.unique-profile-progress{width:80%;height:8px;background:var(--bg-tertiary);border-radius:4px;margin:12px 0 4px;overflow:hidden}.unique-profile-progress-bar{height:100%;border-radius:4px;transition:width .3s,background .3s}.unique-profile-progress-label{font-size:.85em;color:var(--text-secondary);margin-bottom:8px}.unique-quick-pins{padding:12px 24px;border-bottom:1px solid var(--border-color)}.unique-pin{display:flex;align-items:center;padding:8px 12px;margin-bottom:4px;border-radius:6px;cursor:pointer;transition:background .2s;color:var(--text-primary)}.unique-pin:hover{background:var(--bg-tertiary)}.unique-pin span{margin-left:8px;font-size:.9em}.unique-menu{flex:1;padding:12px 0}.unique-menu-item{display:flex;align-items:center;padding:12px 24px;cursor:pointer;transition:background .2s;color:var(--text-primary)}.unique-menu-item:hover{background:var(--bg-tertiary)}.unique-menu-icon{margin-right:12px;font-size:1.1em}.room-manager{background:var(--bg-primary);border-radius:8px;padding:16px;height:100%;overflow-y:auto;border:1px solid var(--border-color)}.rooms-list{display:flex;flex-direction:column;gap:8px}.room-item{display:flex;justify-content:space-between;align-items:center;padding:12px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);cursor:pointer;transition:all .2s ease}.room-item:hover{background:var(--bg-hover);border-color:var(--accent-color)}.room-item.selected{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.room-item.selected .room-name{color:#fff}.room-item.selected .room-description{color:#fffc}.room-item.selected .room-meta{color:#ffffffb3}.room-info{flex:1;min-width:0}.room-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.room-name{font-weight:600;color:var(--text-primary);font-size:14px}.private-badge{font-size:12px;opacity:.7}.room-description{color:var(--text-secondary);font-size:12px;margin-bottom:4px;line-height:1.3}.room-meta{display:flex;gap:12px;font-size:11px;color:var(--text-secondary)}.room-id{font-family:monospace;background:var(--bg-primary);padding:2px 6px;border-radius:4px;cursor:pointer;transition:background-color .2s ease}.room-id:hover{background:var(--accent-color);color:#fff}.member-count{opacity:.8}.room-actions{display:flex;gap:4px;align-items:center}.room-actions button{transition:transform .1s ease}.room-actions button:hover{transform:scale(1.05)}.modal-backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--bg-primary);border-radius:8px;padding:24px;max-width:400px;width:90%;max-height:80vh;overflow-y:auto;border:1px solid var(--border-color)}.modal h3{margin:0 0 16px;color:var(--text-primary);font-size:18px}.modal label{display:block;margin-bottom:8px;color:var(--text-primary);font-weight:500}.modal input,.modal textarea{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);font-size:14px;font-family:inherit}.modal input:focus,.modal textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #4f8cff33}.modal button{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s ease}.modal button[type=submit]{background:var(--accent-color);color:#fff}.modal button[type=submit]:hover{background:#3a7bd5}.modal button[type=button]{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.modal button[type=button]:hover{background:var(--bg-hover)}.modal button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.room-manager{padding:12px}.room-item{padding:10px}.room-header{flex-direction:column;align-items:flex-start;gap:4px}.room-meta{flex-direction:column;gap:4px}.modal{width:95%;padding:20px}}.user-search-panel{position:fixed;top:0;right:0;height:100vh;width:360px;background:var(--bg-primary, #111318);color:var(--text-primary, #e9eef8);border-left:1px solid var(--border-color, #1e2230);box-shadow:-8px 0 24px #00000040;display:flex;flex-direction:column;z-index:1000}.usp-header{display:flex;align-items:center;justify-content:space-between;padding:12px;border-bottom:1px solid var(--border-color, #1e2230)}.usp-title{font-size:14px;font-weight:600;color:var(--text-primary, #e9eef8)}.usp-close{background:transparent;border:none;color:var(--text-secondary, #a7b1c2);cursor:pointer;padding:6px;border-radius:6px}.usp-close:hover{background:#ffffff0f}.usp-input-row{display:flex;gap:8px;padding:12px;border-bottom:1px solid var(--border-color, #1e2230)}.usp-input{flex:1;height:36px;border-radius:8px;background:var(--bg-secondary, #0d0f14);color:var(--text-primary, #e9eef8);border:1px solid var(--border-color, #1e2230);padding:0 10px}.usp-input::placeholder{color:var(--text-secondary, #8b95a7)}.usp-search-btn{height:36px;min-width:40px;border-radius:8px;border:1px solid var(--border-color, #1e2230);background:var(--bg-secondary, #0d0f14);color:var(--text-secondary, #a7b1c2);cursor:pointer}.usp-search-btn:disabled{opacity:.6;cursor:default}.usp-error{margin:8px 12px 0;color:#ff6b6b;font-size:12px}.usp-results{padding:8px 8px 16px;overflow-y:auto}.usp-item{display:flex;align-items:center;gap:8px;padding:8px;border-radius:8px}.usp-item:hover{background:#ffffff0a}.usp-item-main{flex:1;display:flex;align-items:center;gap:10px;border:none;background:transparent;color:inherit;text-align:left;cursor:pointer}.usp-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;display:grid;place-items:center;background:#1a1f2b;color:#9bb0d3}.usp-avatar img{width:100%;height:100%;object-fit:cover}.usp-meta{display:flex;flex-direction:column;gap:2px}.usp-name{font-size:13px;font-weight:600;color:var(--text-primary, #e9eef8)}.usp-sub{font-size:12px;color:var(--text-secondary, #8b95a7)}.usp-add{border:none;background:#4f8cff1f;color:#4f8cff;border:1px solid rgba(79,140,255,.25);height:28px;width:28px;border-radius:6px;cursor:pointer}.usp-add:hover{background:#4f8cff33}.usp-empty{padding:24px 12px;font-size:12px;color:var(--text-secondary, #8b95a7)}@media (max-width: 768px){.user-search-panel{width:100vw}}:root{--bg-primary: #fff;--bg-secondary: #f8f9fa;--bg-tertiary: #e9ecef;--text-primary: #222;--text-secondary: #666;--border-color: #ddd;--accent-color: #4f8cff;--modal-bg: #fff;--modal-color: #222;--sidebar-bg: #f8f9fa;--chat-bg: #fff;--message-bg: #f1f1f1;--my-message-bg: #4f8cff;--my-message-color: #fff;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 20px;--spacing-2xl: 24px;--spacing-3xl: 32px;--spacing-4xl: 40px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--header-padding: var(--spacing-lg);--content-padding: var(--spacing-xl);--message-padding: var(--spacing-md);--input-padding: var(--spacing-md);--button-padding: var(--spacing-md) var(--spacing-lg)}body.light-mode{--bg-primary: #fff;--bg-secondary: #f8f9fa;--bg-tertiary: #e9ecef;--text-primary: #222;--text-secondary: #666;--border-color: #ddd;--accent-color: #4f8cff;--modal-bg: #fff;--modal-color: #222;--sidebar-bg: #f8f9fa;--chat-bg: #fff;--message-bg: #f1f1f1;--my-message-bg: #4f8cff;--my-message-color: #fff}body.dark-mode{--bg-primary: #181a1b;--bg-secondary: #232f3e;--bg-tertiary: #2a2a2a;--text-primary: #fff;--text-secondary: #ccc;--border-color: #444;--accent-color: #4f8cff;--modal-bg: #232f3e;--modal-color: #fff;--sidebar-bg: #232f3e;--chat-bg: #181a1b;--message-bg: #2a2a2a;--my-message-bg: #4f8cff;--my-message-color: #fff}body.light-mode,body.dark-mode{background:var(--bg-primary);color:var(--text-primary);overflow:hidden}.app-main-layout{display:flex;flex-direction:row;min-height:100vh;width:100vw;background:var(--bg-primary)}.app-content{flex:1;padding:var(--content-padding) var(--spacing-3xl);background:var(--bg-primary);height:100vh;overflow:hidden;display:flex;flex-direction:row;gap:var(--spacing-3xl)}.login-container{background:var(--bg-secondary);padding:2rem 2.5rem;border-radius:8px;box-shadow:0 2px 12px #00000014;display:flex;flex-direction:column;align-items:center;margin:60px auto;max-width:350px;color:var(--text-primary)}.login-container input{margin:.5rem 0;padding:.5rem;width:200px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary)}.login-container button{margin-top:1rem;padding:.5rem 1.5rem;background:var(--accent-color);color:#fff;border:none;border-radius:4px;cursor:pointer}.login-container .error{color:#e74c3c;margin-top:.5rem}.avatar-upload input[type=file]{display:none}.avatar-upload span{display:inline-block;background:#eee;padding:.3rem .7rem;border-radius:4px;cursor:pointer;margin-bottom:.5rem}.chat-list{width:220px;background:var(--sidebar-bg);color:var(--text-primary);overflow-y:auto;padding:0;border-right:1px solid var(--border-color);border-radius:8px;margin-right:24px}.favorites-panel{width:220px;background:var(--sidebar-bg);color:var(--text-primary);padding:16px;border-right:1px solid var(--border-color);border-radius:8px;margin-right:24px}.add-favorite-form{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.add-favorite-form input,.add-favorite-form select{padding:8px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary)}.add-favorite-form button{padding:8px;background:var(--accent-color);color:#fff;border:none;border-radius:4px;cursor:pointer}.favorites-list{display:flex;flex-direction:column;gap:8px}.favorite-item{display:flex;align-items:center;padding:8px;border-radius:6px;cursor:pointer;transition:background .2s;color:var(--text-primary)}.favorite-item:hover,.favorite-item.selected{background:var(--bg-tertiary)}.favorite-icon{margin-right:8px;font-size:1.2em}.favorite-name{flex:1;font-weight:500}.remove-favorite{background:none;border:none;color:#ff6b6b;cursor:pointer;font-size:1.1em;padding:2px 6px;border-radius:3px}.remove-favorite:hover{background:#ff6b6b1a}.chat-list-item{display:flex;align-items:center;padding:12px 10px;cursor:pointer;border-bottom:1px solid var(--border-color);transition:background .2s}.chat-list-item.selected,.chat-list-item:hover{background:var(--bg-tertiary)}.chat-list-info{flex:1;margin-left:10px}.chat-list-title{font-weight:700;color:var(--text-primary)}.chat-list-last{font-size:.85em;color:var(--text-secondary);margin-top:2px}.chat-list-badge{background:var(--accent-color);color:#fff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:.75em;font-weight:700;margin-left:8px}.chat-list-badge.mention-badge{background:#ff6b6b}.add-to-favorites-btn{background:none;border:none;color:gold;cursor:pointer;font-size:.9em;padding:4px;margin-left:8px;border-radius:3px;transition:background .2s}.add-to-favorites-btn:hover{background:#ffd7001a}.remove-from-favorites-btn{background:none;border:none;color:gold;cursor:pointer;font-size:.9em;padding:4px;margin-left:8px;border-radius:3px;transition:background .2s}.remove-from-favorites-btn:hover{background:#ff6b6b1a;color:#ff6b6b}.call-interface{position:fixed;inset:0;background:#000000e6;z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:center}.call-interface video{border-radius:8px;object-fit:cover}.call-controls{display:flex;gap:15px;margin-top:20px}.call-controls button{border-radius:50%;width:50px;height:50px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.call-controls button:hover{transform:scale(1.1)}.call-controls .mute-btn{background:#4caf50;color:#fff}.call-controls .mute-btn.muted{background:#ff6b6b}.call-controls .video-btn{background:#4caf50;color:#fff}.call-controls .video-btn.off{background:#ff6b6b}.call-controls .end-call-btn{background:#ff6b6b;color:#fff;transform:rotate(135deg)}.call-controls .end-call-btn:hover{transform:rotate(135deg) scale(1.1)}.chat-messages .my-message,.chat-messages .other-message{cursor:pointer;transition:background-color .2s}.chat-messages .my-message:hover,.chat-messages .other-message:hover{background-color:#ffffff0d}.chat-messages .my-message:hover .message-actions-hint,.chat-messages .other-message:hover .message-actions-hint{opacity:1}.pinned-messages{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:12px;margin-bottom:16px;max-height:200px;overflow-y:auto}.pinned-messages h4{margin:0 0 8px;color:var(--text-primary);font-size:14px;display:flex;align-items:center;gap:4px}.pinned-message{display:flex;align-items:center;gap:8px;padding:4px 0;border-bottom:1px solid var(--border-color)}.pinned-message:last-child{border-bottom:none}.pinned-sender{font-weight:700;color:var(--accent-color);font-size:12px;min-width:60px}.pinned-text{flex:1;color:var(--text-primary);font-size:13px;word-break:break-word}.unpin-btn{background:none;border:none;cursor:pointer;font-size:14px;color:#ff6b6b;padding:2px;border-radius:4px;transition:background-color .2s}.unpin-btn:hover{background-color:#ff6b6b1a}.context-menu{animation:fadeIn .2s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.delete-dialog-overlay{animation:fadeIn .2s ease-in-out}.delete-dialog{animation:fadeIn .3s ease-in-out;transform-origin:center}.delete-dialog h3{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:600}.delete-dialog p{font-size:14px;line-height:1.4;background:var(--bg-tertiary);padding:12px;border-radius:6px;border-left:3px solid #ff6b6b}.delete-dialog button{transition:all .2s ease;position:relative;overflow:hidden}.delete-dialog button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.delete-dialog button:active{transform:translateY(0)}.delete-dialog button span{display:block;margin-top:4px;font-weight:400}.chat-window{flex:1;background:var(--chat-bg);border-radius:var(--radius-md);display:flex;flex-direction:column;border:1px solid var(--border-color);color:var(--text-primary);height:calc(100vh - 120px);max-height:calc(100vh - 120px);overflow:hidden}.chat-window-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);font-style:italic}.chat-header{padding:var(--header-padding);border-bottom:1px solid var(--border-color);background:var(--bg-secondary);border-radius:var(--radius-md) var(--radius-md) 0 0;display:flex;align-items:center;justify-content:space-between;min-height:60px}.chat-messages{flex:1;padding:var(--content-padding);overflow-y:auto;overflow-x:hidden;background:var(--chat-bg);max-height:calc(100vh - 240px);display:flex;flex-direction:column;gap:var(--spacing-sm)}.my-message,.other-message{position:relative;max-width:80%;margin:0;display:flex;align-items:flex-start;padding:var(--message-padding) var(--spacing-lg);border-radius:var(--radius-xl);box-shadow:0 2px 8px #00000012;animation:msgIn .25s cubic-bezier(.4,2,.6,1) both;background:#e6f0ff;color:#222;word-wrap:break-word;line-height:1.4}.my-message{align-self:flex-end;background:var(--my-message-bg);color:var(--my-message-color);border-bottom-right-radius:4px}.other-message{align-self:flex-start;background:var(--message-bg);color:var(--text-primary);border-bottom-left-radius:4px}.my-message:after,.other-message:after{content:"";position:absolute;bottom:0;width:0;height:0}.my-message:after{right:-10px;border-left:10px solid #4f8cff;border-top:10px solid transparent;border-bottom:0 solid transparent}.other-message:after{left:-10px;border-right:10px solid #f1f1f1;border-top:10px solid transparent;border-bottom:0 solid transparent}@keyframes msgIn{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.msg-user{font-weight:700;margin-right:.5em}.msg-time{font-size:.75em;color:var(--text-secondary);margin-left:.5em}.chat-input{position:relative;display:flex;align-items:center;border-top:1px solid var(--border-color);padding:var(--spacing-md);background:var(--bg-secondary);border-radius:0 0 var(--radius-md) var(--radius-md);gap:var(--spacing-sm);min-height:60px}.chat-input input[type=text]{flex:1;padding:var(--input-padding);border:1px solid var(--border-color);border-radius:var(--radius-sm);margin-right:var(--spacing-sm);background:var(--bg-primary);color:var(--text-primary);font-size:14px;line-height:1.4;min-height:40px}.chat-input button{padding:var(--button-padding);background:var(--accent-color);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;font-weight:500;min-height:40px;transition:background-color .2s ease}.emoji-btn{background:none;border:none;font-size:1.5em;cursor:pointer;margin-right:var(--spacing-xs);padding:var(--spacing-sm);border-radius:var(--radius-sm);transition:background-color .2s ease;min-height:40px;display:flex;align-items:center;justify-content:center}.emoji-picker{position:absolute;bottom:60px;left:10px;z-index:10}.file-label{display:flex;align-items:center;margin-left:var(--spacing-sm);cursor:pointer;padding:var(--spacing-sm);border-radius:var(--radius-sm);transition:background-color .2s ease;min-height:40px}.file-input{display:none}.chat-input .voice-btn,.chat-input .schedule-btn,.chat-input .search-btn{background:none;border:none;cursor:pointer;padding:8px;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:color .2s;min-height:40px}.chat-input .voice-btn:hover,.chat-input .schedule-btn:hover,.chat-input .search-btn:hover{color:var(--accent-color)}.file-preview{margin:.5rem 0 0;display:flex;align-items:center;gap:.5rem}.chat-img{max-width:120px;max-height:80px;border-radius:6px;margin:.3rem 0}.chat-file{display:inline-block;margin:.3rem 0;color:#4f8cff;text-decoration:underline}.avatar-img{border-radius:50%;object-fit:cover;margin-right:8px;vertical-align:middle}.msg-reactions{margin-top:4px;display:flex;align-items:center;gap:4px}.msg-reaction{background:#eee;color:#222;border-radius:12px;padding:2px 8px;font-size:1em;margin-right:2px;-webkit-user-select:none;user-select:none;transition:background .15s}.msg-reaction.reacted{background:#4f8cff;color:#fff}.msg-reaction.add-reaction{background:#ddd;color:#555;font-weight:700}.reaction-picker-popup{position:absolute;background:#fff;border:1px solid #ccc;border-radius:8px;padding:6px 10px;z-index:10;margin-top:4px;box-shadow:0 2px 8px #0000001f}.settings-section{margin-bottom:24px;padding:16px;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border-color)}.settings-section h4{margin:0 0 12px;color:var(--text-primary);font-size:16px;font-weight:600}.settings-section label{display:flex;align-items:center;margin-bottom:12px;color:var(--text-secondary);font-size:14px;cursor:pointer}.settings-section input[type=checkbox]{margin-right:8px;width:16px;height:16px;accent-color:var(--accent-color)}.settings-section select{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:4px;padding:6px 8px;font-size:14px}.settings-section select:focus{outline:none;border-color:var(--accent-color)}.modal-backdrop{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--modal-bg);border-radius:12px;padding:20px;box-shadow:0 8px 32px #0006;color:var(--modal-color);min-width:320px;max-width:450px;max-height:85vh;overflow-y:auto;position:relative}.modal h3{margin:0;color:var(--modal-color);font-size:18px;font-weight:600}.modal button{background:var(--accent-color);color:#fff;border:none;border-radius:4px;padding:8px 16px;cursor:pointer;font-size:14px;transition:background .2s}.modal button:hover{background:#3a7cff}.modal button[type=button]{background:#555}.modal button[type=button]:hover{background:#666}.modal form{display:flex;flex-direction:column;gap:16px}.modal label{display:flex;flex-direction:column;gap:6px;font-weight:500;color:var(--text-primary)}.modal input[type=text]{padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;transition:border-color .2s}.modal input[type=text]:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #4f8cff1a}.avatar-upload{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;border:2px dashed var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s;background:var(--bg-secondary)}.avatar-upload:hover{border-color:var(--accent-color);background:var(--bg-tertiary)}.camera-icon{font-size:24px;color:var(--accent-color)}.upload-text{font-size:12px;color:var(--text-secondary);text-align:center}.avatar-preview{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;border-radius:8px;background:var(--bg-secondary)}.avatar-preview img{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid var(--accent-color)}.modal-button-group{display:flex;gap:8px;margin-top:8px}.modal-button-group button{flex:1;padding:10px 16px;font-size:14px;font-weight:500}.privacy-settings{border-top:1px solid var(--border-color);padding-top:16px;margin-top:16px}.privacy-option{margin-bottom:8px}.privacy-option label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--text-primary);padding:4px 0}.privacy-option input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent-color)}.privacy-option span{flex:1}.profile-status{margin:8px 0}.status-text{font-style:italic;color:var(--text-secondary);font-size:14px}.profile-bio{margin:12px 0;padding:12px;background:var(--bg-secondary);border-radius:8px;border-left:3px solid var(--accent-color)}.profile-bio p{margin:0;color:var(--text-primary);font-size:14px;line-height:1.4}.typing-indicator{font-style:italic;font-size:.95em;margin-left:8px;animation:typingFade 1.2s infinite alternate}@keyframes typingFade{0%{opacity:.6}to{opacity:1}}.contacts-sidebar{width:280px;background:var(--sidebar-bg);color:var(--text-primary);padding:var(--spacing-lg);border-right:1px solid var(--border-color);border-radius:var(--radius-md);margin-right:var(--spacing-2xl);height:calc(100vh - 120px);overflow-y:auto}.contacts-sidebar h3{margin:0 0 var(--spacing-lg) 0;font-size:1.2em;color:var(--text-primary);font-weight:600}.add-contact-form{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.add-contact-form input{padding:var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:14px;min-height:40px}.add-contact-form button{padding:var(--button-padding);background:var(--accent-color);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;font-weight:500;min-height:40px;transition:background-color .2s ease}.search-contact{width:100%;padding:var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);margin-bottom:var(--spacing-lg);font-size:14px;min-height:40px}.contacts-list{list-style:none;padding:0;margin:0;max-height:calc(100vh - 300px);overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-xs)}.contacts-list li{display:flex;align-items:center;padding:var(--spacing-md);border-radius:var(--radius-sm);cursor:pointer;transition:background .2s;color:var(--text-primary);margin:0;min-height:48px}.contacts-list li:hover,.contacts-list li.selected-contact{background:var(--bg-tertiary)}.contact-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-color);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;margin-right:8px}.message-search-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:20px;width:90%;max-width:600px;max-height:80vh;overflow-y:auto;z-index:1000;box-shadow:0 10px 30px #0000004d}.search-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid var(--border-color)}.search-header h3{margin:0;color:var(--text-primary)}.close-btn{background:none;border:none;font-size:20px;cursor:pointer;color:var(--text-secondary);padding:5px}.search-input-section{display:flex;gap:10px;margin-bottom:20px}.search-input-group{display:flex;flex:1}.search-input-group input{flex:1;padding:10px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary)}.search-input-group button{padding:10px 15px;background:var(--accent-color);color:#fff;border:none;border-radius:6px;cursor:pointer;margin-left:5px}.filter-toggle{padding:10px 15px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);cursor:pointer}.filter-toggle.active{background:var(--accent-color);color:#fff}.search-filters{background:var(--bg-secondary);padding:15px;border-radius:8px;margin-bottom:20px}.filter-row{display:flex;gap:15px;margin-bottom:10px;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:5px}.filter-group label{font-size:12px;color:var(--text-secondary)}.filter-group input{padding:8px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary)}.clear-filters-btn{padding:8px 12px;background:#ff6b6b;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px}.search-results{max-height:400px;overflow-y:auto}.search-result-item{padding:15px;border:1px solid var(--border-color);border-radius:8px;margin-bottom:10px;cursor:pointer;transition:background-color .2s}.search-result-item:hover{background:var(--bg-secondary)}.result-header{display:flex;justify-content:space-between;margin-bottom:8px}.sender{font-weight:700;color:var(--text-primary)}.timestamp{font-size:12px;color:var(--text-secondary)}.result-content p{margin:0 0 8px;color:var(--text-primary)}.file-indicator{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-secondary)}.result-highlight{margin-top:8px}.highlight{background:#ff0;color:#000;padding:2px 4px;border-radius:3px;font-size:12px}.no-results{text-align:center;color:var(--text-secondary);padding:40px 20px}.message-translator-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:20px;width:90%;max-width:500px;max-height:80vh;overflow-y:auto;z-index:1000;box-shadow:0 10px 30px #0000004d}.translator-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid var(--border-color)}.translator-header h3{margin:0;color:var(--text-primary)}.translator-content{display:flex;flex-direction:column;gap:20px}.original-message{background:var(--bg-secondary);padding:15px;border-radius:8px}.original-message h4,.message-content p{margin:0 0 10px;color:var(--text-primary)}.message-meta{display:flex;gap:15px;font-size:12px;color:var(--text-secondary)}.translation-controls{display:flex;gap:10px;align-items:center}.language-selector{display:flex;flex-direction:column;gap:5px;flex:1}.language-selector label{font-size:12px;color:var(--text-secondary)}.language-selector select{padding:8px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary)}.translate-btn{padding:8px 15px;background:var(--accent-color);color:#fff;border:none;border-radius:4px;cursor:pointer;display:flex;align-items:center;gap:5px}.translate-btn:disabled{background:var(--text-secondary);cursor:not-allowed}.translated-message{background:var(--bg-secondary);padding:15px;border-radius:8px}.translated-message h4,.translated-content p{margin:0 0 10px;color:var(--text-primary)}.translation-actions{display:flex;gap:10px}.copy-btn,.use-translation-btn{padding:6px 12px;border:none;border-radius:4px;cursor:pointer;font-size:12px;display:flex;align-items:center;gap:5px}.copy-btn{background:#4caf50;color:#fff}.use-translation-btn{background:var(--accent-color);color:#fff}.translation-history{border-top:1px solid var(--border-color);padding-top:15px}.history-toggle{width:100%;padding:10px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:5px}.history-list{margin-top:10px;max-height:200px;overflow-y:auto}.history-item{background:var(--bg-secondary);padding:10px;border-radius:6px;margin-bottom:8px;position:relative}.history-original,.history-translated{margin-bottom:5px;font-size:12px}.history-meta{display:flex;gap:10px;font-size:10px;color:var(--text-secondary)}.copy-history-btn{position:absolute;top:5px;right:5px;background:#4caf50;color:#fff;border:none;border-radius:3px;padding:3px 6px;cursor:pointer;font-size:10px}.voice-message-recorder{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:20px;width:90%;max-width:400px;z-index:1000;box-shadow:0 10px 30px #0000004d}.recorder-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid var(--border-color)}.recorder-header h3{margin:0;color:var(--text-primary)}.recorder-content{display:flex;flex-direction:column;gap:20px}.recording-interface{text-align:center}.recording-status{margin-bottom:20px;color:var(--text-primary)}.recording-indicator{display:flex;align-items:center;justify-content:center;gap:10px;color:#ff6b6b}.pulse-dot{width:12px;height:12px;background:#ff6b6b;border-radius:50%;animation:pulse 1.5s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.recording-controls{margin-bottom:20px}.record-btn,.stop-btn{width:60px;height:60px;border-radius:50%;border:none;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;margin:0 auto}.record-btn{background:#4caf50;color:#fff}.stop-btn{background:#ff6b6b;color:#fff}.recording-timer{font-size:18px;font-weight:700;color:var(--text-primary)}.playback-interface{display:flex;flex-direction:column;gap:15px}.audio-player{display:flex;flex-direction:column;gap:10px}.playback-controls{display:flex;justify-content:center}.play-btn,.pause-btn{width:40px;height:40px;border-radius:50%;border:none;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center}.play-btn{background:#4caf50;color:#fff}.pause-btn{background:#ff9800;color:#fff}.audio-progress{display:flex;flex-direction:column;gap:5px}.progress-bar{width:100%;height:6px;background:var(--bg-secondary);border-radius:3px;cursor:pointer;position:relative}.progress-fill{height:100%;background:var(--accent-color);border-radius:3px;transition:width .1s}.time-display{display:flex;justify-content:space-between;font-size:12px;color:var(--text-secondary)}.recording-actions{display:flex;gap:10px;justify-content:center}.delete-btn,.send-btn{padding:8px 15px;border:none;border-radius:6px;cursor:pointer;font-size:14px;display:flex;align-items:center;gap:5px}.send-btn{background:var(--accent-color);color:#fff}.recorder-footer{margin-top:20px;padding-top:15px;border-top:1px solid var(--border-color)}.recording-tip{font-size:12px;color:var(--text-secondary);text-align:center;margin:0}.message-scheduler-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:20px;width:90%;max-width:500px;max-height:80vh;overflow-y:auto;z-index:1000;box-shadow:0 10px 30px #0000004d}.scheduler-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid var(--border-color)}.scheduler-header h3{margin:0;color:var(--text-primary)}.scheduler-content{display:flex;flex-direction:column;gap:20px}.schedule-form{display:flex;flex-direction:column;gap:15px}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{font-size:14px;color:var(--text-primary);display:flex;align-items:center;gap:5px}.form-group textarea,.form-group input{padding:10px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-family:inherit}.form-group textarea{resize:vertical;min-height:80px}.form-row{display:flex;gap:15px}.form-row .form-group{flex:1}.scheduled-info{background:var(--bg-secondary);padding:10px;border-radius:6px;text-align:center}.scheduled-info p{margin:0;color:var(--text-primary)}.form-actions{display:flex;gap:10px}.schedule-btn,.update-btn,.cancel-btn{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-size:14px;display:flex;align-items:center;gap:5px;flex:1;justify-content:center}.schedule-btn,.update-btn{background:var(--accent-color);color:#fff}.cancel-btn{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.scheduled-list h4{margin:0 0 15px;color:var(--text-primary)}.scheduled-messages{display:flex;flex-direction:column;gap:10px}.scheduled-message-item{background:var(--bg-secondary);padding:15px;border-radius:8px;border:1px solid var(--border-color)}.message-content p{margin:0 0 10px;color:var(--text-primary)}.message-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:12px;color:var(--text-secondary);margin-bottom:10px}.status{font-weight:700}.time-until{color:var(--accent-color)}.message-actions{display:flex;gap:8px}.edit-btn,.cancel-btn,.delete-btn{padding:6px 12px;border:none;border-radius:4px;cursor:pointer;font-size:12px}.edit-btn{background:#4caf50;color:#fff}.delete-btn{background:#ff6b6b;color:#fff}.scheduler-footer{margin-top:20px;padding-top:15px;border-top:1px solid var(--border-color)}.toggle-list-btn{width:100%;padding:10px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:5px}
