.map-filters{position:relative;z-index:10}.filter-toggle{display:flex;align-items:center;gap:8px;padding:12px 20px;background:#fff;border:none;border-radius:8px;box-shadow:0 2px 8px #00000026;cursor:pointer;font-size:14px;font-weight:600;color:#1a1a1a;transition:all .2s ease}.filter-toggle:hover{box-shadow:0 4px 12px #0003;transform:translateY(-1px)}.filter-toggle:active{transform:translateY(0)}.filter-panel{position:absolute;top:60px;left:0;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;padding:20px;min-width:300px;max-width:400px;max-height:80vh;overflow-y:auto;animation:slideDown .2s ease-out}.filter-section{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid #e5e7eb}.filter-section:last-of-type{border-bottom:none;padding-bottom:0}.filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.filter-section h4{margin:0;font-size:14px;font-weight:700;color:#1a1a1a;text-transform:uppercase;letter-spacing:.5px}.text-button{background:none;border:none;color:#3b82f6;font-size:12px;font-weight:600;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background-color .2s}.text-button:hover{background-color:#eff6ff}.filter-options{display:flex;flex-direction:column;gap:8px}.filter-option{display:flex;align-items:center;gap:10px;cursor:pointer;padding:8px;border-radius:6px;transition:background-color .2s}.filter-option:hover{background-color:#f9fafb}.filter-option input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#3b82f6}.rarity-badge,.theme-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:capitalize;color:#fff;transition:all .2s}.toggle-option{padding:12px;background-color:#f9fafb;border-radius:8px}.toggle-option span{font-size:14px;font-weight:500;color:#1a1a1a}.date-inputs{display:flex;flex-direction:column;gap:8px;align-items:stretch}.date-inputs input[type=date]{padding:10px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;color:#1a1a1a;transition:border-color .2s}.date-inputs input[type=date]:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.date-inputs span{font-size:12px;color:#6b7280;text-align:center}.clear-filters-button{width:100%;padding:12px;background-color:#ef4444;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:8px}.clear-filters-button:hover{background-color:#dc2626;transform:translateY(-1px);box-shadow:0 2px 8px #ef44444d}.clear-filters-button:active{transform:translateY(0)}@media (max-width: 768px){.filter-panel{position:fixed;top:auto;bottom:0;left:0;right:0;min-width:unset;max-width:unset;border-radius:20px 20px 0 0;max-height:70vh;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.filter-toggle{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:1000;box-shadow:0 4px 20px #0003}.map-filters.open .filter-toggle{display:none}}.filter-panel::-webkit-scrollbar{width:8px}.filter-panel::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.filter-panel::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.filter-panel::-webkit-scrollbar-thumb:hover{background:#94a3b8}.map-legend{position:fixed;top:0;right:0;width:320px;height:100vh;background:#fff;box-shadow:-2px 0 8px #0000001a;display:flex;flex-direction:column;z-index:100}.legend-header{padding:20px;border-bottom:2px solid #e5e7eb;background:linear-gradient(135deg,#667eea,#764ba2)}.legend-header h3{margin:0;font-size:18px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px}.legend-content{flex:1;overflow-y:auto;padding:20px}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.legend-section{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.legend-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.legend-section h4{margin:0 0 12px;font-size:13px;font-weight:700;color:#1a1a1a;text-transform:uppercase;letter-spacing:.5px}.legend-items{display:flex;flex-direction:column;gap:10px}.legend-item{display:flex;align-items:center;gap:12px}.legend-icon{width:32px;height:32px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.legend-text{display:flex;flex-direction:column;gap:2px;flex:1}.legend-label{font-size:13px;font-weight:600;color:#1a1a1a;text-transform:capitalize}.legend-description{font-size:11px;color:#6b7280}.house-themes{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.house-theme-item{display:flex;align-items:center;gap:8px;padding:6px;border-radius:6px;background-color:#f9fafb}.theme-color-swatch{width:20px;height:20px;border-radius:4px;flex-shrink:0;border:2px solid white;box-shadow:0 1px 3px #0003}.theme-name{font-size:12px;font-weight:500;color:#1a1a1a;text-transform:capitalize}.point-values{display:flex;flex-direction:column;gap:6px}.point-item{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background-color:#f9fafb;border-radius:6px}.point-rarity{font-size:12px;font-weight:600;text-transform:capitalize}.point-value{font-size:12px;font-weight:700;color:#1a1a1a}@media (max-width: 768px){.map-legend{width:100%;height:50vh;top:auto;bottom:0;border-radius:20px 20px 0 0;box-shadow:0 -2px 8px #0000001a}.legend-header{padding:16px 20px}.legend-header h3{font-size:16px}.legend-content{padding:16px}.house-themes{grid-template-columns:repeat(3,1fr)}}.legend-content::-webkit-scrollbar{width:8px}.legend-content::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.legend-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.legend-content::-webkit-scrollbar-thumb:hover{background:#94a3b8}.map-search{position:relative;width:100%;max-width:400px}.search-input-container{position:relative;display:flex;align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000026;transition:box-shadow .2s ease}.search-input-container:focus-within{box-shadow:0 4px 12px #0003}.search-icon{position:absolute;left:14px;color:#6b7280;pointer-events:none}.search-input{width:100%;padding:12px 40px 12px 44px;border:none;border-radius:8px;font-size:14px;color:#1a1a1a;outline:none;background:transparent}.search-input::placeholder{color:#9ca3af}.clear-button{position:absolute;right:10px;width:24px;height:24px;padding:0;border:none;background:none;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.clear-button:hover{background-color:#f3f4f6;color:#1a1a1a}.search-suggestions{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;max-height:300px;overflow-y:auto;z-index:1000;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.suggestion-item{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;cursor:pointer;transition:background-color .2s;border-bottom:1px solid #f3f4f6}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background-color:#f9fafb}.suggestion-icon{color:#6b7280;flex-shrink:0;margin-top:2px}.suggestion-text{flex:1;min-width:0}.suggestion-main{font-size:14px;font-weight:600;color:#1a1a1a;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.suggestion-secondary{font-size:12px;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media (max-width: 768px){.map-search{max-width:100%}.search-input{font-size:16px}.search-suggestions{max-height:200px}}.search-suggestions::-webkit-scrollbar{width:8px}.search-suggestions::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.search-suggestions::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.search-suggestions::-webkit-scrollbar-thumb:hover{background:#94a3b8}.rock-map-view{position:relative;width:calc(100% - 320px);height:100vh;overflow:hidden}.rock-map-view>div:not(.map-controls):not(.rock-count-badge):not(.map-legend){width:100%!important;height:100%!important}.map-controls{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:10;padding:20px;display:flex;flex-direction:column}.map-controls>*{pointer-events:auto}.map-controls-top{display:flex;justify-content:center;margin-bottom:auto}.map-controls-bottom-left{position:absolute;bottom:20px;left:20px}.map-controls-bottom-right{position:absolute;bottom:20px;right:20px}.rock-count-badge{position:absolute;top:80px;left:50%;transform:translate(-50%);z-index:10;display:flex;align-items:center;gap:8px;padding:10px 20px;background:#fff;border-radius:20px;box-shadow:0 2px 8px #00000026;font-size:14px;font-weight:600;color:#1a1a1a;pointer-events:none;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.rock-count-badge svg{color:#3b82f6}.user-location-marker{position:relative;width:20px;height:20px}.user-location-dot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;background:#3b82f6;border:3px solid white;border-radius:50%;box-shadow:0 2px 8px #3b82f680;z-index:2}.user-location-pulse{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;background:#3b82f64d;border-radius:50%;animation:pulse 2s infinite;z-index:1}@keyframes pulse{0%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(2.5);opacity:0}}@media (max-width: 768px){.rock-map-view{width:100%;height:50vh}.map-controls{padding:12px}.map-controls-bottom-left{bottom:12px;left:12px}.rock-count-badge{top:70px;padding:8px 16px;font-size:13px}.map-controls-top{width:100%;padding:0 12px}}@media (max-width: 480px){.rock-count-badge{font-size:12px;padding:6px 12px}.rock-count-badge svg{width:16px;height:16px}}@media (max-height: 500px) and (orientation: landscape){.map-controls{padding:8px}.rock-count-badge{top:60px}.map-controls-bottom-left,.map-controls-bottom-right{bottom:8px}}.cluster-marker{display:flex;align-items:center;justify-content:center;width:50px;height:50px;border-radius:50%;color:#fff;font-weight:700;font-size:16px;border:3px solid white;box-shadow:0 2px 12px #0000004d;cursor:pointer;transition:transform .2s ease}.cluster-marker:hover{transform:scale(1.1)}.rock-map-view.loading:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:50px;height:50px;border:4px solid #f3f4f6;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;z-index:1000}@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}#root{height:100vh;width:100vw;margin:0;padding:0;overflow:hidden}.starter-instructions{color:light-dark(#333,#ccc);text-align:left;max-width:800px}.starter-instructions p{text-align:left}.starter-instructions code{display:inline-block;padding:0 .3em;color:light-dark(#000,#fff);background-color:light-dark(#eee,#3a3a3a);border-radius:4px;font-family:Courier New,monospace;font-size:.9em}.starter-instructions ol{line-height:1.8}.starter-instructions li{margin-bottom:12px}.starter-instructions h2{margin-top:24px;margin-bottom:12px}.starter-instructions a{color:#3b82f6;text-decoration:none}.starter-instructions a:hover{text-decoration:underline}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
