:root{--cat-nature:#22C55E;--cat-sport:#F97316;--cat-culture:#A855F7;--cat-fun:#EC4899;--cat-indoor:#3B82F6;--cat-food:#EAB308;--cat-water:#06B6D4;--cat-animal:#10B981;--age-0-3:#F472B6;--age-4-8:#FB923C;--age-9-12:#34D399;--age-teens:#60A5FA;--sidebar-w:340px;--bg-panel:#FFFFFF;--bg-hover:#F8FAFC;--border:#E2E8F0;--text-dark:#0F172A;--text-mid:#475569;--text-light:#94A3B8;--shadow-sm:0 1px 3px rgba(0,0,0,0.08);--shadow-md:0 4px 16px rgba(0,0,0,0.1);--shadow-lg:0 12px 40px rgba(0,0,0,0.15);--radius-sm:8px;--radius-md:12px;--radius-lg:16px}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Outfit',-apple-system,sans-serif;background:#F1F5F9;color:var(--text-dark);overflow:hidden;height:100vh;width:100vw}
.top-header{position:fixed;top:0;left:0;right:0;z-index:2500;height:56px;background:#FFF;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:16px;box-shadow:0 1px 4px rgba(0,0,0,0.06)}
.header-left{display:flex;align-items:center;gap:10px;flex-shrink:0}
.mobile-toggle-header{display:none;width:36px;height:36px;border-radius:8px;border:none;background:var(--bg-hover);cursor:pointer;font-size:18px;align-items:center;justify-content:center}
.header-logo{display:flex;align-items:center;gap:8px}
.header-logo .logo-icon{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#6366F1,#EC4899);display:flex;align-items:center;justify-content:center;font-size:17px;box-shadow:0 2px 6px rgba(99,102,241,0.25)}
.header-logo-text{font-size:13px;font-weight:800;line-height:1.15;white-space:nowrap}
.header-center{flex:1;display:flex;justify-content:center;align-items:center;max-width:520px;margin:0 auto;gap:8px}
.header-search-wrapper{position:relative;flex:1}
.search-autocomplete{display:none;position:absolute;top:100%;left:0;right:0;margin-top:4px;background:#FFF;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:1px solid var(--border);max-height:260px;overflow-y:auto;z-index:3000}
.search-autocomplete.open{display:block}
.search-ac-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;font-size:12.5px;font-weight:500;transition:background .1s}
.search-ac-item:hover{background:var(--bg-hover)}
.search-ac-item .ac-icon{font-size:16px;opacity:.5}
.search-ac-item .ac-main{font-weight:700;color:var(--text-dark)}
.search-ac-item .ac-sub{font-size:11px;color:var(--text-light);margin-left:6px}
.geolocate-btn{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--border);background:#FFF;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#6366F1;transition:all .2s;flex-shrink:0}
.geolocate-btn:hover{border-color:#6366F1;background:rgba(99,102,241,0.04);transform:scale(1.05)}
.header-search-wrapper{position:relative;width:100%}
.header-search-wrapper .search-input{width:100%;padding:9px 14px 9px 38px;border:1.5px solid var(--border);border-radius:20px;font-family:'Outfit',sans-serif;font-size:13px;font-weight:500;color:var(--text-dark);background:var(--bg-hover);outline:none;transition:all .2s}
.header-search-wrapper .search-input:focus{border-color:#6366F1;background:#FFF;box-shadow:0 0 0 3px rgba(99,102,241,0.1)}
.header-search-wrapper .search-icon-el{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:14px;opacity:.4;pointer-events:none}
.header-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.auth-btn{display:flex;align-items:center;gap:6px;padding:7px 16px;background:#FFF;border:1.5px solid var(--border);border-radius:20px;cursor:pointer;font-family:'Outfit',sans-serif;font-size:12.5px;font-weight:600;color:var(--text-dark);transition:all .15s;white-space:nowrap}
.auth-btn:hover{border-color:#6366F1;color:#6366F1;background:rgba(99,102,241,0.04)}
.auth-btn.logged-in{border-color:#22C55E;color:#166534;background:rgba(34,197,94,0.06)}
.auth-user-menu{position:relative}
.auth-dropdown{position:absolute;top:100%;right:0;margin-top:6px;background:#FFF;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:1px solid var(--border);min-width:180px;z-index:3000;display:none;overflow:hidden}
.auth-dropdown.open{display:block}
.auth-dropdown a{display:block;padding:10px 16px;font-size:12.5px;font-weight:600;color:var(--text-dark);text-decoration:none;transition:background .1s;cursor:pointer}
.auth-dropdown a:hover{background:var(--bg-hover)}
.auth-dropdown a.danger{color:#EF4444}
.auth-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,0.5);backdrop-filter:blur(4px);z-index:4000;justify-content:center;align-items:center}
.auth-overlay.open{display:flex}
.auth-modal{background:#FFF;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:400px;max-width:95vw;overflow:hidden}
.auth-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}
.auth-tabs{display:flex;gap:4px}
.auth-tab{padding:7px 16px;border:none;background:none;border-radius:8px;cursor:pointer;font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;color:var(--text-light);transition:all .15s}
.auth-tab.active{background:#6366F1;color:#FFF}
.auth-body{padding:20px}
.auth-submit{width:100%;padding:12px;border:none;border-radius:var(--radius-md);background:linear-gradient(135deg,#6366F1,#8B5CF6);color:#FFF;font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;margin-top:16px}
.auth-submit:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(99,102,241,0.3)}
.auth-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}
.auth-submit-green{background:linear-gradient(135deg,#22C55E,#16A34A)}
.auth-submit-green:hover{box-shadow:0 4px 12px rgba(34,197,94,0.3)}
.event-float-btn{display:flex;align-items:center;gap:8px;padding:10px 18px;background:linear-gradient(135deg,#F59E0B,#D97706);border-radius:24px;border:none;box-shadow:var(--shadow-md);cursor:pointer;font-family:'Outfit',sans-serif;font-size:13px;font-weight:700;color:#FFF;transition:all .2s;white-space:nowrap}
.event-float-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(245,158,11,0.4)}
.events-list{display:flex;flex-direction:column;gap:2px}
.ev-item{display:flex;align-items:center;gap:10px;padding:10px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s}
.ev-item:hover{background:var(--bg-hover)}
.ev-item-icon{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#F59E0B,#D97706);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;color:#FFF}
.ev-item-info{flex:1;min-width:0}
.ev-item-title{font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ev-item-meta{font-size:10px;color:var(--text-light);margin-top:2px}
.ev-item-badge{font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:0.5px;flex-shrink:0}
.ev-item-badge.public{background:rgba(34,197,94,0.1);color:#166534}
.ev-item-badge.private{background:rgba(239,68,68,0.1);color:#991B1B}
.ev-user-results{max-height:120px;overflow-y:auto;margin-top:4px}
.ev-user-result{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;transition:background .1s}
.ev-user-result:hover{background:var(--bg-hover)}
.ev-invitee-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.ev-invitee-tag{display:flex;align-items:center;gap:4px;padding:4px 10px;background:rgba(99,102,241,0.08);border:1px solid rgba(99,102,241,0.2);border-radius:12px;font-size:11px;font-weight:600;color:#4338CA}
.ev-invitee-tag .remove{cursor:pointer;font-size:14px;line-height:1;margin-left:2px;opacity:.6}
.ev-invitee-tag .remove:hover{opacity:1}
.ev-detail-hero{width:100%;height:160px;object-fit:cover;border-radius:var(--radius-sm);margin-bottom:14px}
.ev-detail-title{font-size:18px;font-weight:800;margin-bottom:6px}
.ev-detail-row{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text-mid);margin-bottom:6px}
.ev-detail-desc{font-size:13px;color:var(--text-mid);line-height:1.5;margin:14px 0;padding:12px;background:var(--bg-hover);border-radius:var(--radius-sm)}
.ev-detail-participants{margin-top:12px}
.ev-detail-participant{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:12px}
.ev-detail-avatar{width:28px;height:28px;border-radius:50%;background:#6366F1;color:#FFF;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;flex-shrink:0}
.notif-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;border-radius:9px;background:#EF4444;color:#FFF;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid #FFF;line-height:1}
.notif-badge-inline{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;border-radius:8px;background:#EF4444;color:#FFF;font-size:9px;font-weight:800;padding:0 4px;margin-left:6px;line-height:1}
.marker-private-badge{position:absolute;top:-4px;right:-6px;background:#6366F1;color:#FFF;font-size:8px;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid #FFF;z-index:1}
.popup-owner-actions{display:flex;gap:2px}
.popup-owner-actions button{border:none;background:none;cursor:pointer;font-size:14px;padding:2px 4px;border-radius:4px;opacity:.5;transition:all .15s}
.popup-owner-actions button:hover{opacity:1;background:rgba(0,0,0,0.05)}
.popup-private-tag{display:inline-block;padding:2px 7px;border-radius:4px;background:#6366F1;color:#FFF;font-size:9px;font-weight:700;letter-spacing:.3px}
.ev-new-badge{display:inline-block;padding:1px 6px;border-radius:4px;background:linear-gradient(135deg,#F59E0B,#EF4444);color:#FFF;font-size:8px;font-weight:800;letter-spacing:0.5px;vertical-align:middle;margin-left:4px;animation:pulse-new 2s ease-in-out infinite}
@keyframes pulse-new{0%,100%{opacity:1}50%{opacity:.6}}
.app-layout{display:flex;height:calc(100vh - 56px - 30px);width:100vw;margin-top:56px}
.app-layout.footer-expanded{height:calc(100vh - 56px - 64px)}
.app-footer{position:fixed;bottom:0;left:0;right:0;z-index:2500;background:#FFF;border-top:1px solid var(--border);display:flex;flex-direction:column;align-items:center;padding:6px 16px;box-shadow:0 -1px 4px rgba(0,0,0,0.06)}
.footer-actions{display:flex;gap:10px;align-items:center;justify-content:center;margin-bottom:4px}
.footer-copy{font-size:10px;color:var(--text-light);font-weight:500}
.footer-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:20px;border:none;cursor:pointer;font-family:'Outfit',sans-serif;font-size:12px;font-weight:700;transition:all .2s;white-space:nowrap}
.footer-event{background:linear-gradient(135deg,#F59E0B,#D97706);color:#FFF;box-shadow:0 2px 8px rgba(245,158,11,0.25)}
.footer-event:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(245,158,11,0.35)}
.footer-add{background:linear-gradient(135deg,#6366F1,#8B5CF6);color:#FFF;box-shadow:0 2px 8px rgba(99,102,241,0.25)}
.footer-add:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(99,102,241,0.35)}
.footer-fav{background:#FFF;border:1.5px solid var(--border);color:var(--text-dark)}
.footer-fav:hover{border-color:#EF4444;color:#EF4444}
.sidebar-title{font-size:15px;font-weight:800;color:var(--text-dark)}
.main-cat-row{display:flex;gap:8px}
.main-cat-btn{flex:1;padding:10px 12px;border-radius:var(--radius-md);border:1.5px solid var(--border);background:#FFF;cursor:pointer;font-family:'Outfit',sans-serif;font-size:12.5px;font-weight:700;color:var(--text-dark);transition:all .15s;text-align:center}
.main-cat-btn.active{border-color:#6366F1;background:rgba(99,102,241,0.06);color:#4338CA}
.main-cat-btn:not(.active){opacity:.5}
.sidebar{width:var(--sidebar-w);height:100%;background:var(--bg-panel);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;z-index:1000;box-shadow:2px 0 20px rgba(0,0,0,0.06)}
.sidebar-header{padding:20px 24px 16px;border-bottom:1px solid var(--border)}
.logo{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.logo-icon{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#6366F1,#EC4899);display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 2px 8px rgba(99,102,241,0.3)}
.logo-text{font-size:15px;font-weight:800;line-height:1.15}
.logo-text small{display:block;font-size:10px;font-weight:500;color:var(--text-light);letter-spacing:.5px;text-transform:uppercase;margin-top:1px}
.search-wrapper{position:relative}
.search-input{width:100%;padding:10px 14px 10px 38px;border:1.5px solid var(--border);border-radius:var(--radius-md);font-family:'Outfit',sans-serif;font-size:13.5px;font-weight:500;color:var(--text-dark);background:var(--bg-hover);outline:none;transition:all .2s}
.search-input:focus{border-color:#6366F1;background:#FFF;box-shadow:0 0 0 3px rgba(99,102,241,0.1)}
.search-input::placeholder{color:var(--text-light)}
.search-icon-el{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:15px;opacity:.4;pointer-events:none}
.sidebar-scroll{flex:1;overflow-y:auto}
.filter-section{padding:16px 20px;border-bottom:1px solid var(--border)}
.filter-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-light);margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.filter-section-title .reset-btn{font-size:10px;font-weight:600;color:#6366F1;cursor:pointer;text-transform:none;letter-spacing:0;border:none;background:none;padding:2px 6px;border-radius:4px;transition:all .15s;display:none}
.filter-section-title .reset-btn.visible{display:inline-block}
.filter-section-title .reset-btn:hover{background:rgba(99,102,241,0.08)}
.category-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.cat-btn{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius-md);background:#FFF;cursor:pointer;transition:all .2s;position:relative;overflow:hidden;font-family:'Outfit',sans-serif}
.cat-btn:hover{border-color:#CBD5E1;background:var(--bg-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.cat-btn.active{border-color:var(--c);background:var(--cbg)}
.cat-btn.active .cat-label{color:var(--c);font-weight:700}
.cat-icon{width:32px;height:32px;border-radius:4px;transform:rotate(45deg);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;border:2px solid #FFF;box-shadow:0 2px 6px rgba(0,0,0,0.2)}
.cat-icon span{transform:rotate(-45deg)}
.cat-label{font-size:12px;font-weight:600;color:var(--text-mid);line-height:1.2}
.cat-count{position:absolute;top:5px;right:8px;font-size:9px;font-weight:700;color:var(--text-light);background:var(--bg-hover);padding:1px 5px;border-radius:6px}
.cat-btn.active .cat-count{background:rgba(255,255,255,0.3);color:var(--c)}
.age-row{display:flex;gap:6px;flex-wrap:wrap}
.age-btn{padding:7px 14px;border-radius:20px;border:1.5px solid var(--border);background:#FFF;font-family:'Outfit',sans-serif;font-size:12px;font-weight:600;color:var(--text-mid);cursor:pointer;transition:all .2s;white-space:nowrap}
.age-btn:hover{border-color:#CBD5E1;transform:translateY(-1px)}
.age-btn.active{color:#FFF;border-color:transparent}
.age-btn[data-age="0-3"].active{background:var(--age-0-3)}
.age-btn[data-age="4-8"].active{background:var(--age-4-8)}
.age-btn[data-age="9-12"].active{background:var(--age-9-12)}
.age-btn[data-age="teens"].active{background:var(--age-teens)}
.weather-row{display:flex;gap:8px}
.weather-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;border-radius:var(--radius-md);border:1.5px solid var(--border);background:#FFF;cursor:pointer;font-family:'Outfit',sans-serif;font-size:12px;font-weight:600;color:var(--text-mid);transition:all .2s}
.weather-btn:hover{border-color:#CBD5E1}
.weather-btn.active{border-color:#3B82F6;background:rgba(59,130,246,0.06);color:#3B82F6}
.weather-btn .w-icon{font-size:18px}
.sidebar-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg-hover)}
.results-count{font-size:12px;font-weight:600;color:var(--text-mid)}
.results-count strong{color:var(--text-dark);font-weight:800;font-size:16px}
.map-area{flex:1;position:relative}
#map{width:100%;height:100%;z-index:1}
.leaflet-control-zoom{border:none!important;box-shadow:var(--shadow-md)!important;border-radius:var(--radius-md)!important;overflow:hidden}
.leaflet-control-zoom a{width:36px!important;height:36px!important;line-height:36px!important;font-size:18px!important;color:var(--text-dark)!important;border-bottom:1px solid var(--border)!important}
.leaflet-control-zoom a:hover{background:var(--bg-hover)!important}
.marker-container{background:none!important;border:none!important}
.marker-forza{display:flex;flex-direction:column;align-items:center;cursor:pointer;filter:drop-shadow(0 3px 6px rgba(0,0,0,0.35));transition:all .25s cubic-bezier(.34,1.56,.64,1)}
.marker-forza:hover{transform:scale(1.3) translateY(-4px);z-index:9999!important;filter:drop-shadow(0 6px 16px rgba(0,0,0,0.45))}
.marker-badge{width:36px;height:36px;border-radius:5px;transform:rotate(45deg);display:flex;align-items:center;justify-content:center;border:2.5px solid #FFF;position:relative}
.marker-badge span{transform:rotate(-45deg);font-size:16px;line-height:1}
.marker-tail{width:3px;height:10px;background:#FFF;margin-top:-3px;border-radius:0 0 2px 2px}
.marker-forza.pulse .marker-badge::after{content:'';position:absolute;inset:-6px;border-radius:7px;border:2px solid currentColor;opacity:0;animation:mp 2s ease-in-out infinite}
@keyframes mp{0%,100%{opacity:0;transform:scale(.9)}50%{opacity:.5;transform:scale(1.15)}}
.marker-forza.dimmed{opacity:.1;filter:grayscale(1);pointer-events:none;transform:scale(.65)}
.marker-fav{position:absolute;top:-4px;right:-4px;width:16px;height:16px;background:#FFF;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;transform:rotate(-45deg);box-shadow:0 1px 4px rgba(0,0,0,0.2);opacity:0;transition:all .2s;cursor:pointer;z-index:10}
.marker-forza:hover .marker-fav{opacity:1}
.marker-fav.active{opacity:1!important;background:var(--cat-fun)}
.leaflet-popup-content-wrapper{border-radius:var(--radius-lg)!important;box-shadow:var(--shadow-lg)!important;padding:0!important;overflow:hidden}
.leaflet-popup-content{margin:0!important;width:300px!important}
.leaflet-popup-tip{box-shadow:var(--shadow-md)!important}
.popup-card{font-family:'Outfit',sans-serif}
.popup-body{padding:16px 18px 18px}
.popup-cat-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#FFF;margin-bottom:8px}
.popup-title{font-size:17px;font-weight:800;line-height:1.2;margin-bottom:4px}
.popup-address{font-size:11.5px;color:var(--text-light);margin-bottom:14px}
.popup-stats{display:flex;gap:6px;margin-bottom:14px}
.popup-stat{flex:1;text-align:center;padding:8px 4px;background:#F8FAFC;border-radius:var(--radius-sm);border:1px solid var(--border)}
.popup-stat-icon{font-size:18px;display:block;margin-bottom:2px}
.popup-stat-val{font-size:14px;font-weight:800;display:block}
.popup-stat-label{font-size:8.5px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-light)}
.popup-ages{display:flex;gap:5px;margin-bottom:14px;flex-wrap:wrap}
.popup-age-tag{padding:3px 10px;border-radius:12px;font-size:10.5px;font-weight:600;background:#F1F5F9;color:var(--text-mid);border:1px solid var(--border)}
.popup-age-tag.match{background:rgba(34,197,94,0.08);border-color:rgba(34,197,94,0.3);color:#166534}
.popup-access-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.popup-access-tag{font-size:10px;font-weight:600;color:var(--text-mid);display:flex;align-items:center;gap:3px}
.popup-desc{font-size:12px;color:#64748B;line-height:1.5;margin-bottom:16px}
.popup-cta{width:100%;padding:12px;border:none;border-radius:var(--radius-md);background:linear-gradient(135deg,#6366F1,#8B5CF6);color:#FFF;font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px rgba(99,102,241,0.3);display:flex;align-items:center;justify-content:center;gap:8px}
.popup-cta:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(99,102,241,0.4)}
.radar-btn-map{position:absolute;top:16px;right:16px;z-index:1000;width:44px;height:44px;border-radius:50%;border:none;background:#FFF;box-shadow:var(--shadow-md);cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.radar-btn-map:hover{transform:scale(1.1);box-shadow:var(--shadow-lg)}
.fav-float-btn{display:flex;align-items:center;gap:8px;padding:10px 18px;background:#FFF;border-radius:24px;border:none;box-shadow:var(--shadow-md);cursor:pointer;font-family:'Outfit',sans-serif;font-size:13px;font-weight:700;color:var(--text-dark);transition:all .2s}
.fav-float-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.fav-float-count{background:var(--cat-fun);color:#FFF;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800}
.fav-panel{position:absolute;bottom:72px;right:16px;z-index:1000;width:300px;max-height:350px;overflow-y:auto;background:#FFF;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border);transform:translateY(10px);opacity:0;pointer-events:none;transition:all .25s cubic-bezier(.34,1.56,.64,1)}
.fav-panel.open{transform:translateY(0);opacity:1;pointer-events:auto}
.fav-panel-header{padding:14px 16px;border-bottom:1px solid var(--border);font-size:13px;font-weight:700;display:flex;align-items:center;gap:6px}
.fav-item{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:1px solid #F1F5F9;cursor:pointer;transition:background .15s}
.fav-item:hover{background:var(--bg-hover)}
.fav-item:last-child{border-bottom:none}
.fav-item-icon{width:30px;height:30px;border-radius:4px;transform:rotate(45deg);display:flex;align-items:center;justify-content:center;font-size:13px;border:2px solid #FFF;box-shadow:0 2px 6px rgba(0,0,0,0.15);flex-shrink:0}
.fav-item-icon span{transform:rotate(-45deg)}
.fav-item-info{flex:1;min-width:0}
.fav-item-name{font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fav-item-meta{font-size:10px;color:var(--text-light);margin-top:1px}
.fav-empty{padding:24px;text-align:center;font-size:12px;color:var(--text-light)}
.legend-bar{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:1000;display:flex;align-items:center;gap:4px;padding:6px 8px;background:rgba(255,255,255,0.92);backdrop-filter:blur(12px);border-radius:14px;box-shadow:var(--shadow-md);border:1px solid rgba(0,0,0,0.06)}
.legend-item{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:8px;font-size:10px;font-weight:600;color:var(--text-mid)}
.legend-dot{width:10px;height:10px;border-radius:3px;transform:rotate(45deg);flex-shrink:0}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#CBD5E1;border-radius:4px}
.mobile-toggle{display:none;position:absolute;top:16px;left:16px;z-index:1001;width:44px;height:44px;border-radius:50%;border:none;background:#FFF;box-shadow:var(--shadow-md);cursor:pointer;font-size:20px;align-items:center;justify-content:center}
.bottom-actions{display:none}
.add-poi-float-btn{display:flex;align-items:center;gap:8px;padding:10px 18px;background:linear-gradient(135deg,#6366F1,#8B5CF6);border-radius:24px;border:none;box-shadow:var(--shadow-md);cursor:pointer;font-family:'Outfit',sans-serif;font-size:13px;font-weight:700;color:#FFF;transition:all .2s}
.add-poi-float-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(99,102,241,0.4)}
.add-poi-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,0.5);backdrop-filter:blur(4px);z-index:3000;justify-content:center;align-items:center}
.add-poi-overlay.open{display:flex}
.add-poi-modal{background:#FFF;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:520px;max-width:95vw;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}
.add-poi-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-size:15px;font-weight:800;font-family:'Outfit',sans-serif}
.add-poi-close{width:32px;height:32px;border-radius:50%;border:none;background:var(--bg-hover);cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;color:var(--text-mid);transition:all .15s}
.add-poi-close:hover{background:#E2E8F0;color:var(--text-dark)}
.add-poi-body{padding:20px;overflow-y:auto;flex:1}
.add-poi-row{display:flex;gap:12px;margin-bottom:12px}
.add-poi-row.checkboxes{flex-wrap:wrap;gap:8px 16px;margin-bottom:14px}
.add-poi-row.wrap{flex-wrap:wrap}
.add-poi-field{flex:1;min-width:0}
.add-poi-field.full{flex:1 1 100%}
.add-poi-field label{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-light);margin-bottom:4px}
.add-poi-field input,.add-poi-field select{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:'Outfit',sans-serif;font-size:13px;font-weight:500;color:var(--text-dark);background:#FFF;outline:none;transition:border-color .15s}
.add-poi-field input:focus,.add-poi-field select:focus{border-color:#6366F1}
.add-poi-check{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text-mid);cursor:pointer;white-space:nowrap}
.add-poi-check input[type="checkbox"]{width:16px;height:16px;accent-color:#6366F1;cursor:pointer}
.add-poi-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-light);margin-bottom:8px}
.add-poi-submit{width:100%;padding:13px;border:none;border-radius:var(--radius-md);background:linear-gradient(135deg,#22C55E,#16A34A);color:#FFF;font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px rgba(34,197,94,0.3);margin-top:8px}
.add-poi-submit:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(34,197,94,0.4)}
.add-poi-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}
.add-poi-error{color:#EF4444;font-size:12px;font-weight:600;margin-top:4px;min-height:18px}
.add-poi-success{color:#22C55E;font-size:12px;font-weight:600;margin-top:4px}
.coords-display{position:absolute;bottom:24px;left:16px;z-index:1000;padding:6px 12px;background:rgba(15,23,42,0.75);backdrop-filter:blur(8px);color:#E2E8F0;font-family:'Outfit',monospace;font-size:11px;font-weight:500;border-radius:8px;pointer-events:none;letter-spacing:0.3px}
.input-with-btn{display:flex;gap:6px}
.input-with-btn input{flex:1}
.geocode-btn{width:40px;height:38px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:#FFF;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.geocode-btn:hover{background:#F1F5F9;border-color:#6366F1}
.add-poi-hint{font-size:10px;color:var(--text-light);margin-top:3px;min-height:14px}
.add-poi-field select:disabled{background:#F1F5F9;color:var(--text-mid);cursor:default}
.leaflet-contextmenu{background:#FFF;border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,0.15);border:1px solid #E2E8F0;padding:4px 0;font-family:'Outfit',sans-serif;font-size:13px;min-width:180px}
.leaflet-contextmenu a{display:block;padding:8px 16px;color:#0F172A;text-decoration:none;font-weight:500;transition:background .1s}
.leaflet-contextmenu a:hover{background:#F1F5F9}
@media(max-width:768px){.sidebar{position:fixed;left:0;top:56px;z-index:2000;bottom:30px;height:auto;transform:translateX(-100%);transition:transform .3s}.app-layout.footer-expanded .sidebar{bottom:64px}.sidebar.open{transform:translateX(0)}.mobile-toggle{display:none}.mobile-toggle-header{display:flex}.header-logo-text{display:none}.legend-bar{display:none}.footer-btn{padding:8px 10px;font-size:11px}}
