.onboarding{height:100%;display:flex;align-items:center;justify-content:center;padding:24px}.onboarding-card{width:100%;max-width:460px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow)}.brand{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:700;letter-spacing:.08em;color:var(--text-secondary);margin-bottom:24px;text-transform:uppercase}.brand-logo-onboarding{width:28px;height:28px;border-radius:7px}.onboarding-card h1{margin:0 0 12px;font-size:24px;font-weight:700}.onboarding-card .muted{margin:0 0 24px;color:var(--text-secondary);line-height:1.5}.btn{display:block;width:100%;padding:12px 16px;border-radius:var(--radius-md);font-weight:600;font-size:15px;margin-top:8px;transition:opacity .15s,background .15s}.btn.primary{background:var(--accent);color:var(--on-accent)}.btn.primary:hover:not(:disabled){opacity:.85}.btn.ghost{background:transparent;color:var(--text-secondary)}.btn.ghost:hover:not(:disabled){background:var(--bg-alt);color:var(--text-primary)}.phrase-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:16px 0 24px}.phrase-chip{display:flex;align-items:center;gap:6px;padding:8px 10px;background:var(--bg-alt);border-radius:var(--radius-sm);font-size:13px;font-family:ui-monospace,SFMono-Regular,monospace}.phrase-chip .num{color:var(--text-tertiary);font-size:11px;min-width:14px}.restore-input{display:block;background:var(--bg-alt);border-radius:var(--radius-md);padding:12px 14px;margin-bottom:8px;font-family:ui-monospace,SFMono-Regular,monospace;resize:vertical;min-height:80px}.error{margin-top:16px;padding:10px 12px;background:var(--bg-alt);border-left:3px solid var(--danger);color:var(--danger);border-radius:var(--radius-sm);font-size:13px}.avatar{display:inline-flex;align-items:center;justify-content:center;background:var(--avatar-bg);color:var(--text-secondary);border-radius:50%;font-weight:600;flex-shrink:0;overflow:hidden;-webkit-user-select:none;user-select:none}.avatar img{width:100%;height:100%;object-fit:cover}.avatar.group-avatar{border-radius:30%;background:linear-gradient(135deg,var(--avatar-bg),var(--bg-alt));color:var(--text-secondary)}.sidebar{width:340px;flex-shrink:0;background:var(--bg-elev);border-right:1px solid var(--divider);display:flex;flex-direction:column;height:100%}.sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;border-bottom:1px solid var(--divider);background:var(--bg-elev)}.brand{display:flex;align-items:center;gap:8px;min-width:0}.brand-logo{width:24px;height:24px;border-radius:6px;display:block;flex-shrink:0}.brand-name{font-size:14px;font-weight:700;letter-spacing:.02em;color:var(--text-primary)}.profile-btn{display:flex;align-items:center;gap:8px;padding:4px 8px 4px 10px;border-radius:var(--radius-pill);transition:background .15s;flex-shrink:0;max-width:50%}.profile-btn:hover{background:var(--bg-alt)}.profile-name{font-weight:600;font-size:13px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.sidebar-search{padding:10px 16px;border-bottom:1px solid var(--divider)}.sidebar-search input{background:var(--bg-alt);padding:9px 14px;border-radius:var(--radius-pill);font-size:14px}.sidebar-list{flex:1;overflow-y:auto}.sidebar-empty{padding:32px 24px;text-align:center;color:var(--text-secondary)}.sidebar-empty p{margin:0 0 8px}.link-btn{color:var(--accent);font-weight:600;padding:4px 8px}.contact-row{display:flex;gap:12px;align-items:center;width:100%;text-align:left;padding:12px 16px;border-bottom:1px solid var(--divider);transition:background .1s}.contact-row:hover,.contact-row.selected{background:var(--bg-alt)}.avatar-wrap{position:relative;flex-shrink:0}.online-dot{position:absolute;right:0;bottom:0;width:12px;height:12px;border-radius:50%;background:var(--success);border:2px solid var(--bg-elev)}.row-body{flex:1;min-width:0}.row-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:2px}.row-name{font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row-time{font-size:12px;color:var(--text-tertiary);flex-shrink:0}.row-bottom{display:flex;align-items:center;justify-content:space-between;gap:8px}.row-preview{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.row-unread{background:var(--success);color:#fff;font-size:11px;font-weight:700;padding:1px 7px;border-radius:var(--radius-pill);min-width:18px;text-align:center}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--divider)}.footer-actions{position:relative}.add-peer{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border-radius:var(--radius-md);font-weight:600;font-size:14px;color:var(--text-primary);transition:background .15s}.add-peer:hover{background:var(--bg-alt)}.add-peer-icon{width:28px;height:28px;border-radius:50%;background:var(--accent);color:var(--on-accent);display:inline-flex;align-items:center;justify-content:center;font-size:18px;font-weight:400;line-height:1}.footer-menu{position:absolute;bottom:calc(100% + 4px);left:0;right:0;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-strong);overflow:hidden}.footer-menu button{display:block;width:100%;text-align:left;padding:10px 14px;font-size:14px;color:var(--text-primary)}.footer-menu button:hover{background:var(--bg-alt)}.sticker-picker{position:absolute;bottom:calc(100% + 8px);left:0;width:320px;max-height:320px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-strong);overflow-y:auto;z-index:20;padding:8px}.sticker-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.sticker-cell{background:var(--bg-alt);border-radius:var(--radius-md);padding:6px;display:flex;align-items:center;justify-content:center;aspect-ratio:1;transition:background .1s}.sticker-cell:hover{background:var(--border)}.sticker-cell img{width:100%;height:100%;object-fit:contain}.reaction-picker{display:flex;gap:2px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-pill);padding:4px 6px;box-shadow:var(--shadow-strong)}.reaction-emoji{font-size:18px;width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:transparent;cursor:pointer;border:none;padding:0;transition:transform .1s,background .1s}.reaction-emoji:hover{background:var(--bg-alt);transform:scale(1.15)}.chat-pane{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--bg)}.chat-empty{align-items:center;justify-content:center}.chat-empty-inner{text-align:center;color:var(--text-secondary);max-width:320px;padding:32px}.chat-empty-mark{font-size:64px;font-weight:100;opacity:.3;line-height:1;margin-bottom:8px}.chat-empty-inner h2{margin:0 0 8px;font-size:18px;color:var(--text-primary)}.chat-empty-inner p{margin:0;font-size:14px}.chat-header{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--divider);background:var(--bg-elev);height:64px;flex-shrink:0;cursor:default}.chat-header.clickable{cursor:pointer}.chat-header.clickable:hover{background:var(--bg-alt)}.chat-header-meta{flex:1;min-width:0}.chat-header-name{font-weight:600;font-size:15px}.chat-header-status{font-size:12px;color:var(--text-secondary)}.chat-header-menu{position:relative;margin-left:auto}.kebab-btn{width:36px;height:36px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:var(--text-secondary)}.kebab-btn:hover{background:var(--bg-alt);color:var(--text-primary)}.kebab-menu{position:absolute;top:100%;right:0;margin-top:4px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-strong);z-index:10;min-width:160px;overflow:hidden}.kebab-menu button{display:block;width:100%;text-align:left;padding:10px 14px;font-size:14px;color:var(--text-primary)}.kebab-menu button:hover{background:var(--bg-alt)}.kebab-menu button.danger{color:var(--danger)}.chat-scroll{flex:1;overflow-y:auto;padding:16px 20px}.chat-zero{height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.chat-stream{display:flex;flex-direction:column;gap:4px;max-width:720px;margin:0 auto}.chat-day{display:flex;flex-direction:column;gap:2px}.day-divider{display:flex;justify-content:center;margin:16px 0 8px}.day-divider span{font-size:11px;color:var(--text-tertiary);background:var(--bg-alt);padding:4px 10px;border-radius:var(--radius-pill);font-weight:600}.bubble-row{display:flex;margin:1px 0}.bubble-row.mine{justify-content:flex-end}.bubble-row.theirs{justify-content:flex-start}.bubble{max-width:70%;padding:9px 14px;border-radius:var(--radius-lg);position:relative;word-wrap:break-word;white-space:pre-wrap;box-shadow:var(--shadow);display:inline-flex;flex-direction:column;gap:2px}.bubble-row.mine .bubble{background:var(--bubble-me);color:var(--bubble-me-text);border-bottom-right-radius:4px}.bubble-row.theirs .bubble{background:var(--bubble-them);color:var(--bubble-them-text);border-bottom-left-radius:4px}.bubble-cluster{display:flex;align-items:flex-end;gap:6px;max-width:75%;position:relative}.bubble-row.mine .bubble-cluster{flex-direction:row-reverse}.bubble-cluster .bubble,.bubble-cluster .sticker-wrap{max-width:100%}.bubble-actions{display:flex;gap:2px;opacity:0;transition:opacity .12s;flex-shrink:0;align-self:center}.bubble-cluster:hover .bubble-actions{opacity:1}.bubble-action-wrap{position:relative}.bubble-action{width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:transparent;color:var(--text-secondary);border:none;padding:0;cursor:pointer}.bubble-action:hover{background:var(--bg-alt);color:var(--text-primary)}.bubble-picker-anchor{position:absolute;bottom:calc(100% + 4px);left:50%;transform:translate(-50%);z-index:10}.bubble-row.mine .bubble-picker-anchor{left:auto;right:0;transform:none}.bubble-reply{display:flex;gap:8px;padding:6px 8px;margin-bottom:6px;background:#0000000f;border-radius:6px;font-size:12.5px;line-height:1.3;max-width:100%;width:100%;text-align:left;border:none;color:inherit;font-family:inherit;cursor:pointer;transition:background .12s}.bubble-reply:hover{background:#0000001a}.bubble-row.mine .bubble-reply:hover{background:#ffffff2e}@keyframes bubble-flash-pulse{0%{box-shadow:0 0 #ffc80000}20%{box-shadow:0 0 0 6px #ffc8008c}to{box-shadow:0 0 #ffc80000}}.bubble-row.bubble-flash>.bubble-cluster>.bubble,.bubble-row.bubble-flash>.bubble-cluster>.sticker-wrap{animation:bubble-flash-pulse 1.4s ease-out;border-radius:var(--radius-lg)}.bubble-row.mine .bubble-reply{background:#ffffff1f}.bubble-reply-bar{width:3px;background:currentColor;opacity:.6;border-radius:1px;align-self:stretch;flex-shrink:0}.bubble-reply-body{flex:1;min-width:0}.bubble-reply-name{font-weight:700;font-size:11.5px;opacity:.85;margin-bottom:1px}.bubble-reply-text{opacity:.85;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.reactions-row{display:flex;gap:4px;flex-wrap:wrap;margin-top:2px}.bubble-row.mine .reactions-row{justify-content:flex-end}.reaction-chip{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:var(--radius-pill);background:var(--bg-elev);border:1px solid var(--border);font-size:12px;line-height:1}.reaction-chip.mine{border-color:var(--accent)}.reaction-chip-emoji{font-size:13px}.reaction-chip-count{font-size:11px;font-weight:600;color:var(--text-secondary)}.reply-strip{display:flex;align-items:stretch;gap:10px;padding:8px 20px;background:var(--bg-alt);border-top:1px solid var(--divider)}.reply-strip-bar{width:3px;background:var(--accent);border-radius:2px;flex-shrink:0}.reply-strip-meta{flex:1;min-width:0}.reply-strip-label{font-size:11px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.04em}.reply-strip-preview{font-size:13px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reply-strip-close{width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:18px;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;align-self:center;flex-shrink:0}.reply-strip-close:hover{background:var(--bg-elev);color:var(--text-primary)}.bubble-text{font-size:14.5px;line-height:1.4}.bubble.image{padding:4px 4px 6px;max-width:320px}.bubble-image-btn{display:block;padding:0;border-radius:var(--radius-md);overflow:hidden;cursor:zoom-in;background:var(--bg-alt)}.bubble-image{display:block;width:100%;max-height:360px;object-fit:cover;border-radius:var(--radius-md)}.bubble-video{display:block;width:100%;max-width:320px;max-height:360px;border-radius:var(--radius-md);background:#000}.bubble.audio{padding:8px 10px;min-width:240px}.bubble-audio{display:flex;flex-direction:column;gap:4px}.bubble-audio audio{width:240px;height:36px}.bubble-file-name{font-size:12px;opacity:.75;word-break:break-all}.bubble.document{padding:8px 10px;min-width:220px}.bubble-document{display:flex;align-items:center;gap:10px;padding:4px 0;text-decoration:none;color:inherit}.doc-icon{font-size:28px;flex-shrink:0}.doc-meta{display:flex;flex-direction:column;min-width:0}.doc-name{font-size:13px;font-weight:600;word-break:break-all}.doc-size{font-size:11px;opacity:.65}.sticker-wrap{display:flex;flex-direction:column;align-items:flex-start;gap:2px;max-width:160px}.bubble-row.mine .sticker-wrap{align-items:flex-end}.sticker-img{width:140px;height:140px;object-fit:contain}.sticker-sender{font-size:12px;font-weight:700;color:var(--accent);opacity:.85;margin-bottom:4px}.sticker-meta{font-size:10.5px;color:var(--text-tertiary);display:flex;align-items:center;gap:4px;padding:0 4px}.sticker-missing{font-size:12px;color:var(--text-tertiary);font-style:italic}.bubble-sender{font-size:12px;font-weight:700;color:var(--accent);margin-bottom:2px;opacity:.85}.bubble-meta{display:flex;align-items:center;gap:4px;align-self:flex-end;font-size:10.5px;opacity:.7;margin-top:-2px}.bubble-status.read{color:#4fc3f7;opacity:1}.bubble-status.failed{color:var(--danger);font-weight:700}.composer{display:flex;align-items:flex-end;gap:8px;padding:12px 20px;background:var(--bg-elev);border-top:1px solid var(--divider);flex-shrink:0}.composer textarea{flex:1;background:var(--bg-alt);padding:10px 14px;border-radius:var(--radius-lg);resize:none;line-height:1.4;max-height:160px;font-size:14.5px}.attach-wrap{position:relative}.attach-btn{width:40px;height:40px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-secondary)}.attach-btn:hover:not(:disabled){background:var(--bg-alt);color:var(--text-primary)}.attach-menu{position:absolute;bottom:calc(100% + 8px);left:0;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-strong);z-index:20;overflow:hidden;min-width:180px}.attach-menu button{display:flex;align-items:center;gap:12px;width:100%;padding:10px 14px;font-size:14px;text-align:left;color:var(--text-primary)}.attach-menu button:hover{background:var(--bg-alt)}.attach-icon{font-size:18px;width:24px;display:inline-flex;justify-content:center}.send-btn{width:40px;height:40px;border-radius:50%;background:var(--accent);color:var(--on-accent);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .15s}.send-btn:hover:not(:disabled){opacity:.85}.send-btn:disabled{background:var(--avatar-bg);color:var(--text-tertiary)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;padding:24px;z-index:100;animation:fade-in .12s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-elev);border-radius:var(--radius-lg);width:100%;max-width:460px;box-shadow:var(--shadow-strong);border:1px solid var(--border);overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--divider)}.modal-header h2{margin:0;font-size:16px;font-weight:600}.modal-close{font-size:24px;color:var(--text-secondary);line-height:1;width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--bg-alt);color:var(--text-primary)}.modal-body{padding:20px}.modal-hint{margin:0 0 16px;color:var(--text-secondary);font-size:13px}.modal-body label{display:block;margin-bottom:14px}.modal-body label>span{display:block;font-size:12px;color:var(--text-secondary);margin-bottom:6px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.modal-body input{background:var(--bg-alt);padding:10px 12px;border-radius:var(--radius-md);font-family:ui-monospace,SFMono-Regular,monospace;font-size:13px}.modal-error{padding:10px 12px;background:var(--bg-alt);border-left:3px solid var(--danger);color:var(--danger);border-radius:var(--radius-sm);font-size:13px;margin-top:4px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid var(--divider)}.modal-btn{padding:9px 16px;border-radius:var(--radius-md);font-weight:600;font-size:14px}.modal-btn.ghost{color:var(--text-secondary)}.modal-btn.ghost:hover{background:var(--bg-alt);color:var(--text-primary)}.modal-btn.primary{background:var(--accent);color:var(--on-accent)}.modal-btn.primary:hover{opacity:.85}.connect-tabs{display:flex;border-bottom:1px solid var(--divider);padding:0 20px}.connect-tab{flex:1;padding:12px 8px;font-weight:600;font-size:14px;color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s}.connect-tab.active{color:var(--text-primary);border-bottom-color:var(--accent)}.connect-meta{font-size:12px;color:var(--text-secondary);margin:4px 0 12px}.connect-preview{background:var(--bg-alt);border-radius:var(--radius-md);padding:12px 14px;margin-bottom:12px}.connect-preview-title{font-size:14px;margin-bottom:4px}.connect-preview-about{font-size:13px;color:var(--text-secondary);font-style:italic}.share-kind{display:flex;gap:6px;margin-bottom:14px;background:var(--bg-alt);padding:4px;border-radius:var(--radius-pill)}.kind-pill{flex:1;padding:7px 12px;border-radius:var(--radius-pill);font-size:13px;font-weight:600;color:var(--text-secondary);transition:background .15s,color .15s}.kind-pill.active{background:var(--bg-elev);color:var(--text-primary);box-shadow:var(--shadow)}.kind-pill:disabled{opacity:.5;cursor:default}.group-select{width:100%;padding:10px 12px;background:var(--bg-alt);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);font:inherit}.profile-section{margin-top:24px;padding-top:16px;border-top:1px solid var(--divider)}.profile-section-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);font-weight:700;margin-bottom:10px}.profile-save-row{display:flex;align-items:center;gap:12px;margin-top:4px}.profile-save-msg{font-size:12px;color:var(--text-secondary)}.profile-status-row{display:flex;align-items:center;gap:10px}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.disconnected{background:var(--danger)}.status-dot.connecting{background:var(--warning)}.status-dot.connected{background:var(--success)}.status-text{font-size:13px;color:var(--text-secondary);flex:1}.privacy-row{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 0;font-size:14px;color:var(--text-primary)}.privacy-row+.privacy-row{border-top:1px solid var(--divider)}.toggle{width:36px;height:20px;border-radius:999px;background:var(--border-strong);position:relative;transition:background .15s;flex-shrink:0}.privacy-row.on .toggle{background:var(--accent)}.knob{position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;top:2px;left:2px;transition:transform .15s}.privacy-row.on .knob{transform:translate(16px)}.privacy-loading{font-size:13px;color:var(--text-secondary)}.avatar-edit{display:flex;justify-content:center;margin-bottom:16px}.avatar-edit-btn{position:relative;padding:0;border-radius:50%;overflow:hidden;display:inline-block}.avatar-edit-btn:hover .avatar-edit-overlay{opacity:1}.avatar-edit-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;opacity:0;transition:opacity .15s;border-radius:50%}.plan-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.plan-badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:var(--radius-pill);text-transform:uppercase;letter-spacing:.04em}.plan-badge.free{background:var(--bg-alt);color:var(--text-secondary)}.plan-badge.plus{background:var(--accent);color:var(--on-accent)}.plan-meta{font-size:13px;color:var(--text-secondary);flex:1;min-width:0}.plan-hint{font-size:11px;color:var(--text-tertiary)}.pending-strip{border-bottom:1px solid var(--divider);background:var(--bg-alt)}.pending-summary{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;font-size:13px;font-weight:600;color:var(--text-primary)}.pending-summary:hover{background:var(--border)}.pending-badge{background:var(--success);color:#fff;font-size:11px;padding:1px 7px;border-radius:var(--radius-pill);min-width:18px;text-align:center}.chev{margin-left:auto;font-size:18px;color:var(--text-tertiary);transition:transform .15s;display:inline-block}.chev.open{transform:rotate(90deg)}.pending-list{border-top:1px solid var(--divider)}.pending-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;border-bottom:1px solid var(--divider)}.pending-item:last-child{border-bottom:0}.pending-meta{flex:1;min-width:0}.pending-title{font-size:13px;color:var(--text-primary);font-weight:600}.pending-time{font-size:11px;color:var(--text-tertiary)}.pending-actions{display:flex;gap:6px;flex-shrink:0}.pending-btn{padding:6px 10px;border-radius:var(--radius-sm);font-size:12px;font-weight:600}.pending-btn.primary{background:var(--accent);color:var(--on-accent)}.pending-btn.primary:hover:not(:disabled){opacity:.85}.pending-btn.ghost{color:var(--text-secondary)}.pending-btn.ghost:hover:not(:disabled){color:var(--text-primary);background:var(--bg-elev)}.step-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:16px;padding-top:16px;border-top:1px solid var(--divider)}.picker-search{margin-bottom:12px}.picker-search input{background:var(--bg-alt);padding:9px 14px;border-radius:var(--radius-pill);font-size:14px}.picker-list{max-height:340px;overflow-y:auto;margin:0 -20px}.picker-row{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:10px 20px;border:none;background:transparent;transition:background .1s}.picker-row:hover,.picker-row.checked{background:var(--bg-alt)}.picker-name{flex:1;font-size:14px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.picker-check{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--border-strong);display:inline-flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;color:var(--on-accent)}.picker-check.on{background:var(--accent);border-color:var(--accent)}.member-list{display:flex;flex-direction:column;gap:4px}.member-row{display:flex;align-items:center;gap:10px;padding:6px 0}.member-meta{flex:1;min-width:0}.member-name{font-size:14px;color:var(--text-primary);font-weight:500}.member-role{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em}.member-remove{width:24px;height:24px;border-radius:50%;color:var(--text-tertiary);font-size:16px;line-height:1}.member-remove:hover{background:var(--bg-alt);color:var(--danger)}.invite-contact-list{display:flex;flex-direction:column;gap:2px;max-height:180px;overflow-y:auto;margin:0 -20px}.invite-contact-row{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:6px 20px;font-size:14px;color:var(--text-primary)}.invite-contact-row:hover{background:var(--bg-alt)}.invite-contact-row>span:nth-of-type(1){flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invite-contact-add{font-size:12px;color:var(--accent);font-weight:600}.token-list{margin-top:12px;display:flex;flex-direction:column;gap:8px}.token-row{display:flex;align-items:center;gap:8px;background:var(--bg-alt);padding:10px 12px;border-radius:var(--radius-md)}.token-meta{flex:1;min-width:0}.token-label{font-size:13px;font-weight:600;color:var(--text-primary)}.token-info{font-size:11px;color:var(--text-tertiary);margin-top:2px}.token-actions{display:flex;gap:4px;flex-shrink:0}.modal-btn.danger{color:var(--danger)}.contacts-modal{display:flex;flex-direction:column;max-height:80vh}.contacts-search{padding:12px 20px;border-bottom:1px solid var(--divider)}.contacts-search input{background:var(--bg-alt);padding:9px 14px;border-radius:var(--radius-pill);font-size:14px}.contacts-list{flex:1;overflow-y:auto;min-height:0}.contacts-empty{padding:32px 24px;text-align:center;color:var(--text-secondary);font-size:13px}.contact-pick{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:10px 20px;font:inherit;color:var(--text-primary);border:none;background:transparent;border-bottom:1px solid var(--divider)}.contact-pick:hover{background:var(--bg-alt)}.contact-pick-meta{flex:1;min-width:0}.contact-pick-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.contact-pick-about{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.contacts-footer{padding:12px 20px;border-top:1px solid var(--divider)}.stories-bar{display:flex;gap:12px;padding:12px 16px;border-bottom:1px solid var(--divider);overflow-x:auto;scrollbar-width:thin}.story-ring{position:relative;display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;padding:0;background:transparent;width:64px}.story-ring>.avatar{border:2px solid var(--accent);padding:0;box-shadow:0 0 0 2px var(--bg-elev) inset;outline:0}.story-ring.viewed>.avatar{border-color:var(--border-strong)}.story-ring.add>.avatar{border-color:var(--border-strong)}.story-add-plus{position:absolute;bottom:18px;right:6px;width:18px;height:18px;border-radius:50%;background:var(--accent);color:var(--on-accent);font-size:14px;line-height:1;display:inline-flex;align-items:center;justify-content:center;border:2px solid var(--bg-elev)}.story-label{font-size:11px;color:var(--text-secondary);max-width:60px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.action-circle{width:48px;height:48px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:var(--bg-alt);color:var(--text-primary);border:2px solid var(--border-strong);box-shadow:0 0 0 2px var(--bg-elev) inset}.story-ring.action:hover .action-circle{background:var(--border)}.story-viewer{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;z-index:200;display:flex;flex-direction:column;align-items:center;padding:12px;animation:fade-in .12s ease}.story-progress{display:flex;gap:4px;width:100%;max-width:460px;padding:4px 0}.progress-bar{flex:1;height:3px;background:#ffffff40;border-radius:2px;overflow:hidden}.progress-bar.done{background:#ffffffd9}.progress-bar.active{background:linear-gradient(to right,#fffffff2 50%,#ffffff40 50%);background-size:200% 100%;animation:progress-fill 5s linear forwards}@keyframes progress-fill{to{background-position:-100% 0}}.story-topbar{display:flex;align-items:center;gap:12px;width:100%;max-width:460px;padding:8px 0 12px;color:#fff}.story-author{flex:1;min-width:0}.story-author-name{font-size:14px;font-weight:600}.story-author-time{font-size:11px;opacity:.7}.story-delete-btn,.story-close-btn{background:transparent;color:#fff;width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:18px}.story-delete-btn:hover,.story-close-btn:hover{background:#ffffff26}.story-stage{position:relative;flex:1;width:100%;max-width:460px;display:flex;align-items:center;justify-content:center}.story-side{position:absolute;top:0;bottom:0;width:40%;cursor:pointer;background:transparent;z-index:2}.story-side.prev{left:0}.story-side.next{right:0}.story-text{width:100%;height:100%;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;padding:32px;color:#fff;text-align:center}.story-text-body{font-size:28px;font-weight:600;line-height:1.3;word-break:break-word}.story-photo-wrap{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center}.story-photo{max-width:100%;max-height:100%;object-fit:contain;border-radius:var(--radius-lg)}.story-photo-caption{position:absolute;left:16px;right:16px;bottom:16px;background:#0000008c;color:#fff;padding:10px 14px;border-radius:var(--radius-md);font-size:14px;line-height:1.4;text-align:center}.story-footer{width:100%;max-width:460px;text-align:center;padding:12px 0;color:#ffffffb3;font-size:13px}.story-tabs{display:flex;border-bottom:1px solid var(--divider);padding:0 20px}.story-tab{flex:1;padding:12px 8px;font-weight:600;font-size:14px;color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s}.story-tab.active{color:var(--text-primary);border-bottom-color:var(--accent)}.story-preview{width:100%;aspect-ratio:9 / 16;max-height:340px;border-radius:var(--radius-lg);margin-bottom:12px;display:flex;align-items:center;justify-content:center;overflow:hidden}.story-preview.text{padding:24px;color:#fff;font-weight:600;font-size:22px;line-height:1.3;text-align:center}.story-preview.placeholder{background:var(--bg-alt);color:var(--text-tertiary);font-size:14px}.story-preview.photo img{width:100%;height:100%;object-fit:cover}.story-preview-text{word-break:break-word}.story-caption-input{background:var(--bg-alt);padding:10px 12px;border-radius:var(--radius-md);margin-bottom:12px;resize:vertical}.story-bg-row{display:flex;gap:8px;margin-bottom:12px}.bg-swatch{width:28px;height:28px;border-radius:50%;border:2px solid transparent;flex-shrink:0;cursor:pointer;padding:0}.bg-swatch.active{border-color:var(--accent);box-shadow:0 0 0 2px var(--bg-elev) inset}.image-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px;cursor:zoom-out}.image-lightbox-img{max-width:95vw;max-height:95vh;object-fit:contain;cursor:default}.image-lightbox-close,.image-lightbox-action{position:absolute;top:16px;width:36px;height:36px;border-radius:50%;background:#ffffff26;color:#fff;display:inline-flex;align-items:center;justify-content:center;border:none;cursor:pointer}.image-lightbox-close{right:16px;font-size:22px;line-height:1}.image-lightbox-action{right:64px}.image-lightbox-close:hover,.image-lightbox-action:hover{background:#ffffff40}.app{height:100%;display:flex;flex-direction:column}.app-shell{flex:1;display:flex;min-height:0}.app-loading{height:100%;background:var(--bg)}.conn-banner{flex-shrink:0;text-align:center;font-size:12px;font-weight:600;padding:6px 12px;color:var(--on-accent)}.conn-banner.connecting{background:var(--warning);color:#fff}.conn-banner.disconnected{background:var(--danger);color:#fff}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color-scheme:light dark;--bg: #fafafa;--bg-elev: #ffffff;--bg-alt: #f5f5f5;--text-primary: rgba(0, 0, 0, .87);--text-secondary: rgba(0, 0, 0, .54);--text-tertiary: rgba(0, 0, 0, .38);--border: #eeeeee;--border-strong: #e0e0e0;--divider: #eeeeee;--avatar-bg: #eeeeee;--input-bg: #fafafa;--bubble-them: #ffffff;--bubble-me: rgba(0, 0, 0, .87);--bubble-them-text: rgba(0, 0, 0, .87);--bubble-me-text: #ffffff;--accent: rgba(0, 0, 0, .87);--on-accent: #ffffff;--success: #43a047;--danger: #e53935;--warning: #fb8c00;--shadow: 0 1px 2px rgba(0, 0, 0, .04), 0 1px 4px rgba(0, 0, 0, .04);--shadow-strong: 0 4px 16px rgba(0, 0, 0, .12);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-pill: 999px}@media (prefers-color-scheme: dark){:root{--bg: #121212;--bg-elev: #1e1e1e;--bg-alt: #2a2a2a;--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .7);--text-tertiary: rgba(255, 255, 255, .45);--border: #2e2e2e;--border-strong: #3a3a3a;--divider: #2e2e2e;--avatar-bg: #3a3a3a;--input-bg: #2a2a2a;--bubble-them: #2a2a2a;--bubble-me: #ffffff;--bubble-them-text: #ffffff;--bubble-me-text: rgba(0, 0, 0, .87);--accent: #ffffff;--on-accent: rgba(0, 0, 0, .87);--shadow: 0 1px 2px rgba(0, 0, 0, .4), 0 1px 4px rgba(0, 0, 0, .3);--shadow-strong: 0 4px 16px rgba(0, 0, 0, .5)}}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text-primary);font-size:14px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button{font:inherit;color:inherit;cursor:pointer;background:transparent;border:none}button:disabled{cursor:default;opacity:.5}input,textarea{font:inherit;color:inherit;background:transparent;border:none;outline:none;width:100%}input::placeholder,textarea::placeholder{color:var(--text-tertiary)}a{color:inherit}
