figure {
  position: relative;
  float: left;
  overflow: hidden;
  margin: 0;
  min-width: 100%;
  max-width: 100%;
  max-height: 100vh;
  height: 100vh;
  width: 100vw;
  /*background: #fff;*/
  text-align: center;
  cursor: pointer;
}
figure h2 {
  letter-spacing: 4px;
  font-weight: 100;
  font-size:17px;
  padding-top: 45vh;
  color:#a0a0a0;
  -webkit-transition: -webkit-transform 0.35s;
  transition: transform 0.35s;
  -webkit-transform: translate3d(0, 0px, 0);
  transform: translate3d(0, 0px, 0);
}
figure h2 abbr.unline {
  display:block;
  width:8%;
  margin:10px 46% 12px 46%;
  border-bottom: 1px solid #a0a0a0;
  float:left;
  text-align: center;
}
figure h2 abbr.untxt {
  display:block;
  width:100%;
  float:left;
  text-align: center;
  letter-spacing: 0px;
  font-size:13px;
  color:#b5b5b5;
  opacity: 0.5;
  line-height: 18px;
}
figure p {
  padding: 150px 2% 0 2%;
  opacity: 0;
  -webkit-transition: opacity 0.35s, -webkit-transform 0.35s;
  transition: opacity 0.35s, transform 0.35s;
  -webkit-transform: translate3d(0, 20px, 0);
  transform: translate3d(0, 20px, 0);
  letter-spacing: 0px;
  font-weight: 100;
  line-height: 18px;
  font-size:12px;
  color:#fff;
}
figure p.c_gray {
  color:#959595;
}
figure p abbr.amore {
  display:block;
  width: 30px;
  height: 30px;
  border:#fff 1px solid;
  text-align: center;
  color:#fff;
  position: absolute;
  margin-top:13px;
  left:46.4%;
}
figure p abbr.amore i {
  color:#fff;
  margin-top:1px;
  font-size:24px;
  margin-left:3px;
}
figure a {
  z-index: 1000;
  text-indent: 200%;
  white-space: nowrap;
  font-size: 0;
  opacity: 0;
}

figure:hover img {
  opacity: 1;
}
figure.vtype1:hover h2 {
  opacity: 1;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  color:#fff;
}
figure.vtype1:hover h2 abbr.unline {
  border-bottom: 1px solid #bbbaba;
}
figure.vtype1:hover h2 abbr.untxt {
  color:#b5b5b5;
}

figure.vtype2:hover h2 {
  opacity: 1;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  color:#434343;
}
figure.vtype2:hover h2 abbr.unline {
  border-bottom: 1px solid #aaaaaa;
}
figure.vtype2:hover h2 abbr.untxt {
  color:#7d7d7d;
}



figure.vtype3:hover h2 {
  opacity: 1;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  color:#fff;
}
figure.vtype3:hover h2 abbr.unline {
  border-bottom: 1px solid #fff;
}
figure.vtype3:hover h2 abbr.untxt {
  color:#b5b5b5;
}

figure.vtype4:hover h2 {
  opacity: 1;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  color:#fff;
}
figure.vtype4:hover h2 abbr.unline {
  border-bottom: 1px solid #fff;
}
figure.vtype4:hover h2 abbr.untxt {
  color:#535353;
}


figure:hover p {
  opacity: 1;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}
