.visual {
  display: grid;
  gap: var(--space-large);
  margin-left: var(--space-medium);
  margin-right: var(--space-medium);
  position: relative;
}

.visual__column {
  display: grid;
  gap: var(--space-large);
}

.visual__aside {
  display: grid;
  gap: 0.7em;
  margin-top: -0.9em;
}

.visual__aside p {
  font-size: var(--font-size-xxx-small);
  letter-spacing: var(--letter-spacing);
  margin-bottom: -0.3em;
  margin-top: -0.575em;
}

.visual__button {
  color: var(--color-black);
  cursor: zoom-in;
  display: grid;
  font-weight: 400;
  place-items: center;
  position: relative;
  text-decoration: none;
}

.visual__figure {
  display: grid;
  gap: var(--space-medium);
  grid-area: 1/1;
  position: relative;
  user-select: none;
  -ms-user-select: none;
  -webkit-user-select: none;
  z-index: 1;
}

.visual__figure img {
  border-radius: 0.2em;
  box-shadow:
    0 0 0 1px rgba(var(--rgb-black), 0.1),
    0 0 0.1em 0.02em rgba(var(--rgb-black), 0.05)
  ;
  overflow: hidden;
}

.visual__figure span {
  background: var(--color-yellow);
  color: var(--color-black);
  font-family: 'Sharpie', Sans-Serif;
  font-size: var(--font-size-xx-small);
  font-variant-ligatures: none;
  font-weight: 400;
  left: 0;
  letter-spacing: 0.04em;
  line-height: 1;
  padding: 0.3em 0.5em 0.4em 0.5em;
  position: absolute;
  text-align: center;
  text-transform: uppercase;
  top: 0;
  transform: rotate(-2deg) translate(-0.7625em, -0.875em);
  white-space: nowrap;
}

.visual__play {
  background: url('/assets/images/general/icon-play.svg') center center/0.8em auto no-repeat var(--color-black);
  border-radius: 100%;
  grid-area: 1/1;
  height: 1.8em;
  opacity: 0;
  pointer-events: none;
  position: relative;
  transform: scale(0.85);
  width: 1.8em;
  will-change: transform;
  z-index: 2;
}

.visual__play--visible {
  opacity: 1;
  transform: scale(1);
}



.visual--pwa {
  margin-left: 0;
  margin-right: 0;
  width: min(100%, 17em);
}

.visual--walkthrough .visual__column {
  margin-inline: auto;
  width: min(100%, 35em);
}

.visual--walkthrough .visual__play {
  opacity: 1;
  transform: scale(1.3);
}



@media(hover: hover) {

  .visual .visual__button .visual__figure img {
    outline: 0.1em solid transparent;
    outline-offset: 0.24em;
    transition:
      outline-color var(--transition-slow),
      outline-offset var(--transition-slow)
    ;
  }

  .visual .visual__button .visual__play {
    transition:
      opacity var(--transition-slow),
      transform var(--transition-slow)
    ;
  }

  .visual .visual__button:focus .visual__figure img,
  .visual .visual__button:hover .visual__figure img {
    outline-color: var(--color-black);
    outline-offset: 0.12em;
  }

  .visual .visual__button:focus .visual__play,
  .visual .visual__button:hover .visual__play {
    opacity: 1;
    transform: scale(1);
  }

  .visual .visual__button:focus .visual__play--visible,
  .visual .visual__button:hover .visual__play--visible {
    transform: scale(1.1);
  }

  .visual--walkthrough .visual__button:focus .visual__play,
  .visual--walkthrough .visual__button:hover .visual__play {
    transform: scale(1.4);
  }

}



@media(min-width: 48em) {

  .visual {
    gap: var(--space-neutral);
    grid-template-columns: repeat(12, 1fr);
  }

  .visual__column {
    align-content: start;
    gap: var(--space-neutral);
    grid-column: 1/-1;
  }

  .visual__column--end {
    align-content: end;
  }

  .visual__column--flex {
    display: flex;
  }

  .visual__column--grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .visual__column--1 {
    grid-column: span 1;
  }

  .visual__column--2 {
    grid-column: span 2;
  }

  .visual__column--3 {
    grid-column: span 3;
  }

  .visual__column--4 {
    grid-column: span 4;
  }

  .visual__column--5 {
    grid-column: span 5;
  }

  .visual__column--6 {
    grid-column: span 6;
  }

  .visual__column--7 {
    grid-column: span 7;
  }

  .visual__column--8 {
    grid-column: span 8;
  }

  .visual__column--9 {
    grid-column: span 9;
  }

  .visual__column--10 {
    grid-column: span 10;
  }

  .visual__column--11 {
    grid-column: span 11;
  }

  .visual__aside {
    grid-column: 1/-1;
    margin-top: 0;
  }

}



@media(min-width: 64em) {

  .visual {
    margin-left: var(--space-neutral);
    margin-right: var(--space-neutral);
  }

}
