﻿/* ============================================================
   SNAPZONE - PAGE CARTE
   styles-map.css
   ============================================================ */

.map-hero {
  position: relative;
  overflow: hidden;
  text-align: center;
  padding-block: var(--section-padding);
}

.map-hero__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}

.map-hero__gradient {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(19, 46, 70, 0.2) 0%, var(--color-bg) 100%);
  z-index: 1;
}

.map-hero .container {
  position: relative;
  z-index: 2;
}

.map-hero__content {
  max-width: 760px;
  margin-inline: auto;
}

.map-hero__title {
  margin-block: var(--space-sm) var(--space-md);
  font-size: clamp(2.5rem, 7vw, 4.4rem);
}

.map-hero__desc {
  color: var(--color-text-muted);
  font-size: var(--text-lg);
}

.map-section {
  position: relative;
}

.world-map-card {
  position: relative;
  background: var(--gradient-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-lg);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}

.world-map-card::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at 15% 15%, rgba(56, 189, 248, 0.12), transparent 42%);
}

.world-map__status {
  position: absolute;
  inset: auto auto var(--space-md) var(--space-md);
  z-index: 2;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin: 0;
  background: rgba(13, 32, 53, 0.9);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  padding: 0.35rem 0.8rem;
}

.world-map__viewport {
  position: relative;
  z-index: 1;
  width: 100%;
  min-height: 500px;
  user-select: none;
  -webkit-user-select: none;
}

.world-map__hint {
  margin-top: var(--space-sm);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

.world-map-svg {
  width: 100%;
  height: auto;
  display: block;
  cursor: grab;
  touch-action: none;
}

.world-map-svg.is-dragging {
  cursor: grabbing;
}

.world-ocean {
  fill: #0f2a42;
  stroke: rgba(56, 189, 248, 0.15);
  stroke-width: 1;
}

.world-country {
  fill: #173854;
  stroke: rgba(240, 239, 244, 0.16);
  stroke-width: 0.5;
  vector-effect: non-scaling-stroke;
  transition: fill var(--transition-fast), stroke var(--transition-fast);
  cursor: pointer;
}

.world-country--has-parts {
  fill: rgba(14, 165, 233, 0.50);
}
.world-country:focus {
  outline: none;
}

.world-country:hover,
.world-country.is-hovered,
.world-country:focus-visible {
  fill: #0ea5e9;
  stroke: rgba(255, 255, 255, 0.7);
  outline: none;
}

.country-tooltip {
  position: fixed;
  z-index: 10000;
  pointer-events: none;
  min-width: 220px;
  max-width: min(320px, calc(100vw - 24px));
  border-radius: var(--radius-md);
  border: 1px solid rgba(56, 189, 248, 0.45);
  background: rgba(8, 18, 30, 0.97);
  box-shadow: var(--shadow-lg);
  padding: 0.75rem 0.9rem;
  color: var(--color-text);
}

.country-tooltip__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  line-height: 1;
  color: var(--color-white);
  margin: 0 0 0.5rem;
}

.country-tooltip__meta {
  font-size: var(--text-sm);
  margin: 0;
  color: var(--color-text-muted);
}

.country-tooltip__list {
  margin-top: 0.55rem;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}

.country-tooltip__item {
  font-size: var(--text-sm);
  color: var(--color-text);
  line-height: 1.3;
}

.country-tooltip__item::before {
  content: '- ';
  color: var(--color-accent-light);
}

@media (max-width: 767px) {
  .world-map__viewport {
    min-height: 360px;
  }

  .world-map-card {
    padding: var(--space-md);
  }

  .country-tooltip {
    max-width: min(280px, calc(100vw - 16px));
  }
}

@media (prefers-reduced-motion: reduce) {
  .world-country {
    transition: none;
  }
}





