:root{font-family:Inter,PingFang SC,Microsoft YaHei,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;color:#1f2724;background:#edf2ef;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,textarea{font:inherit}button{border:0;cursor:pointer}.app-shell{position:relative;min-height:100vh;max-width:480px;margin:0 auto;overflow:hidden;background:#eef3ef}.map-stage{position:relative;min-height:56vh;padding:max(16px,env(safe-area-inset-top)) 16px 118px;background:#eef3ef}.status-bar{position:relative;z-index:4;display:flex;align-items:center;justify-content:space-between;gap:12px}.eyebrow{margin:0 0 4px;color:#63756d;font-size:12px;font-weight:800}h1,h2,p{margin:0}h1{font-size:24px;line-height:1.12;letter-spacing:0}h2{font-size:19px;line-height:1.18;letter-spacing:0}.icon-button{display:grid;width:42px;height:42px;place-items:center;border:1px solid rgba(36,54,48,.13);border-radius:8px;color:#243630;background:#ffffffe6;box-shadow:0 12px 30px #23342d1f}.search-row{position:relative;z-index:4;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;margin-top:16px;padding:0 12px;height:46px;border:1px solid rgba(30,43,39,.12);border-radius:8px;color:#64746d;background:#fffffff0;box-shadow:0 14px 28px #26352f1c}.search-row input{min-width:0;border:0;outline:0;color:#1f2724;background:transparent}.search-row input::placeholder{color:#71817a}.source-status{position:relative;z-index:4;display:inline-flex;max-width:100%;min-height:30px;align-items:center;margin-top:10px;padding:0 10px;color:#465750;border:1px solid rgba(30,43,39,.12);border-radius:8px;background:#ffffffe6;box-shadow:0 10px 22px #26352f17;font-size:12px;font-weight:800}.source-status span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.source-status.loading{color:#7a5b24}.source-status.ready{color:#1f6b52}.source-status.error{color:#9a3f31}.map-canvas{position:absolute;inset:0;overflow:hidden;background:#dbe9de}.real-map-frame{position:absolute;inset:0;width:100%;height:100%;border:0}.map-dim{position:absolute;inset:0;pointer-events:none;background:#eef3ef1a}.map-marker{position:absolute;z-index:3;display:grid;width:38px;height:38px;place-items:center;color:#fff;border:3px solid #ffffff;border-radius:50%;background:#2d6f5f;box-shadow:0 14px 28px #182d2538;transform:translate(-50%,-50%);transition:transform .15s ease,background .15s ease}.map-marker.is-active{background:#d9543f;transform:translate(-50%,-50%) scale(1.13)}.map-marker.is-closed{background:#808a86}.quick-actions{position:absolute;right:16px;bottom:94px;z-index:4;display:grid;gap:8px}.quick-actions button{min-width:54px;height:34px;padding:0 10px;color:#34423d;border:1px solid rgba(36,54,48,.12);border-radius:8px;background:#ffffffed;box-shadow:0 10px 24px #23342d1f}.quick-actions .active{color:#fff;background:#263c34}.bottom-panel{position:absolute;left:0;right:0;bottom:0;z-index:6;max-height:58vh;padding:10px 16px max(16px,env(safe-area-inset-bottom));overflow:auto;border-radius:18px 18px 0 0;background:#fbfaf4;box-shadow:0 -22px 48px #15201c33}.drag-handle{width:42px;height:4px;margin:0 auto 12px;border-radius:999px;background:#c8d0ca}.panel-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:12px;padding:4px;border:1px solid #e0e4db;border-radius:8px;background:#f1f4ef}.panel-tabs button{display:flex;align-items:center;justify-content:center;gap:6px;min-width:0;height:36px;color:#53635c;border-radius:7px;background:transparent;font-weight:800}.panel-tabs .active{color:#fff;background:#263c34;box-shadow:0 8px 20px #263c3429}.filter-strip{display:flex;gap:8px;padding-bottom:12px;overflow-x:auto}.filter-strip button{flex:0 0 auto;height:34px;padding:0 12px;color:#415049;border:1px solid #dce1d8;border-radius:8px;background:#fff}.filter-strip .selected{color:#fff;border-color:#254f45;background:#254f45}.hero-card{display:grid;grid-template-columns:1fr auto;gap:14px;padding:14px;border:1px solid #e2e3d9;border-radius:8px;background:#fff}.hero-card-main{min-width:0}.badge-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:9px;color:#71817a;font-size:12px}.badge-row span{padding:4px 7px;border-radius:8px;background:#f1f4ef}.badge-row .status{color:#fff;font-weight:800}.badge-row .open{background:#1f7a5b}.badge-row .closed{background:#7a7f7a}.hero-card p{margin-top:7px;color:#5b675f;font-size:13px;line-height:1.45}.metric-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:12px}.metric{display:grid;min-height:68px;place-items:center;gap:2px;color:#52635b;border-radius:8px;background:#f3f6f1}.metric strong{color:#1f2724;font-size:15px}.metric span{font-size:11px}.go-button{display:grid;width:54px;min-height:100%;place-items:center;color:#fff;border-radius:8px;background:#d9543f}.intel-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-top:10px}.intel{display:grid;min-height:58px;place-items:center;gap:4px;color:#24483e;border:1px solid #e2e5da;border-radius:8px;background:#fff;font-size:12px;text-align:center}.intel.muted{color:#8b918d;background:#f0f1ed}.list-header{display:flex;align-items:center;justify-content:space-between;margin:16px 0 8px;color:#5a6b63;font-size:13px;font-weight:800}.list-header button{display:inline-flex;align-items:center;gap:5px;height:34px;padding:0 10px;color:#fff;border-radius:8px;background:#263c34}.toilet-list{display:grid;gap:8px}.list-item{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;width:100%;padding:10px;color:#1f2724;border:1px solid #e4e5dd;border-radius:8px;background:#fff;text-align:left}.list-item.selected{border-color:#d9543f;box-shadow:0 0 0 2px #d9543f1a}.item-icon{display:grid;width:38px;height:38px;place-items:center;color:#fff;border-radius:8px;background:#2d6f5f}.list-item strong{display:block;overflow:hidden;font-size:14px;text-overflow:ellipsis;white-space:nowrap}.list-item span{display:block;margin-top:3px;overflow:hidden;color:#68756f;font-size:12px;text-overflow:ellipsis;white-space:nowrap}.list-item small{color:#53645c;font-weight:800}.review-card{margin-top:10px;padding:13px;border:1px solid #e2e3d9;border-radius:8px;background:#fff}.review-form{display:grid;gap:9px}.rating-picker{display:flex;gap:4px}.rating-picker button{display:grid;width:32px;height:32px;place-items:center;color:#b6bdb7;border:1px solid #e2e6dc;border-radius:8px;background:#fbfcf8}.rating-picker .active{color:#d9543f;border-color:#d9543f42;background:#fff3ee}.comment-input{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.comment-input input{min-width:0;height:40px;padding:0 10px;color:#1f2724;border:1px solid #dfe3d9;border-radius:8px;outline:0;background:#fff}.comment-input button{display:grid;width:42px;height:40px;place-items:center;color:#fff;border-radius:8px;background:#263c34}.comment-list{display:grid;gap:8px;margin-top:10px}.comment-row{display:grid;gap:6px;padding:10px;border:1px solid #eef0e8;border-radius:8px;background:#fbfcf8}.comment-topline{display:flex;align-items:center;justify-content:space-between;gap:8px}.comment-topline strong{overflow:hidden;color:#1f2724;font-size:13px;text-overflow:ellipsis;white-space:nowrap}.comment-topline span{flex:0 0 auto;color:#7a8580;font-size:11px}.comment-stars{display:flex;gap:2px;color:#c2c9c2}.comment-stars .active{color:#d9543f}.comment-row p{color:#4f5d56;font-size:13px;line-height:1.45}.comment-row button{display:inline-flex;align-items:center;justify-self:start;gap:4px;height:30px;padding:0 9px;color:#d9543f;border:1px solid #dfe4db;border-radius:8px;background:#fff;font-weight:800}.ranking-view{display:grid;gap:12px}.ranking-summary{display:flex;align-items:center;justify-content:space-between;gap:12px}.ranking-summary button{display:inline-flex;align-items:center;gap:5px;height:34px;padding:0 10px;color:#fff;border-radius:8px;background:#d9543f;font-weight:800}.ranking-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.ranking-stats div{display:grid;min-height:64px;place-items:center;border:1px solid #e2e5da;border-radius:8px;background:#fff}.ranking-stats strong{color:#1f2724;font-size:18px;line-height:1.1}.ranking-stats span{color:#65736d;font-size:11px}.leaderboard-card{padding:13px;border:1px solid #e2e3d9;border-radius:8px;background:#fff}.section-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;color:#d9543f;margin-bottom:10px}.leader-list,.top-comment-list{display:grid;gap:8px}.leader-row,.top-comment-row{display:grid;align-items:center;gap:10px;width:100%;min-width:0;padding:10px;border:1px solid #eef0e8;border-radius:8px;background:#fbfcf8}.leader-row{grid-template-columns:auto minmax(0,1fr) auto}.expand-board-button{display:grid;width:100%;height:36px;place-items:center;margin-top:8px;color:#2d6f5f;border:1px solid #dfe7df;border-radius:8px;background:#fff;font-size:12px;font-weight:900}.rank-number{display:grid;width:34px;height:34px;place-items:center;color:#fff;border-radius:8px;background:#71817a;font-weight:900}.rank-1 .rank-number{background:#d9543f}.rank-2 .rank-number{background:#2d6f5f}.rank-3 .rank-number{background:#816a35}.leader-main,.top-comment-main{min-width:0}.leader-main strong,.top-comment-main strong{display:block;overflow:hidden;color:#1f2724;font-size:14px;text-overflow:ellipsis;white-space:nowrap}.leader-main span,.top-comment-main span{display:block;margin-top:3px;overflow:hidden;color:#68756f;font-size:12px;text-overflow:ellipsis;white-space:nowrap}.leader-score{display:grid;justify-items:end;gap:3px}.leader-score strong{display:inline-flex;align-items:center;gap:3px;color:#1f2724;font-size:14px;white-space:nowrap}.leader-score span{color:#68756f;font-size:11px}.top-comment-row{align-items:start;grid-template-columns:auto minmax(0,1fr)}.top-comment-main p{display:-webkit-box;overflow:hidden;margin-top:5px;color:#4f5d56;font-size:12px;line-height:1.35;-webkit-box-orient:vertical;-webkit-line-clamp:2}.top-comment-likes{display:inline-flex;align-items:center;grid-column:2;justify-self:start;gap:3px;margin-top:-2px;color:#d9543f;font-size:12px;font-weight:900;line-height:1.2;white-space:nowrap}.pants-icon{display:inline-grid;width:18px;min-width:18px;height:18px;place-items:center;border-radius:6px;background:#fff1e5;color:#d9543f;font-size:13px;line-height:1}.sheet-backdrop{position:fixed;inset:0;z-index:20;display:grid;align-items:end;background:#161f1c6b}.report-sheet{width:min(480px,100%);margin:0 auto;padding:16px 16px max(20px,env(safe-area-inset-bottom));border-radius:18px 18px 0 0;background:#fbfaf4}.sheet-title{display:flex;align-items:center;justify-content:space-between;gap:12px}.report-close-button{display:grid;flex:0 0 34px;width:34px;height:34px;place-items:center;margin-left:auto;color:#243630;border:1px solid rgba(36,54,48,.13);border-radius:8px;background:#fff;line-height:1}.report-options{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:16px}.report-options button{display:flex;align-items:center;justify-content:center;gap:8px;min-height:54px;color:#21342e;border:1px solid #e1e4dc;border-radius:8px;background:#fff}.report-options button.selected{color:#d9543f;border-color:#d9543f73;background:#fff7f2;font-weight:900}.report-target{margin-top:10px;padding:8px 10px;overflow:hidden;color:#53645c;border:1px solid #e7e9e1;border-radius:8px;background:#fff;font-size:12px;font-weight:800;text-overflow:ellipsis;white-space:nowrap}label{display:grid;gap:7px;margin-top:14px;color:#4f5e57;font-size:13px;font-weight:800}textarea{width:100%;min-height:88px;padding:10px;resize:none;color:#1f2724;border:1px solid #dfe3d9;border-radius:8px;outline:0;background:#fff}.report-error{margin-top:8px;color:#d9543f;font-size:12px;font-weight:900}.submit-button{display:grid;width:100%;height:48px;place-items:center;margin-top:14px;color:#fff;border-radius:8px;background:#d9543f;font-weight:900}@media(min-width:760px){body{display:grid;min-height:100vh;place-items:center;background:#dce5df}.app-shell{min-height:860px;max-height:920px;border:1px solid rgba(31,39,36,.12);border-radius:30px;box-shadow:0 30px 90px #141f1b38}.sheet-backdrop{align-items:center}.report-sheet{border-radius:18px}}@media(max-width:360px){.map-stage,.bottom-panel{padding-left:12px;padding-right:12px}h1{font-size:22px}.metric-grid,.intel-row{gap:6px}}
