*{box-sizing:border-box;margin:0;padding:0}body{width:100vw;height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;overflow:hidden}#map{width:100%;height:100vh}.splash{z-index:9999;background:#1a1a2e;justify-content:center;align-items:center;transition:opacity .6s;display:flex;position:fixed;inset:0}.splash.hidden{display:none}.splash.fade-out{opacity:0}.splash-content{text-align:center;animation:.8s ease-out splashIn}.splash-logo{border-radius:50%;width:160px;height:160px;margin-bottom:24px;animation:2s ease-in-out infinite logoPulse;box-shadow:0 8px 40px #00000080}.splash-title{color:#fff;letter-spacing:2px;margin-bottom:8px;font-size:36px;font-weight:800}.splash-subtitle{color:#fff9;letter-spacing:1px;font-size:16px}@keyframes splashIn{0%{opacity:0;transform:scale(.8)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes logoPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.onboarding{z-index:9998;background:#1a1a2e;justify-content:center;align-items:center;padding:20px;animation:.4s fadeIn;display:flex;position:fixed;inset:0}.onboarding.hidden{display:none}.onboarding-card{text-align:center;width:100%;max-width:320px}.onboarding-logo{border-radius:50%;width:80px;height:80px;margin-bottom:20px;box-shadow:0 4px 20px #0006}.onboarding-card h2{color:#fff;margin-bottom:6px;font-size:22px}.onboarding-card p{color:#fff6;margin-bottom:20px;font-size:14px}.onboard-input{color:#e0e0e0;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:10px;outline:none;width:100%;margin-bottom:10px;padding:12px 16px;font-family:inherit;font-size:15px}.onboard-input:focus{background:#ffffff14;border-color:#4285f4}.onboard-input::placeholder{color:#ffffff4d}.onboard-btn{cursor:pointer;color:#fff;background:#4285f4;border:none;border-radius:10px;width:100%;margin-top:6px;padding:12px;font-size:15px;font-weight:700;transition:background .2s}.onboard-btn:disabled{color:#ffffff4d;cursor:not-allowed;background:#4285f44d}.onboard-btn:not(:disabled):hover{background:#357ae8}.onboard-skip{color:#ffffff4d;cursor:pointer;background:0 0;border:none;margin-top:14px;padding:8px;font-size:13px}.onboard-skip:hover{color:#ffffff80}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.loading{z-index:1000;color:#ccc;background:#1a1a2ef2;border-radius:12px;padding:20px 30px;font-size:16px;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 4px 20px #0000004d}.loading.hidden{display:none}.filter-bar{z-index:1000;background:#1a1a2e;border-radius:25px;gap:6px;padding:6px 10px;display:flex;position:fixed;top:10px;left:50%;transform:translate(-50%);box-shadow:0 2px 12px #0000004d}.filter-btn{cursor:pointer;color:#fff6;background:#ffffff14;border:2px solid #0000;border-radius:20px;align-items:center;gap:4px;padding:6px 12px;font-size:12px;font-weight:600;transition:all .2s;display:flex}.filter-btn.active{color:#fff;background:#ffffff26;border-color:#ffffff4d}.filter-btn .filter-icon{font-size:14px}.controls{z-index:1000;flex-wrap:wrap;justify-content:center;gap:8px;max-width:calc(100% - 20px);display:flex;position:fixed;bottom:20px;left:50%;transform:translate(-50%)}.control-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#1a1a2e;border:none;border-radius:25px;padding:10px 16px;font-size:13px;font-weight:600;transition:all .2s;box-shadow:0 2px 12px #0000004d}.control-btn:hover{background:#252545}.control-btn:active{transform:scale(.95)}.info-panel{z-index:1000;color:#e0e0e0;background:#1a1a2e;border-radius:20px;max-height:65vh;padding:30px 16px 14px;transition:transform .3s;position:fixed;bottom:8px;left:8px;right:8px;overflow-y:auto;box-shadow:0 -4px 30px #0006}.info-panel.hidden{transform:translateY(100%)}.info-panel:before{content:"";background:#fff3;border-radius:2px;width:36px;height:4px;position:absolute;top:8px;left:50%;transform:translate(-50%)}.close-btn{color:#ffffff80;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:28px;display:flex;position:absolute;top:4px;right:8px}.close-btn:hover{color:#fff;background-color:#ffffff1a}.info-type-badge{color:#fff;letter-spacing:.5px;border-radius:10px;margin-bottom:6px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.info-type-bench{background:#2d6a4f}.info-type-elevator{background:#1565c0}.info-type-restroom{background:#7b1fa2}.info-item{border-bottom:1px solid #ffffff0f;align-items:baseline;gap:8px;padding:4px 0;display:flex}.info-item:last-child{border-bottom:none}.info-label{color:#ffffff59;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;min-width:55px;font-size:10px}.info-value{color:#e0e0e0;font-size:14px;font-weight:500}.info-subtle{color:#ffffff73;font-size:12px;font-weight:400}.status-open{color:#66bb6a}.status-closed{color:#ef5350}.subway-lines{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.subway-badge{border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:13px;font-weight:800;line-height:1;display:inline-flex}.panel-tabs{border-bottom:1px solid #ffffff1a;gap:0;margin-bottom:10px;display:flex}.panel-tab{color:#ffffff59;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:8px 0;font-size:13px;font-weight:600;transition:all .2s}.panel-tab.active{color:#fff;border-bottom-color:#4285f4}.tab-content{display:none}.tab-content.active{display:block}.info-actions{border-top:1px solid #ffffff14;margin-top:8px;padding-top:8px}.route-btn{color:#fff;cursor:pointer;background:#4285f4;border:none;border-radius:10px;width:100%;padding:10px 16px;font-size:13px;font-weight:600}.route-btn:hover{background:#357ae8}.stats-bar{align-items:center;gap:8px;margin-bottom:6px;display:flex}.avg-rating{color:#f5a623;font-size:16px;font-weight:700}.comment-count{color:#ffffff80;font-size:12px}.no-rating{color:#ffffff4d;font-size:12px}.tag-display{flex-wrap:wrap;gap:4px;margin-bottom:6px;display:flex}.tag-stat{color:#ffffff80;align-items:center;gap:3px;font-size:11px;display:flex}.tag{color:#66bb6a;background:#2d6a4f4d;border-radius:8px;padding:2px 6px;font-size:10px;font-weight:600;display:inline-block}.photo-gallery{gap:4px;margin-bottom:6px;display:flex;overflow-x:auto}.gallery-photo{object-fit:cover;border:1px solid #ffffff1a;border-radius:6px;flex-shrink:0;width:56px;height:56px}.comments-list{max-height:140px;margin-bottom:8px;overflow-y:auto}.comment{border-bottom:1px solid #ffffff0f;padding:6px 0}.comment:last-child{border-bottom:none}.comment-header{align-items:center;gap:6px;margin-bottom:2px;font-size:12px;display:flex}.comment-header strong{color:#fff}.comment-rating{color:#f5a623;font-size:11px}.comment-date{color:#ffffff4d;margin-left:auto;font-size:10px}.comment-tags{gap:3px;margin-bottom:2px;display:flex}.comment-text{color:#ffffffb3;font-size:13px;line-height:1.3}.comment-photo{border-radius:6px;max-width:100%;max-height:100px;margin-top:4px}.no-comments,.loading-comments{text-align:center;color:#ffffff4d;padding:10px 0;font-size:12px}.comment-form{background:#ffffff0d;border:1px solid #ffffff14;border-radius:8px;padding:10px}.comment-input,.comment-textarea{color:#e0e0e0;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:6px;width:100%;margin-bottom:6px;padding:6px 10px;font-family:inherit;font-size:13px}.comment-textarea{resize:none;height:44px}.comment-input:focus,.comment-textarea:focus{background:#ffffff14;border-color:#4285f4;outline:none}.comment-input::placeholder,.comment-textarea::placeholder{color:#ffffff4d}.rating-input{align-items:center;gap:4px;margin-bottom:6px;display:flex}.rating-label{color:#ffffff80;font-size:12px}.star{color:#ffffff26;cursor:pointer;font-size:20px;transition:color .15s}.star:hover,.star.filled{color:#f5a623}.tag-picker{flex-wrap:wrap;gap:4px;margin-bottom:8px;display:flex}.tag-pick{cursor:pointer;color:#ffffff80;background:#ffffff0f;border:1px solid #0000;border-radius:14px;padding:4px 10px;font-size:11px;transition:all .15s}.tag-pick.selected{color:#66bb6a;background:#2d6a4f4d;border-color:#4caf50}.tag-pick:hover{background:#ffffff1a}.submit-comment-btn{color:#fff;cursor:pointer;background:#4caf50;border:none;border-radius:8px;width:100%;padding:10px 20px;font-size:14px;font-weight:600}.submit-comment-btn:hover{background:#43a047}.photo-upload-row{margin-bottom:6px}.photo-upload-btn{color:#fff9;cursor:pointer;background:#ffffff14;border:1px solid #ffffff1f;border-radius:6px;padding:6px 12px;font-size:12px;display:inline-block}.photo-upload-btn:hover{color:#fff;background:#ffffff1f}.photo-file-input{display:none}.photo-preview{margin-bottom:6px}.photo-preview-img{border:1px solid #ffffff1a;border-radius:6px;max-width:100%;max-height:80px}.add-btn{background:#2d6a4f!important}.add-btn:hover{background:#3a8063!important}.modal{z-index:2000;background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal.hidden{display:none}.modal-content{color:#e0e0e0;background:#1a1a2e;border:1px solid #ffffff1a;border-radius:16px;width:100%;max-width:360px;padding:24px;box-shadow:0 4px 30px #00000080}.modal-content h3{color:#fff;margin-bottom:6px;font-size:18px}.modal-hint{color:#fff6;margin-bottom:14px;font-size:12px}.modal-coords{color:#ffffff59;background:#ffffff0d;border-radius:6px;margin-bottom:14px;padding:6px 10px;font-size:12px}.modal-actions{flex-direction:column;gap:8px;display:flex}.modal-btn{cursor:pointer;border:none;border-radius:8px;width:100%;padding:10px 16px;font-size:13px;font-weight:600}.modal-btn.primary{color:#fff;background:#2d6a4f}.modal-btn.primary:disabled{color:#ffffff4d;cursor:not-allowed;background:#2d6a4f4d}.modal-btn.secondary{color:#e0e0e0;background:#ffffff1a}.modal-btn.cancel{color:#fff6;background:0 0}.location-permission{z-index:2000;background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.location-permission.hidden{display:none}.location-permission-content{text-align:center;background:#1a1a2e;border:1px solid #ffffff1a;border-radius:16px;max-width:400px;padding:30px;box-shadow:0 4px 30px #00000080}.location-permission-content p{color:#e0e0e0;margin-bottom:20px;font-size:16px;line-height:1.5}.location-btn{color:#fff;cursor:pointer;background:#4285f4;border:none;border-radius:8px;width:100%;padding:12px 30px;font-size:16px;font-weight:600}.location-btn:hover{background:#357ae8}.location-btn-skip{color:#fff6;cursor:pointer;background:0 0;border:none;margin-top:10px;padding:10px 20px;font-size:14px}.location-btn-skip:hover{color:#ffffffb3}.feedback-fab{z-index:999;color:#ffffff80;cursor:pointer;background:#1a1a2e;border:1px solid #ffffff26;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;font-weight:700;display:flex;position:fixed;bottom:20px;right:16px;box-shadow:0 2px 8px #0000004d}.feedback-fab:hover{color:#fff;border-color:#ffffff4d}.fb-types{gap:6px;margin-bottom:12px;display:flex}.fb-type-btn{color:#ffffff80;cursor:pointer;text-transform:capitalize;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;flex:1;padding:6px 8px;font-size:12px}.fb-type-btn.active{color:#fff;background:#4285f426;border-color:#4285f4}@media (min-width:768px){.info-panel{max-width:420px;max-height:85vh;bottom:20px;left:auto;right:20px}}
