custom-scanner {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 100;
  flex-flow: column nowrap;
  align-items: center;
  justify-content: center;
  transition: background-color 0.3s;
  background-color: #000000dd;
  transition: background-color 0.1s;
}

custom-scanner .custom-scanner-content {
  flex: 1;
  width: 80%;
  max-height: 80%;
  position: relative;
}

custom-scanner .custom-scanner-content > video,
custom-scanner .custom-scanner-content > div {
  position: absolute;
  top: 0%;
  left: 0%;
  max-height: 100%;
  max-width: 100%;
  height: 100%;
  width: 100%;
}

custom-scanner .custom-scanner-content > div {
  display: flex;
  z-index: 5;
  flex-flow: column nowrap;
  align-items: center;
  justify-content: center;
  color: #fff;
}

custom-scanner .custom-scanner-loader {
  background-color: transparent;
  display: block;
  aspect-ratio: 1;
  font-size: 2em;
  width: 1em;
  height: 1em;
  position: absolute;
  top: calc(50% - 0.5em);
  left: calc(50% - 0.5em);
  transform-origin: center;
  border-radius: 50%;
  border: solid 0.25em white;
  animation: cs_loader 1s linear 0s infinite alternate, cs_spinning 1.5s linear 0s infinite normal;
}

custom-scanner .custom-scanner-message {
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
}

custom-scanner .custom-scanner-footer {
  text-align: center;
  padding: 1em;
}

custom-scanner .custom-scanner-closer {
  border: none;
  display: inline-block;
  padding: 0.5em 1em;
  color: #fff;
  background: var(--color);
  cursor: pointer;
  text-transform: uppercase;
  transition-property: background;
}

custom-scanner[open] {
  display: flex;
}

custom-scanner.custom-scanner--ok {
  background-color: #197c4b99;
}

custom-scanner.custom-scanner--error, custom-scanner.custom-scanner--deja {
  background-color: #ff000099;
}

custom-scanner.custom-scanner--loading {
  background-color: #050547cc;
}

@keyframes cs_loader {
  0% {
    clip-path: polygon(0% 0%, 100% 0%, 100% 0%, 100% 0%, 50% 50%);
  }
  50% {
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 100% 100%, 50% 50%);
  }
  100% {
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%, 50% 50%);
  }
}

@keyframes cs_spinning {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

.scan_body {
  min-height: 100vh;
  display: flex;
  flex-flow: column nowrap;
}

.scan_list {
  flex: 1;
}

.scan_list ul {
  list-style-type: none;
  margin: 1em;
  padding: 0 1em;
  background-color: #00000022;
}

.scan_list ul li {
  display: flex;
  padding: 0.5em 0.5em;
  flex-flow: row nowrap;
  align-items: center;
  border-bottom: solid 2px var(--color);
}

.scan_list ul li small {
  color: var(--color);
}

.scan_list-item-content {
  flex: 1;
}

.scan_list-item-action button {
  border: solid 2px var(--color);
  background-color: var(--color);
  color: #fff;
  transition: 0.3s;
  border-radius: 1em;
  cursor: pointer;
}

.scan_list-item-action button:hover {
  color: var(--color);
  background-color: transparent;
}

.scan_footerBtn {
  cursor: pointer;
  position: sticky;
  padding: 1em 1em;
  font-size: 1rem;
  font-weight: bold;
  border: solid thick var(--color);
  background-color: var(--color);
  color: #fff;
  bottom: 0;
  transition: 0.3s;
}

.scan_footerBtn:hover {
  color: var(--color);
  background-color: transparent;
}
