:root{--bg-primary:#f5f7fa;--bg-secondary:#fff;--bg-tertiary:#e8ecf1;--text-primary:#1a1a2e;--text-secondary:#65778b;--text-muted:#9ba8b7;--border-color:#e1e5ea;--accent:#e74c5e;--accent-light:#ffe0e4;--accent-hover:#d43a4c;--shadow-sm:0 1px 3px #0000000f;--shadow-md:0 4px 16px #00000014;--shadow-lg:0 8px 32px #0000001f;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--max-width:680px;--transition:.25s ease;--msg-other:#f0f2f5;--msg-self:#e74c5e;--msg-self-text:#fff;--tag-bg:#edeaff;--tag-text:#5b5bd6;--skeleton:#e4e8ed;--overlay:#0006}[data-theme=dark]{--bg-primary:#0d1117;--bg-secondary:#161b22;--bg-tertiary:#21262d;--text-primary:#e6edf3;--text-secondary:#8b949e;--text-muted:#6e7681;--border-color:#30363d;--accent:#f85149;--accent-light:#3d1a1c;--accent-hover:#ff6b63;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--msg-other:#21262d;--msg-self:#f85149;--msg-self-text:#fff;--tag-bg:#1f2937;--tag-text:#c4b5fd;--skeleton:#21262d;--overlay:#000000b3}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-primary);color:var(--text-primary);transition:background var(--transition), color var(--transition);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;line-height:1.6}input,textarea,button{font-family:inherit}a{color:var(--accent);text-decoration:none}button{cursor:pointer;background:0 0;border:none;outline:none}img{max-width:100%;display:block}ul{list-style:none}#root{min-height:100vh;padding-bottom:72px}.app-container{max-width:480px;min-height:100vh;margin:0 auto;position:relative}.page{padding:12px 16px}.page-title{z-index:10;background:var(--bg-primary);transition:background var(--transition);margin-bottom:16px;padding:8px 0;font-size:22px;font-weight:700;position:sticky;top:0}.bottom-nav{background:var(--bg-secondary);border-top:1px solid var(--border-color);z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);width:100%;max-width:480px;transition:background var(--transition);display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-item{color:var(--text-muted);transition:color var(--transition);background:0 0;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;padding:8px 0;font-size:10px;display:flex}.nav-item.active{color:var(--accent)}.nav-item svg{width:24px;height:24px}.nav-fab{flex:1;justify-content:center;align-items:center;display:flex}.nav-fab button{background:var(--accent);color:#fff;width:44px;height:44px;transition:transform var(--transition), box-shadow var(--transition);border-radius:50%;justify-content:center;align-items:center;margin-top:-16px;display:flex;box-shadow:0 4px 14px #e74c5e66}.nav-fab button:active{transform:scale(.95)}.nav-fab button svg{width:22px;height:22px}.avatar{object-fit:cover;background:var(--bg-tertiary);border-radius:50%;flex-shrink:0;width:40px;height:40px}.avatar.sm{width:32px;height:32px}.avatar.lg{width:64px;height:64px}.avatar.xl{width:96px;height:96px}.badge{background:var(--tag-bg);color:var(--tag-text);transition:background var(--transition), color var(--transition);white-space:nowrap;border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.badge.active{background:var(--accent);color:#fff}.btn{border-radius:var(--radius-sm);transition:all var(--transition);padding:8px 20px;font-size:14px;font-weight:600}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-ghost{color:var(--text-secondary)}@keyframes heartbeat{0%{transform:scale(1)}15%{transform:scale(1.35)}30%{transform:scale(1)}45%{transform:scale(1.2)}60%{transform:scale(1)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOutDown{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes ripple{0%{opacity:.6;transform:scale(0)}to{opacity:0;transform:scale(2.5)}}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}@media (width>=768px){.app-container{border-left:1px solid var(--border-color);border-right:1px solid var(--border-color)}}.feed-header{margin-bottom:16px;padding:8px 0;font-size:26px;font-weight:800}.tag-filter{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:8px;padding-bottom:16px;display:flex;overflow-x:auto}.tag-filter::-webkit-scrollbar{display:none}.post-list{flex-direction:column;gap:16px;padding-bottom:16px;display:flex}.post-item{animation:.4s both fadeInUp}.post-card{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:background var(--transition), box-shadow var(--transition);padding:16px}.post-card:hover{box-shadow:var(--shadow-md)}.post-header{align-items:center;gap:10px;margin-bottom:12px;display:flex}.post-user-info{flex-direction:column;flex:1;display:flex}.post-username{font-size:14px;font-weight:600}.post-time{color:var(--text-muted);font-size:11px}.post-tags{gap:4px;display:flex}.post-content{color:var(--text-primary);white-space:pre-wrap;margin-bottom:12px;font-size:14px;line-height:1.7}.post-images{border-radius:var(--radius-md);gap:4px;margin-bottom:12px;display:grid;overflow:hidden}.post-images.count-1{grid-template-columns:1fr}.post-images.count-2,.post-images.count-3{grid-template-columns:1fr 1fr}.post-img-wrap{aspect-ratio:3/2;cursor:pointer;position:relative;overflow:hidden}.post-img-wrap img{object-fit:cover;width:100%;height:100%;transition:transform .3s}.post-img-wrap:hover img{transform:scale(1.03)}.img-more{color:#fff;background:#00000080;justify-content:center;align-items:center;font-size:20px;font-weight:700;display:flex;position:absolute;inset:0}.post-video{border-radius:var(--radius-md);background:#000;margin-bottom:12px;overflow:hidden}.post-video video{object-fit:contain;width:100%;max-height:300px}.post-actions{border-top:1px solid var(--border-color);gap:4px;padding-top:8px;display:flex}.action-btn{color:var(--text-secondary);border-radius:var(--radius-sm);transition:color var(--transition), background var(--transition);flex:1;justify-content:center;align-items:center;gap:6px;padding:8px;font-size:13px;display:flex}.action-btn:hover{color:var(--accent);background:var(--accent-light)}.action-btn svg{width:18px;height:18px}.like-btn.liked{color:var(--accent)!important}.like-icon{display:inline-flex;position:relative}.like-icon svg{width:20px;height:20px}.like-icon.heartbeat svg{animation:.6s heartbeat}.like-ripple{background:var(--accent);pointer-events:none;border-radius:50%;animation:.6s ease-out forwards ripple;position:absolute;inset:-4px}.comments-section{border-top:1px solid var(--border-color);flex-direction:column;gap:12px;margin-top:12px;padding-top:12px;display:flex}.comment-item{gap:8px;animation:.3s both fadeInUp;display:flex}.comment-body{flex-direction:column;gap:2px;display:flex}.comment-name{color:var(--accent);font-size:12px;font-weight:600}.comment-text{color:var(--text-primary);font-size:13px;line-height:1.5}.comment-time{color:var(--text-muted);font-size:11px}.comment-input-wrap{align-items:center;gap:8px;padding-top:8px;display:flex}.comment-input{border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);transition:border-color var(--transition);border-radius:20px;outline:none;flex:1;padding:8px 12px;font-size:13px}.comment-input:focus{border-color:var(--accent)}.comment-send{width:32px;height:32px;color:var(--accent);transition:background var(--transition);border-radius:50%;justify-content:center;align-items:center;display:flex}.comment-send:disabled{opacity:.3}.comment-send:not(:disabled):hover{background:var(--accent-light)}.comment-send svg{width:16px;height:16px}.image-viewer{z-index:200;background:var(--overlay);justify-content:center;align-items:center;padding:24px;animation:.2s fadeInUp;display:flex;position:fixed;inset:0}.image-viewer-content{max-width:100%;max-height:100%;animation:.3s scaleIn;position:relative}.image-viewer-content img{border-radius:var(--radius-md);object-fit:contain;max-width:100%;max-height:80vh}.viewer-close{color:#fff;background:#fff3;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:20px;display:flex;position:absolute;top:-40px;right:0}.viewer-dots{justify-content:center;gap:6px;padding:12px 0;display:flex}.viewer-dot{cursor:pointer;width:8px;height:8px;transition:all var(--transition);background:#fff6;border-radius:50%}.viewer-dot.active{background:#fff;transform:scale(1.2)}.viewer-nav{pointer-events:none;justify-content:space-between;align-items:center;display:flex;position:absolute;inset:0}.viewer-btn{pointer-events:all;color:#fff;background:#fff3;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.viewer-btn.prev{margin-left:12px}.viewer-btn.next{margin-right:12px}.publish-page{flex-direction:column;min-height:100vh;display:flex}.publish-header{z-index:10;background:var(--bg-primary);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:12px 16px;display:flex;position:sticky;top:0}.publish-header h2{font-size:16px;font-weight:700}.publish-body{flex-direction:column;flex:1;gap:16px;padding:16px;display:flex}.publish-user{align-items:center;gap:10px;font-size:14px;font-weight:600;display:flex}.publish-textarea{resize:vertical;width:100%;min-height:120px;color:var(--text-primary);background:0 0;border:none;outline:none;font-size:15px;line-height:1.7}.publish-textarea::placeholder{color:var(--text-muted)}.publish-images{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.pub-img-wrap{aspect-ratio:1;border-radius:var(--radius-sm);position:relative;overflow:hidden}.pub-img-wrap img{object-fit:cover;width:100%;height:100%}.pub-img-remove{color:#fff;background:#00000080;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:16px;display:flex;position:absolute;top:4px;right:4px}.pub-img-size{color:#fff;background:#00000080;border-radius:4px;padding:2px 6px;font-size:10px;position:absolute;bottom:4px;left:4px}.pub-img-add{aspect-ratio:1;border-radius:var(--radius-sm);border:2px dashed var(--border-color);color:var(--text-muted);cursor:pointer;transition:border-color var(--transition);justify-content:center;align-items:center;display:flex}.pub-img-add:hover{border-color:var(--accent)}.pub-img-add svg{width:28px;height:28px}.pub-video-wrap{border-radius:var(--radius-md);background:#000;position:relative;overflow:hidden}.pub-video-wrap video{object-fit:contain;width:100%;max-height:240px}.pub-video-remove{color:#fff;background:#0009;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;display:flex;position:absolute;top:8px;right:8px}.pub-dropzone{border-radius:var(--radius-md);border:2px dashed var(--border-color);color:var(--text-muted);text-align:center;cursor:pointer;transition:all var(--transition);flex-direction:column;align-items:center;gap:8px;padding:32px;display:flex}.pub-dropzone:hover,.pub-dropzone.drag-over{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.pub-dropzone p{font-size:14px;font-weight:500}.pub-dropzone span{font-size:12px}.pub-tags h4{margin-bottom:8px;font-size:14px;font-weight:600}.pub-tags-list{flex-wrap:wrap;gap:8px;display:flex}.publish-toolbar{border-top:1px solid var(--border-color);background:var(--bg-secondary);transition:background var(--transition);gap:16px;padding:12px 16px;display:flex;position:sticky;bottom:72px}.publish-toolbar button{border-radius:var(--radius-sm);width:40px;height:40px;color:var(--text-secondary);transition:color var(--transition), background var(--transition);justify-content:center;align-items:center;display:flex}.publish-toolbar button:hover{color:var(--accent);background:var(--accent-light)}.messenger-list{padding-bottom:16px}.conv-list{flex-direction:column;gap:2px;display:flex}.conv-item{border-radius:var(--radius-md);text-align:left;width:100%;transition:background var(--transition);align-items:center;gap:12px;padding:12px 4px;display:flex}.conv-item:hover{background:var(--bg-secondary)}.conv-avatar-wrap{flex-shrink:0;position:relative}.online-dot{border:2px solid var(--bg-primary);background:#22c55e;border-radius:50%;width:10px;height:10px;position:absolute;bottom:1px;right:1px}.conv-info{flex:1;min-width:0}.conv-top{justify-content:space-between;align-items:center;display:flex}.conv-name{font-size:15px;font-weight:600}.conv-time{color:var(--text-muted);flex-shrink:0;font-size:11px}.conv-bottom{justify-content:space-between;align-items:center;margin-top:2px;display:flex}.conv-last{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;overflow:hidden}.conv-badge{background:var(--accent);color:#fff;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:8px;padding:0 5px;font-size:10px;font-weight:700;display:flex}.chat-room{z-index:150;background:var(--bg-primary);flex-direction:column;width:100%;max-width:480px;margin:0 auto;animation:.3s slideUp;display:flex;position:fixed;inset:0}.chat-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);transition:background var(--transition);align-items:center;gap:10px;padding:12px 16px;display:flex}.chat-back{width:32px;height:32px;color:var(--text-secondary);justify-content:center;align-items:center;display:flex}.chat-header-info{flex-direction:column;display:flex}.chat-name{font-size:15px;font-weight:600}.chat-status{color:var(--text-muted);font-size:11px}.chat-status.online{color:#22c55e}.chat-messages{flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.chat-msg{flex-direction:column;animation:.3s both fadeInUp;display:flex}.chat-msg.other{align-items:flex-start}.chat-msg.self{align-items:flex-end}.msg-bubble{word-break:break-word;border-radius:18px;max-width:75%;padding:10px 14px;font-size:14px;line-height:1.5}.chat-msg.other .msg-bubble{background:var(--msg-other);color:var(--text-primary);border-bottom-left-radius:4px}.chat-msg.self .msg-bubble{background:var(--msg-self);color:var(--msg-self-text);border-bottom-right-radius:4px}.msg-meta{justify-content:flex-end;align-items:center;gap:6px;margin-top:4px;display:flex}.msg-time,.msg-status{opacity:.7;font-size:10px}.msg-status.read:after{content:"✓✓"}.msg-status.sent:after{content:"✓"}.msg-recall{color:var(--text-muted);opacity:0;transition:opacity var(--transition);margin-top:4px;padding:2px 8px;font-size:11px}.chat-msg.self:hover .msg-recall{opacity:1}.msg-recalled{color:var(--text-muted);padding:6px 12px;font-size:12px;font-style:italic}.chat-input-bar{background:var(--bg-secondary);border-top:1px solid var(--border-color);transition:background var(--transition);align-items:center;gap:8px;padding:12px 16px;display:flex}.chat-input{border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);transition:border-color var(--transition);border-radius:22px;outline:none;flex:1;padding:10px 16px;font-size:14px}.chat-input:focus{border-color:var(--accent)}.chat-send-btn{background:var(--accent);color:#fff;width:40px;height:40px;transition:opacity var(--transition);border-radius:50%;justify-content:center;align-items:center;display:flex}.chat-send-btn:disabled{opacity:.4}.search-bar{background:var(--bg-secondary);border-radius:var(--radius-md);transition:background var(--transition);color:var(--text-muted);align-items:center;gap:10px;margin-bottom:16px;padding:10px 16px;display:flex}.search-input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-size:14px}.search-input::placeholder{color:var(--text-muted)}.search-clear{width:20px;height:20px;color:var(--text-muted);justify-content:center;align-items:center;font-size:16px;display:flex}.circle-grid{flex-direction:column;gap:12px;padding-bottom:16px;display:flex}.circle-card{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:background var(--transition), box-shadow var(--transition);animation:.4s both fadeInUp;overflow:hidden}.circle-card:hover{box-shadow:var(--shadow-md)}.circle-cover{height:140px;position:relative;overflow:hidden}.circle-cover img{object-fit:cover;width:100%;height:100%}.circle-members{color:#fff;background:#00000080;border-radius:12px;align-items:center;gap:4px;padding:4px 8px;font-size:11px;display:flex;position:absolute;bottom:8px;right:8px}.circle-info{padding:12px 14px}.circle-info h3{margin-bottom:8px;font-size:16px;font-weight:700}.circle-actions{justify-content:space-between;align-items:center;display:flex}.circle-join{background:var(--accent);color:#fff;transition:all var(--transition);border-radius:16px;padding:6px 16px;font-size:12px;font-weight:600}.circle-join.joined{background:var(--bg-tertiary);color:var(--text-secondary)}.circle-join:active{transform:scale(.95)}.profile-card{background:var(--bg-secondary);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-sm);transition:background var(--transition);padding:24px 16px}.profile-avatar-section{cursor:pointer;flex-direction:column;align-items:center;gap:8px;margin-bottom:16px;display:flex}.profile-avatar-wrap{position:relative}.avatar-edit-badge{background:var(--accent);color:#fff;border:2px solid var(--bg-secondary);border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;display:flex;position:absolute;bottom:2px;right:2px}.avatar-edit-hint{color:var(--text-muted);font-size:12px}.profile-info{flex-direction:column;align-items:center;gap:8px;display:flex}.profile-name{font-size:20px;font-weight:700}.profile-bio{color:var(--text-secondary);font-size:14px}.profile-edit-form{text-align:left;flex-direction:column;gap:12px;display:flex}.form-field{flex-direction:column;gap:4px;display:flex}.form-field label{color:var(--text-secondary);font-size:13px;font-weight:600}.form-field input,.form-field textarea{border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);resize:vertical;transition:border-color var(--transition);outline:none;padding:10px 12px;font-size:14px}.form-field input:focus,.form-field textarea:focus{border-color:var(--accent)}.form-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.profile-interests{text-align:left;margin-top:20px}.profile-interests h4{margin-bottom:10px;font-size:14px;font-weight:600}.profile-tags{flex-wrap:wrap;gap:8px;display:flex}.profile-stats{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:background var(--transition);margin-top:12px;display:flex}.stat-item{flex-direction:column;flex:1;align-items:center;padding:16px 0;display:flex}.stat-item:not(:last-child){border-right:1px solid var(--border-color)}.stat-value{color:var(--accent);font-size:20px;font-weight:700}.stat-label{color:var(--text-muted);margin-top:2px;font-size:11px}.crop-modal{z-index:200;background:var(--bg-primary);flex-direction:column;display:flex;position:fixed;inset:0}.crop-header{justify-content:space-between;align-items:center;padding:12px 16px;font-size:15px;font-weight:600;display:flex}.crop-area{cursor:grab;touch-action:none;background:#000;flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.crop-area:active{cursor:grabbing}.crop-img{object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;max-width:100%;max-height:100%}.crop-overlay{border:2px solid #fff;position:absolute;box-shadow:0 0 0 9999px #00000080}.crop-grid{grid-template-rows:1fr 1fr 1fr;grid-template-columns:1fr 1fr 1fr;display:grid;position:absolute;inset:0}.crop-grid div:first-child,.crop-grid div:nth-child(3),.crop-grid div:nth-child(7),.crop-grid div:nth-child(9){border:1px solid #ffffff4d}
