.citymap{width:min(100%,980px);height:100%;font-family:Source Code Pro,sans-serif;position:relative;overflow:hidden}.citymap__img{width:100%;height:auto;animation:18s ease-in-out infinite cityBreath;display:block}@keyframes cityBreath{0%,to{transform:scale(1)}50%{transform:scale(1.015)}}.district-label{left:var(--x);top:var(--y);z-index:4;letter-spacing:.12em;text-transform:uppercase;color:#ebebf5b3;cursor:help;-webkit-user-select:none;user-select:none;padding:20px;font-size:13px;font-weight:650;position:absolute;transform:translate(-50%,-50%)}.district-label:after{content:"";opacity:0;filter:blur(2px);pointer-events:none;z-index:-1;background:radial-gradient(circle,#6e92ff3d 0%,#6e7fff1f 35%,#6ea3fffc 70%);width:180px;height:180px;transition:opacity .22s,transform .22s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(.95)}.district-label:hover:after{opacity:1;transform:translate(-50%,-50%)scale(1.25)}.district-tooltip{text-transform:none;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);color:#ebebf5f2;opacity:0;pointer-events:none;background:#0a0a0a33;border-radius:20px;min-width:220px;max-width:280px;padding:10px 12px;font-family:Roboto,sans-serif;font-size:11px;font-weight:400;line-height:1.25;transition:opacity .18s,transform .18s;position:absolute;top:90%;left:50%;transform:translate(-50%);box-shadow:0 1px 10px #0000008c;z-index:999!important}.district-label:hover .district-tooltip{opacity:1;transform:translate(-50%)translateY(4px)}.district-tooltip strong{margin-bottom:4px;font-size:13px;font-weight:400;display:block}.district-tooltip p{opacity:.8;margin:0 0 6px;font-family:Roboto,sans-serif}.hotspot{left:var(--x);top:var(--y);--accent:37, 99, 235;z-index:1;cursor:crosshair;border-radius:999px;width:12px;height:12px;position:absolute;transform:translate(-50%,-50%)}.hotspot.danger,.hotspot.police{--accent:37, 99, 235}.hotspot:before{content:"";border-radius:inherit;background:rgb(var(--accent));box-shadow:0 0 8px rgba(var(--accent), .85), 0 0 22px rgba(var(--accent), .45);position:absolute;inset:0}.hotspot:after{content:"";background:rgba(var(--accent), .22);border-radius:999px;width:12px;height:12px;animation:2.8s ease-out infinite pulseZone;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes pulseZone{0%{opacity:.45;width:12px;height:12px}70%{opacity:.14;width:90px;height:90px}to{opacity:0;width:120px;height:120px}}.hotspot:hover:before{box-shadow:0 0 12px rgba(var(--accent), .95), 0 0 36px rgba(var(--accent), .55)}.hotspot:hover:after{background:rgba(var(--accent), .3)}.hotspot__tip{color:#ebebf5f2;opacity:0;pointer-events:none;white-space:nowrap;z-index:20;background:#0a0b10eb;border:1px solid #a0bcff2e;border-radius:10px;padding:8px 10px;font-size:12px;line-height:1.15;transition:opacity .18s,transform .18s;position:absolute;top:50%;left:18px;transform:translateY(-50%);box-shadow:0 10px 30px #00000073}.hotspot__tip strong{margin-bottom:2px;font-weight:650;display:block}.hotspot__tip em{opacity:.75;font-style:normal;display:block}.hotspot:hover .hotspot__tip{opacity:1;transform:translateY(-50%)translate(4px)}@media (max-width:520px){.district-tooltip{min-width:180px;max-width:220px}.hotspot__tip{white-space:normal;max-width:200px}}
