.umodal-disable-scroll {
  max-width: 100%;
  position: fixed;
  left: 0;
  right: 0;
  box-sizing: border-box;
}

.umodal {
  display: none;
  position: fixed;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  justify-content: center;
  align-items: center;
  background: #f2f2f2;
  z-index: 9999;
}

.umodal_show {
  display: flex;
}

.umodal_image {
  overflow: hidden;
}

.umodal_loading:before {
  content: '';
  position: absolute;
  width: 50px;
  height: 50px;
  border: 2px dashed #000;
  border-radius: 100%;
  animation: umodal-preloader 2.5s infinite linear;
}

.umodal__inner {
  position: relative;
  max-width: 950px;
  max-height: 95%;
  display: flex;
  flex-direction: column;
  padding: 40px;
  box-sizing: border-box;
}

.umodal_image .umodal__inner {
  max-width: 100%;
}

.umodal__content {
  max-width: 100vw;
  padding: 20px 25px;
  border: 2px solid #000;
  background: #fff;
  box-sizing: border-box;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.umodal_image .umodal__content {
  padding: 0;
  border: 0;
  background: none;
  overflow: hidden;
}

.umodal_loading .umodal__content {
  background: none;
  border: 0;
}

.umodal__open {
  cursor: pointer;
}

.umodal__close {
  position: absolute;
  right: 5px;
  top: 5px;
  width: 25px;
  height: 25px;
  border: 0;
  background: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB2aWV3Qm94PSIwIDAgNjQgNjQiIHhtbDpzcGFjZT0icHJlc2VydmUiPgogIDxwYXRoIGZpbGw9IiMyMjIyMjIiIGQ9Ik0yOC45NDEsMzEuNzg2TDAuNjEzLDYwLjExNGMtMC43ODcsMC43ODctMC43ODcsMi4wNjIsMCwyLjg0OWMwLjM5MywwLjM5NCwwLjkwOSwwLjU5LDEuNDI0LDAuNTkgICBjMC41MTYsMCwxLjAzMS0wLjE5NiwxLjQyNC0wLjU5bDI4LjU0MS0yOC41NDFsMjguNTQxLDI4LjU0MWMwLjM5NCwwLjM5NCwwLjkwOSwwLjU5LDEuNDI0LDAuNTljMC41MTUsMCwxLjAzMS0wLjE5NiwxLjQyNC0wLjU5ICAgYzAuNzg3LTAuNzg3LDAuNzg3LTIuMDYyLDAtMi44NDlMMzUuMDY0LDMxLjc4Nkw2My40MSwzLjQzOGMwLjc4Ny0wLjc4NywwLjc4Ny0yLjA2MiwwLTIuODQ5Yy0wLjc4Ny0wLjc4Ni0yLjA2Mi0wLjc4Ni0yLjg0OCwwICAgTDMyLjAwMywyOS4xNUwzLjQ0MSwwLjU5Yy0wLjc4Ny0wLjc4Ni0yLjA2MS0wLjc4Ni0yLjg0OCwwYy0wLjc4NywwLjc4Ny0wLjc4NywyLjA2MiwwLDIuODQ5TDI4Ljk0MSwzMS43ODZ6Ii8+Cjwvc3ZnPgo=) no-repeat center;
  transition: visibility .3s;
  outline: none;
  cursor: pointer;
  -moz-appearance: none;
  -webkit-appearance: none;
  z-index: 9999;
}

/* DARK STYLE */

.umodal_inverse  {
  background: rgba(0, 0, 0, 0.9);  
}

.umodal_inverse.umodal_image  {
  color: #d4d4d4;
}

.umodal_inverse.umodal_loading:before {
  border-color: #d4d4d4;
}

