.bottom-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000040;z-index:50}.bottom-sheet-container{position:fixed;top:0;right:0;bottom:0;left:0;overflow-y:auto;z-index:50}.bottom-sheet-wrapper{display:flex;min-height:100%;align-items:flex-end;justify-content:center;padding:1rem}.bottom-sheet-panel{width:100%;max-width:28rem;transform:translateY(0);opacity:1;background-color:#fff;border-top-left-radius:1rem;border-top-right-radius:1rem;padding:1.5rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;transition:all .3s ease-out}.bottom-sheet-panel.closed{transform:translateY(100%);opacity:0}.bottom-sheet-title{font-size:1.125rem;font-weight:500;line-height:1.5;color:#111827;padding-right:2rem}.bottom-sheet-content{margin-top:1rem;display:flex;flex-direction:column;gap:.75rem}.bottom-sheet-text{font-size:.875rem;color:#4b5563}.bottom-sheet-text strong{font-weight:600;color:#1f2937}.bottom-sheet-accessible{font-size:.875rem;color:#059669}.bottom-sheet-buttons{margin-top:1.5rem;display:flex;flex-direction:column;gap:.5rem}.btn-primary{width:100%;border-radius:.5rem;background-color:#3b82f6;padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#fff;border:none;cursor:pointer;transition:background-color .2s}.btn-primary:hover{background-color:#2563eb}.btn-primary:focus{outline:none;ring:2px solid #3B82F6;ring-offset:2px}.btn-secondary{width:100%;border-radius:.5rem;border:1px solid #D1D5DB;background-color:transparent;padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#374151;cursor:pointer;transition:background-color .2s}.btn-secondary:hover{background-color:#f9fafb}.btn-secondary:focus{outline:none;ring:2px solid #D1D5DB;ring-offset:2px}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideDown{0%{transform:translateY(0);opacity:1}to{transform:translateY(100%);opacity:0}}.bottom-sheet-enter{animation:slideUp .3s ease-out forwards}.bottom-sheet-exit{animation:slideDown .2s ease-in forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.backdrop-enter{animation:fadeIn .3s ease-out forwards}.backdrop-exit{animation:fadeOut .2s ease-in forwards}.poi-filter-container{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:8px 12px;width:100%;border:1px solid #e0e0e0}.poi-filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #eee}.poi-filter-title{font-size:14px;font-weight:600;color:#333}.poi-filter-count{font-size:12px;color:#666;background:#f5f5f5;padding:2px 6px;border-radius:16px}.poi-filter-list{display:flex;flex-wrap:nowrap;gap:8px;overflow-x:auto;overflow-y:hidden;padding-bottom:4px;margin-bottom:8px;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.poi-filter-list::-webkit-scrollbar{height:4px}.poi-filter-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.poi-filter-list::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.poi-filter-list::-webkit-scrollbar-thumb:hover{background:#555}.poi-filter-item{display:inline-flex;align-items:center;padding:6px 12px;background-color:#f5f5f5;border:1px solid #e0e0e0;border-radius:30px;cursor:pointer;transition:all .2s ease;font-size:13px;-webkit-user-select:none;user-select:none;flex:0 0 auto;white-space:nowrap}.poi-filter-item:hover{background-color:#eee;border-color:#d0d0d0}.poi-filter-item.selected{background-color:#4285f4;border-color:#4285f4;color:#fff}.poi-filter-item.selected:hover{background-color:#357ae8;border-color:#357ae8}.poi-filter-dot{width:6px;height:6px;border-radius:50%;background-color:#ccc;margin-right:6px;transition:background-color .2s}.poi-filter-dot.selected{background-color:#fff}.poi-filter-name{margin-right:4px;font-weight:500;font-size:12px}.poi-filter-badge{font-size:10px;background-color:#0000001a;padding:2px 5px;border-radius:12px;min-width:16px;text-align:center;color:#666;font-weight:500}.poi-filter-item.selected .poi-filter-badge{background-color:#fff3;color:#fff}.poi-filter-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px;padding-top:6px;border-top:1px solid #eee}.poi-filter-btn{padding:4px 10px;font-size:11px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer;color:#666;transition:all .2s;font-weight:500}.poi-filter-btn:hover{background:#f5f5f5;border-color:#999}.poi-filter-btn.clear{color:#c62828;border-color:#ffcdd2}.poi-filter-btn.clear:hover{background:#ffebee;border-color:#ef9a9a}.poi-filter-btn.select-all{color:#4285f4;border-color:#b8d1ff}.poi-filter-btn.select-all:hover{background:#e8f0fe;border-color:#4285f4}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}.app-container{display:flex;flex-direction:column;height:100vh;width:100vw}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:16px 20px;box-shadow:0 2px 8px #0000001a;z-index:10}.header h1{font-size:24px;font-weight:600;margin-bottom:12px}.controls{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:12px}.location-info{font-size:14px;opacity:.9;background:#fff3;padding:8px 12px;border-radius:6px}.filter-wrapper{margin-top:8px;width:100%}.filter-wrapper .poi-filter-container{background:#fff;border-radius:8px;padding:8px 12px;width:100%;border:1px solid rgba(255,255,255,.2);box-shadow:0 2px 8px #00000026}.filter-wrapper .poi-filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #eee}.filter-wrapper .poi-filter-title{font-size:14px;font-weight:600;color:#333}.filter-wrapper .poi-filter-count{font-size:12px;color:#666;background:#f5f5f5;padding:2px 6px;border-radius:16px}.filter-wrapper .poi-filter-list{display:flex;flex-wrap:nowrap;gap:8px;overflow-x:auto;overflow-y:hidden;padding-bottom:4px;margin-bottom:8px;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.filter-wrapper .poi-filter-list::-webkit-scrollbar{height:4px}.filter-wrapper .poi-filter-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.filter-wrapper .poi-filter-list::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.filter-wrapper .poi-filter-list::-webkit-scrollbar-thumb:hover{background:#555}.filter-wrapper .poi-filter-item{display:inline-flex;align-items:center;padding:6px 12px;background-color:#f5f5f5;border:1px solid #e0e0e0;border-radius:30px;cursor:pointer;transition:all .2s ease;font-size:13px;-webkit-user-select:none;user-select:none;flex:0 0 auto;white-space:nowrap}.filter-wrapper .poi-filter-item:hover{background-color:#eee;border-color:#d0d0d0}.filter-wrapper .poi-filter-item.selected{background-color:#667eea;border-color:#667eea;color:#fff}.filter-wrapper .poi-filter-item.selected:hover{background-color:#5a6fd6;border-color:#5a6fd6}.filter-wrapper .poi-filter-dot{width:6px;height:6px;border-radius:50%;background-color:#ccc;margin-right:6px;transition:background-color .2s}.filter-wrapper .poi-filter-dot.selected{background-color:#fff}.filter-wrapper .poi-filter-name{margin-right:4px;font-weight:500;font-size:12px}.filter-wrapper .poi-filter-badge{font-size:10px;background-color:#0000001a;padding:2px 5px;border-radius:12px;min-width:16px;text-align:center;color:#666;font-weight:500}.filter-wrapper .poi-filter-item.selected .poi-filter-badge{background-color:#fff3;color:#fff}.filter-wrapper .poi-filter-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px;padding-top:6px;border-top:1px solid #eee}.filter-wrapper .poi-filter-btn{padding:4px 10px;font-size:11px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer;color:#666;transition:all .2s;font-weight:500}.filter-wrapper .poi-filter-btn:hover{background:#f5f5f5;border-color:#999}.filter-wrapper .poi-filter-btn.clear{color:#c62828;border-color:#ffcdd2}.filter-wrapper .poi-filter-btn.clear:hover{background:#ffebee;border-color:#ef9a9a}.filter-wrapper .poi-filter-btn.select-all{color:#667eea;border-color:#c5cae9}.filter-wrapper .poi-filter-btn.select-all:hover{background:#e8eaf6;border-color:#667eea}.error-banner,.loading-banner{padding:12px 24px;text-align:center;font-size:14px;z-index:10}.error-banner{background-color:#fee;color:#c33;border-bottom:1px solid #fcc}.loading-banner{background-color:#e3f2fd;color:#1976d2;border-bottom:1px solid #bbdefb}.map-container{flex:1;position:relative;min-height:0}.footer{background:#fff;padding:12px 24px;border-top:1px solid #e0e0e0;box-shadow:0 -2px 4px #0000000d;z-index:10}.stats{display:flex;gap:24px;font-size:14px;color:#666}.stats span{font-weight:500}.error-message{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;padding:24px;text-align:center;background:#f5f5f5}.error-message h2{color:#333;margin-bottom:12px}.error-message p{color:#666;margin-bottom:8px}.error-message code{background:#e0e0e0;padding:4px 8px;border-radius:4px;font-family:Courier New,monospace;font-size:13px}@media (max-width: 768px){.header{padding:12px 16px}.header h1{font-size:20px;margin-bottom:10px}.controls{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:10px}.controls button,.location-info{width:100%}.filter-wrapper .poi-filter-container{padding:6px 10px}.filter-wrapper .poi-filter-item{padding:5px 10px;font-size:12px}.filter-wrapper .poi-filter-name{font-size:11px}.filter-wrapper .poi-filter-badge{font-size:9px;padding:1px 4px}.stats{flex-direction:column;gap:8px}}
