:root{--bg:#0f0f12;--bg-elevated:#18181c;--border:#2a2a30;--text:#e4e4e7;--text-muted:#a1a1aa;--accent:#6366f1;--accent-hover:#818cf8;--danger:#ef4444;--success:#22c55e;--radius:8px;--radius-sm:6px;--shadow:0 4px 12px rgba(0,0,0,.3);--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}button,input,textarea{font:inherit}button{cursor:pointer}button:focus-visible,input:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:2px}.app-shell{display:flex;min-height:100vh;background:var(--bg)}.app-shell .sidebar{width:240px;background:#1e1e22;display:flex;flex-direction:column;border-right:1px solid var(--border)}.app-shell .server-header{height:52px;display:flex;align-items:center;padding:0 16px;border-bottom:1px solid var(--border);gap:12px}.app-shell .server-icon{font-size:1.25rem}.app-shell .server-name{font-weight:700;color:var(--text);text-decoration:none;font-size:1rem}.app-shell .server-name:hover{color:var(--text)}.app-shell .nav-section{padding:12px 8px;flex:0 0 auto}.app-shell .nav-section-header{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em;padding:0 8px 4px}.app-shell .channel-list{display:flex;flex-direction:column;gap:2px}.app-shell .channel-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:4px;color:var(--text-muted);text-decoration:none;font-size:14px}.app-shell .channel-item:hover{background:var(--bg-elevated);color:var(--text)}.app-shell .channel-item.active{background:var(--accent);color:#fff}.app-shell .channel-icon{opacity:.8;font-weight:600}.app-shell .channel-name{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-shell .channel-add,.app-shell .nav-item{color:var(--text-muted)}.app-shell .nav-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:4px;text-decoration:none;font-size:14px}.app-shell .nav-item:hover{background:var(--bg-elevated);color:var(--text)}.app-shell .nav-item.active{background:var(--accent);color:#fff}.app-shell .nav-icon{font-size:1rem}.app-shell .user-block{margin-top:auto;padding:8px;display:flex;align-items:center;gap:10px;background:var(--bg);border-top:1px solid var(--border);min-height:52px}.app-shell .user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}.app-shell .user-info{flex:1 1;min-width:0;display:flex;flex-direction:column}.app-shell .user-name{font-size:13px;font-weight:600;color:var(--text)}.app-shell .user-email{font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-shell .sign-out{padding:4px 8px;border-radius:4px;color:var(--text-muted);text-decoration:none;font-size:14px}.app-shell .sign-out:hover{background:var(--bg-elevated);color:var(--danger)}.app-shell .main-content{flex:1 1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.channel-header{padding:10px 16px 12px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:10px;flex-shrink:0}.channel-header-top{display:flex;align-items:center;gap:12px}.channel-search{flex:1 1;max-width:280px;padding:6px 12px;font-size:13px;background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--text)}.channel-search::placeholder{color:var(--text-muted)}.messages-area{flex:1 1;overflow-y:auto;padding:12px 20px;flex-direction:column;gap:0;min-width:0}.message-bubble,.messages-area{display:flex;width:100%;box-sizing:border-box}.message-bubble{gap:12px;padding:2px 0;max-width:100%;align-items:flex-end}.message-bubble:not(.message-bubble-mine){justify-content:flex-start;align-items:center}.message-bubble-mine{flex-direction:row-reverse;justify-content:flex-start}.message-bubble-mine .message-body{align-items:flex-end;max-width:75%;margin-left:0}.message-bubble-mine .message-header{flex-direction:row-reverse;justify-content:flex-end;text-align:right}.message-bubble-mine .message-content,.message-bubble-mine .message-content-grouped{background:hsla(0,0%,100%,.06);color:var(--text);padding:8px 12px;border-radius:12px 12px 4px 12px;max-width:100%;text-align:right;margin-left:auto}.message-bubble-mine .message-content-grouped{display:flex;flex-direction:row;align-items:baseline;justify-content:flex-end;gap:8px}.message-bubble-mine .message-time-inline{margin-left:0;margin-right:0;flex-shrink:0;color:var(--text-muted)}.message-bubble-mine .message-reactions-wrapper{display:flex;flex-direction:row-reverse;justify-content:flex-end;align-items:center;flex-wrap:wrap}.message-bubble-mine .message-reactions-wrapper .reaction-trigger{order:1}.message-bubble-mine .message-reactions-wrapper .message-reactions{order:0;margin-left:0;margin-right:4px}.message-content-grouped{margin-top:2px}.message-time-inline{font-size:11px;color:var(--text-muted);margin-left:8px}.message-body{min-width:0;max-width:75%}.message-bubble:hover{background:hsla(0,0%,100%,.02);border-radius:4px}.message-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}.message-header{display:flex;align-items:baseline;gap:8px;margin-bottom:2px}.message-username{font-weight:600;font-size:14px;color:var(--text)}.message-time{font-size:12px;color:var(--text-muted)}.message-content{font-size:14px;color:var(--text);word-break:break-word;line-height:1.4;background:hsla(0,0%,100%,.06);padding:8px 12px;border-radius:12px 12px 12px 4px}.message-reactions-wrapper{position:relative;margin-top:4px;min-height:28px;opacity:0;pointer-events:none;transform:translateY(4px);transition:opacity .2s ease-out,transform .2s ease-out;transition-delay:0s}.message-bubble-mine:hover .message-reactions-wrapper,.message-bubble:hover .message-reactions-wrapper{opacity:1;pointer-events:auto;transform:translateY(0);transition-delay:1s}.reaction-trigger{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px 6px;font-size:14px;border-radius:4px}.reaction-trigger:hover{color:var(--text)}.message-reactions-wrapper .message-reactions{display:inline-flex;flex-wrap:wrap;gap:4px;margin-left:4px;vertical-align:middle}.message-reactions{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.reaction-pill{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:12px;background:var(--bg-elevated);border:1px solid var(--border);font-size:12px;color:var(--text);cursor:pointer}.reaction-pill:hover{background:var(--border)}.reaction-pill.has-reacted{border-color:var(--accent);background:rgba(99,102,241,.2)}.message-input-area{padding:16px;border-top:1px solid var(--border);flex-shrink:0}.message-input-row{align-items:flex-end}.message-input-row input{flex:1 1;padding:10px 14px;font-size:14px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text)}.message-input-row button{padding:10px 20px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-weight:500}.message-input-row button:hover{background:var(--accent-hover)}.message-input-row button:disabled{opacity:.5;cursor:not-allowed}.add-reaction-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;font-size:14px}.add-reaction-btn:hover{color:var(--text)}.welcome-view{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;color:var(--text-muted);text-align:center}.welcome-view h2{color:var(--text);margin-bottom:8px}.typing-indicator{font-size:13px;color:var(--text-muted);font-style:italic;padding:6px 16px 8px;flex-shrink:0;border-top:1px solid var(--border);background:var(--bg)}.channel-header-name{font-weight:600;color:var(--text)}.channel-invite-btn{padding:6px 12px;font-size:13px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:6px;color:var(--text);cursor:pointer}.channel-invite-btn:hover{background:var(--bg);border-color:var(--accent);color:var(--accent)}.channel-call-btn{padding:6px 12px;font-size:13px;background:var(--accent);border:none;border-radius:6px;color:#fff;text-decoration:none;cursor:pointer}.channel-call-btn:hover{filter:brightness(1.1);color:#fff}.message-file-link{display:inline-flex;align-items:center;gap:6px;margin-top:4px;padding:6px 10px;background:hsla(0,0%,100%,.08);border:1px solid var(--border);border-radius:6px;color:var(--accent);cursor:pointer;font-size:13px}.message-file-link:hover{background:hsla(0,0%,100%,.12)}.message-caption{display:block;margin-bottom:4px}.message-call{font-style:italic;color:var(--text-muted)}.message-attach-btn{padding:8px 12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:6px;color:var(--text);cursor:pointer;font-size:16px}.message-attach-btn:disabled{opacity:.6;cursor:not-allowed}.message-input-row{display:flex;align-items:center;gap:8px}.message-camera-btn{padding:8px 12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:6px;color:var(--text);cursor:pointer;font-size:16px}.message-camera-btn:disabled{opacity:.6;cursor:not-allowed}.message-file-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.message-file-actions{display:inline-flex;align-items:center;gap:4px}.message-file-download{padding:6px 10px;background:hsla(0,0%,100%,.08);border:1px solid var(--border);border-radius:6px;color:var(--text-muted);cursor:pointer;font-size:14px}.message-file-download:hover{color:var(--accent);background:hsla(0,0%,100%,.12)}.channel-delete-btn{padding:6px 12px;font-size:13px;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-muted);cursor:pointer}.channel-delete-btn:hover{border-color:#c53030;color:#e53e3e}.channel-dm-avatar-wrap{position:relative;flex-shrink:0;width:24px;height:24px}.channel-dm-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;display:block}.channel-dm-avatar-initial{width:24px;height:24px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600}.channel-dm-status{position:absolute;bottom:0;right:0;width:8px;height:8px;border-radius:50%;border:2px solid var(--bg-elevated)}.channel-dm-status.online{background:#48bb78}.channel-dm-status.offline{background:var(--text-muted)}.channel-dm-unread{margin-left:auto;min-width:18px;height:18px;padding:0 5px;font-size:11px;font-weight:600;line-height:18px;text-align:center;background:var(--accent);color:#fff;border-radius:9px}.camera-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.camera-modal{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:20px;max-width:400px;display:flex;flex-direction:column;gap:16px}.camera-modal-video{width:100%;max-height:320px;background:#000;border-radius:8px}.invite-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.invite-modal{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;min-width:320px;max-width:400px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;gap:12px}.invite-modal-hint{font-size:13px;color:var(--text-muted);margin:0}.invite-modal-results{max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.invite-modal-results-unified{max-height:280px}.invite-search-section{margin-bottom:12px}.invite-search-section-label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}.invite-search-row{display:flex;align-items:center;gap:10px;padding:8px 0;cursor:pointer;border-radius:4px}.invite-search-row:hover{background:hsla(0,0%,100%,.05)}.invite-search-row input{cursor:pointer}.invite-search-icon{font-size:18px}.invite-search-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover}.invite-search-initial{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600}.main-with-banner{flex:1 1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.top-banner{height:52px;padding:0 20px;border-bottom:1px solid var(--border);justify-content:space-between;gap:16px;background:var(--bg-elevated)}.top-banner,.top-banner-user{flex-shrink:0;display:flex;align-items:center}.top-banner-user{gap:10px;position:relative}.top-banner-username{font-size:14px;font-weight:500;color:var(--text);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.top-banner-avatar-btn{padding:0;border:none;background:none;cursor:pointer;border-radius:50%;display:block}.top-banner-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;display:block}.top-banner-avatar-initial{width:32px;height:32px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600}.user-dropdown{position:absolute;top:calc(100% + 4px);right:0;min-width:180px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);z-index:100;padding:6px 0}.user-dropdown-item{display:block;padding:10px 14px;font-size:14px;color:var(--text);text-decoration:none;transition:background .15s}.user-dropdown-item:hover{background:var(--bg)}.user-dropdown-signout{color:var(--danger);border-top:1px solid var(--border);margin-top:4px;padding-top:10px}.global-search-wrap{position:relative;flex:1 1;max-width:420px}.global-search-input{width:100%;padding:10px 16px 10px 40px;font-size:14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text)}.global-search-input::placeholder{color:var(--text-muted)}.global-search-input:focus{border-color:var(--accent)}.global-search-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;max-height:400px;overflow-y:auto;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);z-index:100;padding:8px 0}.global-search-placeholder{padding:16px;color:var(--text-muted);font-size:14px;margin:0}.global-search-section{padding:4px 0}.global-search-section-title{display:block;padding:6px 12px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.global-search-item{display:block;padding:10px 12px;color:var(--text);text-decoration:none;font-size:14px;transition:background .15s}.global-search-item:hover{background:var(--bg)}.global-search-person{display:flex;align-items:center;gap:10px}.global-search-person-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0}.global-search-person-initial{width:32px;height:32px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}.global-search-person-name{font-weight:500;color:var(--text)}.global-search-message{display:flex;flex-direction:column;gap:2px}.global-search-msg-channel{font-size:12px;color:var(--text-muted)}.global-search-msg-content{font-size:13px;color:var(--text)}.call-room{padding:24px;display:flex;flex-direction:column;align-items:center;gap:24px}.call-room-back{color:var(--accent);text-decoration:none}.call-room-back:hover{text-decoration:underline}.call-room-error{color:var(--danger);max-width:400px;text-align:center}.call-room-error p{margin:0}.call-room-error p+p{margin-top:8px;font-size:14px}.call-room-ended{text-align:center;padding:24px;max-width:360px}.call-room-ended-title{font-size:18px;font-weight:600;margin:0 0 8px;color:var(--text)}.call-room-ended-detail{color:var(--text-muted);margin:0 0 20px;font-size:14px}.call-boxes{display:flex;gap:24px;flex-wrap:wrap;justify-content:center}.call-box{display:flex;flex-direction:column;align-items:center;padding:12px;border-radius:12px;background:var(--bg-elevated);border:2px solid transparent;transition:box-shadow .3s ease,border-color .3s ease}.call-box-talking{animation:call-pulse 2s ease-in-out infinite}@keyframes call-pulse{0%,to{box-shadow:0 0 0 0 rgba(34,197,94,.35);border-color:rgba(34,197,94,.4)}50%{box-shadow:0 0 0 12px rgba(34,197,94,0);border-color:rgba(34,197,94,.6)}}.call-box-header{display:flex;align-items:center;gap:10px;margin-bottom:8px;width:100%;justify-content:center}.call-box-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}.call-box-avatar-initial{width:40px;height:40px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:600}.call-box-name{font-weight:600;font-size:15px;color:var(--text)}.call-box-video{width:100%;height:100%;object-fit:cover;background:var(--bg);border-radius:8px;display:block}.call-box-video-wrap .call-box-video{position:absolute;inset:0;width:100%;height:100%}.call-hear-self{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-muted);cursor:pointer}.call-hear-self input{cursor:pointer}.call-unlock-hint{font-size:13px;color:var(--text-muted);margin:0 0 8px;text-align:center}.call-box-video-wrap{position:relative;width:320px;height:240px;border-radius:8px;overflow:hidden;background:var(--bg)}.call-box-video-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.7);color:var(--text-muted);font-size:14px}.call-controls{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px;justify-content:center}.call-control-btn{padding:10px 18px;font-size:14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer}.call-control-btn:hover{background:var(--bg);border-color:var(--accent)}.call-control-btn.call-control-off{opacity:.8;color:var(--text-muted)}.call-control-end{background:#c53030;border-color:#c53030;color:#fff}.call-control-end:hover{background:#e53e3e;border-color:#e53e3e;color:#fff}.incoming-call-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:1000}.incoming-call-modal{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:28px 32px;min-width:320px;box-shadow:var(--shadow)}.incoming-call-title{margin:0 0 8px;font-size:18px;font-weight:600;color:var(--text)}.incoming-call-caller{margin:0 0 20px;color:var(--text-muted);font-size:14px}.incoming-call-actions{display:flex;gap:12px}.btn-accept{background:var(--success)}.btn-accept,.btn-decline{flex:1 1;padding:12px 20px;color:#fff;border:none;border-radius:var(--radius);font-weight:600;cursor:pointer}.btn-decline{background:var(--danger)}.page-content{padding:24px;overflow-y:auto}.page-title{margin:0 0 8px;font-size:22px;font-weight:600;color:var(--text)}.page-description{margin:0 0 24px;color:var(--text-muted);font-size:14px}.card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:20px;max-width:480px}.form-card{display:flex;flex-direction:column;gap:16px}.card-title{margin:0 0 8px;font-size:16px;font-weight:600}.form-label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text-muted)}.form-input{padding:10px 14px;font-size:14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text)}.form-input:focus{outline:none;border-color:var(--accent)}.form-actions{display:flex;gap:10px;margin-top:8px}.btn-primary{padding:10px 20px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:500;font-size:14px;cursor:pointer}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{padding:10px 20px;background:transparent;color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;cursor:pointer}.btn-secondary:hover{background:var(--bg-elevated)}.member-checkboxes{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.member-check{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text);cursor:pointer}.member-check input{width:auto}.form-message{margin:0;font-size:13px;color:var(--success)}.form-message-error{color:var(--danger)!important}.app-shell .user-avatar-img{width:32px;height:32px}.app-shell .user-avatar-img,.message-avatar-img{border-radius:50%;object-fit:cover;flex-shrink:0}.message-avatar-img{width:40px;height:40px}.settings-avatar-row{margin-bottom:8px}.avatar-label{display:inline-flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer}.settings-avatar,.settings-avatar-placeholder{width:80px;height:80px;border-radius:50%;object-fit:cover}.settings-avatar-placeholder{background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:600}.avatar-file-input{display:none}.avatar-hint{font-size:12px;color:var(--text-muted)}.welcome-view-left{align-items:flex-start;padding:24px}.welcome-inner{width:100%;max-width:560px}.welcome-title{margin:0 0 8px;font-size:22px;font-weight:600;color:var(--text)}.welcome-desc{margin:0 0 24px;color:var(--text-muted);font-size:14px}@media (max-width:767px){.mobile-menu-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;min-width:44px;min-height:44px;padding:0;border:none;background:transparent;color:var(--text);cursor:pointer;border-radius:var(--radius)}.mobile-menu-btn:hover{background:var(--bg)}.mobile-menu-btn:active{opacity:.8}.app-shell .sidebar{position:fixed;top:0;left:0;bottom:0;width:min(280px,85vw);max-width:280px;z-index:600;transform:translateX(-100%);transition:transform .25s ease-out,box-shadow .25s ease-out;overflow-y:auto;-webkit-overflow-scrolling:touch;box-shadow:none}.app-shell.sidebar-open .sidebar{transform:translateX(0);box-shadow:8px 0 24px rgba(0,0,0,.4)}.app-shell .sidebar-overlay{display:block;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:550;opacity:0;pointer-events:none;transition:opacity .25s ease-out}.app-shell.sidebar-open .sidebar-overlay{opacity:1;pointer-events:auto}body.mobile-menu-open{overflow:hidden;touch-action:none}.app-shell .main-with-banner{width:100%;min-width:0}.app-shell .main-content{min-height:0;-webkit-overflow-scrolling:touch}.top-banner{padding:max(0px,env(safe-area-inset-top)) max(12px,env(safe-area-inset-right)) 0 max(12px,env(safe-area-inset-left));gap:8px;min-height:52px}.app-shell .sidebar{padding-top:env(safe-area-inset-top)}.global-search-wrap{max-width:none;flex:1 1;min-width:0}.global-search-input{padding:10px 12px 10px 36px;font-size:16px;min-height:44px}.top-banner-avatar,.top-banner-avatar-btn,.top-banner-avatar-initial{width:40px;height:40px;min-width:40px;min-height:40px}.top-banner-username{max-width:100px}.user-dropdown{min-width:200px;padding:8px 0}.user-dropdown-item{padding:14px 16px;font-size:15px;min-height:44px;display:flex;align-items:center}.channel-header{padding:10px 12px 12px}.channel-header-top{flex-wrap:wrap;gap:8px}.channel-search{max-width:none;width:100%;min-height:44px;font-size:16px}.channel-call-btn,.channel-delete-btn,.channel-invite-btn{min-height:44px;padding:10px 14px}.messages-area{padding:12px;-webkit-overflow-scrolling:touch}.message-input-area{padding:12px 12px max(12px,env(safe-area-inset-bottom))}.message-input-row{flex-wrap:wrap;gap:10px}.message-input-row input{min-height:44px;font-size:16px;flex:1 1 100%}.message-attach-btn,.message-camera-btn,.message-input-row button{min-height:44px;min-width:44px;padding:10px 14px}.message-body,.message-bubble-mine .message-body{max-width:85%}.add-reaction-btn,.reaction-trigger{min-height:36px;min-width:36px;padding:6px}.page-content{padding:16px;-webkit-overflow-scrolling:touch}.card{max-width:none}.btn-primary,.btn-secondary{min-height:44px;padding:12px 20px}.call-room{padding:16px;gap:16px;min-height:100%;-webkit-overflow-scrolling:touch}.call-room-back{display:inline-block;padding:10px 0;min-height:44px;line-height:24px}.call-room h1{font-size:20px;margin:0}.call-boxes{flex-direction:column;gap:16px}.call-box,.call-boxes{width:100%;max-width:100%}.call-box{padding:12px}.call-box-video-wrap{width:100%;max-width:100%;height:200px;min-height:180px}.call-box-video{object-fit:cover}.call-controls{flex-wrap:nowrap;gap:12px;margin-top:20px;padding:0 8px max(16px,env(safe-area-inset-bottom));justify-content:center}.call-control-btn{flex:1 1;min-height:52px;padding:14px 12px;font-size:13px}.call-control-end{flex:0 0 auto;min-width:100px}.call-unlock-hint{font-size:14px;padding:0 8px}.call-room-ended{padding:20px 16px}.call-room-error p+p{font-size:15px}.incoming-call-overlay{padding:16px;align-items:center}.incoming-call-modal{width:100%;max-width:100%;min-width:0;padding:24px 20px}.incoming-call-actions{flex-direction:column;gap:12px}.btn-accept,.btn-decline{min-height:52px;padding:16px 24px;font-size:16px}.camera-modal-overlay{padding:0;align-items:stretch}.camera-modal{max-width:none;width:100%;flex:1 1;min-height:0;display:flex;flex-direction:column;justify-content:center;padding:16px}.camera-modal-video{max-height:min(60vh,480px);width:100%;object-fit:cover;border-radius:12px}.camera-modal .form-actions{display:flex;gap:12px;margin-top:16px}.camera-modal .btn-primary,.camera-modal .btn-secondary{flex:1 1;min-height:48px}.invite-modal-overlay{padding:12px;align-items:flex-end}.invite-modal{max-width:none;width:100%;max-height:85vh;min-height:200px}.invite-modal-results,.invite-modal-results-unified{max-height:50vh;-webkit-overflow-scrolling:touch}}@media (min-width:768px){.mobile-menu-btn,.sidebar-overlay{display:none!important}}