.umodal_inverse .umodal__close {
  background: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2NCA2NCI+CiAgPHBhdGggZmlsbD0iI2ZmZiIgZD0iTTI4Ljk0MSwzMS43ODZMMC42MTMsNjAuMTE0Yy0wLjc4NywwLjc4Ny0wLjc4NywyLjA2MiwwLDIuODQ5YzAuMzkzLDAuMzk0LDAuOTA5LDAuNTksMS40MjQsMC41OSAgIGMwLjUxNiwwLDEuMDMxLTAuMTk2LDEuNDI0LTAuNTlsMjguNTQxLTI4LjU0MWwyOC41NDEsMjguNTQxYzAuMzk0LDAuMzk0LDAuOTA5LDAuNTksMS40MjQsMC41OWMwLjUxNSwwLDEuMDMxLTAuMTk2LDEuNDI0LTAuNTkgICBjMC43ODctMC43ODcsMC43ODctMi4wNjIsMC0yLjg0OUwzNS4wNjQsMzEuNzg2TDYzLjQxLDMuNDM4YzAuNzg3LTAuNzg3LDAuNzg3LTIuMDYyLDAtMi44NDljLTAuNzg3LTAuNzg2LTIuMDYyLTAuNzg2LTIuODQ4LDAgICBMMzIuMDAzLDI5LjE1TDMuNDQxLDAuNTljLTAuNzg3LTAuNzg2LTIuMDYxLTAuNzg2LTIuODQ4LDBjLTAuNzg3LDAuNzg3LTAuNzg3LDIuMDYyLDAsMi44NDlMMjguOTQxLDMxLjc4NnoiLz4KPC9zdmc+Cg==) no-repeat center;
}

.umodal__close:focus,
.umodal__close:hover {
  transform: scale(1.1);
}

.umodal_loading .umodal__close {
  visibility: hidden;
}

.umodal__image {
  max-width: 100%;
  display: block;
  opacity: 0;
  margin: auto;
  transition: opacity .2s .1s;
  -webkit-transform: translateZ(0);
  -moz-transform: translateZ(0);
  -ms-transform: translateZ(0);
  -o-transform: translateZ(0);
  transform: translateZ(0);
  pointer-events: none;
}

.umodal__image_show {
  opacity: 1;
}

@keyframes umodal-preloader {
  100% { transform: rotate(360deg) }
}

@media only screen and (max-width: 500px) {
  .umodal__inner {
    height: 100%;
    max-height: 100%;
    width: 100%;
    padding: 0;
    justify-content: center;
    background: #fff;
  }
  .umodal_inverse .umodal__inner {
    background: none;
  }
  .umodal_loading .umodal__inner {
    background: none;
  }
  .umodal__content {
    border: 0;
  }
  .umodal__close {
    width: 45px;
    height: 45px;
    top: 10px;
    right: 10px;
    background: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciICB3aWR0aD0iMjEuMTg4IiBoZWlnaHQ9IjIxLjE4OCIgdmlld0JveD0iMCAwIDIxLjE4OCAyMS4xODgiPiAgPHBhdGggZmlsbD0iIzIyMiIgZD0iTTIxLjIwMSwxOS4wNzkgTDE5LjA3OSwyMS4yMDAgTDEwLjU4NSwxMi43MDUgTDIuMTg0LDIxLjEwNiBMMC4wODEsMTkuMDA0IEw4LjQ4MiwxMC42MDMgTC0wLjAxMywyLjEwOCBMMi4xMDksLTAuMDEzIEwxMC42MDQsOC40ODIgTDE5LjAwNCwwLjA4MSBMMjEuMTA3LDIuMTgzIEwxMi43MDYsMTAuNTg0IEwyMS4yMDEsMTkuMDc5IFoiLz48L3N2Zz4=) no-repeat center;
  }
  .umodal_inverse .umodal__close {
    background: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMS4xODgiIGhlaWdodD0iMjEuMTg4IiB2aWV3Qm94PSIwIDAgMjEuMTg4IDIxLjE4OCI+PHBhdGggZmlsbD0iI2ZmZiIgZD0iTTIxLjIwMSwxOS4wNzkgTDE5LjA3OSwyMS4yMDAgTDEwLjU4NSwxMi43MDUgTDIuMTg0LDIxLjEwNiBMMC4wODEsMTkuMDA0IEw4LjQ4MiwxMC42MDMgTC0wLjAxMywyLjEwOCBMMi4xMDksLTAuMDEzIEwxMC42MDQsOC40ODIgTDE5LjAwNCwwLjA4MSBMMjEuMTA3LDIuMTgzIEwxMi43MDYsMTAuNTg0IEwyMS4yMDEsMTkuMDc5IFoiLz48L3N2Zz4=) no-repeat center;
  }
}
