#jhb-map{--ink:#0f172a;--mapH:clamp(520px,56vw,900px);--house-svg:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%230b1220' d='M12 3 3 10h2v9h5v-6h4v6h5v-9h2L12 3z'/></svg>");font-family:Nunito,Arial,sans-serif;color:var(--ink);position:relative;isolation:isolate;scroll-margin-top:96px;margin-top:0;margin-bottom:clamp(34px,5vw,68px)}
#jhb-map *{box-sizing:border-box}
@media (min-width:1280px){#jhb-map{--mapH:clamp(620px,56vw,660px)}}
@media (max-width:1024px){#jhb-map{--mapH:min(82vh,128vw)}}
@media (max-width:600px){#jhb-map{--mapH:min(88vh,150vw)}}
#jhb-map .brb-map-wrap{position:relative;max-width:1200px;margin:0 auto}
#jhb-map .brb-map-stagehead{max-width:860px;margin:0 auto 26px;padding:0 20px;text-align:center}
#jhb-map .brb-map-stagehead__eyebrow{display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;border-radius:999px;background:#fff;border:1px solid #efe4da;color:#7a4b29;font-size:12px;font-weight:800;letter-spacing:.2px;box-shadow:0 6px 16px rgba(0,0,0,.05)}
#jhb-map .brb-map-stagehead__title{margin:16px 0 10px;font-size:clamp(30px,3.2vw,44px);line-height:1.08;font-weight:900;color:#17221e;text-wrap:balance}
#jhb-map .brb-map-stagehead__text{max-width:760px;margin:0 auto 16px;color:#5d6a64;font-size:15.5px;line-height:1.65}
#jhb-map .brb-map-legend{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}
#jhb-map .brb-map-legend__item{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:999px;background:#fff;border:1px solid #e7eceb;color:#25313d;font-size:13px;font-weight:800;box-shadow:0 6px 16px rgba(16,24,40,.05)}
#jhb-map .brb-map-legend__dot{width:10px;height:10px;border-radius:50%;background:#fff;border:2px solid #111;display:inline-block}
#jhb-map .brb-map-legend__dot--admin{background:#111;border-color:#111}
#jhb-map .brb-map-legend__icon{width:14px;height:14px;display:inline-block;flex:0 0 14px}
#jhb-map .brb-map-legend__icon--admin{background:var(--house-svg) no-repeat center/contain}
#jhb-map .brb-map-canvas{position:relative;width:100%;height:var(--mapH);background:transparent;overflow:visible;border-radius:22px}
#jhb-map .map{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;pointer-events:none;z-index:1}
#jhb-map #bounds{position:absolute;inset:0;z-index:2}
#jhb-map #inner{position:absolute;left:0;top:0;width:100%;height:100%;z-index:3}
#jhb-map .layer{position:absolute;inset:0;z-index:4;pointer-events:none}
#jhb-map .layer .brb-pop,#jhb-map .layer .hint{pointer-events:auto}
@keyframes jhb-pulse-blue{0%{box-shadow:0 0 0 0 rgba(37,99,235,.28)}70%{box-shadow:0 0 0 16px rgba(37,99,235,0)}100%{box-shadow:0 0 0 0 rgba(37,99,235,0)}}
#jhb-map .marker{position:absolute;left:var(--x);top:var(--y);transform:translate(-50%,-50%);width:var(--size,20px);height:var(--size,20px);padding:0;margin:0;border:2px solid #111;border-radius:50%;display:inline-grid;place-items:center;cursor:pointer;user-select:none;touch-action:manipulation;appearance:none;-webkit-appearance:none;background:#fff;animation:jhb-pulse-blue 2.1s infinite;box-shadow:0 1px 6px rgba(0,0,0,.18);z-index:5;transition:transform .18s ease,box-shadow .18s ease}
#jhb-map .marker:hover,#jhb-map .marker.is-active{transform:translate(-50%,-50%) scale(1.12);box-shadow:0 8px 20px rgba(16,24,40,.22)}
#jhb-map .marker:focus{outline:2px solid #2563eb;outline-offset:2px}
@media (max-width:600px){#jhb-map .marker{--size:15px;border-width:1.8px}}
#jhb-map .marker-admin{background:#fff;border-color:#111;color:#111}
#jhb-map .marker-admin .i-admin{width:75%;height:75%;background:var(--house-svg) no-repeat center/contain;display:block}
#jhb-map .brb-pop{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);min-width:280px;max-width:390px;background:#fff;border:1px solid rgba(2,6,23,.08);border-radius:18px;box-shadow:0 24px 64px rgba(16,24,40,.14),0 10px 28px rgba(16,24,40,.12);padding:16px;text-align:center;z-index:10}
#jhb-map .brb-pop .logo{width:72px;height:72px;border-radius:50%;display:grid;place-items:center;margin:0 auto 8px;background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.12), inset 0 0 0 7px #fff;border:1px solid rgba(2,6,23,.08);overflow:hidden}
#jhb-map .brb-pop .logo img{max-width:80%;max-height:80%;object-fit:contain;display:block}
#jhb-map .brb-pop .hd{font-weight:900;font-size:18px;line-height:1.2;margin-top:2px;letter-spacing:.1px}
#jhb-map .brb-pop .sub{font-size:13px;color:#64748b;margin-top:2px}
#jhb-map .person{margin-top:10px}
#jhb-map .person .lbl{display:block;font-size:13px;color:#6b7280;margin-bottom:2px}
#jhb-map .person .who{display:block;font-size:19px;line-height:1.15;font-weight:800;color:#0b1220}
#jhb-map .sep{position:relative;margin:12px 0;height:12px}
#jhb-map .sep:before{content:"";position:absolute;left:14px;right:14px;top:5px;height:1px;border-radius:2px;background:linear-gradient(90deg,rgba(2,6,23,.06),rgba(2,6,23,.3),rgba(2,6,23,.06))}
#jhb-map .sep:after{content:"";position:absolute;left:50%;top:1px;width:10px;height:10px;transform:translateX(-50%) rotate(45deg);background:#fff;border:1px solid rgba(2,6,23,.18);box-shadow:0 2px 6px rgba(16,24,40,.15);border-radius:2px}
#jhb-map .addr{font-size:14px;line-height:1.45;color:#475569;margin:8px 0 14px}
#jhb-map .btn{appearance:none;border-radius:999px;padding:11px 18px;font-size:15px;font-weight:800;letter-spacing:.2px;cursor:pointer;border:1px solid rgba(2,6,23,.18);background:linear-gradient(180deg,#4f8bff,#2563eb);color:#fff;box-shadow:0 8px 18px rgba(37,99,235,.18);display:inline-block;transition:transform .24s cubic-bezier(.22,1,.36,1),box-shadow .24s cubic-bezier(.22,1,.36,1),background .24s ease}
#jhb-map .btn:hover{transform:translateY(-2px);box-shadow:0 10px 20px rgba(37,99,235,.18);background:linear-gradient(180deg,#6297ff,#2563eb)}
#jhb-map .x{position:absolute;top:10px;right:10px;width:34px;height:34px;border-radius:50%;border:none;background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.15);cursor:pointer;display:flex;align-items:center;justify-content:center}
#jhb-map .x:before{content:"✕";font-size:18px;color:#444;font-weight:800}
#jhb-map .groups{text-align:left;margin-top:8px}
#jhb-map .group{border:1px solid #e5e7eb;border-radius:14px;padding:10px 12px;margin:10px 0;background:#f8fafc}
#jhb-map .group .badge{display:inline-block;font-size:12.5px;font-weight:800;padding:5px 10px;border-radius:999px;background:#eef2ff;border:1px solid #e0e7ff}
#jhb-map .group .lbl{display:block;font-size:12px;color:#64748b;margin:8px 0 2px}
#jhb-map .group .who{display:block;font-size:16px;font-weight:800;color:#0b1220;line-height:1.2}
#jhb-map .group .addr{font-size:13.5px;color:#475569;margin-top:6px}
@media (max-width:640px){#jhb-map .brb-map-stagehead{margin-bottom:18px;padding:0 16px}#jhb-map .brb-map-stagehead__title{font-size:26px;line-height:1.14}#jhb-map .brb-map-stagehead__text{font-size:14px;line-height:1.55}#jhb-map .brb-pop{transform:translate(-50%,-55%);max-width:340px}}
@media (hover:hover) and (pointer:fine){#jhb-map .hint{position:absolute;transform:translate(-50%,calc(-100% - 14px));background:#fff;border:1px solid rgba(2,6,23,.14);border-radius:12px;padding:10px 14px;box-shadow:0 14px 32px rgba(16,24,40,.18),0 6px 14px rgba(16,24,40,.14);pointer-events:none;z-index:9;text-align:center}#jhb-map .hint:after{content:"";position:absolute;left:50%;bottom:-7px;transform:translateX(-50%) rotate(45deg);width:14px;height:14px;background:#fff;border-right:1px solid rgba(2,6,23,.14);border-bottom:1px solid rgba(2,6,23,.14);box-shadow:2px 2px 5px rgba(16,24,40,.08)}#jhb-map .hint .t{display:block;font-weight:900;font-size:15.5px;line-height:1.15;color:#0b1220;letter-spacing:.1px}#jhb-map .hint .p{display:block;font-size:13.5px;color:#334155;margin-top:3px;line-height:1.2}}
