:root{--brand-pink: #ff4fa3;--brand-hot-pink: #f12aa8;--brand-magenta: #d923c7;--brand-purple: #7628e7;--brand-violet: #5a2ed8;--brand-coral: #ff9a5c;--brand-ink: #191521;--text-main: #241f2d;--text-muted: #746b7e;--text-soft: #94889f;--surface: #ffffff;--surface-soft: #fbf8ff;--surface-muted: #f2eef8;--surface-deep: #ebe7f2;--line: rgba(48, 39, 63, .11);--line-strong: rgba(48, 39, 63, .18);--focus-ring: rgba(241, 42, 168, .2);--brand-gradient: linear-gradient(135deg, #ff5ea8 0%, #f12aa8 42%, #7628e7 100%);--brand-gradient-soft: linear-gradient(135deg, rgba(255, 79, 163, .14), rgba(118, 40, 231, .13));color:var(--text-main);background:#f3f0f7;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}html,body,#root{min-width:320px;min-height:100%;height:100%;margin:0}button,input{font:inherit}button{border:0;cursor:pointer}.connection-banner{position:fixed;top:12px;left:50%;z-index:20;max-width:min(520px,calc(100vw - 24px));transform:translate(-50%);border:1px solid var(--line);border-radius:8px;padding:9px 13px;background:#fffffff0;box-shadow:0 12px 28px #2d1f3e1f;color:var(--text-muted);font-size:.86rem;font-weight:800;text-align:center}.message-toast-stack{position:fixed;top:16px;right:16px;z-index:45;display:grid;width:min(360px,calc(100vw - 32px));gap:10px}.message-toast{display:grid;grid-template-columns:minmax(0,1fr) 34px;align-items:stretch;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:#fffffffa;box-shadow:0 18px 40px #2d1f3e29}.message-toast>button:first-child{display:grid;grid-template-columns:34px minmax(0,1fr) auto;align-items:center;gap:10px;min-width:0;padding:11px 12px;background:transparent;color:var(--text-main);text-align:left}.message-toast>button:first-child>svg{width:22px;height:22px;color:var(--brand-hot-pink)}.message-toast>button:first-child>span{display:grid;min-width:0;gap:2px}.message-toast strong,.message-toast span span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.message-toast strong{font-size:.88rem}.message-toast span span{color:var(--text-muted);font-size:.8rem;font-weight:700}.message-toast time{color:var(--text-soft);font-size:.72rem;font-weight:800}.message-toast-close{display:grid;width:34px;place-items:center;background:#30273f0d;color:var(--text-muted)}.message-toast-close svg{width:16px;height:16px}.identity-page{display:grid;min-height:100%;place-items:center;padding:24px;background:linear-gradient(135deg,#ffffffad,#f7eefce0),linear-gradient(160deg,rgba(255,154,92,.14),transparent 36%),var(--surface-deep)}.identity-shell{width:min(920px,calc(100vw - 48px));padding:36px;border:1px solid rgba(255,255,255,.76);border-radius:8px;background:#ffffffe0;box-shadow:0 24px 70px #2d1f3e29}.brand-lockup{display:inline-flex;max-width:min(360px,100%);align-items:center;gap:12px}.brand-symbol{width:66px;height:66px;object-fit:contain}.brand-wordmark{width:min(210px,calc(100vw - 150px));height:auto;object-fit:contain}.eyebrow,.panel-kicker{margin:18px 0 6px;color:var(--brand-hot-pink);font-size:.75rem;font-weight:800;letter-spacing:0;text-transform:uppercase}.identity-shell h1{max-width:720px;margin:0;color:var(--brand-ink);font-size:clamp(2rem,6vw,4.1rem);line-height:1.02}.identity-copy{max-width:620px;margin:18px 0 28px;color:var(--text-muted);font-size:1rem;line-height:1.7}.auth-switch{display:inline-flex;gap:6px;margin:0 0 18px;padding:5px;border-radius:8px;background:#30273f12}.auth-switch button{height:36px;border-radius:7px;padding:0 14px;background:transparent;color:var(--text-muted);font-weight:800}.auth-switch button.active{background:var(--surface);color:var(--brand-hot-pink);box-shadow:0 6px 18px #2d1f3e1a}.identity-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.identity-card{display:grid;min-height:180px;justify-items:center;align-content:center;gap:10px;padding:18px 12px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft);color:var(--text-main);text-align:center;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.identity-card:hover{transform:translateY(-3px);border-color:#f12aa86b;box-shadow:0 16px 28px #2d1f3e21}.identity-name{font-size:1.05rem;font-weight:800}.identity-status{max-width:100%;overflow:hidden;color:var(--text-muted);font-size:.87rem;text-overflow:ellipsis;white-space:nowrap}.identity-handle{color:var(--brand-magenta);font-size:.78rem;font-weight:800}.register-form{display:grid;width:100%;max-width:520px;gap:12px}.register-preview{display:flex;align-items:center;gap:14px;padding:14px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft)}.register-preview span{display:grid;gap:3px}.register-preview strong{color:var(--text-main);font-size:1.05rem}.register-preview small{color:var(--brand-magenta);font-weight:800}.register-form label{display:grid;gap:7px;color:var(--text-muted);font-size:.84rem;font-weight:800}.register-form input{height:46px;min-width:0;border:1px solid var(--line);border-radius:8px;outline:0;padding:0 12px;background:#fff;color:var(--text-main)}.register-form input:focus{border-color:#f12aa89e;box-shadow:0 0 0 4px var(--focus-ring)}.privacy-check{display:flex;grid-template-columns:none;align-items:flex-start;gap:10px;border:1px solid var(--line);border-radius:8px;padding:12px;background:#fbf8ffc7;color:var(--text-main);line-height:1.5}.privacy-check input{width:18px;height:18px;min-width:18px;margin:2px 0 0;padding:0;accent-color:var(--brand-hot-pink)}.security-note{display:flex;align-items:flex-start;gap:10px;border-radius:8px;padding:12px;background:var(--surface-muted);color:var(--text-muted);font-size:.84rem;font-weight:700;line-height:1.55}.security-note svg{width:18px;height:18px;flex:0 0 auto;margin-top:2px;color:#22a46f}.register-hint{min-height:20px;margin:-2px 0 0;color:#c64239;font-size:.82rem;font-weight:800}.register-hint.success{color:#357d4d}.register-submit{display:inline-flex;height:48px;align-items:center;justify-content:center;gap:9px;border-radius:8px;background:var(--brand-gradient);color:#fff;font-weight:900;box-shadow:0 12px 22px #f12aa838}.register-submit:disabled{cursor:not-allowed;opacity:.45}.register-submit svg{width:19px;height:19px}.form-link-button{justify-self:center;border-radius:8px;padding:8px 12px;background:transparent;color:var(--text-muted);font-size:.84rem;font-weight:800}.form-link-button:hover{background:#30273f12;color:var(--brand-hot-pink)}.legal-mini-links,.legal-link-list,.legal-link-row{display:flex;flex-wrap:wrap;gap:10px 14px}.legal-mini-links{margin-top:18px}.legal-mini-links a,.legal-link-list a,.legal-link-row a{color:var(--brand-hot-pink);font-size:.82rem;font-weight:800;text-decoration:none}.legal-mini-links a:hover,.legal-link-list a:hover,.legal-link-row a:hover{color:var(--brand-purple);text-decoration:underline}.legal-page{min-height:100%;padding:28px;background:linear-gradient(135deg,#ffffffbd,#f6eefce0),var(--surface-deep)}.legal-shell{width:min(920px,calc(100vw - 56px));margin:0 auto;border:1px solid rgba(255,255,255,.76);border-radius:8px;padding:28px;background:#ffffffe6;box-shadow:0 22px 58px #2d1f3e24}.legal-back{display:inline-flex;align-items:center;gap:7px;color:var(--text-muted);font-size:.88rem;font-weight:900;text-decoration:none}.legal-back svg{width:18px;height:18px}.legal-header{margin-top:20px;padding-bottom:20px;border-bottom:1px solid var(--line)}.legal-header h1{margin:0;color:var(--brand-ink);font-size:clamp(2rem,5vw,3.5rem);line-height:1.04}.legal-header p{max-width:680px;margin:12px 0 0;color:var(--text-muted);line-height:1.7}.legal-header time{display:inline-block;margin-top:14px;color:var(--brand-magenta);font-size:.82rem;font-weight:800}.legal-sections{display:grid;gap:12px;margin-top:18px}.legal-card{border:1px solid var(--line);border-radius:8px;padding:16px;background:var(--surface-soft)}.legal-card h2{margin:0 0 8px;color:var(--text-main);font-size:1rem}.legal-card p,.legal-card ol{margin:0;color:var(--text-muted);line-height:1.72}.legal-card ol{padding-left:20px}.legal-link-row{margin-top:22px;padding-top:18px;border-top:1px solid var(--line)}.app-shell{position:fixed;inset:0;display:flex;width:100%;height:100vh;height:100dvh;min-height:0;overflow:hidden;overscroll-behavior:none;background:var(--surface-deep)}.nav-rail{display:flex;width:76px;flex:0 0 76px;flex-direction:column;align-items:center;gap:14px;padding:20px 12px;background:linear-gradient(180deg,#ff5ea8,#d923c7 48%,#642be3);color:#fff}.rail-brand{display:grid;width:44px;height:44px;place-items:center;border-radius:8px;background:#ffffff2e;box-shadow:inset 0 0 0 1px #ffffff2e}.rail-brand img{width:34px;height:34px;object-fit:contain}.rail-profile{padding-bottom:10px}.rail-buttons{display:grid;gap:12px}.rail-button{position:relative;display:grid;width:48px;height:48px;place-items:center;border-radius:8px;background:transparent;color:#ffffffb8;transition:background .16s ease,color .16s ease,transform .16s ease}.rail-button:hover,.rail-button.active{background:#fff3;color:#fff}.rail-button:active{transform:scale(.96)}.rail-button svg{width:24px;height:24px}.rail-badge{position:absolute;top:6px;right:4px;display:grid;min-width:19px;height:19px;place-items:center;padding:0 5px;border-radius:999px;background:#ff3768;color:#fff;font-size:.72rem;font-weight:800}.rail-logout{margin-top:auto}.workspace{display:grid;height:100%;min-width:0;min-height:0;flex:1;grid-template-columns:minmax(310px,390px) minmax(0,1fr)}.list-panel{display:flex;min-width:0;flex-direction:column;gap:14px;overflow:hidden;border-right:1px solid var(--line);background:var(--surface-soft)}.panel-header{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;padding:28px 24px 4px}.panel-header h2{margin:0;font-size:1.75rem;line-height:1.1}.panel-kicker{margin:0 0 5px}.header-actions{display:inline-flex;align-items:center;gap:8px}.icon-action{display:grid;width:36px;height:36px;place-items:center;border-radius:8px;background:var(--surface-muted);color:var(--text-muted)}.icon-action:hover,.icon-action.active{background:var(--brand-gradient);color:#fff}.icon-action svg{width:19px;height:19px}.count-pill{display:inline-flex;min-width:32px;height:28px;align-items:center;justify-content:center;padding:0 10px;border-radius:999px;background:var(--surface-muted);color:var(--brand-magenta);font-size:.86rem;font-weight:800}.search-box{display:flex;height:42px;align-items:center;gap:10px;margin:0 24px;padding:0 12px;border:1px solid var(--line);border-radius:8px;background:var(--surface-muted);color:var(--text-soft)}.search-box svg{width:18px;height:18px}.search-box input{min-width:0;flex:1;border:0;outline:0;background:transparent;color:var(--text-main)}.chat-filter{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;margin:-2px 24px 0;padding:5px;border-radius:8px;background:var(--surface-muted)}.chat-filter button{display:inline-flex;height:34px;align-items:center;justify-content:center;gap:6px;border-radius:7px;background:transparent;color:var(--text-muted);font-size:.86rem;font-weight:900}.chat-filter button.active{background:var(--surface);color:var(--brand-hot-pink);box-shadow:0 5px 14px #2d1f3e14}.chat-filter span{min-width:18px;border-radius:999px;padding:2px 6px;background:#f12aa81a;font-size:.72rem}.add-friend-card,.group-creator-card{display:grid;gap:10px;margin:0 24px;padding:14px;border:1px solid var(--line);border-radius:8px;background:#fff}.add-friend-card label{display:grid;gap:8px;color:var(--text-muted);font-size:.84rem;font-weight:800}.group-creator-card>label{display:grid;gap:8px;color:var(--text-muted);font-size:.84rem;font-weight:800}.group-creator-card>label input{height:42px;min-width:0;border:1px solid var(--line);border-radius:8px;outline:0;padding:0 12px;background:var(--surface-soft);color:var(--text-main)}.group-creator-card>label input:focus{border-color:#f12aa89e;box-shadow:0 0 0 4px var(--focus-ring)}.section-label.inline{margin:0}.member-picker{display:grid;max-height:230px;gap:6px;overflow:auto}.member-picker.compact{max-height:160px}.member-option{display:flex;min-width:0;align-items:center;gap:10px;border-radius:8px;padding:9px;background:var(--surface-soft)}.member-option input{width:18px;height:18px;flex:0 0 auto;accent-color:var(--brand-hot-pink)}.friend-search-row{display:flex;height:42px;align-items:center;gap:10px;border:1px solid var(--line);border-radius:8px;padding:0 12px;background:var(--surface-soft);color:var(--text-soft)}.friend-search-row svg{width:18px;height:18px}.friend-search-row input{min-width:0;flex:1;border:0;outline:0;background:transparent;color:var(--text-main)}.friend-result{display:flex;min-width:0;align-items:center;gap:12px;border-radius:8px;padding:10px;background:var(--surface-muted)}.request-hint{margin:0;color:var(--text-muted);font-size:.82rem;font-weight:800;line-height:1.45}.request-hint.error{color:#c64239}.self-card{display:flex;align-items:center;gap:14px;margin:0 24px;padding:16px;border:1px solid var(--line);border-radius:8px;background:#fff}.friend-profile-card{display:grid;justify-items:center;gap:10px;margin:0 24px;padding:22px 16px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft);text-align:center}.friend-profile-card strong{color:var(--text-main);font-size:1.2rem}.friend-profile-card span{color:var(--brand-magenta);font-size:.86rem;font-weight:800}.friend-profile-card .soft-action{width:100%}.friend-settings-form{display:grid;width:100%;gap:9px;text-align:left}.friend-settings-form label{display:grid;gap:7px;color:var(--text-muted);font-size:.82rem;font-weight:800}.friend-settings-form input{height:42px;min-width:0;border:1px solid var(--line);border-radius:8px;outline:0;padding:0 12px;background:#fff;color:var(--text-main)}.friend-settings-form input:focus{border-color:#f12aa89e;box-shadow:0 0 0 4px var(--focus-ring)}.status-chip{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:5px 9px;background:var(--surface-muted);color:var(--text-muted);font-size:.74rem;font-weight:900}.status-chip.danger{background:#f7e7e5;color:#b33932}.section-label{margin:5px 24px -4px;color:var(--text-soft);font-size:.8rem;font-weight:800}.request-list{display:grid;gap:8px;margin:0 12px;padding:4px 12px}.request-list.compact{padding-bottom:0}.request-row{display:flex;min-width:0;align-items:center;gap:12px;border-radius:8px;padding:10px 12px;background:var(--surface)}.request-actions{display:inline-flex;flex:0 0 auto;gap:8px;margin-left:auto}.mini-action{display:grid;width:34px;height:34px;place-items:center;border-radius:8px;background:var(--surface-muted);color:var(--text-muted)}.mini-action.accept{background:#e9f4ea;color:#3c8553}.mini-action.reject{background:#f7e7e5;color:#c64239}.mini-action:disabled{cursor:not-allowed;opacity:.5}.mini-action svg{width:17px;height:17px}.pending-chip{flex:0 0 auto;margin-left:auto;border-radius:999px;padding:5px 9px;background:var(--surface-muted);color:var(--brand-magenta);font-size:.75rem;font-weight:900}.people-list,.chat-list{min-height:0;overflow:auto;padding:4px 12px 24px}.person-row,.chat-row{display:flex;width:100%;min-width:0;align-items:center;gap:12px;padding:12px;border-radius:8px;background:transparent;color:inherit;text-align:left;transition:background .16s ease}.person-row:hover,.chat-row:hover,.chat-row.active{background:var(--surface-muted)}.person-copy,.chat-row-copy{display:grid;min-width:0;gap:4px}.person-copy strong,.chat-row-copy strong{overflow:hidden;color:var(--text-main);font-size:.98rem;text-overflow:ellipsis;white-space:nowrap}.person-copy span,.chat-preview,.chat-row-top time{overflow:hidden;color:var(--text-muted);font-size:.86rem;text-overflow:ellipsis;white-space:nowrap}.row-action{width:19px;height:19px;flex:0 0 auto;margin-left:auto;color:var(--text-soft)}.empty-list{display:grid;justify-items:center;gap:7px;margin:12px;padding:28px 18px;border:1px dashed var(--line-strong);border-radius:8px;background:var(--surface-soft);color:var(--text-muted);text-align:center}.empty-list svg{width:24px;height:24px;color:var(--brand-hot-pink)}.empty-list strong{color:var(--text-main)}.empty-list span{max-width:220px;font-size:.86rem;line-height:1.55}.chat-row{position:relative;min-height:76px}.chat-row-top{display:flex;min-width:0;align-items:center;justify-content:space-between;gap:12px}.chat-row-top time{flex:0 0 auto;font-size:.78rem}.unread-badge{display:grid;min-width:20px;height:20px;flex:0 0 auto;place-items:center;margin-left:auto;padding:0 6px;border-radius:999px;background:#ff3768;color:#fff;font-size:.72rem;font-weight:800}.profile-panel{overflow-y:auto;background:linear-gradient(180deg,rgba(255,79,163,.13),transparent 44%),var(--surface-soft)}.profile-hero{display:grid;justify-items:center;gap:10px;margin:18px 24px 0;padding:34px 18px;border:1px solid var(--line);border-radius:8px;background:#ffffffc7;text-align:center}.profile-hero h3{margin:12px 0 0;font-size:1.5rem}.profile-hero span{color:var(--brand-magenta);font-size:.86rem;font-weight:800}.profile-hero p{margin:0;color:var(--text-muted)}.profile-actions{display:grid;gap:10px;margin:6px 24px}.status-editor,.profile-editor{display:grid;gap:10px;margin:6px 24px 0}.security-card{display:grid;gap:10px;margin:6px 24px 0;padding:14px;border:1px solid var(--line);border-radius:8px;background:#ffffffd1}.notification-settings{display:flex;min-width:0;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--line);border-radius:8px;padding:10px;background:#ffffffdb}.notification-settings>span{display:flex;min-width:0;align-items:center;gap:10px}.notification-settings>span>svg{width:20px;height:20px;flex:0 0 auto;color:var(--brand-hot-pink)}.notification-settings span span{display:grid;min-width:0;gap:2px}.notification-settings strong,.notification-settings small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notification-settings strong{color:var(--text-main);font-size:.86rem}.notification-settings small{color:var(--text-muted);font-size:.76rem;font-weight:800}.status-editor label,.profile-editor label,.profile-editor-label,.security-card label{color:var(--text-soft);font-size:.8rem;font-weight:800}.security-card label{display:grid;gap:7px}.security-card input{height:42px;min-width:0;border:1px solid var(--line);border-radius:8px;outline:0;padding:0 12px;background:#fff;color:var(--text-main)}.security-card select,.security-card textarea,.report-form select,.report-form textarea{min-width:0;border:1px solid var(--line);border-radius:8px;outline:0;padding:0 12px;background:#fff;color:var(--text-main);font:inherit}.security-card select,.report-form select{height:42px}.security-card textarea,.report-form textarea{min-height:76px;padding-top:10px;resize:vertical}.security-card input:focus,.security-card select:focus,.security-card textarea:focus,.report-form select:focus,.report-form textarea:focus{border-color:#f12aa89e;box-shadow:0 0 0 4px var(--focus-ring)}.safety-center,.danger-zone,.report-form{text-align:left}.safety-section,.report-form{display:grid;gap:10px}.safety-section>strong,.report-form-title{display:inline-flex;align-items:center;gap:8px;color:var(--text-main);font-size:.92rem;font-weight:900}.report-form-title svg{width:17px;height:17px}.report-form-title span{color:var(--text-main);font-size:.92rem;font-weight:900}.report-form label{display:grid;gap:7px;color:var(--text-muted);font-size:.82rem;font-weight:800}.report-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.safety-list,.report-list{display:grid;gap:8px}.safety-row{display:flex;min-width:0;align-items:center;gap:10px;border-radius:8px;padding:10px;background:var(--surface-soft)}.report-row{display:grid;gap:10px;border:1px solid var(--line);border-radius:8px;padding:12px;background:var(--surface-soft)}.report-row>div:first-child{display:grid;gap:5px}.report-row strong{color:var(--text-main)}.report-row p,.report-row time{margin:0;color:var(--text-muted);font-size:.78rem;font-weight:800;line-height:1.45}.report-status{width:fit-content}.report-status.open,.report-status.reviewing{background:#fff0df;color:#b45a20}.report-status.resolved{background:#e9f4ea;color:#3c8553}.report-status.rejected{background:#f7e7e5;color:#b33932}.report-status-actions{display:flex;flex-wrap:wrap;gap:8px}.danger-zone{border-color:#c642392e;background:#fff8f6}.security-card .privacy-check{display:flex;align-items:flex-start;gap:10px;color:var(--text-main)}.security-card .privacy-check input{width:18px;height:18px;min-width:18px;margin:2px 0 0;padding:0;flex:0 0 auto}.status-input-row{display:flex;height:46px;align-items:center;gap:10px;border:1px solid var(--line);border-radius:8px;padding:0 12px;background:#fff;color:var(--text-soft)}.status-input-row svg{width:17px;height:17px}.status-input-row input{min-width:0;flex:1;border:0;outline:0;background:transparent;color:var(--text-main)}.avatar-color-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}.color-swatch{height:34px;border:2px solid rgba(255,255,255,.8);border-radius:8px;box-shadow:0 0 0 1px var(--line)}.color-swatch.active{box-shadow:0 0 0 2px var(--brand-hot-pink),0 8px 18px #2d1f3e29}.soft-action{display:flex;height:46px;align-items:center;justify-content:center;gap:9px;border-radius:8px;background:var(--surface-muted);color:var(--text-main);font-weight:800}.soft-action.primary{background:var(--brand-gradient);color:#fff;box-shadow:0 10px 20px #f12aa82e}.soft-action.danger{background:#f7e7e5;color:#b33932}.soft-action:disabled{cursor:not-allowed;opacity:.48}.soft-action svg{width:18px;height:18px}.chat-window{position:relative;display:grid;height:100%;min-width:0;min-height:0;grid-template-rows:auto minmax(0,1fr) auto;overflow:hidden;background-color:#ece8f4;background-image:linear-gradient(180deg,rgba(255,255,255,.4),transparent 34%),repeating-linear-gradient(135deg,rgba(255,255,255,.22) 0 2px,transparent 2px 16px)}.chat-header{display:flex;min-height:74px;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid rgba(48,39,63,.11);background:#ffffffc7;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.back-button{display:none;width:40px;height:40px;place-items:center;border-radius:8px;background:#ffffffad;color:var(--text-main)}.back-button svg{width:24px;height:24px}.chat-title-copy{display:grid;min-width:0;flex:1;gap:2px}.chat-title-copy h2{margin:0;overflow:hidden;font-size:1.08rem;text-overflow:ellipsis;white-space:nowrap}.chat-title-copy span{overflow:hidden;color:var(--text-muted);font-size:.84rem;text-overflow:ellipsis;white-space:nowrap}.chat-header-action{display:grid;width:40px;height:40px;flex:0 0 auto;place-items:center;margin-left:auto;border-radius:8px;background:#ffffffad;color:var(--text-main)}.chat-header-action:hover,.chat-header-action.active{background:var(--brand-gradient);color:#fff}.chat-header-action svg{width:20px;height:20px}.group-info-panel{position:absolute;top:86px;right:18px;z-index:4;display:grid;width:min(360px,calc(100% - 36px));max-height:calc(100% - 170px);gap:12px;overflow:auto;border:1px solid var(--line);border-radius:8px;padding:14px;background:#fffffff5;box-shadow:0 18px 44px #2d1f3e29}.group-info-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.group-info-header strong{color:var(--text-main);font-size:1rem}.group-member-list{display:flex;flex-wrap:wrap;gap:8px}.member-chip{display:inline-flex;max-width:100%;align-items:center;gap:7px;border-radius:999px;padding:5px 9px 5px 5px;background:var(--surface-muted);color:var(--text-main);font-size:.82rem;font-weight:800}.member-chip svg{width:14px;height:14px;color:var(--brand-hot-pink)}.member-chip button{display:grid;width:22px;height:22px;place-items:center;border-radius:999px;background:#c642391a;color:#b33932}.member-chip button:disabled{cursor:not-allowed;opacity:.5}.member-chip button svg{width:13px;height:13px;color:currentColor}.group-panel-form{display:grid;gap:10px}.group-panel-form label{display:grid;gap:7px;color:var(--text-muted);font-size:.84rem;font-weight:800}.group-panel-form input[type=text],.group-panel-form>label>input{height:42px;min-width:0;border:1px solid var(--line);border-radius:8px;outline:0;padding:0 12px;background:#fff;color:var(--text-main)}.group-panel-form input:focus{border-color:#f12aa89e;box-shadow:0 0 0 4px var(--focus-ring)}.message-scroller{display:flex;min-height:0;flex-direction:column;gap:12px;overflow:auto;overscroll-behavior:contain;padding:22px}.load-more-messages{align-self:center;min-height:34px;border-radius:8px;padding:0 14px;background:#ffffffe0;color:var(--text-muted);font-size:.78rem;font-weight:900;box-shadow:0 5px 14px #2d1f3e14}.load-more-messages:disabled{cursor:not-allowed;opacity:.55}.message-row{display:flex;max-width:min(74%,720px);align-items:flex-start;gap:9px}.message-row.own{align-self:flex-end;justify-content:flex-end}.message-stack{display:grid;min-width:0;gap:5px}.message-sender{margin-left:2px;color:#241f2dad;font-size:.74rem;font-weight:800}.bubble{overflow-wrap:anywhere;border-radius:8px;background:#fff;padding:11px 13px;box-shadow:0 4px 14px #2d1f3e14;color:var(--text-main);line-height:1.55}.own .bubble{background:var(--brand-gradient);color:#fff;box-shadow:0 8px 18px #f12aa82e}.bubble.deleted{background:#ffffff9e;color:#25303494;font-style:italic}.media-bubble{display:grid;gap:9px;max-width:min(420px,100%);padding:7px}.image-bubble a{display:block;overflow:hidden;border-radius:7px}.image-bubble img{display:block;width:100%;max-width:306px;max-height:360px;object-fit:cover;background:#30273f14}.video-bubble video{display:block;width:min(420px,100%);max-height:360px;border-radius:7px;background:#111}.media-bubble p{margin:0;padding:0 6px 4px;line-height:1.55}.message-meta{display:inline-flex;align-items:center;gap:4px;color:#241f2da3;font-size:.74rem}.own .message-meta{justify-content:flex-end}.message-meta svg{width:13px;height:13px}.message-meta-action{display:grid;width:23px;height:23px;place-items:center;border-radius:7px;background:#30273f14;color:#241f2dad}.message-meta-action:hover{background:#c642391f;color:#b33932}.message-meta-action svg{width:13px;height:13px}.message-action-error{margin:-8px 18px 8px;color:#b33932;font-size:.8rem;font-weight:800;text-align:right}.chat-report-panel{margin:0 18px 10px;border-radius:8px;padding:12px;background:#fffffff0;box-shadow:0 10px 24px #2d1f3e24}.typing-row{align-items:center}.typing-bubble{display:inline-flex;align-items:center;gap:5px;border-radius:8px;background:#fff;padding:13px 14px;box-shadow:0 4px 14px #2d1f3e14}.typing-bubble span{width:6px;height:6px;border-radius:999px;animation:typing-pulse .92s infinite ease-in-out;background:var(--brand-hot-pink)}.typing-bubble span:nth-child(2){animation-delay:.14s}.typing-bubble span:nth-child(3){animation-delay:.28s}@keyframes typing-pulse{0%,80%,to{opacity:.38;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}.composer{display:flex;align-items:center;gap:10px;padding:14px 18px 18px;background:#ffffffe0}.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap}.composer-preview{display:flex;min-height:36px;align-items:center;justify-content:space-between;gap:10px;margin:0 18px -2px;border-radius:8px;padding:8px 10px 8px 12px;background:#ffffffeb;color:var(--text-muted);font-size:.82rem;font-weight:800}.composer-preview.error{background:#f7e7e5;color:#b33932}.composer-preview span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.composer-preview button{display:grid;width:26px;height:26px;flex:0 0 auto;place-items:center;border-radius:7px;background:#30273f14;color:currentColor}.composer-preview button svg{width:15px;height:15px}.composer input{min-width:0;height:48px;flex:1;border:1px solid var(--line);border-radius:8px;outline:0;padding:0 14px;background:#fff;color:var(--text-main)}.composer input:focus{border-color:#f12aa89e;box-shadow:0 0 0 4px var(--focus-ring)}.composer button{display:grid;width:48px;height:48px;flex:0 0 auto;place-items:center;border-radius:8px;background:var(--brand-gradient);color:#fff;box-shadow:0 10px 20px #f12aa833}.composer button svg{width:21px;height:21px}.composer button:disabled{cursor:not-allowed;opacity:.45}.empty-chat{display:grid;place-items:center;align-content:center;gap:14px;padding:30px;background:var(--surface-deep);color:var(--text-muted);text-align:center}.empty-chat h2{margin:0;color:var(--text-main)}.empty-chat p{max-width:380px;margin:0;line-height:1.7}.empty-icon{display:grid;width:78px;height:78px;place-items:center;border-radius:28px;background:var(--brand-gradient);color:#fff;box-shadow:0 14px 26px #f12aa833}.empty-icon svg{width:36px;height:36px}.avatar{display:grid;flex:0 0 auto;place-items:center;border:2px solid rgba(255,255,255,.72);border-radius:38%;color:#fff;font-weight:900;letter-spacing:0;box-shadow:inset 0 -12px 24px #0000001a}.avatar-sm{width:36px;height:36px;font-size:.72rem}.avatar-md{width:48px;height:48px;font-size:.82rem}.avatar-lg{width:64px;height:64px;font-size:.98rem}.avatar-xl{width:92px;height:92px;font-size:1.35rem}@media(max-width:900px){.app-shell{min-height:0}.nav-rail{width:64px;flex-basis:64px;padding:14px 8px}.workspace{position:relative;grid-template-columns:minmax(0,1fr)}.list-panel{border-right:0}.chat-window{position:absolute;inset:0;transform:translate(100%);transition:transform .18s ease;z-index:2}.chat-window.mobile-open{transform:translate(0)}.passive-empty-chat{display:none}.back-button{display:grid}.message-row{max-width:86%}.group-info-panel{top:78px;right:10px;width:calc(100% - 20px);max-height:calc(100% - 154px)}}@media(max-width:680px){.message-toast-stack{top:10px;right:10px;left:10px;width:auto}.message-toast>button:first-child{grid-template-columns:28px minmax(0,1fr)}.message-toast time{display:none}.legal-page{padding:12px}.legal-shell{padding:22px 16px}.legal-header{margin-top:16px}.legal-card{padding:14px}.identity-page{padding:12px}.identity-shell{width:min(100%,calc(100vw - 48px));padding:24px 16px}.identity-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.identity-card{min-height:156px}.app-shell{min-height:0}.nav-rail{width:58px;flex-basis:58px}.rail-button{width:44px;height:44px}.panel-header{padding:22px 18px 4px}.search-box,.chat-filter,.add-friend-card,.group-creator-card,.self-card,.friend-profile-card,.profile-hero,.status-editor,.profile-editor,.security-card,.profile-actions{margin-right:18px;margin-left:18px}.people-list,.chat-list{padding-right:8px;padding-left:8px}.message-scroller{padding:16px 12px}.composer{padding:10px}.composer input,.composer button{height:44px}.composer button{width:44px}}
