body {
  color: #000;
  background: #fff;
}
ol,
ul {
  list-style: none;
}
table {
  border-collapse: separate;
  border-spacing: 0;
  vertical-align: middle;
}
caption,
th,
td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle;
}
a img {
  border: none;
}
* {
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
p {font-size:14px; line-height:1.6em; margin:0;}
.container {
  max-width: 1040px;
  margin: 0 auto;
}
.section {
  padding-top: 50px;
  zoom: 1;
}
.section:before,
.section:after {
  content: "";
  display: table;
}
.section:after {
  clear: both;
}
.section__title {
  font-size: 30px;
  font-weight: bold;
  margin-bottom: 50px;
  color: #343434;
  text-align: center;
  clear: both;
}
.partner {
  *zoom: 1;
  float: left;
  clear: none;
  text-align: inherit;
  width: 22%;
  margin-left: 0%;
  margin-right: 4%;
  margin-bottom: 4%;
  border: 1px solid #f8f8f8;
  border-radius: 5px;
  position: relative;
  cursor: pointer;
}
.partner:before,
.partner:after {
  content: '';
  display: table;
}
.partner:after {
  clear: both;
}
.partner:nth-child(4n) {
  margin-right: 0%;
  float: right;
}
.partner:nth-child(4n+1) {
  clear: both;
}
@media all and (max-width: 800px) {
    .partner {
        width: 48%;
    }
    .partner:nth-child(2n) {
        margin-right: 0%;
        float: right;
    }
    .partner:nth-child(2n+1) {
        clear: both;
    }
}
@media all and (max-width: 400px) {
    .partner {
        width: 100%;
        margin-right: 0;
    }
}
.partner__logo {
  text-align: center;
  height: 145px;
  position: relative;
  padding: 5px;
  background-color: #fff;
}
.partner__logo img {
  position: absolute;
  -webkit-transform-style: preserve-3d;
  -ms-transform-style: preserve-3d;
  transform-style: preserve-3d;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  max-width: 100%;
}
.partner__name {
  font-size: 14px;
  color: #343434;
  padding: 0 20px;
  display: block;
  height: 39px;
  line-height: 39px;
  text-align: center;
  vertical-align: middle;
  background: #f8f8f8;
  overflow: hidden;
}
.partner__description {
  position: absolute;
  z-index: -1;
  overflow: hidden;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0);
  color: #fff;
  font-size: 16px;
  padding: 20px;
  background: rgba(0,0,0,0.8);
  border-radius: 5px;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  font-family: 'PT Sans', sans-serif;
}
.partner:hover .partner__description {
  opacity: 1;
  -ms-filter: none;
  -webkit-filter: none;
          filter: none;
  z-index: 1;
}