/* ============================================
   Interactive Map Styles
   ============================================ */

.map_container {
  width: 100%;
  padding: var(--space-2xl) 0;
}

.map-wrapper {
  max-width: var(--container-max-width);
  margin: 0 auto;
  padding: 0 var(--container-padding);
  position: relative;
}

.interactive-map {
  width: 100%;
  height: auto;
  position: relative;
  overflow: hidden; /* Hide overflow for drag functionality */
  user-select: none; /* Prevent text selection during drag */
  -webkit-user-select: none;
}

.interactive-map.dragging {
  cursor: grabbing !important;
}

.interactive-map.dragging path {
  pointer-events: none; /* Disable path interactions while dragging */
}

.interactive-map svg {
  width: 100%;
  height: auto;
  display: block;
}

/* Default country styles */
.interactive-map path {
  transition: fill 0.3s ease-in-out, transform 0.3s ease-in-out, filter 0.3s ease-in-out;
  stroke: white;
  stroke-width: 0.5;
  transform-origin: center center;
  will-change: transform;
}

/* Current active countries (red) */
.interactive-map path[data-active="true"] {
  fill: var(--color-primary);
  cursor: pointer;
}

/* Hover state for active countries */
.interactive-map path[data-active="true"]:hover {
  fill: var(--color-secondary);
  transform: scale(1.01);
  transform-origin: center center;
  filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.15));
}

/* Past countries (beige) */
.interactive-map path[data-past="true"] {
  fill: #FAF4E7;
  cursor: default;
}

/* Tooltip for country info */
.map-tooltip {
  position: absolute;
  background-color: var(--color-white);
  border: 2px solid var(--color-primary);
  border-radius: var(--radius-sm);
  padding: var(--space-md) var(--space-base);
  box-shadow: var(--shadow-md);
  pointer-events: none;
  opacity: 0;
  transform: translate(-50%, -100%) translateY(-10px);
  transition: opacity var(--transition-base);
  z-index: var(--z-tooltip);
  min-width: 200px;
}

.map-tooltip.active {
  opacity: 1;
}

.map-tooltip__title {
  font-family: var(--font-heading);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  color: var(--color-primary);
  margin-bottom: var(--space-xs);
}

.map-tooltip__info {
  font-size: var(--font-size-sm);
  color: var(--color-text);
  line-height: var(--line-height-relaxed);
}

.map-tooltip__cta {
  margin-top: var(--space-sm);
  font-size: var(--font-size-xs);
  color: var(--color-secondary);
  font-weight: var(--font-weight-semibold);
}

/* Country detail modal */
.country-modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7);
  z-index: var(--z-modal);
  opacity: 0;
  transition: opacity var(--transition-base);
}

.country-modal.active {
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 1;
}

.country-modal__content {
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  max-width: 600px;
  width: 90%;
  max-height: 80vh;
  overflow-y: auto;
  padding: var(--space-xl);
  position: relative;
  transform: scale(0.9);
  transition: transform var(--transition-base);
}

.country-modal.active .country-modal__content {
  transform: scale(1);
}

.country-modal__close {
  position: absolute;
  top: var(--space-base);
  right: var(--space-base);
  width: 32px;
  height: 32px;
  background: none;
  border: none;
  cursor: pointer;
  font-size: 24px;
  color: var(--color-text);
  transition: color var(--transition-fast);
}

.country-modal__close:hover {
  color: var(--color-primary);
}

.country-modal__title {
  font-family: var(--font-heading);
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-primary);
  margin-bottom: var(--space-base);
}

.country-modal__description {
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  color: var(--color-text);
  margin-bottom: var(--space-lg);
}

.country-modal__stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: var(--space-base);
  margin-bottom: var(--space-lg);
}

.country-modal__stat {
  text-align: center;
  padding: var(--space-base);
  background-color: var(--color-gray-lightest);
  border-radius: var(--radius-sm);
}

.country-modal__stat-value {
  display: block;
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-primary);
}

.country-modal__stat-label {
  display: block;
  font-size: var(--font-size-sm);
  color: var(--color-text-light);
  margin-top: var(--space-xs);
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .map_container .map-wrapper {
    max-width: 100%;
    padding: 0;
  }

  .arbeiten .container {
    max-width: 100%;
    padding: 0;
  }

  .map-tooltip {
    display: none; /* Tooltip auf Mobile deaktiviert */
  }

  .interactive-map {
    height: 80vh;
    overflow: hidden; /* Changed from overflow-x: auto */
    cursor: grab;
  }

  .interactive-map:active {
    cursor: grabbing;
  }

  .interactive-map svg {
    height: 100%;
    width: auto;
    min-width: 200%; /* Karte breiter als Container für Drag */
    will-change: transform; /* Optimize for animations */
  }

  .country-modal__content {
    padding: var(--space-lg);
    width: 95%;
  }
}
