:root{--bg:#0f1419;--panel:#171d26;--panel2:#1e2733;--line:#2a3441;--txt:#e6edf3;--muted:#8b98a8;--accent:#3fb6ff;--green:#39d98a;--amber:#ffc14d}
*{box-sizing:border-box}
html,body{margin:0;height:100%;font-family:-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--txt)}
#app{display:flex;height:100vh;overflow:hidden}
#side{width:340px;min-width:340px;background:var(--panel);border-right:1px solid var(--line);display:flex;flex-direction:column}
#side header{padding:16px 18px;border-bottom:1px solid var(--line)}
#side h1{margin:0;font-size:18px}#side h1 span{color:var(--accent)}
.sub{color:var(--muted);font-size:12px;margin-top:4px;line-height:1.4}
#crumbs{display:flex;flex-wrap:wrap;gap:6px;padding:10px 18px;border-bottom:1px solid var(--line);font-size:13px;align-items:center}
#crumbs a{color:var(--accent);cursor:pointer}#crumbs .sep{color:var(--muted)}
#list{flex:1;overflow-y:auto;padding:8px 10px}
.row{padding:10px 12px;border-radius:9px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:8px}
.row:hover{background:var(--panel2)}.row .ct{font-size:12px;color:var(--muted);background:#23303d;padding:2px 8px;border-radius:20px}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:7px}.dot.v{background:var(--green)}.dot.c{background:var(--amber)}
#map{flex:1;height:100%}
#detail{position:absolute;right:14px;top:14px;width:440px;max-width:calc(100vw - 28px);background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:0 12px 40px rgba(0,0,0,.5);display:none;z-index:1000;overflow:hidden}
#detail .thumb{height:300px;background:#0a0e13;display:flex;align-items:center;justify-content:center;position:relative;border-bottom:1px solid var(--line)}
#detail .thumb img{width:100%;height:100%;object-fit:cover}
#detail .thumb .media{width:100%;height:100%;border:0;display:block;object-fit:cover;background:#000}
#detail .badge{position:absolute;left:10px;top:10px;font-size:11px;background:rgba(0,0,0,.6);padding:3px 9px;border-radius:20px}
#detail .live{position:absolute;right:10px;top:10px;display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;letter-spacing:.5px;color:#fff;background:rgba(0,0,0,.6);padding:3px 9px;border-radius:20px}
#detail .live i{width:8px;height:8px;border-radius:50%;background:#ff4d4f;display:inline-block;animation:livepulse 1.4s ease-in-out infinite}
@keyframes livepulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(255,77,79,.7)}50%{opacity:.6;box-shadow:0 0 0 6px rgba(255,77,79,0)}}
#detail .thumb img.fade{animation:framefade .5s ease}
@keyframes framefade{from{opacity:.45}to{opacity:1}}
#detail .body{padding:14px 16px}#detail h2{margin:0 0 2px;font-size:16px}
#detail .loc{color:var(--muted);font-size:13px;margin-bottom:12px}
.kv{display:flex;font-size:13px;padding:5px 0;border-top:1px solid var(--line)}.kv .k{width:96px;color:var(--muted)}.kv .v{flex:1}
.pill{font-size:11px;padding:2px 8px;border-radius:20px;background:#23303d}
.actions{margin-top:14px}.btn{display:block;text-align:center;padding:9px;border-radius:9px;font-size:13px;cursor:pointer;background:var(--accent);color:#06243a;font-weight:600;text-decoration:none}
#close{position:absolute;right:8px;top:8px;width:26px;height:26px;border-radius:50%;background:rgba(0,0,0,.5);border:none;color:#fff;cursor:pointer;z-index:2}
#stats{padding:10px 18px;border-top:1px solid var(--line);font-size:12px;color:var(--muted);display:flex;justify-content:space-between}
.legend{position:absolute;left:14px;bottom:14px;background:rgba(23,29,38,.92);border:1px solid var(--line);border-radius:10px;padding:8px 12px;font-size:12px;z-index:1000}
.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:var(--panel);color:var(--txt)}
