:focus{
  box-shadow: none;
  outline: none;
}

img, svg {
  max-width: 100%;
  height: auto;
  object-fit: contain;

  -webkit-backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  -moz-backface-visibility: hidden;
  -ms-backface-visibility: hidden;
  -o-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  -o-user-select: none;
  user-select: none;
  -webkit-transform-style: flat;
  -webkit-transform-style: flat;
  -moz-transform-style: flat;
  -ms-transform-style: flat;
  -o-transform-style: flat;
  transform-style: flat;
  -webkit-tap-highlight-color: transparent;
  -webkit-user-drag: none;
  outline: 0;
  position: relative;
  overflow: hidden;
}


/* flickity slider */

.flickity-viewport {
  width: 100%;
}

.slider {
  width: 100%;
  height: auto;
}

.flickity-slider {
  cursor: pointer;
  position: relative;
  z-index: 0;
  -webkit-transform: none !important;
  transform: none !important;
}

.slide {
  width: 100%;
  top: 0 !important;
  left: 0 !important;
  visibility: hidden;
}

.slide.is-selected{
  visibility: visible;
  z-index: 1;
  left: 0 !important;
}  

.slider-footer {
  width: 100%;
  height: auto;
  margin-top: .4rem;
}


/* lazyloading */

.lazy {
  -webkit-transition: opacity 200ms ease;
  -moz-transition: opacity 200ms ease;
  -ms-transition: opacity 200ms ease;
  -o-transition: opacity 200ms ease;
  transition: opacity 200ms ease;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0);
}

.lazy.lazyloaded, .lazy.flickity-lazyloaded{
  opacity: 1;
  -ms-filter: none;
  filter: none;
}


/* placeholder to prevent reflow */

.responsive-image {
  outline: 0;
  position: relative;
  overflow: hidden;
}

.responsive-image img {
  position: absolute;
  top: 0;
  left: 0;
}