html,body{height:100%;margin:0;padding:0;overflow:hidden}body{display:flex;flex-direction:column}.navbar{flex-shrink:0}.map-page-container{flex:1;display:flex;position:relative;overflow:hidden;background-color:var(--bg-light)}.map-sidebar{width:400px;height:100%;background-color:#fff;border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:40;position:relative;box-shadow:4px 0 24px #0f172a08;transition:transform .4s cubic-bezier(.16,1,.3,1),width .4s cubic-bezier(.16,1,.3,1)}.map-sidebar.collapsed{transform:translate(-100%);width:0}.sidebar-header{padding:16px 16px 12px;border-bottom:1px solid var(--border-color);flex-shrink:0}.search-row{display:flex;gap:8px;align-items:center;width:100%}.search-wrapper{display:flex;align-items:center;background-color:var(--bg-light);border:1px solid var(--border-color);border-radius:12px;padding:2px 6px 2px 14px;margin-bottom:0;flex:1;transition:all .2s ease}.search-wrapper:focus-within{border-color:var(--brand-primary);background-color:#fff;box-shadow:0 0 0 4px #2563eb14}.search-input{border:none;outline:none;background:transparent;font-family:inherit;font-size:14px;color:var(--text-slate-800);flex:1;padding:8px 0}.search-input::placeholder{color:var(--text-slate-400)}.search-icon-btn{background:none;border:none;color:var(--text-slate-400);padding:6px;cursor:pointer;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.search-wrapper:focus-within .search-icon-btn{color:var(--brand-primary)}.btn-locate-icon{width:38px;height:38px;display:flex;align-items:center;justify-content:center;background-color:var(--bg-light);border:1px solid var(--border-color);color:var(--text-slate-500);border-radius:12px;cursor:pointer;transition:all .2s ease;flex-shrink:0}.btn-locate-icon:hover{border-color:var(--brand-primary);color:var(--brand-primary);background-color:#eff6ff;box-shadow:0 4px 12px #2563eb14}.btn-locate-icon svg{transition:transform .3s ease}.btn-locate-icon:hover svg{transform:rotate(45deg)}.categories-outer-wrapper{border-bottom:1px solid var(--border-color);flex-shrink:0;width:100%;background-color:#fff}.categories-filter-wrapper{display:flex;flex-wrap:wrap;gap:8px 6px;padding:12px 16px;width:100%}.category-pill{display:inline-block;padding:5px 12px;background-color:var(--bg-light);border:1px solid var(--border-color);border-radius:9999px;font-size:12px;font-weight:600;color:var(--text-slate-500);cursor:pointer;transition:all .25s cubic-bezier(.16,1,.3,1)}.category-pill:hover{color:var(--text-slate-900);border-color:var(--text-slate-300);background-color:#fff}.category-pill.active{background-color:var(--brand-primary);color:#fff;border-color:var(--brand-primary);box-shadow:0 4px 12px #2563eb26}.sidebar-results{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.sidebar-pagination{padding:12px 16px;border-top:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;background-color:#fff;flex-shrink:0}.pagination-btn{background:none;border:1px solid var(--border-color);color:var(--text-slate-600);padding:6px 12px;font-size:13px;font-weight:600;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background-color:var(--bg-light);color:var(--brand-primary);border-color:var(--brand-primary)}.pagination-btn:disabled{opacity:.35;cursor:not-allowed}.pagination-btn svg{flex-shrink:0}.pagination-info{font-size:12px;font-weight:700;color:var(--text-slate-500);letter-spacing:.05em;text-transform:uppercase}.map-product-card{display:flex;gap:12px;padding:10px;background-color:#fff;border:1px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .25s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden;border-left:3px solid transparent;flex-shrink:0}.map-product-card:hover{background-color:#f8fafc;border-color:#e2e8f0cc;border-left-color:#cbd5e1;transform:translateY(-1px)}.map-product-card.selected{background-color:#eff6ff;border-color:#2563eb26;border-left-color:var(--brand-primary);box-shadow:0 6px 16px #2563eb08}.map-product-card:has(.tag-green):hover,.map-product-card:has(.tag-green).selected{border-left-color:var(--brand-green)}.map-product-card:has(.tag-blue):hover,.map-product-card:has(.tag-blue).selected{border-left-color:var(--brand-primary)}.map-product-card:has(.tag-amber):hover,.map-product-card:has(.tag-amber).selected{border-left-color:#06b6d4}.map-product-card:has(.tag-indigo):hover,.map-product-card:has(.tag-indigo).selected{border-left-color:#10b981}.map-product-card:has(.tag-purple):hover,.map-product-card:has(.tag-purple).selected{border-left-color:#2563eb}.map-product-media{width:68px;height:68px;border-radius:8px;overflow:hidden;flex-shrink:0;position:relative;background-color:var(--bg-light)}.map-product-image{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.map-product-card:hover .map-product-image{transform:scale(1.06)}.map-product-info{display:flex;flex-direction:column;flex:1;min-width:0}.map-product-title{font-size:14px;font-weight:700;color:var(--text-slate-900);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.map-product-meta{margin-top:auto;display:flex;align-items:center;justify-content:space-between}.map-category-tag{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.1em}.tag-purple{color:#1d4ed8}.map-view{flex:1;height:100%;position:relative;z-index:10}.leaflet-container{font-family:inherit!important}.custom-map-pin{width:36px!important;height:36px!important;background-color:#fff;border:2px solid var(--brand-primary);border-radius:9999px;box-shadow:0 8px 16px #2563eb33;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);position:relative}.custom-map-pin:after{content:"";position:absolute;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--brand-primary);bottom:-6px;left:50%;transform:translate(-50%)}.custom-map-pin:hover,.custom-map-pin.active{background-color:var(--brand-primary);color:#fff;transform:scale(1.15) translateY(-4px);box-shadow:0 12px 24px #2563eb59}.custom-map-pin svg{width:18px;height:18px;stroke:currentColor;fill:none;transition:stroke .3s ease}.custom-map-pin:hover svg,.custom-map-pin.active svg{stroke:#fff}.custom-map-pin.gratis-pin{border-color:var(--brand-green);box-shadow:0 8px 16px #12a15033}.custom-map-pin.gratis-pin:after{border-top-color:var(--brand-green)}.custom-map-pin.gratis-pin:hover,.custom-map-pin.gratis-pin.active{background-color:var(--brand-green);box-shadow:0 12px 24px #12a15059}.custom-map-pin.taken-pin{border-color:#94a3b8;box-shadow:0 4px 10px #94a3b84d;opacity:.6;filter:grayscale(70%)}.custom-map-pin.taken-pin:after{border-top-color:#94a3b8}.pin-ring-pulse{position:absolute;width:52px;height:52px;border-radius:9999px;border:2px solid var(--brand-primary);pointer-events:none;animation:marker-pulse-glow 1.8s infinite ease-out;opacity:0}.custom-map-pin.gratis-pin .pin-ring-pulse{border-color:var(--brand-green)}@keyframes marker-pulse-glow{0%{transform:scale(.6);opacity:.8}to{transform:scale(1.3);opacity:0}}.leaflet-popup-content-wrapper{background:#fffffff5!important;backdrop-filter:blur(12px)!important;-webkit-backdrop-filter:blur(12px)!important;border:1px solid rgba(226,232,240,.8)!important;border-radius:18px!important;box-shadow:0 20px 50px -12px #0f172a26!important;padding:0!important;overflow:hidden!important}.leaflet-popup-content{margin:0!important;width:280px!important}.leaflet-popup-tip-container{opacity:.95}.leaflet-popup-tip{background:#fff!important;border:1px solid rgba(226,232,240,.5)!important;box-shadow:none!important}.popup-product-card{display:flex;flex-direction:column}.popup-media{width:100%;height:140px;position:relative;overflow:hidden;background-color:var(--bg-light)}.popup-image{width:100%;height:100%;object-fit:cover}.popup-info{padding:16px}.popup-tag-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.popup-title{font-size:15px;font-weight:800;color:var(--text-slate-900);margin-bottom:6px;line-height:1.3}.popup-desc{font-size:12px;color:var(--text-slate-500);line-height:1.4;margin-bottom:12px}.popup-btn-claim{width:100%;padding:10px;background-color:var(--brand-primary);color:#fff;border:none;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;text-align:center;transition:background-color .2s ease}.popup-btn-claim:hover{background-color:var(--brand-primary-hover)}.popup-product-card.gratis-card .popup-btn-claim{background-color:var(--brand-green)}.popup-product-card.gratis-card .popup-btn-claim:hover{background-color:#0e8341}.leaflet-popup-close-button{width:24px!important;height:24px!important;line-height:24px!important;background:#fff!important;border-radius:9999px!important;box-shadow:0 4px 10px #0000001a!important;color:var(--text-slate-600)!important;top:8px!important;right:8px!important;z-index:100!important;font-size:14px!important;text-align:center!important;font-weight:700!important;transition:all .2s ease!important}.leaflet-popup-close-button:hover{color:var(--text-slate-900)!important;transform:scale(1.05)}.sidebar-toggle-btn{position:absolute;top:50%;right:-16px;transform:translateY(-50%);width:32px;height:32px;background-color:#fff;border:1px solid var(--border-color);box-shadow:4px 0 10px #0000000d,0 4px 6px #00000005;border-radius:9999px;display:flex;align-items:center;justify-content:center;color:var(--text-slate-600);cursor:pointer;z-index:100;transition:all .2s ease}.sidebar-toggle-btn:hover{color:var(--brand-primary);box-shadow:4px 0 14px #2563eb1a,0 4px 10px #00000008}.map-sidebar.collapsed .sidebar-toggle-btn{right:-40px;transform:translateY(-50%) rotate(180deg)}.mobile-view-switcher{display:none;position:absolute;bottom:24px;left:50%;transform:translate(-50%);z-index:45;background-color:var(--text-slate-900);box-shadow:0 10px 25px #0f172a40;border-radius:9999px;padding:6px;gap:4px}.switcher-btn{background:none;border:none;color:#cbd5e1;font-size:13px;font-weight:700;padding:8px 18px;border-radius:9999px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s ease}.switcher-btn.active{background-color:#fff;color:var(--text-slate-900);box-shadow:0 4px 10px #0000001a}.switcher-btn svg{width:16px;height:16px;stroke:currentColor}.empty-state{padding:40px 16px;text-align:center;display:flex;flex-direction:column;align-items:center;color:var(--text-slate-400)}.empty-state svg{margin-bottom:16px;color:var(--text-slate-300)}.empty-state h4{font-size:16px;font-weight:700;color:var(--text-slate-800);margin-bottom:8px}.empty-state p{font-size:13px;line-height:1.5}@media(max-width:768px){.map-page-container{flex-direction:column}.map-sidebar{position:absolute;bottom:0;left:0;width:100%;height:100%;border-right:none;box-shadow:0 -8px 24px #0f172a0d;transform:translateY(0);transition:transform .4s cubic-bezier(.16,1,.3,1)}.map-sidebar.hidden{transform:translateY(100%)}.sidebar-toggle-btn{display:none}.mobile-view-switcher{display:flex}.map-view{width:100%;height:100%}}.map-privacy-banner{position:absolute;bottom:16px;left:16px;right:auto;max-width:440px;background:#ffffffe0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(226,232,240,.8);border-radius:12px;padding:10px 14px;font-size:11px;color:var(--text-slate-600);display:flex;align-items:center;gap:10px;z-index:1000;box-shadow:0 10px 30px #0f172a0f;line-height:1.4;transition:all .3s ease;pointer-events:auto}.privacy-icon{color:var(--brand-primary);flex-shrink:0}@media(max-width:768px){.map-privacy-banner{bottom:80px;left:12px;right:12px;max-width:none;padding:8px 12px}}.banner-close-btn{background:none;border:none;color:var(--text-slate-400);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease;flex-shrink:0}.banner-close-btn:hover{color:var(--text-slate-900);background-color:var(--bg-light)}
