.lswm-wrap {
  position: relative;
  background: transparent;
  user-select: none;
  -webkit-user-select: none;
  overflow: hidden;
  border-radius: 12px;
}

.lswm-stage {
  width: 100%;
  height: 100%;
  position: relative;
  cursor: grab;
}
.lswm-stage.dragging { cursor: grabbing; }

/* Botões */
.lswm-controls {
  position: absolute;
  top: 10px; right: 10px;
  display: grid; gap: 6px;
  z-index: 3;
}
.lswm-controls button{
  width: 36px; height: 36px; line-height: 36px;
  font: 600 16px/36px system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  border-radius: 8px; border: 1px solid rgba(0,0,0,.2);
  background: rgba(255,255,255,.9);
  box-shadow: 0 2px 6px rgba(0,0,0,.1);
  cursor: pointer;
}
.lswm-controls button:hover { transform: translateY(-1px); }

/* Tooltip */
.lswm-tooltip{
  position: absolute;
  z-index: 4;
  pointer-events: none;
  transform: translate(-50%, -110%);
  background: rgba(22,24,28,.96);
  color: #fff;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 10px;
  min-width: 220px;
  max-width: 320px;
  padding: 10px 12px;
  opacity: 0; transition: opacity .15s ease, transform .15s ease;
}
.lswm-tooltip.show{
  opacity: 1; transform: translate(-50%, -120%);
}
.lswm-tooltip .lswm-tooltip-title{
  font-weight: 700; margin-bottom: 6px;
}
.lswm-tooltip .lswm-tooltip-content{
  font-size: 13px; line-height: 1.35;
}

/* Marcador “pulse” (SVG <g> com circle) */
.lswm-marker circle.pulse-dot{
  r: 3.5;
}
.lswm-marker circle.pulse-ring{
  r: 3.5;
  fill: none;
  stroke-width: 2.5;
  animation: lswm-pulse 1.8s ease-out infinite;
  opacity: .7;
}

@keyframes lswm-pulse {
  0%   { transform: scale(1);   opacity: .7; }
  70%  { transform: scale(4);   opacity: 0; }
  100% { transform: scale(4.2); opacity: 0; }
}

/* País ativo (hover ou item) — podes ajustar */
svg .lswm-country-hover { filter: brightness(1.05) saturate(1.05); }

.lswm-stage svg { position: relative; z-index: 1; }
.lswm-tooltip   { position: absolute; z-index: 10; }

/* Tooltip fixa em mobile (centrada em baixo) */
.lswm-tooltip.mobile-fixed {
  position: fixed;
  left: 50%;
  bottom: auto!important;
  top: 16px ;
  transform: translateX(-50%);
  max-width: calc(100vw - 24px);
  /* opcional: evitar que capture scroll */
  touch-action: manipulation;
}
/* Legenda (canto inferior esquerdo) */
.lswm-legend {
  display: flex;
  align-items: center;
  gap: .5rem;
  position: absolute;
  left: 10px;
  bottom: 10px;
  z-index: 4;
  background: rgba(255, 255, 255, 0.92);
  color: #000;
  border-radius: 10px;
  padding: 8px 10px;
  font: 600 11px/1.4 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

.lswm-legend-title {
  font-size: 11px;
  line-height:1;	
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.lswm-legend-colors {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.lswm-legend-swatch {
  width: 15px;
  height: 15px;
  border-radius: 3px;
}
