
/* ---- grid ---- */

.grid {
  margin-top: 5.5em;
}

/* clear fix */
.grid:after {
  content: '';
  display: block;
  clear: both;
}

/* ---- .grid-item ---- */

@media screen and (max-width: 600px) {
  .grid-sizer,
  .grid-item {
    width: 100%;
  }
  .grid-item {
    padding-left: 0;
    padding-right: 0;
  }
}
@media screen and (min-width: 601px) and (max-width: 900px) {
  .grid-sizer,
  .grid-item {
    width: 50%;
  }
  .grid-item {
    padding-left: 12px;
    padding-right: 12px;
  }
}
@media screen and (min-width: 901px) and (max-width: 1500px) {
  .grid-sizer,
  .grid-item {
    width: 33.333%;
  }
  .grid-item {
    padding-left: 12px;
    padding-right: 12px;
  }
}
@media screen and (min-width: 1501px) and (max-width: 2000px) {
  .grid-sizer,
  .grid-item {
    width: 33.333%;
  }
  .grid-item {
    padding-left: 12px;
    padding-right: 12px;
  }
}
@media screen and (min-width: 2001px) {
  .grid-sizer,
  .grid-item {
    width: 25%;
  }
  .grid-item {
    padding-left: 12px;
    padding-right: 12px;
  }
}
/* @media screen and (min-width: 2401px) {
  .grid-sizer,
  .grid-item {
    width: 20%;
  }
  .grid-item {
    padding-left: 12px;
    padding-right: 12px;
  }
} */
.grid-item {
  padding-top: 0px;
  padding-bottom: 50px;
  float: left;
}

.grid-item img {
  display: block;
  max-width: 100%;
  -webkit-transition: opacity 0.5s ease-out;
  -moz-transition: opacity 0.5s ease-out;
  -o-transition: opacity 0.5s ease-out;
  transition: opacity 0.5s ease-out;
}

.grid-item:hover img {
  opacity: 0.5;
}

.numero {
  display: block;
  float: left;
  margin-top: 0.125em;
}

.text {
  display: block;
  text-align: center;
}

figcaption {
  margin-top: 0.85em;
  letter-spacing: 0.2em;
  font-size: 0.6725em;
}
