*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--brand: #F27326;--brand-hover: #FF9000;--brand-subtle: rgba(242, 115, 38, .1);--bg: #121212;--bg-card: #1E1E1E;--bg-card-hover: #2A2A2A;--bg-input: #1A1A1A;--bg-secondary: #2A2A2A;--text: #F5F5F7;--text-muted: #A1A1A6;--text-tertiary: #6B6B70;--border: #2A2A2A;--border-strong: #3A3A3A;--green: #4ADE80;--yellow: #FBBF24;--blue: #3B82F6;--red: #EF4444;--radius: 12px;--radius-card: 28px;--radius-inner: 12px;--safe-bottom: env(safe-area-inset-bottom, 0px)}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:Inter,-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;min-height:100dvh;-webkit-overflow-scrolling:touch}#root{min-height:100vh;min-height:100dvh}a{color:var(--brand);text-decoration:none}a:hover{color:var(--brand-hover)}button{font-family:inherit;cursor:pointer;touch-action:manipulation}input,textarea,select{font-family:inherit;font-size:16px}.header{border-bottom:1px solid var(--border);background:#1e1e1ee0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:100;padding-top:env(safe-area-inset-top,0px)}.header-inner{max-width:720px;margin:0 auto;padding:12px 16px;display:flex;align-items:center;justify-content:space-between}.header-logo{display:flex;align-items:center;gap:8px;color:var(--text);font-weight:600;font-size:1.05rem}.header-logo:hover{color:var(--text)}.header-icon-img{width:28px;height:28px;border-radius:6px}.header-actions{display:flex;align-items:center;gap:8px}.header-admin{display:flex;align-items:center;gap:10px}.admin-badge{background:var(--brand-subtle);color:var(--brand);padding:2px 10px;border-radius:20px;font-size:.8rem;font-weight:600}.btn-ghost{background:none;border:1px solid var(--border-strong);color:var(--text-muted);padding:8px 16px;border-radius:var(--radius);font-size:.85rem;transition:all .15s;min-height:36px}.btn-ghost:hover{color:var(--text);border-color:var(--text-muted)}.upvote-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border-strong);border-radius:var(--radius-inner);color:var(--text-muted);min-width:52px;min-height:52px;transition:all .15s;flex-shrink:0;touch-action:manipulation}.upvote-btn:active,.upvote-btn.upvoted{border-color:var(--brand);color:var(--brand);background:var(--brand-subtle)}.upvote-arrow{transition:transform .15s}.upvote-btn:active .upvote-arrow{transform:translateY(-2px)}.upvote-count{font-weight:600;font-size:.85rem}.status-badge{font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.3px}.status-open{background:#6b6b7026;color:var(--text-muted)}.status-planned{background:#fbbf2426;color:var(--yellow)}.status-in-progress{background:#3b82f626;color:var(--blue)}.status-done{background:#4ade8026;color:var(--green)}.post-card{display:flex;gap:12px;padding:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-card);transition:background .15s}.post-card:active{background:var(--bg-card-hover)}.post-card-content{flex:1;min-width:0}.post-card-title{font-weight:600;font-size:.95rem;color:var(--text);display:block;margin-bottom:4px}.post-card-title:hover{color:var(--brand)}.post-card-body{color:var(--text-muted);font-size:.85rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:4px}.post-card-body.expanded{display:block;-webkit-line-clamp:unset;white-space:pre-wrap}.post-card-expand{background:none;border:none;color:var(--brand);font-size:.8rem;font-weight:500;padding:0;margin-bottom:8px}.post-card-meta{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--text-muted);flex-wrap:wrap}.post-card-author{font-weight:500}.post-card-dot{opacity:.4}.post-card-comments{color:var(--text-muted)}.post-card-image{width:100%;max-height:140px;object-fit:cover;border-radius:var(--radius-inner);margin-bottom:8px}.create-post-trigger{width:100%;padding:16px;background:var(--bg-card);border:1px dashed var(--border-strong);border-radius:var(--radius-card);color:var(--text-muted);font-size:.95rem;transition:all .15s;min-height:48px;touch-action:manipulation}.create-post-trigger:active{border-color:var(--brand);color:var(--brand);background:var(--brand-subtle)}.create-post-form{display:flex;flex-direction:column;gap:10px;padding:16px;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:var(--radius-card)}.form-input{width:100%;padding:12px 14px;background:var(--bg-input);border:1px solid var(--border-strong);border-radius:var(--radius-inner);color:var(--text);font-size:16px;outline:none;transition:border-color .15s;-webkit-appearance:none}.form-input:focus{border-color:var(--brand)}.form-textarea{width:100%;padding:12px 14px;background:var(--bg-input);border:1px solid var(--border-strong);border-radius:var(--radius-inner);color:var(--text);font-size:16px;outline:none;resize:vertical;min-height:100px;transition:border-color .15s;-webkit-appearance:none}.form-textarea:focus{border-color:var(--brand)}.form-actions{display:flex;justify-content:flex-end;gap:8px}.btn-primary{padding:10px 20px;background:var(--brand);color:var(--bg);border:none;border-radius:9999px;font-size:.9rem;font-weight:500;transition:background .15s;min-height:44px;touch-action:manipulation}.btn-primary:active{background:var(--brand-hover)}.btn-primary:disabled{opacity:.6}.image-attach-btn{display:flex;align-items:center;gap:8px;padding:10px 14px;background:none;border:1px dashed var(--border-strong);border-radius:var(--radius-inner);color:var(--text-muted);font-size:.85rem;transition:all .15s;touch-action:manipulation}.image-attach-btn:active{border-color:var(--brand);color:var(--brand)}.image-preview{position:relative;border-radius:var(--radius-inner);overflow:hidden}.image-preview-img{width:100%;max-height:200px;object-fit:cover;border-radius:var(--radius-inner);display:block}.image-preview-remove{position:absolute;top:8px;right:8px;width:28px;height:28px;background:#000000b3;border:none;border-radius:50%;color:#fff;font-size:1.1rem;display:flex;align-items:center;justify-content:center;line-height:1}.feed{display:flex;flex-direction:column;gap:16px}.feed-header{margin-bottom:4px}.feed-title{font-size:1.5rem;font-weight:700;margin-bottom:4px}.feed-subtitle{color:var(--text-muted);font-size:.95rem}.feed-controls{display:flex;justify-content:space-between;align-items:center}.sort-tabs{display:flex;gap:2px;background:var(--bg-card);padding:3px;border-radius:8px;border:1px solid var(--border)}.sort-tab{padding:6px 16px;background:none;border:none;border-radius:6px;color:var(--text-muted);font-size:.85rem;font-weight:500;transition:all .15s}.sort-tab:hover{color:var(--text)}.sort-tab.active{background:var(--brand);color:var(--bg)}.feed-list{display:flex;flex-direction:column;gap:8px}.feed-loading,.feed-empty,.feed-error{text-align:center;padding:48px 16px;color:var(--text-muted)}.feed-error-detail{font-size:.8rem;color:var(--text-tertiary);margin-top:4px}.post-detail{display:flex;flex-direction:column;gap:20px}.back-link{color:var(--text-muted);font-size:.9rem}.back-link:hover{color:var(--text)}.detail-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-card);padding:16px}.detail-top{display:flex;gap:16px;margin-bottom:16px}.detail-info{flex:1}.detail-title{font-size:1.3rem;font-weight:700;margin-bottom:6px}.detail-meta{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-muted);flex-wrap:wrap}.meta-dot{opacity:.4}.detail-body{color:var(--text);font-size:.95rem;line-height:1.7;white-space:pre-wrap}.detail-image{width:100%;border-radius:var(--radius-inner);margin-top:16px;cursor:pointer;transition:opacity .15s}.detail-image:active{opacity:.8}.lightbox{position:fixed;inset:0;z-index:1000;background:#000000e6;display:flex;align-items:center;justify-content:center;padding:20px;cursor:pointer}.lightbox-img{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px}.admin-controls{display:flex;gap:10px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.status-select{padding:6px 12px;background:var(--bg-input);border:1px solid var(--border-strong);border-radius:var(--radius-inner);color:var(--text);font-size:.85rem;outline:none}.btn-danger{padding:6px 14px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-inner);color:var(--red);font-size:.85rem;transition:all .15s}.btn-danger:hover{background:#ef444433}.comments-section{display:flex;flex-direction:column;gap:12px}.comments-title{font-size:1.1rem;font-weight:600}.comment{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-card);padding:16px}.comment-admin{border-color:#f273264d;background:#f273260d}.comment-header{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:.85rem}.comment-author{font-weight:600;display:flex;align-items:center;gap:6px}.dev-badge{background:var(--brand-subtle);color:var(--brand);padding:1px 7px;border-radius:20px;font-size:.7rem;font-weight:700;text-transform:uppercase}.comment-time{color:var(--text-muted);margin-left:auto}.comment-delete{background:none;border:none;color:var(--text-muted);font-size:1.1rem;padding:0 4px;line-height:1}.comment-delete:hover{color:var(--red)}.comment-body{color:var(--text);font-size:.9rem;line-height:1.6;white-space:pre-wrap}.comment-form{display:flex;flex-direction:column;gap:10px;padding:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-card)}.detail-loading{text-align:center;padding:48px;color:var(--text-muted)}.admin-login{max-width:380px;margin:40px auto}.login-title{font-size:1.4rem;font-weight:700;margin-bottom:4px}.login-subtitle{color:var(--text-muted);font-size:.9rem;margin-bottom:20px}.login-form{display:flex;flex-direction:column;gap:10px}.login-form .btn-primary{margin-top:4px}.app{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.main{max-width:720px;width:100%;margin:0 auto;padding:16px;padding-bottom:calc(16px + var(--safe-bottom));flex:1}
