.fm-container{max-width:680px;margin:0 auto;padding:1.5rem 1rem}.fm-hero{text-align:center;padding:1rem 0 1.5rem}.fm-hero-title{font-family:var(--font-brand),serif;text-transform:uppercase;color:var(--text-primary);letter-spacing:.05em;margin-bottom:.375rem;font-size:2rem;font-weight:800}.fm-hero-desc{color:var(--text-secondary);font-size:.875rem;line-height:1.5}.fm-search-bar{margin-bottom:1rem;position:relative}.fm-search-icon{color:var(--text-secondary);pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.fm-search-input{border:1px solid var(--border-color);background:var(--bg-secondary);width:100%;color:var(--text-primary);border-radius:10px;outline:none;padding:.7rem 2.5rem .7rem 2.75rem;font-family:inherit;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.fm-search-input:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #ef444414}.fm-search-clear{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:4px;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.fm-toolbar{border-bottom:1px solid var(--border-color);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.625rem 0;display:flex}.fm-toolbar-left{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.fm-create-btn{background:var(--accent-color);color:#fff;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:.375rem;padding:.5rem 1rem;font-family:inherit;font-size:.825rem;font-weight:600;transition:background .15s;display:inline-flex}.fm-create-btn:hover{background:var(--accent-hover)}.fm-sort-group{background:var(--bg-tertiary);border-radius:8px;gap:2px;padding:3px;display:flex}.fm-sort-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.35rem .75rem;font-family:inherit;font-size:.8rem;font-weight:500;transition:all .15s}.fm-sort-btn.active{background:var(--bg-secondary);color:var(--text-primary);font-weight:600;box-shadow:0 1px 3px #00000014}.fm-filter-wrap{position:relative}.fm-filter-btn{border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;border-radius:8px;align-items:center;gap:.375rem;padding:.4rem .75rem;font-family:inherit;font-size:.8rem;transition:all .15s;display:flex}.fm-filter-btn.active{border-color:var(--accent-color);color:var(--accent-color);background:#ef44440a}.fm-filter-dropdown{background:var(--bg-secondary);border:1px solid var(--border-color);z-index:100;border-radius:10px;min-width:200px;max-height:320px;margin-top:6px;padding:4px;position:absolute;top:100%;right:0;overflow-y:auto;box-shadow:0 8px 24px #0000001f}[data-theme=dark] .fm-filter-dropdown{box-shadow:0 8px 24px #0006}.fm-filter-option{text-align:left;width:100%;color:var(--text-primary);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.5rem .75rem;font-family:inherit;font-size:.825rem;transition:background .1s;display:block}.fm-filter-option:hover{background:var(--bg-tertiary)}.fm-filter-option.active{color:var(--accent-color);font-weight:600}.fm-active-filter{color:var(--accent-color);background:#ef44440f;border:1px solid #ef444426;border-radius:6px;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.375rem .75rem;font-size:.8rem;display:inline-flex}.fm-active-filter button{cursor:pointer;color:inherit;background:0 0;border:none;padding:0;display:flex}.fm-post-card{background:var(--bg-secondary);border:1px solid var(--border-color);cursor:pointer;border-radius:12px;margin-bottom:.75rem;padding:1.25rem;transition:border-color .15s,box-shadow .15s}.fm-post-card:hover{border-color:var(--accent-color);box-shadow:0 2px 12px #ef44440f}.fm-pinned-badge{color:#f59e0b;background:#f59e0b1a;border-radius:4px;align-items:center;gap:.25rem;margin-bottom:.625rem;padding:.2rem .5rem;font-size:.7rem;font-weight:700;display:inline-flex}.fm-post-header{align-items:center;gap:.625rem;margin-bottom:.75rem;display:flex}.fm-post-avatar{color:#fff;background:linear-gradient(135deg,#ef4444,#f87171);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.85rem;font-weight:700;display:flex;overflow:hidden}.fm-post-avatar img{object-fit:cover;width:100%;height:100%}.fm-post-meta{flex-direction:column;flex:1;gap:1px;display:flex}.fm-post-author{color:var(--text-primary);font-size:.875rem;font-weight:600}.fm-post-time{color:var(--text-secondary);font-size:.75rem}.fm-resolved-badge{color:#10b981;background:#10b9811a;border-radius:4px;align-items:center;gap:.25rem;padding:.2rem .5rem;font-size:.7rem;font-weight:600;display:inline-flex}.fm-post-title{color:var(--text-primary);margin-bottom:.5rem;font-size:1.05rem;font-weight:700;line-height:1.4}.fm-post-content{color:var(--text-secondary);margin-bottom:.75rem;font-size:.875rem;line-height:1.6}.fm-post-images{border-radius:10px;gap:4px;margin-bottom:.75rem;display:grid;overflow:hidden}.fm-post-images.count-1{grid-template-columns:1fr}.fm-post-images.count-2,.fm-post-images.count-3,.fm-post-images.count-4{grid-template-columns:1fr 1fr}.fm-post-img-wrap{aspect-ratio:4/3;cursor:pointer;position:relative;overflow:hidden}.fm-post-img-wrap img{object-fit:cover;width:100%;height:100%;transition:transform .2s}.fm-post-img-wrap:hover img{transform:scale(1.03)}.fm-post-img-more{color:#fff;background:#00000080;justify-content:center;align-items:center;font-size:1.25rem;font-weight:700;display:flex;position:absolute;inset:0}.fm-post-tags{flex-wrap:wrap;gap:.375rem;margin-bottom:.75rem;display:flex}.fm-post-tag{background:var(--bg-tertiary);color:var(--text-secondary);border-radius:4px;padding:.2rem .5rem;font-size:.725rem;font-weight:500;display:inline-block}.fm-post-footer{border-top:1px solid var(--border-color);align-items:center;gap:1rem;padding-top:.625rem;display:flex}.fm-action-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:.35rem;padding:.3rem .5rem;font-family:inherit;font-size:.8rem;transition:all .15s;display:inline-flex}.fm-action-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.fm-action-btn.liked{color:var(--accent-color)}.fm-like-pop{animation:.35s likePop}@keyframes likePop{0%{transform:scale(1)}30%{transform:scale(1.3)}60%{transform:scale(.9)}to{transform:scale(1)}}.fm-action-btn.disabled{cursor:default}.fm-back-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:.375rem;margin-bottom:1rem;padding:.5rem 0;font-family:inherit;font-size:.875rem;transition:color .15s;display:inline-flex}.fm-back-btn:hover{color:var(--accent-color)}.fm-detail-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.fm-detail-title{color:var(--text-primary);margin-bottom:1rem;font-size:1.35rem;font-weight:750;line-height:1.35}.fm-detail-content{color:var(--text-primary);white-space:pre-wrap;margin-bottom:1rem;font-size:.925rem;line-height:1.75}.fm-detail-images{flex-wrap:wrap;gap:8px;margin-bottom:1rem;display:flex}.fm-detail-img{cursor:pointer;object-fit:cover;border-radius:8px;max-width:300px;max-height:240px;transition:opacity .15s}.fm-detail-img:hover{opacity:.9}.fm-detail-actions{border-top:1px solid var(--border-color);align-items:center;gap:1rem;padding-top:.75rem;display:flex}.fm-comments-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.25rem}.fm-comments-title{color:var(--text-primary);border-bottom:1px solid var(--border-color);margin-bottom:1rem;padding-bottom:.75rem;font-size:1rem;font-weight:700}.fm-no-comments{text-align:center;color:var(--text-secondary);padding:1.5rem 0;font-size:.875rem}.fm-comment{margin-bottom:.25rem}.fm-comment-inner{gap:.5rem;padding:.375rem 0;display:flex}.fm-comment-avatar{color:#fff;background:linear-gradient(135deg,#6366f1,#818cf8);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.75rem;font-weight:700;display:flex;overflow:hidden}.fm-comment-avatar img{object-fit:cover;width:100%;height:100%}.fm-comment-body{flex:1;min-width:0}.fm-comment-bubble{background:var(--bg-tertiary);border-radius:12px;padding:.625rem .875rem}.fm-comment-author{color:var(--text-primary);margin-bottom:2px;font-size:.8rem;font-weight:700;display:block}.fm-comment-reply-to{color:var(--text-secondary);margin-left:.25rem}.fm-comment-text{color:var(--text-primary);white-space:pre-wrap;word-break:break-word;font-size:.85rem;line-height:1.5}.fm-comment-images{margin-top:.5rem}.fm-comment-img{cursor:pointer;object-fit:cover;border-radius:8px;max-width:200px;max-height:160px}.fm-comment-actions{align-items:center;gap:.75rem;padding:.25rem .5rem;display:flex}.fm-comment-action{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:.725rem;font-weight:600;transition:color .15s}.fm-comment-action:hover{color:var(--text-primary)}.fm-comment-action.liked{color:var(--accent-color)}.fm-comment-time{color:var(--text-secondary);font-size:.7rem}.fm-comment-input-wrap{border-top:1px solid var(--border-color);margin-top:1rem;padding-top:1rem}.fm-reply-indicator{color:#6366f1;background:#6366f10f;border-left:3px solid #6366f1;border-radius:0 6px 6px 0;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding:.5rem .75rem;font-size:.8rem;display:flex}.fm-reply-indicator button{cursor:pointer;color:inherit;background:0 0;border:none;padding:0;display:flex}.fm-comment-img-preview{margin-bottom:.5rem}.fm-comment-img-thumb{display:inline-block;position:relative}.fm-comment-img-thumb img{object-fit:cover;border-radius:6px;height:60px}.fm-comment-img-thumb button{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:.75rem;display:flex;position:absolute;top:-6px;right:-6px}.fm-comment-input-row{align-items:flex-start;gap:.5rem;display:flex}.fm-comment-input-avatar{color:#fff;background:linear-gradient(135deg,#ef4444,#f87171);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.75rem;font-weight:700;display:flex;overflow:hidden}.fm-comment-input-avatar img{object-fit:cover;width:100%;height:100%}.fm-comment-input-field{background:var(--bg-tertiary);border-radius:12px;flex:1;overflow:hidden}.fm-comment-textarea{width:100%;color:var(--text-primary);resize:none;background:0 0;border:none;outline:none;min-height:40px;padding:.625rem .875rem;font-family:inherit;font-size:.875rem}.fm-comment-textarea::placeholder{color:var(--text-secondary)}.fm-comment-input-actions{justify-content:flex-end;align-items:center;gap:.375rem;padding:.25rem .5rem .375rem;display:flex}.fm-comment-img-btn{width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .15s;display:flex}.fm-comment-img-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.fm-comment-send{background:var(--accent-color);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:background .15s;display:flex}.fm-comment-send:hover:not(:disabled){background:var(--accent-hover)}.fm-comment-send:disabled{opacity:.4;cursor:not-allowed}.fm-modal-overlay{z-index:1100;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.fm-modal{background:var(--bg-secondary);border-radius:14px;flex-direction:column;width:100%;max-width:560px;max-height:90vh;display:flex;box-shadow:0 20px 60px #0003}.fm-modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1.125rem 1.25rem;display:flex}.fm-modal-header h2{color:var(--text-primary);font-size:1.1rem;font-weight:700}.fm-modal-close{width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:background .15s;display:flex}.fm-modal-close:hover{background:var(--bg-tertiary)}.fm-modal-body{flex:1;padding:1.25rem;overflow-y:auto}.fm-modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;align-items:center;gap:.625rem;padding:1rem 1.25rem;display:flex}.fm-error{color:#ef4444;background:#ef444414;border:1px solid #ef444433;border-radius:8px;margin-bottom:1rem;padding:.625rem .875rem;font-size:.825rem}.fm-input{border:1px solid var(--border-color);background:var(--bg-primary);width:100%;color:var(--text-primary);border-radius:8px;outline:none;margin-bottom:.75rem;padding:.7rem .875rem;font-family:inherit;font-size:.925rem;font-weight:600;transition:border-color .15s}.fm-input:focus{border-color:var(--accent-color)}.fm-textarea{border:1px solid var(--border-color);background:var(--bg-primary);width:100%;color:var(--text-primary);resize:vertical;border-radius:8px;outline:none;min-height:120px;margin-bottom:1rem;padding:.7rem .875rem;font-family:inherit;font-size:.875rem;line-height:1.6;transition:border-color .15s}.fm-textarea:focus{border-color:var(--accent-color)}.fm-label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.8rem;font-weight:600;display:block}.fm-tags-section{margin-bottom:1rem}.fm-tags-list{flex-wrap:wrap;gap:.375rem;display:flex}.fm-tag-chip{border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;border-radius:16px;padding:.3rem .625rem;font-family:inherit;font-size:.775rem;transition:all .15s}.fm-tag-chip.active{border-color:var(--accent-color);color:var(--accent-color);background:#ef44440f;font-weight:600}.fm-images-section{margin-bottom:.5rem}.fm-images-grid{flex-wrap:wrap;gap:8px;display:flex}.fm-image-preview{border-radius:8px;width:100px;height:100px;position:relative;overflow:hidden}.fm-image-preview img{object-fit:cover;width:100%;height:100%}.fm-image-remove{color:#fff;cursor:pointer;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;display:flex;position:absolute;top:4px;right:4px}.fm-image-add{border:2px dashed var(--border-color);width:100px;height:100px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:.25rem;font-family:inherit;font-size:.7rem;transition:all .15s;display:flex}.fm-image-add:hover{border-color:var(--accent-color);color:var(--accent-color)}.fm-btn-primary{background:var(--accent-color);color:#fff;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:.375rem;padding:.5rem 1.25rem;font-family:inherit;font-size:.875rem;font-weight:600;transition:background .15s;display:inline-flex}.fm-btn-primary:hover:not(:disabled){background:var(--accent-hover)}.fm-btn-primary:disabled{opacity:.5;cursor:not-allowed}.fm-btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;border:none;border-radius:8px;padding:.5rem 1.25rem;font-family:inherit;font-size:.875rem;font-weight:500;transition:background .15s}.fm-btn-secondary:hover{background:var(--border-color)}.fm-btn-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.fm-img-modal{z-index:1200;cursor:pointer;background:#000000e6;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}.fm-img-modal img{object-fit:contain;border-radius:4px;max-width:90vw;max-height:90vh}.fm-img-modal-close{cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;padding:8px;display:flex;position:absolute;top:1rem;right:1rem}.fm-loading,.fm-feed{min-height:200px}.fm-skeleton{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:.75rem;padding:1.25rem}.fm-skeleton-header{gap:.625rem;margin-bottom:1rem;display:flex}.fm-skeleton-avatar{background:var(--bg-tertiary);border-radius:50%;width:36px;height:36px;animation:1.5s ease-in-out infinite pulse}.fm-skeleton-lines{flex-direction:column;flex:1;gap:6px;display:flex}.fm-skeleton-line{background:var(--bg-tertiary);border-radius:4px;height:12px;animation:1.5s ease-in-out infinite pulse}.fm-skeleton-line.w80{width:80%}.fm-skeleton-line.w60{width:60%}.fm-skeleton-line.w40{width:40%}.fm-skeleton-line.w20{width:20%}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.fm-empty{text-align:center;color:var(--text-secondary);padding:3rem 1rem}.fm-empty p{color:var(--text-primary);margin-top:1rem;font-size:1rem;font-weight:600}.fm-empty span{font-size:.85rem}.fm-load-more{justify-content:center;padding:2rem;display:flex}.fm-spinner{justify-content:center;padding:1rem;display:flex}.fm-spinner-dot{border:3px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;width:24px;height:24px;animation:.7s linear infinite spin}.fm-detail-loading{text-align:center;color:var(--text-secondary);padding:3rem}@media (max-width:768px){.fm-container{padding:1rem .75rem 100px}.fm-hero-title{font-size:1.35rem}.fm-toolbar{flex-direction:column;align-items:flex-start}.fm-toolbar-left{flex-direction:column;align-items:stretch;width:100%}.fm-create-btn{justify-content:center}.fm-sort-group,.fm-filter-wrap{align-self:flex-start}.fm-post-card,.fm-detail-card{padding:1rem}.fm-modal{max-height:85vh}}
