:root{--bg:#f8f9fa;--surface:#fff;--border:#e2e8f0;--text:#1a202c;--text-muted:#718096;--primary:#3b82f6;--primary-hover:#2563eb;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--pin-bg:#fffaec;--pin-border:#f3d38a;--pin-accent:#b45309;--radius:8px;--shadow:0 1px 3px #00000014;--shadow-card:0 1px 2px #0000000f, 0 4px 12px #0000000a;--bottom-nav-height:56px}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5}button{cursor:pointer;font:inherit;border:none}input,select,textarea{font:inherit}.app{min-height:100vh;display:flex}.app-loading{min-height:100vh;color:var(--text-muted);place-items:center;display:grid}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:240px;padding:1rem 0;display:flex}.sidebar h1{margin-bottom:1.5rem;padding:0 1rem;font-size:1.25rem}.sidebar nav{flex-direction:column;gap:2px;display:flex}.sidebar a{color:var(--text-muted);align-items:center;gap:.75rem;padding:.625rem 1rem;font-size:.9rem;text-decoration:none;transition:all .15s;display:flex}.sidebar a:hover{background:var(--bg);color:var(--text)}.sidebar a.active{color:var(--primary);background:#eff6ff;font-weight:500}.main{flex:1;width:100%;min-width:0;max-width:960px;margin:0 auto;padding:1.5rem}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.page-header h2{font-size:1.5rem}.page-header .count{color:var(--text-muted);margin-left:.4rem;font-size:1rem;font-weight:400}.btn{border-radius:var(--radius);color:var(--text);background:0 0;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){opacity:.9}.btn-ghost{color:var(--text-muted);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg);color:var(--text)}.btn-sm{padding:.25rem .625rem;font-size:.8rem}.post-list{flex-direction:column;gap:.9rem;display:flex}.post-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:1.1rem 1.25rem;transition:box-shadow .15s,transform .15s;position:relative}.post-card.pinned{background:var(--pin-bg);border-color:var(--pin-border)}.post-header{align-items:flex-start;gap:.6rem;margin-bottom:.35rem;display:flex}.post-title{word-break:break-word;flex:1;font-size:1.1rem;font-weight:600;line-height:1.35}.post-card.pinned .post-title{color:var(--pin-accent)}.post-pin-icon{color:var(--pin-accent);flex-shrink:0;margin-top:3px}.post-actions{flex-shrink:0;gap:.25rem;display:flex}.post-meta{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.8rem;display:flex}.post-meta .dot{opacity:.5}.post-body{color:var(--text);word-break:break-word;font-size:.95rem}.post-body.empty{color:var(--text-muted);font-style:italic}.markdown{color:var(--text);line-height:1.55}.markdown p{margin:.4rem 0}.markdown p:first-child{margin-top:0}.markdown p:last-child{margin-bottom:0}.markdown a{color:var(--primary)}.markdown a:hover{color:var(--primary-hover)}.markdown ul,.markdown ol{margin:.4rem 0 .4rem 1.25rem}.markdown li{margin:.15rem 0}.markdown code{background:#0000000d;border-radius:3px;padding:.1rem .3rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.88em}.markdown pre{border-radius:var(--radius);background:#0000000a;margin:.5rem 0;padding:.6rem .75rem;overflow-x:auto}.markdown pre code{background:0 0;padding:0}.markdown blockquote{border-left:3px solid var(--border);color:var(--text-muted);margin:.5rem 0;padding-left:.75rem}.markdown h1,.markdown h2,.markdown h3,.markdown h4{margin:.6rem 0 .25rem;line-height:1.25}.markdown h1{font-size:1.3rem}.markdown h2{font-size:1.15rem}.markdown h3{font-size:1rem}.markdown hr{border:0;border-top:1px solid var(--border);margin:.8rem 0}.markdown img{border-radius:4px;max-width:100%}.form-group{margin-bottom:1rem}.form-group label{margin-bottom:.25rem;font-size:.85rem;font-weight:500;display:block}.form-input,.form-textarea{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);width:100%;color:var(--text);padding:.5rem .75rem;font-size:.9rem;transition:border-color .15s}.form-textarea{resize:vertical;min-height:120px;font-family:inherit;line-height:1.5}.form-input:focus,.form-textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #3b82f61a}.form-row{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.form-checkbox{cursor:pointer;align-items:center;gap:.5rem;font-size:.9rem;display:flex}.form-checkbox input{width:1.1rem;height:1.1rem;accent-color:var(--primary);cursor:pointer}.form-hint{color:var(--text-muted);margin-top:.25rem;font-size:.8rem}.modal-overlay{z-index:50;background:#0006;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--radius);width:100%;max-width:540px;max-height:90vh;padding:1.5rem;overflow-y:auto;box-shadow:0 20px 60px #00000026}.modal h3{margin-bottom:1rem}.modal-actions{justify-content:flex-end;gap:.5rem;margin-top:1.5rem;display:flex}.modal-actions .spacer{flex:1}.activity-list{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.activity-item{border-bottom:1px solid var(--border);align-items:baseline;gap:.75rem;padding:.75rem 1rem;font-size:.9rem;display:flex}.activity-item:last-child{border-bottom:none}.activity-item .action{text-transform:capitalize;min-width:80px;font-weight:500}.activity-item .time{color:var(--text-muted);white-space:nowrap;margin-left:auto;font-size:.8rem}.pagination{justify-content:center;align-items:center;gap:.5rem;padding:1rem;display:flex}.empty{text-align:center;color:var(--text-muted);padding:3rem 1rem}.toast{background:var(--text);color:#fff;border-radius:var(--radius);z-index:100;padding:.75rem 1.25rem;font-size:.9rem;animation:.2s fadeIn;position:fixed;bottom:1.5rem;right:1.5rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem}.stat-card .label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem;font-size:.8rem}.stat-card .value{font-size:1.75rem;font-weight:700}.tenant-badge{background:var(--bg);color:var(--text-muted);border:1px solid var(--border);white-space:nowrap;border-radius:999px;align-items:center;gap:.25rem;padding:.1rem .45rem;font-size:.72rem;display:inline-flex}.tenant-badge.tenant-chat{color:#4338ca;background:#eef2ff;border-color:#c7d2fe}.tenant-badge.tenant-contact{color:#047857;background:#ecfdf5;border-color:#a7f3d0}.bottom-nav{height:var(--bottom-nav-height);background:var(--surface);border-top:1px solid var(--border);z-index:50;display:none;position:fixed;bottom:0;left:0;right:0}.bottom-nav a{min-width:44px;min-height:44px;color:var(--text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;font-size:.7rem;text-decoration:none;transition:color .15s,background .15s;display:flex}.bottom-nav a:hover{color:var(--text);background:var(--bg)}.bottom-nav a.active{color:var(--primary);background:#eff6ff}.error{color:var(--danger);font-size:.9rem}@media (width<=768px){.sidebar{display:none}.main{padding:1rem;padding-bottom:calc(var(--bottom-nav-height) + 1rem);max-width:100%}.bottom-nav{display:flex}.toast{bottom:calc(var(--bottom-nav-height) + 1rem);text-align:center;left:1rem;right:1rem}.page-header{flex-direction:column;align-items:stretch}.page-header .btn-primary{justify-content:center}.post-card{padding:.9rem 1rem}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}.activity-item{flex-wrap:wrap}.activity-item .time{width:100%;margin-left:0}}
