:root{font-family:Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;color:#172033;background:#eef2f7;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}html,body,#app{margin:0;width:100%;height:100%;min-height:100%;overflow:hidden}body{min-height:100vh;min-height:100dvh;overflow:hidden}button,input{font:inherit}input,textarea,select,button{-webkit-text-size-adjust:100%;touch-action:manipulation}button{border:0}.app-shell{width:min(1480px,100%);height:100vh;height:100dvh;min-height:0;margin:0 auto;padding:18px;display:grid;grid-template-columns:360px minmax(0,1fr);gap:14px;overflow:hidden}.rail,.chat-pane{min-height:0;border:1px solid #d9e0ea;background:#fff;box-shadow:0 18px 42px #1f2d3d14}.rail{display:flex;flex-direction:column;gap:14px;overflow-x:hidden;overflow-y:auto;border-radius:18px;padding:16px;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.drawer-button,.drawer-close,.sidebar-scrim,.mobile-requests{display:none}.brand-row{display:flex;align-items:center;gap:12px;min-height:48px}.brand-mark,.account-avatar,.conversation-avatar,.avatar-button{position:relative;display:grid;place-items:center;padding:0;color:#fff;font-weight:800;flex:0 0 auto;overflow:hidden;line-height:1}.account-avatar img,.conversation-avatar img,.avatar-button img,.user-sheet-avatar img,.room-member-card img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block;object-fit:cover;object-position:center;transform:none}.account-avatar img{border-radius:inherit}.brand-mark{width:44px;height:44px;border-radius:12px;background:transparent}.brand-mark img{width:100%;height:100%;display:block}.brand-copy h1,.brand-copy p,.panel-title h2,.chat-header h2,.chat-header p,.account-main strong,.account-main span,.conversation-text strong,.conversation-text small,.message p{margin:0}.brand-copy h1{font-size:1.25rem;line-height:1.1}.brand-copy p,.account-main span,.conversation-text small,.quiet-note,.outgoing-note,.chat-header p,.chat-meta,.message time{color:#657084}.account-panel{display:grid;grid-template-columns:44px 1fr;gap:12px;align-items:center;min-width:0;padding:12px;border-radius:14px;background:#f5f7fb}.account-avatar{width:44px;height:44px;border-radius:14px}.account-avatar.editable{cursor:pointer;box-shadow:0 0 0 3px #2347f51f}.hidden-file-input{display:none}.account-main{display:grid;gap:3px;min-width:0}.account-main strong,.conversation-text strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-panel,.side-actions,.requests-panel{padding:12px;border-radius:14px;background:#f9fafc;border:1px solid #e5eaf2}.side-actions{display:grid;gap:8px}.auth-panel{position:relative;overflow:visible;padding:14px;background:radial-gradient(circle at 12% 0%,rgba(35,71,245,.16),transparent 34%),linear-gradient(180deg,#fff,#f8fbff);box-shadow:inset 0 1px #ffffffe6}.auth-panel:before{content:"";position:absolute;top:-46px;right:-34px;width:116px;height:116px;border-radius:999px;background:linear-gradient(135deg,#2347f529,#10b9811a);pointer-events:none}.auth-hero{position:relative;display:grid;gap:7px;margin-bottom:12px}.auth-kicker{width:fit-content;padding:4px 8px;border-radius:999px;color:#2442d8;background:#e8eeff;font-size:.7rem;font-weight:900;letter-spacing:.08em}.auth-hero h2{margin:0;font-size:1.35rem;letter-spacing:-.03em}.auth-hero p{margin:0;color:#657084;font-size:.9rem;line-height:1.55}.auth-badges{display:flex;flex-wrap:wrap;gap:6px}.auth-badges span{padding:5px 8px;border-radius:999px;color:#465166;background:#edf1f8e6;font-size:.76rem;font-weight:800}.auth-tabs{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:4px;margin-bottom:12px;border-radius:14px;background:#edf1f8}.auth-tabs button{min-height:38px;border-radius:11px;color:#59657a;background:transparent;cursor:pointer;font-weight:800}.auth-tabs button.active{color:#fff;background:#2347f5;box-shadow:0 8px 18px #2347f533}.field-grid{position:relative;display:grid;gap:8px}.field-grid label{margin-top:4px;color:#465166;font-size:.86rem;font-weight:650}.field-grid input,.composer input{width:100%;border:1px solid #d7dfeb;border-radius:10px;outline:none;background:#fff;color:#172033;transition:border-color .16s ease,box-shadow .16s ease}.field-grid input{min-height:44px;padding:10px 12px;border-radius:13px}.composer input{min-height:42px;padding:9px 12px}.field-grid input:focus,.composer input:focus{border-color:#4763ff;box-shadow:0 0 0 3px #4763ff21}.auth-actions,.account-actions,.request-actions{display:grid;gap:8px}.auth-actions{grid-template-columns:1fr 1fr;margin-top:12px}.auth-actions.single{grid-template-columns:1fr}.guest-action{width:100%;min-height:40px;margin-top:8px;border-radius:14px;color:#0f5132;background:#dcfce7;border:1px solid #bbf7d0;cursor:pointer;font-weight:800}.admin-entry{width:100%;min-height:38px;margin-top:8px;border-radius:14px;color:#2442d8;background:#e8eeff;border:1px solid #d9e2ff;cursor:pointer;font-weight:850}.guest-note{align-self:center;color:#657084;font-size:.86rem}.account-actions{grid-template-columns:1fr auto;margin-top:8px}.primary-action,.soft-action,.text-action,.mini-primary,.mini-soft,.send-button,.menu-action{min-height:40px;border-radius:10px;cursor:pointer;font-weight:750}.primary-action,.mini-primary,.send-button,.menu-action{color:#fff;background:#2347f5}.primary-action{min-height:44px;border-radius:14px;background:linear-gradient(135deg,#2347f5,#6b7cff);box-shadow:0 14px 26px #2347f538}.soft-action,.mini-soft,.menu-action.subtle{color:#1f2a44;background:#edf1f8;border:1px solid #dce4ef}.menu-action.danger{color:#991b1b;background:#fee2e2;border:1px solid #fecaca}.text-action{color:#59657a;background:transparent;padding:0 8px}button:disabled{cursor:not-allowed;opacity:.55}.message-toast{position:fixed;top:max(14px,env(safe-area-inset-top));left:50%;z-index:80;width:min(420px,calc(100vw - 28px));display:grid;gap:4px;padding:12px 14px;border-radius:16px;color:#172033;text-align:left;background:#fffffff5;border:1px solid #dfe6f0;box-shadow:0 18px 48px #0f172a33;transform:translate(-50%);cursor:pointer}.message-toast span{overflow:hidden;color:#657084;text-overflow:ellipsis;white-space:nowrap}.quick-compose-fab,.quick-composer-backdrop,.user-sheet-backdrop,.room-details-backdrop,.user-sheet,.room-details{display:none}.room-details-backdrop{display:grid;position:fixed;top:0;right:0;bottom:0;left:0;z-index:74;place-items:center;padding:20px;background:#0f172a59}.room-details{display:block;width:min(520px,100%);max-height:min(720px,calc(100vh - 40px));overflow:auto;padding:18px;border-radius:24px;background:#fff;border:1px solid #dfe6f0;box-shadow:0 28px 80px #0f172a3d}.room-details-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.room-details-header h3{margin:4px 0 2px;font-size:1.35rem}.room-details-header p,.room-notice{color:#657084;line-height:1.55}.eyebrow{color:#2442d8;font-size:.8rem;font-weight:900;letter-spacing:.08em}.room-details-header button,.more-button{min-height:38px;padding:0 12px;border-radius:999px;color:#4d5870;background:#edf1f8;font-weight:900;cursor:pointer}.room-members-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:14px 0}.room-member-card{min-width:0;display:grid;justify-items:center;gap:6px;padding:10px 6px;border-radius:16px;background:#f5f7fb;cursor:pointer}.room-member-card:disabled{cursor:default;opacity:.78}.room-member-card span{position:relative;display:grid;place-items:center;width:42px;height:42px;border-radius:14px;color:#fff;font-weight:900;overflow:hidden}.room-member-card strong{max-width:100%;overflow:hidden;color:#172033;font-size:.82rem;text-overflow:ellipsis;white-space:nowrap}.room-settings{display:grid;gap:10px;padding:12px;margin:14px 0 10px;border-radius:16px;background:#f3f6fb;border:1px solid #dfe6f0}.room-settings>div:first-child{display:flex;align-items:center;justify-content:space-between;gap:10px}.room-settings span{color:#657084}.room-setting-actions{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:8px}.room-setting-actions input{min-width:0;min-height:38px;padding:8px 10px;border:1px solid #d7dfeb;border-radius:12px;outline:none}.room-setting-actions button{min-height:38px;padding:0 12px;border-radius:12px;background:#e8eef8;font-weight:900}.mute-panel{display:grid;gap:8px;margin-top:10px;padding:10px;border-radius:12px;background:#f3f6fb;border:1px solid #dfe6f0}.mute-title{display:flex;align-items:center;justify-content:space-between;gap:10px;color:#465166;font-size:.82rem}.mute-title span{color:#657084}.mute-controls{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:7px}.mute-controls input{min-width:0;min-height:34px;padding:6px 9px;border:1px solid #d7dfeb;border-radius:9px;outline:none}.conversation-list{flex:0 0 auto;min-height:0;overflow:visible;display:flex;flex-direction:column;gap:8px;padding-right:2px}.conversation-list .conversation-item:first-child{position:sticky;top:0;z-index:2;background:#eef3ff}.conversation-item{width:100%;display:grid;grid-template-columns:42px 1fr auto;gap:10px;align-items:center;min-height:62px;padding:10px;border-radius:12px;text-align:left;color:#172033;background:transparent;cursor:pointer}.conversation-item:hover,.conversation-item.active{background:#eef3ff}.conversation-avatar{width:42px;height:42px;border-radius:13px;background:#45546d}.public-avatar{background:#101928}.conversation-text{min-width:0;display:grid;gap:3px}.conversation-badge{padding:4px 8px;border-radius:999px;background:#dfe7ff;color:#2442d8;font-size:.78rem;font-weight:800}.panel-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.panel-title h2{font-size:1rem}.panel-title span{min-width:26px;padding:3px 7px;border-radius:999px;background:#e8edf5;text-align:center;color:#465166;font-weight:800}.request-list{display:grid;gap:8px}.request-item{padding:10px;border-radius:12px;background:#fff;border:1px solid #e3e8f0}.request-item strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.request-actions{grid-template-columns:1fr 1fr;margin-top:8px}.quiet-note,.outgoing-note{font-size:.9rem;line-height:1.45;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-pane{display:grid;grid-template-rows:auto auto minmax(0,1fr) auto;height:calc(100vh - 36px);height:calc(100dvh - 36px);max-height:calc(100vh - 36px);max-height:calc(100dvh - 36px);overflow:hidden;border-radius:18px}.admin-page{min-height:0;height:calc(100vh - 36px);height:calc(100dvh - 36px);overflow:auto;border:1px solid #d9e0ea;border-radius:18px;background:radial-gradient(circle at 88% 0%,rgba(35,71,245,.12),transparent 32%),#fff;box-shadow:0 18px 42px #1f2d3d14}.auth-page{min-height:0;height:calc(100vh - 36px);height:calc(100dvh - 36px);display:grid;place-items:center;overflow:auto;border:1px solid #d9e0ea;border-radius:18px;background:radial-gradient(circle at 82% 12%,rgba(35,71,245,.16),transparent 30%),linear-gradient(135deg,#fff,#f5f8ff);box-shadow:0 18px 42px #1f2d3d14;padding:20px}.auth-card{width:min(440px,100%);display:grid;gap:14px;padding:22px;border-radius:24px;background:#ffffffeb;border:1px solid #dfe6f0;box-shadow:0 24px 70px #0f172a24}.auth-back{justify-self:start}.admin-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:22px;border-bottom:1px solid #e4e9f1}.admin-header h2{margin:4px 0;font-size:1.55rem}.admin-header p{margin:0;color:#657084}.admin-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;padding:18px}.admin-card{display:grid;gap:10px;align-content:start;padding:16px;border-radius:18px;background:#f8fbff;border:1px solid #e1e8f3}.admin-card h3,.admin-card p{margin:0}.admin-card p{color:#657084;line-height:1.6}.admin-card label{color:#465166;font-weight:800}.admin-card input{width:100%;min-height:44px;padding:10px 12px;border:1px solid #d7dfeb;border-radius:13px;outline:none}.admin-note{background:#f3f6fb}.admin-note strong{color:#2442d8;line-height:1.55}.chat-header{min-height:78px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px;border-bottom:1px solid #e4e9f1;background:#fff}.chat-title-block{min-width:0}.chat-title-block h2{font-size:1.35rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-meta{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:999px;background:#f3f6fb;white-space:nowrap}.public-shortcut{min-height:38px;padding:0 12px;border-radius:999px;color:#2442d8;background:#dfe7ff;cursor:pointer;font-weight:800;white-space:nowrap}.connection-dot{width:8px;height:8px;border-radius:999px;background:#9aa5b5}.connection-dot.live{background:#10b981}.error{margin:12px 18px 0;padding:11px 13px;border-radius:10px;background:#fff1f1;color:#aa1f1f;border:1px solid #ffd7d7}.messages{min-height:0;height:100%;overflow-x:hidden;overflow-y:auto;padding:22px 22px 92px;display:flex;flex-direction:column;gap:14px;background:#f7f9fc;overscroll-behavior:contain;scroll-padding-bottom:92px;-webkit-overflow-scrolling:touch}.message{width:100%;max-width:100%;display:grid;grid-template-columns:38px minmax(0,1fr);gap:10px;align-self:flex-start;touch-action:auto}.message.own{grid-template-columns:minmax(0,1fr) 38px;align-self:flex-end}.message:last-child{margin-bottom:44px}.message.own .avatar-button{grid-column:2;grid-row:1}.message.own .message-body{grid-column:1;grid-row:1;align-items:flex-end}.avatar-button{width:38px;height:38px;border-radius:12px;cursor:pointer}.message-body{display:flex;flex-direction:column;gap:5px;min-width:0;max-width:min(720px,82%)}.message.own .message-body{justify-self:end}.message-meta{display:flex;align-items:baseline;gap:8px;color:#4a5568;font-size:.88rem}.message.own .message-meta{flex-direction:row-reverse}.message p{width:fit-content;max-width:100%;padding:10px 12px;border-radius:14px;background:#fff;border:1px solid #e4e9f1;line-height:1.55;white-space:pre-wrap;overflow-wrap:anywhere;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;touch-action:manipulation}.message.own p{color:#fff;background:#2347f5;border-color:#2347f5}.message.recalled p,.message.own.recalled p{color:#7a8598;background:#eef2f7;border-color:#dfe6f0;font-style:italic}.empty-state{width:min(560px,100%);margin:auto;padding:18px;border-radius:12px;color:#687386;text-align:center;background:#fff;border:1px dashed #cdd6e4}.load-older{align-self:center;min-height:34px;padding:0 14px;border-radius:999px;color:#2442d8;background:#e8eeff;border:1px solid #d9e2ff;cursor:pointer;font-weight:850}.welcome-state{width:min(620px,100%);margin:auto;padding:26px;border-radius:24px;color:#172033;text-align:center;background:radial-gradient(circle at 20% 15%,rgba(35,71,245,.14),transparent 32%),linear-gradient(135deg,#fff,#f3f7ff);border:1px solid #dfe6f0;box-shadow:0 22px 60px #0f172a14}.welcome-state span{display:inline-grid;place-items:center;width:46px;height:46px;margin-bottom:12px;border-radius:16px;color:#fff;background:#2347f5;font-size:.68rem;font-weight:900}.welcome-state h3{margin-bottom:8px;font-size:1.35rem}.welcome-state p{color:#657084;line-height:1.7}.composer{display:flex;flex-wrap:wrap;gap:8px;align-items:center;align-self:end;min-height:62px;height:auto;max-height:116px;padding:10px 14px;border-top:1px solid #e4e9f1;background:#fff;overflow:hidden;position:relative;z-index:10}.upload-strip{flex:0 0 100%;display:grid;gap:5px;min-width:0;padding:6px 8px;border-radius:10px;color:#465166;background:#f3f6fb;border:1px solid #dfe6f0}.upload-strip-meta{display:flex;justify-content:space-between;gap:10px;min-width:0;font-size:.82rem}.upload-strip-meta span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-strip-meta strong{color:#2347f5}.upload-track{height:5px;overflow:hidden;border-radius:999px;background:#dfe6f0}.upload-track span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#2347f5,#7c8dff);transition:width .22s ease}.file-input{display:none}.attach-button,.clear-file-button{flex:0 0 auto;width:40px;height:40px;border-radius:999px;cursor:pointer;color:#1f2a44;background:#edf1f8;border:1px solid #dce4ef;font-weight:850}.clear-file-button{width:34px;height:34px;color:#657084;background:transparent}.send-button{flex:0 0 auto;min-width:92px;height:40px;min-height:40px;padding:0 16px;border-radius:999px}.composer input{flex:1 1 180px;width:auto;min-width:160px;height:40px;min-height:40px;max-height:40px;border-radius:999px;font-size:16px}.attachment{margin-top:8px}.attachment-image,.attachment-video{display:block;max-width:min(360px,100%);max-height:260px;border-radius:12px;border:1px solid #dfe6f0;background:#0f172a;object-fit:contain;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.attachment-image,.attachment-video{cursor:zoom-in;pointer-events:auto;touch-action:manipulation}.attachment-file{display:grid;gap:3px;width:min(300px,100%);padding:11px 12px;border-radius:12px;color:#172033;text-decoration:none;background:#fff;border:1px solid #dfe6f0;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.attachment-file span,.attachment-file small{color:#657084}.attachment-file.unavailable{color:#8a3340;background:#fff1f1}.context-menu{position:fixed;z-index:40;width:170px;padding:8px;border-radius:12px;background:#fff;border:1px solid #dfe6f0;box-shadow:0 18px 42px #1f2d3d2e}.context-menu button{width:100%}.context-menu button+button{margin-top:7px}.media-preview{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:grid;place-items:center;padding:18px;background:#0f172ae0;touch-action:manipulation}.media-preview img,.media-preview video{max-width:100%;max-height:88vh;border-radius:14px;object-fit:contain;box-shadow:0 24px 80px #00000059}.media-preview video{background:#000}.media-preview-close{position:fixed;top:max(16px,env(safe-area-inset-top));right:16px;min-height:40px;padding:0 14px;border-radius:999px;color:#172033;background:#fff;cursor:pointer;font-weight:800}@media (max-width: 980px){.app-shell{height:100vh;height:100dvh;min-height:0;grid-template-columns:minmax(0,1fr);padding:10px}.rail{position:fixed;top:10px;bottom:10px;left:10px;z-index:30;width:min(360px,calc(100vw - 28px));transform:translate(calc(-100% - 18px));transition:transform .22s ease;grid-template-rows:auto;align-content:start;max-height:none;overflow-y:auto;overscroll-behavior:contain}.rail.open{transform:translate(0)}.sidebar-scrim{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:25;background:#0f172a61;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.drawer-button{display:inline-grid;place-items:center;min-height:38px;padding:0 12px;border-radius:10px;color:#1f2a44;background:#edf1f8;border:1px solid #dce4ef;cursor:pointer;font-weight:800}.drawer-close{display:inline-grid;place-items:center;justify-self:end;min-height:34px;padding:0 10px;border-radius:9px;color:#59657a;background:#edf1f8;cursor:pointer;font-weight:750}.chat-pane{min-height:0;height:calc(100vh - 20px);height:calc(100dvh - 20px);max-height:calc(100vh - 20px);max-height:calc(100dvh - 20px)}.messages{min-height:0}}@media (max-width: 620px){:root{font-size:15px}.app-shell{height:100vh;height:100dvh;padding:0;gap:0}.rail,.chat-pane{border-radius:0;border-left:0;border-right:0}.auth-actions,.account-actions{grid-template-columns:1fr}.auth-actions{margin-top:10px}.account-actions{margin-top:6px}.mute-title{display:grid;gap:4px}.mute-controls{grid-template-columns:1fr}.mute-controls input,.mute-controls button{width:100%}.primary-action,.soft-action,.text-action{min-height:34px;border-radius:9px}.rail{top:0;bottom:0;left:0;width:min(318px,calc(100vw - 76px));padding:12px;gap:10px;border-right:1px solid #d9e0ea;display:flex;flex-direction:column}.brand-row{min-height:40px}.brand-mark{width:38px;height:38px;border-radius:10px}.brand-copy h1{font-size:1.08rem}.account-panel{grid-template-columns:38px 1fr;padding:10px}.account-avatar{width:38px;height:38px;border-radius:11px}.auth-panel{padding:10px}.auth-hero{gap:5px;margin-bottom:10px}.auth-hero h2{font-size:1.12rem}.auth-hero p{font-size:.82rem;line-height:1.45}.auth-badges span{padding:4px 7px;font-size:.7rem}.auth-tabs button{min-height:34px}.field-grid input{min-height:38px;padding:7px 10px;border-radius:11px}.field-grid label{margin:2px 0 4px;font-size:.82rem}.conversation-list{min-height:0;overflow:visible}.desktop-requests{display:none}.mobile-requests{display:block;max-height:none;overflow:visible}.requests-panel{max-height:190px;overflow:auto}.mobile-requests.requests-panel{max-height:none;overflow:visible}.conversation-item{min-height:54px;grid-template-columns:36px 1fr auto;padding:8px}.conversation-avatar{width:36px;height:36px;border-radius:11px}.chat-pane{height:100vh;height:100dvh;min-height:0;max-height:100vh;max-height:100dvh}.admin-page{height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;border-radius:0}.auth-page{height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;border-radius:0;padding:14px}.auth-card{padding:16px;border-radius:22px}.admin-header{padding:14px;gap:10px}.admin-header h2{font-size:1.2rem}.admin-grid{grid-template-columns:1fr;gap:10px;padding:12px}.chat-header{min-height:64px;padding:12px 14px;gap:8px}.chat-title-block{flex:1 1 auto}.chat-title-block h2{font-size:1.08rem}.chat-meta{padding:6px 8px;font-size:.86rem}.public-shortcut{min-height:34px;padding:0 9px;font-size:.86rem}.more-button{min-width:38px;min-height:34px;padding:0 9px}.messages{padding:14px 10px 176px;gap:10px;min-height:0;scroll-padding-bottom:176px}.message{width:100%;max-width:100%;grid-template-columns:32px minmax(0,1fr);gap:8px}.message.own{grid-template-columns:minmax(0,1fr) 32px}.message:last-child{margin-bottom:54px}.avatar-button{width:32px;height:32px;border-radius:10px;font-size:.82rem}.message-meta{font-size:.78rem}.message p{padding:8px 10px;border-radius:12px}.message-body{max-width:88%}.composer{display:flex;flex-wrap:wrap;gap:6px;min-height:54px;height:auto;max-height:112px;padding:8px 8px calc(8px + env(safe-area-inset-bottom));align-items:center}.upload-strip{flex:0 0 100%;padding:5px 7px;border-radius:9px}.upload-strip-meta{font-size:.76rem}.composer input{flex:1 1 0;width:auto;min-width:120px;min-height:38px;height:38px;max-height:38px;padding:7px 11px;border-radius:999px;font-size:16px}.send-button{flex:0 0 auto;min-width:56px;min-height:38px;height:38px;padding:0 10px;border-radius:999px;font-size:16px}.attach-button{flex:0 0 38px;width:38px;height:38px}.clear-file-button{flex:0 0 30px;width:30px;height:30px}.attachment-image,.attachment-video{max-width:min(260px,100%);max-height:220px}.context-menu{max-width:calc(100vw - 24px)}.quick-compose-fab{position:fixed;right:14px;bottom:calc(82px + env(safe-area-inset-bottom));z-index:35;display:grid;place-items:center;width:54px;height:54px;border-radius:999px;color:#fff;background:#2347f5;box-shadow:0 16px 38px #2347f557;font-weight:900;cursor:pointer}.quick-composer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;display:block;background:#0f172a59}.user-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:72;display:block;background:#0f172a61}.room-details-backdrop{align-items:end;padding:10px;z-index:74}.room-details{width:100%;max-height:min(82vh,720px);padding:14px;border-radius:22px}.room-members-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.room-setting-actions{grid-template-columns:1fr}.user-sheet{position:fixed;left:10px;right:10px;bottom:calc(10px + env(safe-area-inset-bottom));display:grid;grid-template-columns:54px 1fr;gap:10px;padding:14px;border-radius:20px;background:#fff;border:1px solid #dfe6f0;box-shadow:0 22px 60px #0f172a40}.user-sheet-avatar{position:relative;display:grid;place-items:center;width:54px;height:54px;border-radius:16px;color:#fff;font-weight:900;overflow:hidden}.user-sheet-main{display:grid;align-content:center;gap:3px;min-width:0}.user-sheet-main strong,.user-sheet-main span,.user-sheet-main small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-sheet-main span,.user-sheet-main small{color:#657084}.user-sheet .menu-action{grid-column:1 / -1;min-height:44px}.quick-composer{position:fixed;left:10px;right:10px;bottom:calc(10px + env(safe-area-inset-bottom));display:grid;gap:10px;padding:12px;border-radius:18px;background:#fff;border:1px solid #dfe6f0;box-shadow:0 22px 60px #0f172a3d}.quick-composer-title,.quick-composer-actions{display:flex;align-items:center;justify-content:space-between;gap:10px}.quick-composer-title button{min-height:32px;padding:0 10px;border-radius:999px;color:#59657a;background:#edf1f8;font-weight:800}.quick-composer input{width:100%;min-height:44px;padding:10px 12px;border:1px solid #d7dfeb;border-radius:14px;outline:none;font-size:16px}.quick-composer .send-button{min-width:76px}}@media (max-width: 390px){.composer{gap:5px;padding-left:6px;padding-right:6px}.composer input{min-width:120px}.send-button{min-width:50px;padding:0 8px}.attach-button{flex-basis:34px;width:34px}}
