#masonry {
  column-count: 2;
  column-gap: 0;
}

@media(min-width: 30em) {
  #masonry {
    column-count: 3;
    column-gap: 1em;
  }
}

@media(min-width: 40em) {
  #masonry {
    column-count: 4;
    column-gap: 1em;
  }
}

@media(min-width: 60em) {
  #masonry {
    column-count: 4;
    column-gap: 1em;
  }
}

@media(min-width: 75em) {
  #masonry {
    /* column-count: 6; */
    column-gap: 0;
    float: left;
    width: 100%;
    /* max-width: 800px; */
  }
}

.item {
  background-color: none;
  display: inline-block;
  /* margin: 0 0 1em 0; */
  width: 100%;
  cursor: pointer;
  overflow: hidden;
  padding: 0;
  transition: all ease-in-out .5s;
}

.item img {
  max-width: 100%;
  height: auto;
  width: 100%;
  float: left;
  /* margin-bottom: -4px; */
  
  /*idk why but this fix stuff*/
  padding: 0;
  transition: all ease-in-out .5s;
  -webkit-transform-origin-x: all ease-in-out .5s;
}

.item.active {
  animation-name: active-in;
  animation-duration: 0.7s;
  animation-fill-mode: forwards;
  animation-direction: alternate;
  position:relative;
  z-index:999;
}

.item.active:before {
  content: "+";
  transform: rotate(45deg);
  font-size: 48px;
  color: white;
  position: absolute;
  top: 20px;
  right: 20px;
  background-color:rgba(0,0,0,0.85);
  border-radius: 50%;
  width:48px;
  height:48px;
  text-align:center;
  line-height:48px;
  z-index:12;
}

.item.active img {
  animation-name: active-in-img;
  animation-duration: 0.7s;
  animation-fill-mode: forwards;
  animation-direction: alternate;
}


@keyframes active-in {
  0% {
    opacity:1;
    background-color:white;
  }
  
  50% {
    opacity:0;
    background-color:rgba(0,0,0,0.90);
  }
  
  100% {
    opacity: 1;
    position:fixed;
    top:0;
    left:0;
    right:0;
    bottom:0;
    background-color:rgba(0,0,0,0.90);
  }
}

@keyframes active-in-img {
  0% {
    opacity:1;
    transform:translate(0%, 0%);
    top: 0;
    left: 0;
    max-width: 100%;
  }
  49% {
    opacity:0;
    transform: translate(0%, -50%);
  }
  50% {
    position:absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -100%);
  }
  100% {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  max-width: 90%;
  width: auto;
  max-height: 95vh;
  opacity:1;
  }
}

.item:hover img{
  transform: scale(1.3);
}