:root{color:#111827;background:#f8fafc;font-family:Inter,PingFang SC,Microsoft YaHei,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:geometricPrecision;--bg: #f8fafc;--chat-bg: #f3f4f6;--surface: #ffffff;--surface-soft: #f1f5f9;--line: #e5e7eb;--line-strong: #d1d5db;--text: #111827;--muted: #6b7280;--subtle: #9ca3af;--primary: #2563eb;--primary-pressed: #1d4ed8;--security: #0f766e;--security-soft: #e6f7f4;--warning: #f59e0b;--warning-soft: #fff7e6;--danger: #dc2626;--danger-soft: #fef2f2;--radius: 8px;--shadow-soft: 0 2px 10px rgba(15, 23, 42, .06)}*{box-sizing:border-box}html,body,#app{min-height:100%}body{margin:0;overflow:hidden;background:var(--bg)}button,input,textarea{font:inherit}button{border:0}button:disabled{cursor:not-allowed}svg{flex:none}.shell{display:grid;grid-template-columns:336px minmax(420px,1fr) 320px;height:100vh;height:100dvh;overflow:hidden;background:var(--bg)}.conversation-pane,.detail-pane{min-height:0;display:flex;flex-direction:column;background:var(--surface)}.conversation-pane{border-right:1px solid var(--line)}.detail-pane{border-left:1px solid var(--line)}.pane-header,.chat-header,.detail-pane header{min-height:56px;padding:0 14px;display:flex;align-items:center;justify-content:space-between;background:#fffffff5;border-bottom:1px solid var(--line)}.pane-header{padding-top:env(safe-area-inset-top);min-height:calc(56px + env(safe-area-inset-top))}.pane-header strong,.chat-header strong,.detail-pane header strong{font-size:17px;font-weight:650;letter-spacing:0}.chat-header{position:relative;z-index:5;display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:8px;padding-top:env(safe-area-inset-top);min-height:calc(56px + env(safe-area-inset-top));box-shadow:var(--shadow-soft)}.title-stack{min-width:0;display:grid;gap:2px;align-content:center}.title-stack strong,.title-stack span,.chat-header span,small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-header span,small{color:var(--muted);font-size:12px}.chat-header nav{display:flex;gap:2px}.mobile-back{display:none}.icon-button{width:36px;height:36px;display:inline-grid;place-items:center;color:#374151;background:transparent;border-radius:8px;cursor:pointer}.icon-button:hover{color:var(--primary);background:var(--surface-soft)}.icon-button.active{color:var(--primary);background:#eff6ff}.icon-button:disabled{opacity:.42;cursor:not-allowed}.icon-button:disabled:hover{color:#374151;background:transparent}.header-add{position:relative}.global-add-menu{position:absolute;top:42px;right:0;z-index:20;width:146px;display:grid;padding:6px;background:#1f2937;border:1px solid rgba(255,255,255,.08);border-radius:8px;box-shadow:0 14px 30px #0f172a3d}.global-add-menu:before{content:"";position:absolute;top:-6px;right:13px;width:12px;height:12px;transform:rotate(45deg);background:#1f2937;border-left:1px solid rgba(255,255,255,.08);border-top:1px solid rgba(255,255,255,.08)}.global-add-menu button{position:relative;min-height:40px;display:flex;align-items:center;gap:9px;padding:0 10px;color:#f8fafc;background:transparent;border-radius:6px;cursor:pointer;text-align:left}.global-add-menu button:hover{background:#ffffff14}.status-strip,.chat-warning{min-height:32px;display:flex;align-items:center;gap:6px;padding:6px 12px;color:var(--security);background:var(--security-soft);border-bottom:1px solid #c9e8e3;font-size:12px;line-height:18px}.status-strip.warning{color:#92400e;background:var(--warning-soft);border-color:#fde4b5}.status-strip.offline{color:#991b1b;background:var(--danger-soft);border-color:#fecaca}.status-strip.connecting,.status-strip.reconnecting{color:#1e40af;background:#eff6ff;border-color:#bfdbfe}.chat-warning{color:#0f766e;background:#f0fdfa}.search-box{margin:10px 12px;min-height:36px;display:flex;align-items:center;gap:8px;padding:0 11px;color:var(--muted);background:var(--surface-soft);border:1px solid transparent;border-radius:8px}.search-box:focus-within{background:var(--surface);border-color:#bfdbfe}.search-box.embedded{margin:0 0 4px}.search-box input{width:100%;min-width:0;border:0;outline:0;color:var(--text);background:transparent}.search-box input::placeholder,.composer textarea::placeholder{color:var(--subtle)}.conversation-list{min-height:0;display:grid;align-content:start;overflow:auto}.conversation-row,.list-row{width:100%;min-width:0;display:grid;grid-template-columns:44px minmax(0,1fr) auto;gap:10px;min-height:68px;align-items:center;padding:9px 12px;color:var(--text);text-align:left;background:var(--surface);border-bottom:1px solid var(--line);cursor:pointer}.list-row{min-height:60px;border-top:0}.create-contact-row{grid-template-columns:22px 44px minmax(0,1fr)}.conversation-row:hover,.list-row:hover{background:#f8fafc}.conversation-row.active{background:#eff6ff}.conversation-row.active .row-title{color:var(--primary)}.avatar,.mini-avatar{overflow:hidden;width:42px;height:42px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#2563eb,#0f766e);border-radius:8px;font-weight:700;letter-spacing:0}.avatar img,.mini-avatar img{width:100%;height:100%;display:block;object-fit:cover}.avatar.large{width:62px;height:62px;margin:0 auto;border-radius:14px}.mini-avatar{width:32px;height:32px;margin-top:1px;border-radius:7px;font-size:11px}.conversation-copy,.list-row span:not(.avatar):not(.check-box){min-width:0;display:grid;gap:4px}.row-title,.row-summary{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.row-title{display:flex;align-items:center;gap:4px;font-size:14px;font-weight:600}.row-summary{display:flex;align-items:center;gap:4px;color:var(--muted);font-size:13px}.row-meta{display:grid;justify-items:end;gap:7px;color:var(--subtle);font-size:12px}.row-meta b{min-width:18px;height:18px;display:grid;place-items:center;padding:0 5px;color:#fff;background:var(--danger);border-radius:999px;font-size:11px;line-height:18px}.row-actions{display:flex;gap:6px;justify-content:flex-end}.row-actions button{min-height:28px;padding:0 8px;color:var(--security);background:var(--security-soft);border-radius:6px;cursor:pointer;font-size:12px}.row-actions button:last-child{color:var(--danger);background:var(--danger-soft)}.row-actions button:only-child,.row-actions button:first-child{color:var(--security);background:var(--security-soft)}.row-actions button:disabled{color:var(--muted);background:var(--surface-soft)}.bottom-tabs,.mobile-bottom-tabs{position:sticky;bottom:0;z-index:4;display:grid;grid-template-columns:repeat(3,1fr);margin-top:auto;padding-bottom:env(safe-area-inset-bottom);background:#fffffffa;border-top:1px solid var(--line)}.mobile-bottom-tabs{display:none}.bottom-tabs button,.mobile-bottom-tabs button{min-height:54px;display:grid;place-items:center;gap:2px;color:var(--muted);background:transparent;cursor:pointer;font-size:12px}.bottom-tabs button.active,.mobile-bottom-tabs button.active{color:var(--primary)}.chat-pane{min-width:0;min-height:0;display:grid;grid-template-rows:auto auto minmax(0,1fr) auto;background:var(--chat-bg)}.message-stream,.work-panel,.call-panel{min-height:0;overflow:auto;padding:16px clamp(12px,2.5vw,28px)}.message-stream{background:radial-gradient(circle at 28px 34px,rgba(210,170,96,.16) 0 2px,transparent 3px),radial-gradient(circle at 96px 92px,rgba(210,170,96,.12) 0 9px,transparent 10px),radial-gradient(circle at 182px 42px,transparent 0 10px,rgba(210,170,96,.14) 11px 12px,transparent 13px),linear-gradient(30deg,transparent 0 46px,rgba(210,170,96,.12) 47px,transparent 49px),linear-gradient(#fffcf6eb,#fffcf6eb);background-color:#fbf5ea;background-size:220px 160px}.time-divider{width:fit-content;margin:0 auto 14px;padding:3px 9px;color:#fff;background:#c3c8d0;border-radius:4px;font-size:12px}.message-row{position:relative;display:flex;gap:10px;align-items:flex-start;width:100%;margin:10px 0;justify-content:flex-start}.message-row.mine{justify-content:flex-end}.message-row.mine .mini-avatar{order:2}.message-row.mine .bubble{order:1}.message-row.system{justify-content:center}.message-row.system .mini-avatar{display:none}.mini-avatar{width:44px;height:44px;display:inline-grid;place-items:center;flex:0 0 auto;color:#d61f69;background:#ffe1eb;border-radius:999px;font-size:17px;font-weight:650}.message-row:nth-of-type(3n) .mini-avatar{color:#008b7a;background:#d9fbf3}.message-row:nth-of-type(3n+1) .mini-avatar{color:#0b8bd9;background:#dff4ff}.bubble{position:relative;max-width:min(72%,680px);min-width:84px;min-height:50px;padding:11px 14px 22px;color:var(--text);background:#fff;border:0;border-radius:4px 10px 10px;box-shadow:0 1px 2px #1f293733}.message-row.mine .bubble{color:var(--text);background:#fff;border-radius:10px 4px 10px 10px}.message-row.system .bubble{max-width:86%;padding:5px 9px;color:var(--muted);background:#ffffffb8;border-color:transparent;border-radius:6px;box-shadow:none}.bubble.revoked,.bubble.burned{color:var(--muted);background:#f3f4f6}.bubble strong{display:block;margin-bottom:4px;color:#d61f69;font-size:15px;line-height:20px}.bubble p{display:flex;align-items:center;gap:4px;margin:0;padding-right:36px;font-size:20px;line-height:1.42;word-break:break-word;white-space:pre-wrap}.voice-message{min-width:min(260px,52vw);display:grid;grid-template-columns:36px minmax(90px,1fr) auto;align-items:center;gap:10px;padding-right:36px}.voice-play{width:36px;height:36px;display:grid;place-items:center;color:#fff;background:var(--security);border-radius:999px;cursor:pointer}.voice-play:disabled{opacity:.46;cursor:wait}.voice-wave{min-width:0;height:34px;display:flex;align-items:center;gap:3px}.voice-wave span{width:3px;min-height:8px;background:#94a3b8;border-radius:999px}.voice-duration{color:var(--muted);font-size:13px;font-variant-numeric:tabular-nums}.image-message{position:relative;width:min(330px,58vw);min-width:180px;margin:-5px -8px 0;padding:0 0 22px}.image-thumb{width:100%;display:block;padding:0;background:transparent;border-radius:7px;cursor:zoom-in}.image-thumb:disabled{cursor:wait}.image-message img,.image-placeholder{width:100%;aspect-ratio:4 / 3;display:block;object-fit:cover;background:#e5e7eb;border-radius:7px}.image-placeholder{display:grid;place-items:center;color:#64748b}.image-message figcaption{margin:8px 4px 0;padding-right:36px;font-size:15px;line-height:20px;word-break:break-word;white-space:pre-wrap}.image-status{position:absolute;inset:0 0 22px;display:grid;place-items:center;color:#fff;background:#0f172a57;border-radius:7px;font-size:13px;font-weight:650}.image-message.failed .image-status{background:#b91c1c94}.image-preview-overlay{position:fixed;inset:0;z-index:70;display:grid;grid-template-rows:minmax(0,1fr) auto;place-items:center;gap:14px;padding:64px 24px 28px;background:#0f172aeb}.image-preview-overlay img{max-width:min(100%,1180px);max-height:calc(100vh - 128px);object-fit:contain;border-radius:8px;box-shadow:0 20px 60px #00000059}.image-preview-overlay p{max-width:min(100%,780px);margin:0;color:#f8fafc;font-size:15px;line-height:1.5;text-align:center}.image-preview-close{position:fixed;top:max(18px,env(safe-area-inset-top));right:18px;width:42px;height:42px;display:grid;place-items:center;color:#fff;background:#0f172ab8;border:1px solid rgba(255,255,255,.18);border-radius:999px;cursor:pointer}.bubble small{position:absolute;right:10px;bottom:5px;display:inline-flex;align-items:center;gap:3px;color:#6b7280;text-align:right;font-size:16px;line-height:20px}.message-row.mine .bubble small{color:#6b7280}.message-meta .receipt-icon{width:16px;height:16px;color:#64748b;stroke-width:2.6}.message-meta .receipt-icon.read{color:#0ea5e9}.message-row.selected .bubble{box-shadow:0 1px 2px #1f293733,0 0 0 2px #2563eb3d}.message-menu{position:fixed;z-index:40;width:156px;display:grid;padding:6px;background:#1f2937fa;border-radius:8px;box-shadow:0 16px 36px #0f172a47}.message-menu button{min-height:38px;padding:0 12px;color:#f9fafb;background:transparent;border-radius:6px;cursor:pointer;text-align:left}.message-menu button:hover{background:#ffffff1a}.message-menu button:disabled{color:#f9fafb61;cursor:not-allowed}.composer{position:relative;z-index:6;display:grid;grid-template-columns:auto minmax(0,1fr) auto auto;gap:8px;align-items:end;padding:9px 12px calc(9px + env(safe-area-inset-bottom));background:#fffffffa;border-top:1px solid var(--line);box-shadow:0 -2px 10px #0f172a0a}.voice-hold-button.recording{color:#fff;background:var(--danger)}.voice-recording-bar{position:absolute;left:12px;right:12px;bottom:calc(58px + env(safe-area-inset-bottom));min-height:44px;display:flex;align-items:center;gap:10px;padding:0 14px;color:var(--text);background:#fff;border:1px solid var(--line);border-radius:999px;box-shadow:0 12px 34px #0f172a29}.voice-recording-bar.cancel{color:var(--danger);border-color:#fecaca;background:#fff1f2}.voice-recording-bar.sending{color:var(--primary)}.voice-recording-bar strong{font-variant-numeric:tabular-nums}.voice-recording-bar span:last-child{min-width:0;overflow:hidden;color:currentColor;text-overflow:ellipsis;white-space:nowrap}.record-dot{width:10px;height:10px;flex:0 0 auto;background:var(--danger);border-radius:999px;box-shadow:0 0 0 6px #dc26261f}.composer textarea{min-height:38px;max-height:104px;min-width:0;resize:none;border:0;outline:0;padding:8px 10px;color:var(--text);background:var(--surface-soft);border-radius:8px;line-height:22px}.composer textarea:focus{background:#fff;box-shadow:inset 0 0 0 1px #bfdbfe}.emoji-panel{position:absolute;right:58px;bottom:calc(60px + env(safe-area-inset-bottom));width:min(288px,calc(100vw - 24px));display:grid;grid-template-columns:repeat(6,1fr);gap:4px;padding:10px;background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:0 12px 34px #0f172a29}.emoji-panel button{aspect-ratio:1;display:grid;place-items:center;color:var(--text);background:transparent;border-radius:8px;cursor:pointer;font-size:21px;line-height:1}.emoji-panel button:hover{background:var(--surface-soft)}.send-button,.primary-action,.login-panel button{min-height:38px;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 14px;color:#fff;background:var(--primary);border-radius:8px;cursor:pointer}.send-button:hover,.primary-action:hover,.login-panel button:hover{background:var(--primary-pressed)}.primary-action:disabled{opacity:.45}.secondary-action{min-height:36px;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 12px;color:#374151;background:#fff;border:1px solid var(--line-strong);border-radius:8px;cursor:pointer}.secondary-action:hover{color:var(--primary);border-color:#bfdbfe}.danger-action{min-height:40px;display:inline-flex;align-items:center;justify-content:center;gap:6px;color:var(--danger);background:#fff;border:1px solid #fecaca;border-radius:8px;cursor:pointer}.plus-panel{position:absolute;right:10px;bottom:calc(60px + env(safe-area-inset-bottom));width:min(300px,calc(100vw - 20px));display:grid;grid-template-columns:repeat(auto-fit,minmax(74px,1fr));gap:8px;padding:12px;background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:0 12px 34px #0f172a29}.hidden-file-input{display:none}.plus-panel button{min-height:70px;display:grid;place-items:center;gap:6px;color:#374151;background:var(--surface-soft);border-radius:8px;cursor:pointer;font-size:12px}.plus-panel button.active,.plus-panel button:hover{color:var(--security);background:var(--security-soft)}.detail-pane{min-width:0;padding-bottom:16px;overflow:auto;background:#f8fafc}.member-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:16px;background:#fff;border-bottom:1px solid var(--line)}.member-grid button{overflow:hidden;aspect-ratio:1;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#2563eb,#0f766e);border-radius:8px;cursor:pointer;font-weight:700}.member-grid img{width:100%;height:100%;display:block;object-fit:cover}.settings-list{display:grid;margin-top:10px;background:#fff;border-top:1px solid var(--line)}.settings-list button{min-height:48px;display:flex;align-items:center;gap:9px;padding:0 16px;color:var(--text);background:transparent;border-bottom:1px solid var(--line);cursor:pointer;text-align:left}.settings-list button:hover{background:#f8fafc}.settings-list .danger-row{color:var(--danger)}.settings-list button span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inline-settings{margin-top:0;border:1px solid var(--line)}.work-panel{display:grid;align-content:start;gap:10px;background:#f8fafc}.work-panel .list-row,.work-panel .info-block,.work-panel .profile-block,.work-panel .single-contact-grid,.work-panel .group-settings-card{border-radius:0}.single-contact-grid{display:flex;gap:18px;align-items:start;padding:18px 16px;background:#fff;border:1px solid var(--line)}.single-contact-card{width:74px;display:grid;justify-items:center;gap:8px;color:var(--text);background:transparent;cursor:pointer;text-align:center}.single-contact-card strong{width:100%;overflow:hidden;color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500}.add-avatar{color:var(--muted);background:var(--surface-soft);border:1px dashed var(--line-strong)}.group-settings-card{display:grid;gap:0;overflow:hidden;background:#fff;border:1px solid var(--line)}.setting-field,.setting-row,.section-title{min-height:52px;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;padding:10px 12px;border-bottom:1px solid var(--line)}.setting-field{grid-template-columns:54px minmax(0,1fr) auto}.setting-field span,.setting-row strong,.section-title strong{color:var(--text);font-weight:600}.setting-row{width:100%;color:var(--text);text-align:left;background:transparent;cursor:pointer}.setting-row:hover{background:#f8fafc}.setting-row span:first-child{min-width:0;display:grid;gap:3px}.setting-row small{color:var(--muted)}.setting-field input{min-width:0;height:36px;padding:0 10px;color:var(--text);background:var(--surface-soft);border:1px solid transparent;border-radius:8px;outline:0}.setting-field input:focus{background:#fff;border-color:#bfdbfe}.switch{position:relative;width:42px;height:24px;background:#cbd5e1;border-radius:999px;transition:background .16s ease}.switch:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:999px;box-shadow:0 1px 2px #0f172a38;transition:transform .16s ease}.switch.active{background:var(--primary)}.switch.active:after{transform:translate(18px)}.section-title .secondary-action{min-height:32px}.member-setting-row{border-bottom:1px solid var(--line)}.danger-zone .setting-row{color:var(--danger)}.danger-zone .setting-row strong,.danger-zone .setting-row small{color:inherit}.selected-strip,.toolbar-line{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:6px 0}.selected-strip span{overflow:hidden;width:38px;height:38px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#2563eb,#0f766e);border-radius:8px;font-weight:700}.selected-strip img{width:100%;height:100%;display:block;object-fit:cover}.check-box{width:22px;height:22px;display:grid;place-items:center;color:#fff;border:1px solid var(--line-strong);border-radius:6px}.check-box.checked{background:var(--primary);border-color:var(--primary)}.segmented{width:fit-content;display:inline-grid;grid-template-columns:repeat(2,82px);padding:2px;background:#e5e7eb;border-radius:8px}.segmented button{height:32px;color:var(--muted);background:transparent;border-radius:6px;cursor:pointer}.segmented button.active{color:var(--primary);background:#fff;box-shadow:0 1px 2px #0f172a14}.presence{width:8px;height:8px;background:#cbd5e1;border-radius:999px}.presence.online{background:var(--security)}.request-badge{min-width:20px;height:20px;display:grid;place-items:center;padding:0 6px;color:#fff;background:var(--danger);border-radius:999px;font-size:12px}.action-avatar{background:linear-gradient(135deg,#0f766e,#2563eb)}.add-friend-card,.request-section{display:grid;gap:10px;padding:12px;background:#fff;border:1px solid var(--line);border-radius:8px}.request-section{padding:12px 0 0;overflow:hidden}.request-section>strong{padding:0 12px;font-size:14px;font-weight:650}.friend-message-input{min-height:38px;width:100%;min-width:0;padding:0 11px;color:var(--text);background:var(--surface-soft);border:1px solid transparent;border-radius:8px;outline:0}.friend-message-input:focus{background:#fff;border-color:#bfdbfe}.empty-state{padding:24px 12px;color:var(--muted);text-align:center;font-size:13px}.info-block,.profile-block{display:grid;gap:7px;padding:14px;background:#fff;border:1px solid var(--line);border-radius:8px}.info-block strong,.profile-block strong,.list-row strong{font-weight:600}.profile-block{justify-items:center;padding:22px 14px}.contact-profile-card{gap:9px}.remark-field{grid-template-columns:54px minmax(0,1fr) auto}.profile-message-action{width:min(340px,100%);justify-self:center;margin-top:4px}.avatar-actions{display:flex;justify-content:center;flex-wrap:wrap;gap:8px;margin-top:6px}.avatar-actions input{display:none}.avatar-actions .secondary-action{min-height:34px}.call-panel{display:grid;align-content:center;justify-items:center;gap:28px;color:#fff;background:linear-gradient(#111827eb,#111827f0),radial-gradient(circle at top,rgba(37,99,235,.28),transparent 42%)}.call-state{display:grid;justify-items:center;gap:6px}.call-state strong{font-size:20px;font-weight:650}.call-state span{color:#cbd5e1}.call-ice-state{width:min(520px,calc(100% - 32px));display:grid;justify-items:center;gap:4px;padding:12px 14px;color:#dbeafe;background:#0f172ab8;border:1px solid rgba(191,219,254,.22);border-radius:8px;text-align:center}.call-ice-state strong{color:#fff;font-size:13px;font-weight:650}.call-ice-state small{max-width:100%;overflow-wrap:anywhere;color:#bfdbfe;font-size:12px;line-height:1.35}.call-grid{display:grid;grid-template-columns:repeat(2,minmax(92px,116px));gap:16px}.call-grid span{overflow:hidden;aspect-ratio:1;display:grid;place-items:center;color:#fff;background:#ffffff24;border:1px solid rgba(255,255,255,.18);border-radius:999px;font-size:28px;font-weight:700}.call-grid img{width:100%;height:100%;display:block;object-fit:cover}.call-controls{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}.call-controls button{width:54px;height:54px;display:grid;place-items:center;color:#fff;background:#ffffff24;border-radius:999px;cursor:pointer}.call-controls button:hover{background:#ffffff38}.call-controls button.active{background:#2563ebd1;box-shadow:0 0 0 3px #93c5fd2e}.call-controls button:disabled{opacity:.4;cursor:not-allowed}.call-controls button:disabled:hover{background:#ffffff24}.call-controls .answer{background:#16a34a}.call-controls .answer:hover{background:#15803d}.call-controls .hangup{background:var(--danger)}.call-controls .hangup:hover{background:#b91c1c}.ios-call{justify-items:center}.pin-dots{color:var(--text);letter-spacing:10px;font-size:24px;font-weight:600}.keypad{display:grid;grid-template-columns:repeat(3,58px);gap:10px}.keypad button{height:48px;color:var(--text);background:#fff;border:1px solid var(--line);border-radius:8px;cursor:pointer}.toast{position:fixed;left:50%;bottom:calc(28px + env(safe-area-inset-bottom));z-index:30;transform:translate(-50%);max-width:calc(100vw - 48px);padding:9px 14px;color:#fff;background:#111827d6;border-radius:8px;box-shadow:0 10px 30px #0f172a38;font-size:13px;text-align:center}.pwa-update-toast{position:fixed;right:18px;bottom:calc(24px + env(safe-area-inset-bottom));z-index:35;width:min(340px,calc(100vw - 32px));min-height:64px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center;padding:12px;color:var(--text);background:#fff;border:1px solid #bfdbfe;border-radius:8px;box-shadow:0 18px 42px #0f172a33}.pwa-update-toast>svg{color:var(--primary)}.pwa-update-toast span{min-width:0;display:grid;gap:2px}.pwa-update-toast strong{font-size:14px;font-weight:650}.pwa-update-toast small{color:var(--muted);font-size:12px}.pwa-update-toast button{min-height:34px;padding:0 12px;color:#fff;background:var(--primary);border-radius:8px;cursor:pointer;white-space:nowrap}.pwa-update-toast button:hover{background:var(--primary-pressed)}.login-shell{min-height:100vh;min-height:100dvh;display:grid;place-items:center;padding:24px;background:linear-gradient(#f8fafcf0,#f8fafcf0),radial-gradient(circle at top left,rgba(37,99,235,.12),transparent 34%),radial-gradient(circle at bottom right,rgba(15,118,110,.12),transparent 36%)}.login-panel{width:min(380px,100%);display:grid;gap:14px;padding:24px 18px;background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow-soft)}.login-panel h1{margin:0 0 4px;font-size:22px;font-weight:650}.auth-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px;padding:4px;background:var(--surface-soft);border-radius:8px}.auth-tabs button{min-height:32px;color:var(--muted);background:transparent}.auth-tabs button.active{color:#fff;background:var(--primary)}.login-panel label{display:grid;gap:6px}.login-panel label span{color:var(--muted);font-size:13px}.login-panel .check-line{grid-template-columns:auto 1fr;align-items:center;color:var(--muted);font-size:13px}.login-panel input{height:40px;padding:0 10px;color:var(--text);background:var(--surface-soft);border:1px solid transparent;border-radius:8px;outline:0}.login-panel input:focus{background:#fff;border-color:#bfdbfe}.login-panel p{margin:0;color:var(--danger);font-size:13px}.restore-panel{justify-items:center;text-align:center}.restore-panel svg{color:var(--security)}.restore-panel p{color:var(--muted)}@media(max-width:1180px){.shell{grid-template-columns:316px minmax(380px,1fr)}.detail-pane{display:none}}@media(max-width:980px){body{overflow:hidden}.shell{display:block;height:100vh;height:100dvh;background:var(--chat-bg)}.conversation-pane,.chat-pane{width:100%;height:100%}.conversation-pane{border-right:0}.shell.is-content-route .conversation-pane,.shell.is-list-route .chat-pane,.detail-pane{display:none}.mobile-back{display:inline-grid}.chat-header{grid-template-columns:36px minmax(0,1fr) auto;box-shadow:none}.chat-header .title-stack{justify-items:center;text-align:center}.chat-header nav{min-width:74px;justify-content:flex-end}.conversation-list{padding-bottom:4px}.mobile-bottom-tabs{position:fixed;left:0;right:0;display:grid}.message-stream,.work-panel,.call-panel{padding:14px 12px}.shell.has-mobile-tabs .message-stream,.shell.has-mobile-tabs .work-panel,.shell.has-mobile-tabs .call-panel{padding-bottom:calc(74px + env(safe-area-inset-bottom))}.bubble{max-width:78%}.message-row.system .bubble{max-width:92%}.work-panel{gap:8px}.toolbar-line{align-items:stretch}.toolbar-line .primary-action,.toolbar-line .secondary-action{flex:1 1 140px}.toast{bottom:calc(78px + env(safe-area-inset-bottom))}.pwa-update-toast{left:12px;right:12px;bottom:calc(78px + env(safe-area-inset-bottom));width:auto}.login-shell{align-items:start;padding-top:calc(56px + env(safe-area-inset-top))}}@media(max-width:420px){.pane-header,.chat-header,.detail-pane header{padding-left:12px;padding-right:12px}.conversation-row,.list-row{grid-template-columns:42px minmax(0,1fr) auto;gap:9px}.plus-panel,.emoji-panel{left:10px;right:10px;width:auto}.call-grid{grid-template-columns:repeat(2,minmax(86px,106px))}}
