:root{--black:#0a0a0a;--black2:#111111;--card-bg:#161616;--red:#e8142a;--red-dark:#b80f20;--white:#fff;--white70:rgba(255,255,255,.7);--white40:rgba(255,255,255,.4);--white10:rgba(255,255,255,.08);--gold:#d4a847;--green:#22c55e;--border:rgba(255,255,255,.08);--radius:10px;}
*{margin:0;padding:0;box-sizing:border-box;}
body{background:var(--black);color:var(--white);font-family:'Inter',sans-serif;font-size:14px;height:100vh;overflow:hidden;display:flex;flex-direction:column;}
header{flex-shrink:0;}
.nav-tabs{flex-shrink:0;}

.map-filters{background:var(--black2);border-bottom:1px solid var(--border);padding:8px 16px;flex-shrink:0;display:flex;flex-direction:row;gap:8px;overflow-x:auto;scrollbar-width:none;align-items:center;-webkit-overflow-scrolling:touch;max-width:100vw;}
.map-filters::-webkit-scrollbar{display:none;}
.filter-pill{display:flex;align-items:center;gap:4px;background:var(--white10);border:1px solid var(--border);border-radius:20px;padding:5px 12px;font-size:12px;font-weight:500;white-space:nowrap;cursor:pointer;transition:all .2s;flex-shrink:0;color:var(--white70);}
.filter-pill:hover,.filter-pill.active{background:var(--red);border-color:var(--red);color:var(--white);}
.filter-divider{width:1px;height:20px;background:var(--border);flex-shrink:0;}
.filter-search{display:flex;align-items:center;gap:6px;background:var(--white10);border:1px solid var(--border);border-radius:20px;padding:5px 12px;flex-shrink:0;position:relative;}
.filter-search input{background:none;border:none;outline:none;color:var(--white);font-family:'Inter',sans-serif;font-size:12px;width:130px;}
.filter-search input::placeholder{color:var(--white40);}
.main{flex:1;display:flex;overflow:hidden;position:relative;z-index:0;}
#map{flex:1;}
.leaflet-container{background:#1a1a1a!important;}
.emoji-pin{font-size:24px;cursor:pointer;filter:drop-shadow(0 2px 6px rgba(0,0,0,.9));transition:transform .15s;line-height:1;display:block;}
.emoji-pin:hover{transform:scale(1.35);}
.sidebar{width:300px;flex-shrink:0;background:var(--black2);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;}
.sidebar-header{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.sidebar-title{font-family:'Inter',sans-serif;font-size:15px;font-weight:600;letter-spacing:0;}
.result-count{font-size:11px;color:var(--white40);}
.sidebar-list{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent;}
.list-item{padding:10px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s;display:flex;gap:10px;align-items:flex-start;}
.list-item:hover{background:var(--white10);}
.list-item.active{background:rgba(232,20,42,.1);border-left:3px solid var(--red);}
.list-thumb{width:50px;height:50px;border-radius:6px;object-fit:cover;flex-shrink:0;background:var(--black);}
.list-info{flex:1;min-width:0;}
.list-name{font-size:12px;font-weight:600;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.list-meta{font-size:10px;color:var(--white40);margin-bottom:3px;}
.list-footer{display:flex;align-items:center;gap:5px;flex-wrap:wrap;}
.list-rating{font-size:10px;font-weight:600;color:var(--gold);}
.list-visits{font-size:9px;color:var(--white40);background:var(--white10);padding:1px 5px;border-radius:8px;}
.badge{display:inline-flex;padding:1px 5px;border-radius:3px;font-size:8px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;}
.badge-sponsored{background:linear-gradient(135deg,#d4a847,#f5d784,#d4a847);color:#1a1000;text-shadow:0 1px 0 rgba(255,255,255,.25);box-shadow:0 1px 4px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.3);}
.badge-deal{background:rgba(34,197,94,.9);color:#000;}
.badge-new{background:rgba(99,102,241,.9);color:#fff;}
.badge-verified{background:rgba(59,130,246,.92);color:#fff;}
/* Popup overlay on pin click */
.map-popup{position:absolute;z-index:500;bottom:80px;left:50%;transform:translateX(-50%);width:calc(100% - 32px);max-width:300px;display:none;pointer-events:none;}
.map-popup.show{display:block;pointer-events:auto;}
.popup-card{background:var(--black2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.8);position:relative;}
.popup-img{width:100%;height:120px;object-fit:cover;display:block;}
.popup-img-overlay{position:absolute;top:0;left:0;right:0;height:120px;display:flex;align-items:flex-start;justify-content:flex-end;gap:6px;padding:8px;}
.popup-close{background:rgba(0,0,0,.5);backdrop-filter:blur(4px);border:none;border-radius:50%;width:32px;height:32px;color:var(--white);cursor:pointer;font-size:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:background .2s;line-height:1;}.popup-close:hover{background:var(--red);}
.popup-heart{background:rgba(0,0,0,.5);backdrop-filter:blur(4px);border:none;border-radius:50%;width:32px;height:32px;color:var(--white);cursor:pointer;font-size:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1;}.popup-heart:hover,.popup-heart.saved{background:var(--red);color:#fff;}
.popup-body{padding:10px 12px 12px;}
.popup-name{font-size:14px;font-weight:700;margin-bottom:4px;}
.popup-meta{font-size:11px;color:var(--white40);margin-bottom:8px;}
.popup-stats{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.popup-rating{font-size:12px;font-weight:700;color:var(--gold);}
.popup-visits{font-size:11px;color:var(--white40);}
.popup-badges{display:flex;gap:4px;flex:1;justify-content:flex-end;}
.popup-actions{display:flex;gap:8px;}
.btn-view{flex:1;background:var(--red);color:var(--white);border:none;border-radius:6px;padding:8px;font-size:12px;font-weight:700;font-family:'Inter',sans-serif;cursor:pointer;text-align:center;text-decoration:none;display:block;}
/* Bottom scrollable card panel (mobile) */
.map-cards-panel{position:fixed;bottom:56px;left:0;right:0;z-index:400;display:flex;gap:10px;padding:8px 12px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;background:linear-gradient(0deg,rgba(10,10,10,.95) 0%,rgba(10,10,10,.75) 80%,transparent 100%);}
.map-cards-panel::-webkit-scrollbar{display:none;}
.map-card{flex-shrink:0;width:220px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;gap:0;text-decoration:none;color:inherit;transition:border-color .2s;cursor:pointer;}
.map-card:hover,.map-card.active{border-color:var(--red);}
.map-card-img{width:72px;height:72px;object-fit:cover;flex-shrink:0;background:#2a1a1a;}
.map-card-body{padding:8px 10px;flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;}
.map-card-name{font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px;}
.map-card-meta{font-size:10px;color:var(--white40);margin-bottom:3px;}
.map-card-foot{display:flex;align-items:center;gap:6px;}
.map-card-rating{font-size:10px;font-weight:700;color:var(--gold);}
.map-card-visits{font-size:9px;color:var(--white40);}
@media(min-width:768px){
  .map-cards-panel{display:none!important;}
}
@media(max-width:767px){
  .sidebar{display:none;}
  .map-popup{bottom:148px;width:calc(100% - 24px);}
  .map-filters{padding:8px 12px;}
}:root{--black:#0a0a0a;--black2:#111111;--card-bg:#161616;--red:#e8142a;--red-dark:#b80f20;--white:#fff;--white70:rgba(255,255,255,.7);--white40:rgba(255,255,255,.4);--white10:rgba(255,255,255,.08);--gold:#d4a847;--green:#22c55e;--border:rgba(255,255,255,.08);--radius:10px;}
*{margin:0;padding:0;box-sizing:border-box;}
body{background:var(--black);color:var(--white);font-family:'Inter',sans-serif;font-size:14px;height:100vh;overflow:hidden;display:flex;flex-direction:column;}
header{flex-shrink:0;}
.nav-tabs{flex-shrink:0;}

.map-filters{background:var(--black2);border-bottom:1px solid var(--border);padding:8px 16px;flex-shrink:0;display:flex;flex-direction:row;gap:8px;overflow-x:auto;scrollbar-width:none;align-items:center;-webkit-overflow-scrolling:touch;max-width:100vw;}
.map-filters::-webkit-scrollbar{display:none;}
.filter-pill{display:flex;align-items:center;gap:4px;background:var(--white10);border:1px solid var(--border);border-radius:20px;padding:5px 12px;font-size:12px;font-weight:500;white-space:nowrap;cursor:pointer;transition:all .2s;flex-shrink:0;color:var(--white70);}
.filter-pill:hover,.filter-pill.active{background:var(--red);border-color:var(--red);color:var(--white);}
.filter-divider{width:1px;height:20px;background:var(--border);flex-shrink:0;}
.filter-search{display:flex;align-items:center;gap:6px;background:var(--white10);border:1px solid var(--border);border-radius:20px;padding:5px 12px;flex-shrink:0;position:relative;}
.filter-search input{background:none;border:none;outline:none;color:var(--white);font-family:'Inter',sans-serif;font-size:12px;width:130px;}
.filter-search input::placeholder{color:var(--white40);}
.main{flex:1;display:flex;overflow:hidden;position:relative;z-index:0;}
#map{flex:1;}
.leaflet-container{background:#1a1a1a!important;}
.emoji-pin{font-size:24px;cursor:pointer;filter:drop-shadow(0 2px 6px rgba(0,0,0,.9));transition:transform .15s;line-height:1;display:block;}
.emoji-pin:hover{transform:scale(1.35);}
.sidebar{width:300px;flex-shrink:0;background:var(--black2);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;}
.sidebar-header{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.sidebar-title{font-family:'Inter',sans-serif;font-size:15px;font-weight:600;letter-spacing:0;}
.result-count{font-size:11px;color:var(--white40);}
.sidebar-list{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent;}
.list-item{padding:10px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s;display:flex;gap:10px;align-items:flex-start;}
.list-item:hover{background:var(--white10);}
.list-item.active{background:rgba(232,20,42,.1);border-left:3px solid var(--red);}
.list-thumb{width:50px;height:50px;border-radius:6px;object-fit:cover;flex-shrink:0;background:var(--black);}
.list-info{flex:1;min-width:0;}
.list-name{font-size:12px;font-weight:600;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.list-meta{font-size:10px;color:var(--white40);margin-bottom:3px;}
.list-footer{display:flex;align-items:center;gap:5px;flex-wrap:wrap;}
.list-rating{font-size:10px;font-weight:600;color:var(--gold);}
.list-visits{font-size:9px;color:var(--white40);background:var(--white10);padding:1px 5px;border-radius:8px;}
.badge{display:inline-flex;padding:1px 5px;border-radius:3px;font-size:8px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;}
.badge-sponsored{background:linear-gradient(135deg,#d4a847,#f5d784,#d4a847);color:#1a1000;text-shadow:0 1px 0 rgba(255,255,255,.25);box-shadow:0 1px 4px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.3);}
.badge-deal{background:rgba(34,197,94,.9);color:#000;}
.badge-new{background:rgba(99,102,241,.9);color:#fff;}
.badge-verified{background:rgba(59,130,246,.92);color:#fff;}
/* Popup overlay on pin click */
.map-popup{position:absolute;z-index:500;bottom:80px;left:50%;transform:translateX(-50%);width:calc(100% - 32px);max-width:300px;display:none;pointer-events:none;}
.map-popup.show{display:block;pointer-events:auto;}
.popup-card{background:var(--black2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.8);position:relative;}
.popup-img{width:100%;height:120px;object-fit:cover;display:block;}
.popup-img-overlay{position:absolute;top:0;left:0;right:0;height:120px;display:flex;align-items:flex-start;justify-content:flex-end;gap:6px;padding:8px;}
.popup-close{background:rgba(0,0,0,.5);backdrop-filter:blur(4px);border:none;border-radius:50%;width:32px;height:32px;color:var(--white);cursor:pointer;font-size:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:background .2s;line-height:1;}.popup-close:hover{background:var(--red);}
.popup-heart{background:rgba(0,0,0,.5);backdrop-filter:blur(4px);border:none;border-radius:50%;width:32px;height:32px;color:var(--white);cursor:pointer;font-size:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1;}.popup-heart:hover,.popup-heart.saved{background:var(--red);color:#fff;}
.popup-body{padding:10px 12px 12px;}
.popup-name{font-size:14px;font-weight:700;margin-bottom:4px;}
.popup-meta{font-size:11px;color:var(--white40);margin-bottom:8px;}
.popup-stats{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.popup-rating{font-size:12px;font-weight:700;color:var(--gold);}
.popup-visits{font-size:11px;color:var(--white40);}
.popup-badges{display:flex;gap:4px;flex:1;justify-content:flex-end;}
.popup-actions{display:flex;gap:8px;}
.btn-view{flex:1;background:var(--red);color:var(--white);border:none;border-radius:6px;padding:8px;font-size:12px;font-weight:700;font-family:'Inter',sans-serif;cursor:pointer;text-align:center;text-decoration:none;display:block;}
/* Bottom scrollable card panel (mobile) */
.map-cards-panel{position:fixed;bottom:56px;left:0;right:0;z-index:400;display:flex;gap:10px;padding:8px 12px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;background:linear-gradient(0deg,rgba(10,10,10,.95) 0%,rgba(10,10,10,.75) 80%,transparent 100%);}
.map-cards-panel::-webkit-scrollbar{display:none;}
.map-card{flex-shrink:0;width:220px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;gap:0;text-decoration:none;color:inherit;transition:border-color .2s;cursor:pointer;}
.map-card:hover,.map-card.active{border-color:var(--red);}
.map-card-img{width:72px;height:72px;object-fit:cover;flex-shrink:0;background:#2a1a1a;}
.map-card-body{padding:8px 10px;flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;}
.map-card-name{font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px;}
.map-card-meta{font-size:10px;color:var(--white40);margin-bottom:3px;}
.map-card-foot{display:flex;align-items:center;gap:6px;}
.map-card-rating{font-size:10px;font-weight:700;color:var(--gold);}
.map-card-visits{font-size:9px;color:var(--white40);}
@media(min-width:768px){
  .map-cards-panel{display:none!important;}
}
@media(max-width:767px){
  .sidebar{display:none;}
  .map-popup{bottom:148px;width:calc(100% - 24px);}
  .map-filters{padding:8px 12px;}
}
