.concert-dates .date{
  margin-bottom: .75rem;
}

@media screen and (max-width: 48rem){
  .project-data h2,
  .project-audio h2 {
    margin-top: var(--spacing-section);
  }
}

@media screen and (min-width: 48.01rem){
  .project-intro,
  .project-programm-and-audio{
    display: grid;
    grid-template-columns: auto 20rem;
    grid-gap: 4rem;
    align-items: start;
  }

  .project-data,
  .project-audio{
    position: sticky;
    top: var(--spacing-page);
  }
}

.project-programm .song,
.project-programm .intermezzo{
  display: grid;
  grid-template-columns: 1fr 1fr;
  padding: 0.375rem 0;
}

.project-programm .song + .intermezzo,
.project-programm .intermezzo + .song,
.project-programm .intermezzo + .heading{
  margin-top: 1.25rem;
}

.project-programm .intermezzo{
  font-size: 1rem;
  font-style: italic;
  padding: 0.125rem 0;
}

.project-programm .intermezzo p:first-of-type{
  padding-right: 2rem;
  text-align: right;
}

.project-programm .heading{
  margin: 1rem 0 .75rem;
  color: var(--color-text-secondary);
  padding-bottom: .25rem;
  border-bottom: 1px solid var(--color-border-default);
}


.audio-file{
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  margin-bottom: .25rem;
}

button.audio{
  width: 2.5rem;
  height: 2.5rem;
  padding: .75rem;
  line-height: 1;
  color: var(--red-light);
  border-radius: 50%;
  background-color: transparent;
}

button.audio:hover,
button.audio.playing{
  color: var(--red-dark);
  background-color: var(--red-lighter);
}

button.audio:active{
  background-color: var(--red-light);
}

button:not(.playing) .pause,
button.playing .play{
  display: none;
}

















