/* ══════════════════════════════════════════════════════
   VENUE MAP COMPONENT — venue-map.css
   Componente: Mapa del venue con leyenda lateral.
   Layout: texto izquierda | foto derecha (desktop)
           foto arriba | texto abajo (mobile)
   Todas las clases usan prefijo vm- para evitar
   conflictos con cualquier otra web.
   ══════════════════════════════════════════════════════ */


/* ─────────────────────────────────────────
   Wrapper exterior — fondo + padding del card
───────────────────────────────────────── */

.vm-outer {
  background: #ffffff;
  padding: 32px 40px;
}


/* ─────────────────────────────────────────
   Card principal — grid 2 columnas
───────────────────────────────────────── */

.vm-card {
  display: grid;
  grid-template-columns: 1fr 1fr;   /* leyenda | foto — ajusta la proporción aquí */
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 8px 40px rgba(0, 0, 0, 0.18);
}


/* ─────────────────────────────────────────
   Columna izquierda — leyenda
───────────────────────────────────────── */

.vm-legend {
  background: #0c3835;              /* cambia este color para adaptar a tu web */
  padding: 52px 48px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* Etiqueta pequeña sobre el título */
.vm-eyebrow {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.5);
  margin: 0 0 14px;
}

/* Título principal */
.vm-title {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(1.8rem, 2.4vw, 2.4rem);
  font-weight: 700;
  line-height: 1.1;
  color: #ffffff;
  text-transform: uppercase;
  margin: 0 0 36px;
}

/* Lista de zonas */
.vm-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* Cada ítem: círculo + etiqueta */
.vm-item {
  display: flex;
  align-items: center;
  gap: 18px;
}

/* Círculo de color */
.vm-dot {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  flex-shrink: 0;
  display: block;
}

/* Texto del ítem */
.vm-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #ffffff;
  line-height: 1;
}

/* Botón CTA — estilos base incluidos para independencia */
.vm-btn {
  display: inline-block;
  align-self: flex-start;
  width: fit-content;
  margin-top: 28px;
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #ffffff;
  background: #319391;
  text-decoration: none;
  padding: 14px 32px;
  border-radius: 100px;
  box-shadow: 0 4px 16px rgba(49, 147, 145, 0.4);
  transition: background 0.25s, box-shadow 0.25s;
  border: none;
  cursor: pointer;
}

.vm-btn:hover {
  background: #267573;
  box-shadow: 0 6px 24px rgba(49, 147, 145, 0.5);
}


/* ─────────────────────────────────────────
   Columna derecha — imagen
───────────────────────────────────────── */

.vm-img {
  overflow: hidden;
}

.vm-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
}


/* ─────────────────────────────────────────
   Mobile — breakpoint 768px
   Foto arriba (1:1) | leyenda abajo
───────────────────────────────────────── */

@media (max-width: 768px) {

  .vm-outer {
    padding: 16px;
  }

  /* Una sola columna */
  .vm-card {
    grid-template-columns: 1fr;
    border-radius: 14px;
  }

  /* Foto primero (arriba) */
  .vm-img {
    order: -1;
    aspect-ratio: 1 / 1;
    height: auto;
  }

  /* Leyenda abajo */
  .vm-legend {
    order: 1;
    padding: 40px 32px 44px;
  }

  /* Título en una sola línea */
  .vm-title {
    font-size: 1.6rem;
    margin-bottom: 24px;
    white-space: nowrap;
  }

  /* Más espacio entre ítems */
  .vm-list {
    gap: 22px;
  }

  .vm-dot {
    width: 28px;
    height: 28px;
  }

  .vm-label {
    font-size: 0.82rem;
  }

  .vm-btn {
    width: 100%;
    text-align: center;
    display: block;
    box-sizing: border-box;
  }

}
