.toile-designer-map {
  --toile-map-accent: #5e7d45;
  --toile-map-bg: #ffffff;
  --toile-map-surface: rgba(38, 43, 34, 0.9);
  --toile-map-border: #353c2f;
  --toile-map-text: #f5f7f2;
  --toile-map-muted: #acb7a4;
  --toile-map-image-opacity: 0.4;
  --toile-map-height: min(86vh, 820px);
  --toile-map-aspect-ratio: 1536 / 1086;
  color: var(--toile-map-text);
}

.toile-designer-map__stage {
  position: relative;
  isolation: isolate;
  width: 100%;
  height: auto;
  aspect-ratio: var(--toile-map-aspect-ratio);
  min-height: 500px;
  max-height: var(--toile-map-height);
  overflow: hidden;
  background: var(--toile-map-bg);
}

.toile-designer-map__bg-layer,
.toile-designer-map__pins {
  position: absolute;
  inset: 0;
  z-index: 1;
  transform-origin: 50% 50%;
  transition: transform 0.35s ease;
}

.toile-designer-map__bg-layer img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center center;
  opacity: var(--toile-map-image-opacity);
  mix-blend-mode: normal;
  filter: grayscale(1) contrast(1.12) brightness(0.88);
  pointer-events: none;
  user-select: none;
}

.toile-designer-map__pins {
  z-index: 3;
  pointer-events: none;
}

.toile-designer-map__pin {
  position: absolute;
  transform: translate(-50%, -50%);
  pointer-events: auto;
}

.toile-designer-map__dot {
  position: relative;
  display: block;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--toile-map-accent);
  border: 2px solid #1d2019;
  box-shadow: 0 0 16px color-mix(in srgb, var(--toile-map-accent) 65%, transparent);
  animation: toile-designer-map-dot 2s ease-in-out infinite;
}

.toile-designer-map__dot.has-pulse::before {
  content: "";
  position: absolute;
  inset: -4px;
  border-radius: inherit;
  background: color-mix(in srgb, var(--toile-map-accent) 72%, transparent);
  opacity: 0.36;
  animation: toile-designer-map-ring 2s cubic-bezier(0.215, 0.61, 0.355, 1) infinite;
}

.toile-designer-map__pin.is-sm .toile-designer-map__dot {
  width: 9px;
  height: 9px;
}

.toile-designer-map__pin.is-lg .toile-designer-map__dot {
  width: 15px;
  height: 15px;
}

.toile-designer-map__tooltip {
  position: absolute;
  top: 50%;
  min-width: 150px;
  max-width: 230px;
  transform: translateY(-50%);
  border: 1px solid var(--toile-map-border);
  background: color-mix(in srgb, var(--toile-map-surface) 95%, transparent);
  backdrop-filter: blur(8px);
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.38);
  padding: 10px 12px;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.22s ease, transform 0.22s ease;
  pointer-events: none;
}

.toile-designer-map__tooltip.is-right {
  left: calc(100% + 16px);
}

.toile-designer-map__tooltip.is-left {
  right: calc(100% + 16px);
}

.toile-designer-map__pin:hover .toile-designer-map__tooltip,
.toile-designer-map__pin:focus-within .toile-designer-map__tooltip {
  opacity: 1;
  visibility: visible;
  transform: translateY(-50%) translateX(0);
}

.toile-designer-map__tooltip-title {
  margin: 0;
  font-size: 14px;
  line-height: 1.25;
  font-weight: 700;
  color: var(--toile-map-text);
}

.toile-designer-map__tooltip-subtitle {
  margin: 4px 0 0;
  font-size: 11px;
  line-height: 1.3;
  color: var(--toile-map-muted);
}

@keyframes toile-designer-map-ring {
  0% {
    transform: scale(0.35);
    opacity: 0.65;
  }
  85%,
  100% {
    transform: scale(1.8);
    opacity: 0;
  }
}

@keyframes toile-designer-map-dot {
  0% {
    transform: scale(0.84);
  }
  50% {
    transform: scale(1);
  }
  100% {
    transform: scale(0.84);
  }
}

@media (max-width: 1024px) {
  .toile-designer-map {
    --toile-map-height: min(76vh, 700px);
  }

  .toile-designer-map__stage {
    min-height: 380px;
  }
}

@media (max-width: 767px) {
  .toile-designer-map {
    --toile-map-height: min(56vh, 420px);
  }

  .toile-designer-map__stage {
    min-height: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .toile-designer-map__dot,
  .toile-designer-map__dot.has-pulse::before {
    animation: none;
  }

  .toile-designer-map__bg-layer,
  .toile-designer-map__pins {
    transition: none;
  }
}