figure img {
  -webkit-transition: opacity 0.35s;
  transition: opacity 0.35s;
  position: relative;
  display: block;
  min-height: 100%;
  max-width: 100%;
  width: 100vw;
}
figure figcaption, figure figcaption > a {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
figure figcaption {
  color: #fff;
  text-transform: uppercase;
  font-size: 1.25em;
  backface-visibility: hidden;
  /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#535353+0,232323+45&0+0,0.8+67 */
  -webkit-transition: opacity 1s ease-in-out;
  -moz-transition: opacity 1s ease-in-out;
  -o-transition: opacity 1s ease-in-out;
  transition: opacity 1s ease-in-out;
  background: -moz-linear-gradient(top,  rgba(81,81,81,0) 0%, rgba(35,35,35,0.54) 45%, rgba(68,68,68,1) 84%);/* FF3.6-15 */
  background: -webkit-linear-gradient(top,  rgba(81,81,81,0) 0%,rgba(35,35,35,0.54) 45%,rgba(68,68,68,1) 84%);/* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(to bottom,  rgba(81,81,81,0) 0%,rgba(35,35,35,0.54) 45%,rgba(68,68,68,1) 84%);/* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00535353', endColorstr='#cc232323',GradientType=0 );/* IE6-9 */
}

/* 滑入背景值歸0 */
figure figcaption:hover {
  background: -moz-linear-gradient(top,  rgba(255,255,255,0) 0%, rgba(255,255,255,0) 100%);
  background: -webkit-linear-gradient(top,  rgba(255,255,255,0) 0%,rgba(255,255,255,0) 100%); 
  background: linear-gradient(to bottom,  rgba(255,255,255,0) 0%,rgba(255,255,255,0) 100%); 
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00ffffff', endColorstr='#00ffffff',GradientType=0 );
  -webkit-transition: opacity 1s ease-in-out;
  -moz-transition: opacity 1s ease-in-out;
  -o-transition: opacity 1s ease-in-out;
  transition: opacity 1s ease-in-out;
}
figure.vtype2 figcaption:hover {
  /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#ffffff+0,333333+100&0+0,0.22+100 */
  background: -moz-linear-gradient(top,  rgba(255,255,255,0) 0%, rgba(51,51,51,0.22) 100%); /* FF3.6-15 */
  background: -webkit-linear-gradient(top,  rgba(255,255,255,0) 0%,rgba(51,51,51,0.22) 100%); /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(to bottom,  rgba(255,255,255,0) 0%,rgba(51,51,51,0.22) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00ffffff', endColorstr='#38333333',GradientType=0 ); /* IE6-9 */
  -webkit-transition: opacity 1s ease-in-out;
  -moz-transition: opacity 1s ease-in-out;
  -o-transition: opacity 1s ease-in-out;
  transition: opacity 1s ease-in-out;
}
figure.vtype4 figcaption:hover {
/* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#ffffff+0,f2f2f2+100&0+0,0.22+100 */
background: -moz-linear-gradient(top,  rgba(255,255,255,0) 0%, rgba(242,242,242,0.22) 100%); /* FF3.6-15 */
background: -webkit-linear-gradient(top,  rgba(255,255,255,0) 0%,rgba(242,242,242,0.22) 100%); /* Chrome10-25,Safari5.1-6 */
background: linear-gradient(to bottom,  rgba(255,255,255,0) 0%,rgba(242,242,242,0.22) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00ffffff', endColorstr='#38f2f2f2',GradientType=0 ); /* IE6-9 */
  -webkit-transition: opacity 1s ease-in-out;
  -moz-transition: opacity 1s ease-in-out;
  -o-transition: opacity 1s ease-in-out;
  transition: opacity 1s ease-in-out;
}
/* 滑入背景值歸0 end */

figure figcaption:before, figure figcaption:after {
  position: absolute;
  top: 30px;
  right: 30px;
  bottom: 30px;
  left: 30px;
  content: '';
  opacity: 0;
  -webkit-transition: opacity 0.35s, -webkit-transform 0.35s;
  transition: opacity 0.35s, transform 0.35s;
}
figure figcaption:after {
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
  -webkit-transform: scale(0, 1);
  transform: scale(0, 1);
}
figure figcaption:before {
  border-right: 1px solid #fff;
  border-left: 1px solid #fff;
  -webkit-transform: scale(1, 0);
  transform: scale(1, 0);
}
figure figcaption:hover:before, figure figcaption:hover:after {
  opacity: 1;
  -webkit-transform: scale(1);
  transform: scale(1);
}

figure.effect-bubba img {
  -webkit-transition: opacity 1s, -webkit-transform 1s;
  transition: opacity 1s, transform 1s;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
figure.effect-bubba:hover img {
  -webkit-transform: scale3d(1.1,1.1,1);
  transform: scale3d(1.1,1.1,1);
  background: -moz-linear-gradient(top,  rgba(255,255,255,0) 0%, rgba(255,255,255,0) 100%);
  background: -webkit-linear-gradient(top,  rgba(255,255,255,0) 0%,rgba(255,255,255,0) 100%); 
  background: linear-gradient(to bottom,  rgba(255,255,255,0) 0%,rgba(255,255,255,0) 100%); 
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00ffffff', endColorstr='#00ffffff',GradientType=0 );
}