/* popup */

.popup {
	position: fixed;
    display: flex;
    flex-direction: row;
    justify-content: center;
    top: 0;
    align-items: center;
    bottom: 0;
    right: 0;
    left: 0;
    z-index: 9999;
    background-color: rgba(0, 0, 0, .7);
    overflow-y: scroll;
}

.popup-form {
  background-color: var(--bg-l-gr);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  padding: 3em 2em;
  border-radius: 5px;
  position: relative;
  margin: 1em;
  min-width: 33%;
}
.popup-form > .close-popup{
  width: 2.5em;
  height: 2.5em;
  position: absolute;
  right: 0.5em;
  top: 0.5em;
  cursor: pointer;
  z-index: 9999;
}

.popup-form .title {
  text-transform: uppercase;
  font-size: 1.75em;
  line-height: 1.25em;
  font-weight: 700;
  margin-bottom: 0.5em;
}

.popup-form .text {
  font-size: 1.5em;
  line-height: 1em;
  font-weight: 300;
  margin-bottom: 2em;
}

.popup-form input, .popup-form textarea, .popup-form select{
      height: 2.25em;
      font-weight: 300;
      font-size: 1.25em;
      padding-left: 1em;
      margin-bottom: 1em;
      border: 1px solid silver;
      border-radius: 5px;
      position: relative;
}
/* .popup-form input:required:invalid {
      border: 1px solid var(--a-color);
} */
.popup-form textarea {
  min-height: 6em;
  padding: 0.5em 1em;
}
.popup-form input[data-req='true'] + span{
  position: relative;
}
.popup-form input[data-req='true'] + span::after {
  content: '*';
  position: absolute;
  top: -55px;
  right: -10px;
  color: var(--a-color);
}
.popup-form span.mandatory{
  font-size: 0.8em;
  position: absolute;
  bottom: 10px;
  font-weight: 500;
  color: var(--a-color-hover);
}
/*.popup-form input[type='file']::after {
  content: '*';
  position: absolute;
  top: -5px;
  right: 0;
  color: var(--a-color);
}*/
.popup-form input[type='file']{
  background-color: transparent;
  border: none;
  display: flex;
  padding: 0;
}
.popup-form input[type='file']::file-selector-button{
  background-color: #fff;
  color: var(--a-color);
  border: 2px solid var(--a-color);
  letter-spacing: 1.1px;
  font-weight: 500;
  min-height: 2rem;
  padding: 0 1.5rem;
  border-radius: 5px;
  font-size: 0.785rem;
  text-transform: uppercase;
  cursor: pointer;
}
.popup-form input[type='file']::file-selector-button:hover{
  background-color: var(--a-color);
  color: white;
  transition: transform 0.75s ease-in-out;
}

.popup-form button.button {
  font-size: 1.1em;
  padding: 0.7em;
}

.popup-form #files-area {
  min-height: 1em;
  font-weight: 300;
  font-size: 1em;
  margin-bottom: 1em;
}
.popup-form #files-area #files-names {
  display: flex;
    flex-direction: column;
}
.popup-form #files-area .file-block {
  padding: 0.5em;
  background-color: #ececec;
  border-radius: 5px;
  margin-bottom: 0.5em;
  position: relative;
}
.popup-form #files-area .file-delete {
  position: absolute;
  right: 10px;
  top: 2px;
  font-size: 1.5em;
  rotate: 45deg;
  font-weight: 500;
}

.spinner {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: none;
  width: 40px;
  height: 40px;
  border: 4px solid lightgray;
  border-top: 4px solid var(--a-color);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}
.form-message{
  text-transform: uppercase;
    font-size: 1.75em;
    line-height: 2em;
    font-weight: 600;
    text-align: center;
    padding: 1.75em 0.5em;
}
@media (min-width:1024px) {
  .popup-form {
    padding: 3em 2.75em;
  }
}

@media (min-width:1280px) {}

@media (min-width:1366px) {}

@media (min-width:1440px) {}

@media (min-width:1600px) {}
