
.tlm-wrap{display:flex;flex-wrap:wrap;gap:12px;align-items:stretch}
.tlm-sidebar{flex:1 1 320px;min-width:280px;background:#0f1630;color:#e6e8ef;border:1px solid #1b2550;border-radius:12px;overflow:hidden}
.tlm-sidebar h3{margin:0;padding:12px 14px;border-bottom:1px solid #1b2550;font:600 16px/1 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif}
.tlm-search{padding:10px;border-bottom:1px solid #1b2550}
.tlm-search input{width:100%;padding:8px 10px;border:1px solid #2a356b;border-radius:10px;background:#0c1430;color:#e6e8ef}
.tlm-list{max-height:300px;overflow:auto;padding:6px}
.tlm-item{padding:8px 10px;margin:6px;border:1px solid #22306b;background:#0c1430;border-radius:10px;cursor:pointer;transition:transform .08s ease,background .2s ease}
.tlm-item:hover{background:#101a3d;transform:translateY(-1px)}
.tlm-footer{padding:8px;border-top:1px solid #1b2550;font-size:12px;opacity:.85;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.tlm-btn{padding:6px 10px;border:1px solid #2a356b;background:#0c1430;color:#cfd5ff;border-radius:8px;cursor:pointer}

.tlm-map{flex:2 1 520px;min-height:420px;border-radius:12px;overflow:hidden;border:1px solid #1b2550}
.pin{position:relative;width:22px;height:22px;border-radius:50%;box-shadow:0 2px 10px rgba(0,0,0,.35);transform-origin:50% 100%}
.pin::after{content:"";position:absolute;left:50%;bottom:-8px;width:2px;height:10px;border-radius:2}
.pin.drop{animation:tlmDrop .6s ease forwards}
.badge{position:absolute;top:-10px;left:14px;min-width:18px;padding:2px 5px;border-radius:10px;background:#1a233f;color:#c6ceff;font-size:11px;border:1px solid #2a356b}
@keyframes tlmDrop{0%{opacity:0;transform:translateY(-240px) scale(.85)}60%{opacity:1;transform:translateY(6px)}100%{transform:translateY(0)}}


/* Legend styles */
.tlm-legend{
  background: rgba(15,22,48,0.95);
  color: #cfd5ff;
  padding: 8px;
  border-radius: 8px;
  border: 1px solid #1b2550;
  font-size: 13px;
  max-height: 320px;
  overflow: auto;
  box-shadow: 0 6px 18px rgba(0,0,0,0.35);
  width: 220px;
}
.tlm-legend-title{ font-weight:700; margin-bottom:6px; text-align:left; }
.tlm-legend-list{ display:flex; flex-direction:column; gap:6px; }
.tlm-legend-item{ display:flex; align-items:center; gap:8px; padding:4px; cursor:pointer; border-radius:6px; }
.tlm-legend-item:hover{ background: rgba(255,255,255,0.03); }
.tlm-legend-swatch{ width:14px; height:14px; border-radius:4px; display:inline-block; border:1px solid rgba(0,0,0,0.2); }
.tlm-legend-name{ white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

/* ensure inline svg icons are visible inside markers */
.tlm-map svg{width:100%;height:100%;display:block}
