@import "https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#111;--bg:#fafaf9;--surface:#fff;--border:#e8e7e3;--separator:#f0efe9;--text:#111;--muted:#8f8f8f;--muted-light:#c8c8c4;--error:#d93025;--verified:#1a9e5a;--pill-bg:#f0efe9;--pill-text:#555550;--avatar-size:36px;--feed-width:620px;--nav-h:54px;--bottom-nav-h:58px;--font:"DM Sans", system-ui, sans-serif;--radius:14px;--radius-sm:10px}html{font-size:16px}body{font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;padding-bottom:var(--bottom-nav-h)}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:var(--font);background:0 0;border:none}img{max-width:100%;display:block}.top-bar{height:var(--nav-h);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border);z-index:100;background:#fafaf9e0;justify-content:space-between;align-items:center;padding:0 1rem;display:flex;position:sticky;top:0}.top-bar-left{align-items:center;gap:.625rem;display:flex}.brand-name{letter-spacing:-.03em;color:var(--text);font-size:1.125rem;font-weight:700}.city-badge{color:var(--muted);background:var(--pill-bg);border-radius:20px;padding:.2rem .55rem;font-size:.775rem;font-weight:500;transition:color .15s}.city-badge:hover{color:var(--text)}.top-bar-right{align-items:center;gap:.375rem;display:flex}.top-bar-btn{background:var(--text);color:var(--bg);cursor:pointer;border:none;border-radius:20px;padding:.4rem 1rem;font-size:.85rem;font-weight:600;transition:opacity .15s}.top-bar-btn:hover{opacity:.8}.top-bar-link{color:var(--muted);border-radius:8px;padding:.4rem .5rem;font-size:.875rem;transition:color .15s}.top-bar-link:hover{color:var(--text)}.bottom-nav{height:var(--bottom-nav-h);-webkit-backdrop-filter:blur(18px);border-top:1px solid var(--border);z-index:100;padding-bottom:env(safe-area-inset-bottom,0);background:#fafaf9f0;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav-item{color:var(--muted);cursor:pointer;text-align:center;font-size:.65rem;font-weight:500;font-family:var(--font);background:0 0;border:none;border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:.2rem;padding:.5rem .75rem;transition:color .15s;display:flex}.bottom-nav-item:hover,.bottom-nav-item.active{color:var(--text)}.nav-icon{font-size:1.25rem;line-height:1;display:block}.bottom-nav-compose{background:var(--text);flex:unset;border-radius:14px;justify-content:center;align-items:center;width:46px;height:46px;padding:0;font-size:1.25rem;transition:transform .15s,opacity .15s;display:flex;color:var(--bg)!important}.bottom-nav-compose:hover{opacity:.8;transform:scale(.97)}.feed-container{max-width:var(--feed-width);background:var(--surface);min-height:calc(100vh - var(--nav-h));margin:0 auto}.feed-filters{scrollbar-width:none;border-bottom:1px solid var(--separator);background:var(--surface);top:var(--nav-h);z-index:90;gap:.5rem;padding:.75rem 1rem;display:flex;position:sticky;overflow-x:auto}.feed-filters::-webkit-scrollbar{display:none}.filter-pill{white-space:nowrap;border:1.5px solid var(--border);color:var(--muted);background:var(--surface);cursor:pointer;font-size:.8rem;font-weight:500;font-family:var(--font);border-radius:20px;flex-shrink:0;padding:.35rem .875rem;transition:all .15s}.filter-pill.active,.filter-pill:hover{border-color:var(--text);color:var(--bg);background:var(--text)}.feed-post{background:var(--surface);gap:.75rem;padding:1rem 1rem 0;display:flex;position:relative}.feed-post+.feed-post{border-top:1px solid var(--separator)}.post-left{flex-direction:column;flex-shrink:0;align-items:center;display:flex}.avatar{width:var(--avatar-size);height:var(--avatar-size);color:#fff;letter-spacing:.01em;-webkit-user-select:none;user-select:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.avatar.anon{background:var(--pill-bg);color:var(--muted);font-size:1rem}.thread-line{background:var(--separator);border-radius:1px;flex:1;width:2px;min-height:28px;margin:.375rem 0 0}.post-right{flex:1;min-width:0;padding-bottom:1rem}.post-header{align-items:baseline;gap:.4rem;margin-bottom:.25rem;display:flex}.post-username{color:var(--text);font-size:.9rem;font-weight:600}.post-time{color:var(--muted);flex-shrink:0;margin-left:auto;font-size:.8rem}.post-category-pill{text-transform:uppercase;letter-spacing:.06em;color:var(--pill-text);background:var(--pill-bg);border-radius:20px;margin-bottom:.35rem;padding:.15rem .5rem;font-size:.7rem;font-weight:600;display:inline-block}.post-title-feed{color:var(--text);-webkit-line-clamp:3;cursor:pointer;-webkit-box-orient:vertical;margin-bottom:.625rem;font-size:.9375rem;font-weight:500;line-height:1.45;text-decoration:none;transition:opacity .15s;display:-webkit-box;overflow:hidden}.post-title-feed:hover{opacity:.7}.post-actions{align-items:center;gap:.25rem;margin-left:-.5rem;display:flex}.post-action-btn{color:var(--muted);font-size:.8125rem;font-family:var(--font);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:.3rem;padding:.35rem .5rem;transition:all .15s;display:flex}.post-action-btn:hover{color:var(--text);background:var(--separator)}.post-detail-wrap{max-width:var(--feed-width);background:var(--surface);min-height:calc(100vh - var(--nav-h));margin:0 auto}.post-detail-back{color:var(--text);border-bottom:1px solid var(--separator);cursor:pointer;align-items:center;gap:.5rem;padding:1rem;font-size:.9375rem;font-weight:500;transition:opacity .15s;display:flex}.post-detail-back:hover{opacity:.6}.post-detail-main{gap:.75rem;padding:1rem 1rem 0;display:flex}.post-detail-content{flex:1;min-width:0;padding-bottom:.75rem}.post-detail-title{letter-spacing:-.01em;margin-bottom:.875rem;font-size:1.1rem;font-weight:600;line-height:1.4}.post-detail-body{color:#2a2a2a;font-size:.9375rem;line-height:1.65}.post-detail-body strong{font-weight:600}.post-detail-body em{font-style:italic}.post-detail-body code{background:var(--separator);border-radius:4px;padding:.1em .35em;font-size:.875em}.post-detail-body a{color:var(--text);text-underline-offset:2px;text-decoration:underline}.post-img{border-radius:10px;max-width:100%;margin:.5rem 0}.post-detail-meta{color:var(--muted);border-top:1px solid var(--separator);flex-wrap:wrap;align-items:center;gap:.75rem;margin-top:.75rem;padding:.875rem 0;font-size:.8125rem;display:flex}.post-detail-meta-actions{border-bottom:1px solid var(--separator);gap:.25rem;margin-left:-.5rem;padding:.25rem 1rem;display:flex}.comments-wrap{max-width:var(--feed-width);background:var(--surface);margin:0 auto}.comments-label{color:var(--muted);text-transform:uppercase;letter-spacing:.07em;border-top:6px solid var(--separator);padding:.875rem 1rem .5rem;font-size:.8rem;font-weight:600}.comment-item{border-top:1px solid var(--separator);gap:.75rem;padding:.875rem 1rem 0;display:flex}.comment-right{flex:1;min-width:0;padding-bottom:.875rem}.comment-body{color:var(--text);margin-top:.25rem;font-size:.9rem;line-height:1.55}.comment-meta{color:var(--muted);margin-top:.35rem;font-size:.775rem}.comment-input-area{border-top:6px solid var(--separator);bottom:var(--bottom-nav-h);-webkit-backdrop-filter:blur(10px);background:#fffffff5;align-items:flex-start;gap:.75rem;padding:1rem;display:flex;position:sticky}.comment-input{resize:none;font-family:var(--font);color:var(--text);background:0 0;border:none;outline:none;flex:1;min-height:36px;max-height:120px;padding:.4rem 0;font-size:.9375rem;line-height:1.5;overflow-y:auto}.comment-input::placeholder{color:var(--muted-light)}.comment-send-btn{background:var(--text);color:var(--bg);font-size:.85rem;font-weight:600;font-family:var(--font);cursor:pointer;white-space:nowrap;border:none;border-radius:20px;flex-shrink:0;margin-top:.25rem;padding:.45rem 1rem;transition:opacity .15s}.comment-send-btn:hover{opacity:.75}.login-to-comment{text-align:center;color:var(--muted);border-top:6px solid var(--separator);padding:1.5rem 1rem;font-size:.875rem}.login-to-comment a{color:var(--text);text-underline-offset:2px;font-weight:600;text-decoration:underline}.modal{z-index:300;-webkit-backdrop-filter:blur(3px);background:#00000059;justify-content:center;align-items:flex-end;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.modal.hidden{display:none}.modal-sheet{background:var(--surface);width:100%;max-width:var(--feed-width);border-radius:20px 20px 0 0;flex-direction:column;gap:.875rem;max-height:90vh;padding:0 1.25rem 2rem;animation:.28s cubic-bezier(.32,.72,0,1) sheetUp;display:flex;overflow-y:auto}@keyframes sheetUp{0%{opacity:.5;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.modal-handle{background:var(--border);border-radius:2px;flex-shrink:0;width:40px;height:4px;margin:1rem auto .25rem}.modal-title{letter-spacing:-.01em;font-size:1rem;font-weight:600}.modal-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;font-size:.9375rem;font-family:var(--font);color:var(--text);background:var(--bg);outline:none;padding:.75rem 1rem;transition:border-color .15s}.modal-input:focus{border-color:var(--text)}.modal-textarea{resize:none;min-height:110px}.modal-select{-webkit-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238F8F8F' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 1rem center;background-repeat:no-repeat;padding-right:2.5rem}.anon-toggle{color:var(--muted);cursor:pointer;align-items:center;gap:.625rem;padding:.25rem 0;font-size:.875rem;display:flex}.anon-toggle input[type=checkbox]{width:auto;accent-color:var(--text)}.modal-footer{justify-content:space-between;align-items:center;padding-top:.25rem;display:flex}.modal-cancel{color:var(--muted);font-size:.9375rem;font-family:var(--font);cursor:pointer;background:0 0;border:none;padding:.5rem 0}.modal-publish{background:var(--text);color:var(--bg);font-size:.9375rem;font-weight:600;font-family:var(--font);cursor:pointer;border:none;border-radius:20px;padding:.6rem 1.5rem;transition:opacity .15s}.modal-publish:hover{opacity:.8}.auth-page{background:var(--bg);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:2rem 1.5rem;display:flex}.auth-logo{letter-spacing:-.05em;color:var(--text);margin-bottom:2.5rem;font-size:2.25rem;font-weight:700}.auth-card{flex-direction:column;gap:1.25rem;width:100%;max-width:380px;display:flex}.auth-card h2{letter-spacing:-.025em;font-size:1.5rem;font-weight:600}.auth-card p{color:var(--muted);margin-top:-.75rem;font-size:.875rem}.auth-form{flex-direction:column;gap:.75rem;display:flex}.auth-field{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;font-size:.9375rem;font-family:var(--font);color:var(--text);background:var(--surface);outline:none;padding:.875rem 1rem;transition:border-color .15s}.auth-field:focus{border-color:var(--text)}.auth-submit{background:var(--text);width:100%;color:var(--bg);border-radius:var(--radius-sm);font-size:.9375rem;font-weight:600;font-family:var(--font);cursor:pointer;border:none;margin-top:.25rem;padding:.875rem;transition:opacity .15s}.auth-submit:hover{opacity:.8}.auth-footer{text-align:center;color:var(--muted);font-size:.875rem}.auth-footer a{color:var(--text);text-underline-offset:2px;font-weight:500;text-decoration:underline}.home-wrap{max-width:var(--feed-width);background:var(--surface);min-height:calc(100vh - var(--nav-h));margin:0 auto}.home-hero{border-bottom:1px solid var(--separator);padding:2.5rem 1.25rem 1.5rem}.home-hero h1{letter-spacing:-.04em;margin-bottom:.625rem;font-size:clamp(2.25rem,7vw,3.5rem);font-weight:700;line-height:1.05}.home-hero p{color:var(--muted);max-width:340px;font-size:1rem;line-height:1.5}.home-search-wrap{border-bottom:1px solid var(--separator);top:var(--nav-h);-webkit-backdrop-filter:blur(14px);z-index:80;background:#fffffff0;padding:1rem 1.25rem;position:sticky}.search-bar{background:var(--bg);border:1.5px solid var(--border);border-radius:20px;align-items:center;gap:.625rem;padding:.5rem 1rem;transition:border-color .15s;display:flex}.search-bar:focus-within{border-color:var(--text)}.search-icon{color:var(--muted);flex-shrink:0;font-size:1rem}.search-field{font-family:var(--font);color:var(--text);background:0 0;border:none;outline:none;flex:1;font-size:.9375rem}.search-field::placeholder{color:var(--muted-light)}.city-results{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);margin-top:.5rem;overflow:hidden}.city-result-row{border-bottom:1px solid var(--separator);cursor:pointer;color:var(--text);justify-content:space-between;align-items:center;padding:.875rem 1rem;transition:background .1s;display:flex}.city-result-row:last-child{border-bottom:none}.city-result-row:hover{background:var(--bg)}.city-result-name{font-size:.9375rem;font-weight:600}.city-result-meta{color:var(--muted);font-size:.8125rem}.city-result-arrow{color:var(--muted);font-size:.875rem}.home-map{height:380px;overflow:hidden}.notif-wrap{position:relative}.notif-btn{width:36px;height:36px;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.125rem;transition:background .15s;display:flex;position:relative}.notif-btn:hover{background:var(--separator)}.notif-count{background:var(--error);color:#fff;border:2px solid var(--bg);border-radius:50%;justify-content:center;align-items:center;width:15px;height:15px;font-size:.6rem;font-weight:700;display:flex;position:absolute;top:1px;right:1px}.notif-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);z-index:200;width:300px;position:absolute;top:calc(100% + .5rem);right:0;overflow:hidden;box-shadow:0 8px 32px #00000017,0 2px 8px #0000000d}.notif-item{border-bottom:1px solid var(--separator);cursor:pointer;padding:.875rem 1rem;font-size:.875rem;line-height:1.4;transition:background .1s}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--bg)}.notif-item.unread{background:#f5f8ff}.notif-time{color:var(--muted);margin-top:.25rem;font-size:.75rem;display:block}.notif-empty{color:var(--muted);text-align:center;padding:1.5rem;font-size:.875rem}.notif-mark-all{width:100%;color:var(--text);font-size:.875rem;font-family:var(--font);background:var(--bg);cursor:pointer;border:none;border-top:1px solid var(--separator);padding:.75rem;font-weight:500}.tenants-wrap{max-width:var(--feed-width);background:var(--surface);margin:0 auto}.tenant-map-wrap{border-bottom:1px solid var(--separator);height:260px}.tenant-filter-row{scrollbar-width:none;border-bottom:1px solid var(--separator);gap:.5rem;padding:.75rem 1rem;display:flex;overflow-x:auto}.tenant-filter-row::-webkit-scrollbar{display:none}.tenant-list{flex-direction:column;display:flex}.tenant-card{border-bottom:1px solid var(--separator);cursor:pointer;color:var(--text);align-items:center;gap:.875rem;padding:.875rem 1rem;text-decoration:none;transition:background .1s;display:flex}.tenant-card:hover{background:var(--bg)}.tenant-thumb{background:var(--separator);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.25rem;display:flex;overflow:hidden}.tenant-thumb img{object-fit:cover;width:100%;height:100%}.tenant-card-info{flex:1;min-width:0}.tenant-card-name{font-size:.9rem;font-weight:600}.tenant-card-sub{color:var(--muted);margin-top:.1rem;font-size:.8rem}.verified-badge{color:var(--verified)}.city-page-wrap{max-width:var(--feed-width);background:var(--surface);min-height:calc(100vh - var(--nav-h));margin:0 auto;padding:1.5rem 1rem}.city-page-wrap h1{letter-spacing:-.025em;margin-bottom:1.5rem;font-size:1.5rem;font-weight:700}.md-body{color:#2d2d2d;font-size:.9375rem;line-height:1.75}.md-body h2{letter-spacing:-.01em;margin:1.5rem 0 .5rem;font-size:1.1rem;font-weight:600}.md-body h3{margin:1rem 0 .4rem;font-size:1rem;font-weight:600}.md-body p{margin-bottom:1rem}.md-body ul{margin-bottom:1rem;padding-left:1.5rem}.md-body li{margin-bottom:.35rem}.md-body blockquote{border-left:3px solid var(--border);color:var(--muted);margin:1rem 0;padding-left:1rem;font-style:italic}.md-body code{background:var(--separator);border-radius:4px;padding:.15rem .4rem;font-size:.875em}.md-body hr{border:none;border-top:1px solid var(--border);margin:1.5rem 0}.md-body a{color:var(--text);text-underline-offset:2px;text-decoration:underline}.md-img{border-radius:10px;max-width:100%;margin:.5rem 0}.not-found-page{text-align:center;color:var(--muted);padding:3rem 1rem}.not-found-page h2{color:var(--text);margin-bottom:.5rem;font-size:1.25rem}.not-found-page code{background:var(--separator);border-radius:4px;padding:.2rem .5rem;font-size:.875em}.loading{color:var(--muted);text-align:center;padding:2.5rem 1rem;font-size:.875rem}.error-msg{color:var(--error);padding:.5rem 0;font-size:.8375rem}.empty-state{color:var(--muted);text-align:center;padding:3rem 1rem;font-size:.9rem}.hidden{display:none!important}@media (min-width:768px){body{padding-bottom:0}.bottom-nav{display:none}.top-bar{padding:0 2rem}.modal{align-items:center}.modal-sheet{border-radius:20px;max-width:520px;animation:.2s sheetFade}@keyframes sheetFade{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.comment-input-area{bottom:0}}
