@charset "UTF-8";
.nosup {
  text-decoration: line-through !important;
  opacity: 0.3 !important;
  pointer-events: none;
}

.bevel {
  --b: .5rem;
  position: relative;
  background: #f5e6bc;
  background: #00ffff;
  clip-path: polygon(var(--b) 0, calc(100% - var(--b)) 0, 100% var(--b), 100% calc(100% - var(--b)), calc(100% - var(--b)) 100%, var(--b) 100%, 0 calc(100% - var(--b)), 0 var(--b));
}

.bevel::before {
  content: "";
  position: absolute;
  background: black;
  z-index: -1;
  width: calc(100% - 0.5rem);
  height: calc(100% - 0.5rem);
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  --b: .42rem;
  clip-path: polygon(var(--b) 0, calc(100% - var(--b)) 0, 100% var(--b), 100% calc(100% - var(--b)), calc(100% - var(--b)) 100%, var(--b) 100%, 0 calc(100% - var(--b)), 0 var(--b));
}

.bevel {
  padding: 3rem 1rem;
  color: #00ffff;
}

* {
  -moz-user-select: none;
       user-select: none;
  -webkit-user-select: none;
}

h1, h2, h3, p {
  margin: 0;
  padding: 0;
  font-size: 1rem;
}

@font-face {
  font-family: "Departure Mono";
  src: url("./assets/fonts/DepartureMono/DepartureMono-Regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
}
body:has(#window-shell.open) #mana-pool-ctr {
  position: sticky;
  z-index: 9000;
  border: 1px solid #b1b1ba;
  background: #1b1d21;
  pointer-events: none;
  padding: 1rem;
  transition: all 0.2s;
}

#app-main {
  background: #1b1d21;
  height: 100dvh;
  padding: 2rem 0.5rem;
  box-sizing: border-box;
  width: 100%;
  overflow: hidden;
}

.main-content {
  display: flex;
  flex-flow: column;
  height: 100%;
  box-sizing: border-box;
}

html, body {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  padding: 0;
  margin: 0;
  color: #b1b1ba;
  font-family: "Departure Mono";
  font-size: 16px;
  display: flex;
  width: 100%;
  justify-content: center;
  overflow: hidden;
}

body {
  width: 100%;
  max-width: 800px;
  overflow: hidden;
  height: 100dvh;
}

button {
  all: unset;
}

.system-button-wrapper {
  background: #b1b1ba;
  border: 1px solid #b1b1ba;
  border-radius: 0.25rem;
}
.system-button-wrapper:hover {
  margin-top: 0.25rem;
}
.system-button-wrapper:hover .systems {
  border-bottom: none;
}

button {
  border: 1px solid #b1b1ba;
  color: #b1b1ba;
  background: #1b1d21;
  font-size: 1rem;
  text-transform: uppercase;
  font-family: "Departure Mono";
  padding: 0.25rem 0.5rem;
}
button[data-state=true]:not(button.signal) {
  background: #00ffff;
  color: #1b1d21;
  border-color: #1b1d21;
}
button.systems {
  background: #1b1d21;
  color: #00ffff;
  padding: 0;
  border: none;
  padding: 0.25rem 0.5rem;
  border-bottom: 0.25rem solid #b1b1ba;
  border-radius: 0.25rem;
  border-bottom-left-radius: 0.45rem;
  border-bottom-right-radius: 0.45rem;
  font-size: 0.8rem;
}
button.direction {
  background: #b1b1ba;
  color: #1b1d21;
  padding: 0.25rem;
}
button.direction:hover {
  background: #00ffff;
  border-color: #00ffff;
}
button.selector {
  font-size: 0.7rem;
  border: none;
  background: #b1b1ba;
  color: #1b1d21;
}
button.selector[data-state=true], button.selector:hover {
  background: #00ffff;
}
button.signal {
  display: flex;
}
button.signal::before {
  content: "[■]";
  color: rgba(177, 177, 186, 0.35);
}
button.signal[data-state=true]::before {
  color: #00ffff;
}
button.text {
  border: none;
  text-decoration: underline;
  color: #00ffff;
  font-size: 0.8rem;
  padding: 0;
  background: none;
}
button.close {
  border: none;
  font-size: 0.8rem;
  padding: 0;
  background: none;
}
button.close::before {
  content: "[X]-CLOSE";
  color: #00ffff;
  text-decoration: underline;
}

.input-text {
  outline: none;
  background: #b1b1ba;
  color: #1b1d21;
  padding-left: 0.25rem;
  white-space: nowrap;
  overflow-x: hidden;
  min-width: 0;
  flex: 1;
  box-sizing: border-box;
  caret-color: #00ffff;
}
.input-text:empty::before {
  content: attr(data-preview);
  pointer-events: none;
  color: rgba(27, 29, 33, 0.25);
}
.input-text:not(:empty)::before {
  display: none;
}

.group {
  display: flex;
  gap: 0.5rem;
}

.main-view {
  display: flex;
  flex-flow: column;
  width: 100%;
  padding: 0.5rem;
  box-sizing: border-box;
  overflow: hidden;
}
.main-view .view-heading {
  box-sizing: border-box;
  border: 1px solid #b1b1ba;
  padding-bottom: 0.5rem;
  border-bottom: none;
  width: 100%;
  position: relative;
}
.main-view .view-heading::after {
  content: attr(data-heading_text);
  position: absolute;
  top: -120%;
  left: 50%;
  transform: translateX(-50%);
  text-align: center;
  padding: 0rem 0.5rem;
  background: #1b1d21;
  text-transform: uppercase;
  color: #00ffff;
  white-space: nowrap;
}
.main-view .view-bottom {
  box-sizing: border-box;
  border: 1px solid #b1b1ba;
  padding-top: 0.5rem;
  border-top: none;
  width: 100%;
}
.main-view .main-view-content {
  text-align: center;
  padding: 0.5rem;
  height: 100%;
  display: flex;
  box-sizing: border-box;
}
.main-view .main-view-content .mana-symbol {
  width: 100%;
  max-width: 1.5rem;
}
.main-view .content-footer {
  display: flex;
  padding: 0 0.5rem;
  gap: 0.5rem;
}

#codex-menu .main-view-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}
#codex-menu .logo {
  min-width: 0;
  max-width: 8rem;
  filter: invert(58%) sepia(35%) saturate(271%) hue-rotate(197deg) brightness(200%) contrast(55%);
  margin-right: auto;
}

#battleground {
  min-height: 0;
  flex: 1;
  position: relative;
}
#battleground:has(#player-hand[data-state=true]) .battleground-filters {
  display: none;
}
#battleground .main-view-content {
  min-height: 0;
  flex-direction: column;
  gap: 0.5rem;
  position: relative;
}
#battleground .main-view-content::before {
  content: "";
  position: absolute;
  background-image: url("./assets/the_stack_logo.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 60%;
  inset: 0;
  opacity: 0.05;
  filter: invert(58%) sepia(35%) saturate(271%) hue-rotate(197deg) brightness(200%) contrast(55%);
  rotate: -5deg;
  z-index: 0;
  pointer-events: none;
}
#battleground .battleground-button-group {
  align-items: flex-end;
}
#battleground .battleground-button-group h2 {
  font-size: 0.8rem;
  margin-right: auto;
}
#battleground .direction {
  border: none;
  background: #b1b1ba;
  color: #1b1d21;
  align-self: flex-end;
  padding-top: 5%;
  padding-bottom: 5%;
}
#battleground .player-bg {
  flex: 1;
  min-height: 0;
  display: flex;
  position: relative;
  box-sizing: border-box;
}
#battleground .player-bg:has(.filter[data-state=true][data-filter_name]) .card-bg {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  position: absolute;
  min-width: 0;
  width: 0;
  height: 0;
  overflow: hidden;
}
#battleground .player-bg:has(.filter[data-state=true][data-filter_name]) .card-bg.filtered {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  position: relative;
  width: auto;
  height: auto;
  min-width: 4.5rem;
  overflow: visible;
}
#battleground .player-bg:has(#player-hand[data-state=true]) .battleground-container {
  filter: blur(6px);
  pointer-events: none;
  z-index: 0;
}
#battleground .player-bg .battleground-filters {
  display: flex;
  position: absolute;
  top: 100%;
  right: 0;
  align-items: center;
}
#battleground .player-bg .battleground-filters h2 {
  font-size: 0.7rem;
  text-transform: uppercase;
  margin-right: 0.5rem;
}
#battleground .player-bg .battleground-filters button {
  font-size: 0.8rem;
  background: #b1b1ba;
  color: #1b1d21;
}
#battleground .player-bg .battleground-filters button[data-state=true] {
  background: #00ffff !important;
  border-color: #00ffff !important;
}
#battleground .player-bg .battleground-filters button.disabled {
  background: rgba(177, 177, 186, 0.25);
  color: #b1b1ba;
  border-color: rgba(177, 177, 186, 0.25);
  opacity: 0.5;
}
#battleground .player-bg .battleground-container {
  display: flex;
  flex-flow: row wrap;
  gap: 1.5rem 0.7rem;
  overflow: scroll;
  flex: 1;
  min-height: 0;
  justify-content: center;
  padding-top: 1rem;
  align-content: flex-start;
  position: relative;
}
#battleground .player-bg .battleground-container.player {
  background: radial-gradient(circle at center, transparent 60%, rgba(0, 255, 255, 0.1) 100%);
}
#battleground .player-bg .battleground-container.opp {
  background: radial-gradient(circle at center, transparent 60%, rgba(245, 83, 115, 0.1) 100%);
}
#battleground .player-bg .battleground-container .card-bg {
  flex: 0 0 10%;
  min-width: 4.5rem;
  transform: translateZ(0);
}
#battleground .player-bg .battleground-container .card-bg.active {
  margin-bottom: 2rem;
  position: relative;
}
#battleground .player-bg .battleground-container .card-bg.active:not(.token)::after {
  content: "❰";
  min-width: 2rem;
  min-height: 2rem;
  color: #00ffff;
  position: absolute;
  bottom: -2rem;
  left: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  transform: translate(-50%) rotate(90deg);
}
#battleground .player-bg .battleground-container .card-bg.active.token::before {
  content: "❰";
  min-width: 2rem;
  min-height: 2rem;
  color: #00ffff;
  position: absolute;
  bottom: -2rem;
  left: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  transform: translate(-50%) rotate(90deg);
}
#battleground .player-bg .battleground-container .card-bg.token[data-mana_color=W]:not([data-is_tapped=true]) .card-image {
  filter: drop-shadow(0 0 0.5rem #fffef5) saturate(0.2);
}
#battleground .player-bg .battleground-container .card-bg.token[data-mana_color=U]:not([data-is_tapped=true]) .card-image {
  filter: drop-shadow(0 0 0.5rem #0f9cfa) saturate(1);
}
#battleground .player-bg .battleground-container .card-bg.token[data-mana_color=B]:not([data-is_tapped=true]) .card-image {
  filter: drop-shadow(0 0 0.5rem #23242b) saturate(1);
}
#battleground .player-bg .battleground-container .card-bg.token[data-mana_color=R]:not([data-is_tapped=true]) .card-image {
  filter: drop-shadow(0 0 0.5rem #ff2457) saturate(1);
}
#battleground .player-bg .battleground-container .card-bg.token[data-mana_color=G]:not([data-is_tapped=true]) .card-image {
  filter: drop-shadow(0 0 0.5rem #67cf06) saturate(1);
}
#battleground .player-bg .battleground-container .card-bg.token[data-mana_color=C]:not([data-is_tapped=true]) .card-image {
  filter: drop-shadow(0 0 0.5rem #c0cbd1) saturate(1);
}
#battleground .player-bg .battleground-container .card-bg.token {
  position: relative;
  display: flex;
  align-self: flex-start;
}
#battleground .player-bg .battleground-container .card-bg.token .token-container {
  display: flex;
}
#battleground .player-bg .battleground-container .card-bg.token .token-container::before {
  content: "";
  position: absolute;
  background: #1b1d21;
  width: 80%;
  height: 80%;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
#battleground .player-bg .battleground-container .card-bg.token .token-img {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 80%;
  height: 70%;
  transform: translate(-50%, -55%);
}
#battleground .player-bg .battleground-container .card-bg.token .token-heading {
  position: absolute;
  bottom: 0.9rem;
  font-size: 0.6rem;
  left: 50%;
  transform: translateX(-50%);
  color: #1b1d21;
}
#battleground .player-bg .battleground-container .card-bg.token::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 12px;
  z-index: -1;
}
#battleground .player-bg .battleground-container .card-bg.token .card-image {
  position: absolute;
  top: 40%;
  left: 50%;
  width: 45%;
  transform: translate(-50%, -50%);
  background-size: 60%;
  background-repeat: no-repeat;
  background-position: center;
  z-index: 2;
  filter: saturate(0.2);
}
#battleground .player-bg .battleground-container .card-bg.token[data-is_tapped=true] .token-container {
  transform: rotate(35deg);
  filter: saturate(0.25) brightness(0.7);
}
#battleground .player-bg .battleground-container .card-bg[data-is_tapped=true]:not(.token) img {
  transform: rotate(35deg) translateZ(0);
  filter: saturate(0.25);
}
#battleground .player-bg .battleground-container .card-bg img {
  width: 100%;
  backface-visibility: hidden;
  transform: translateZ(0);
  will-change: transform, opacity, filter;
}
#battleground #game-phase-group {
  margin-top: 0.5rem;
  align-items: center;
  gap: 0;
}
#battleground #game-phase-group h2, #battleground #game-phase-group p, #battleground #game-phase-group button {
  font-size: 0.8rem;
}
#battleground #game-phase-group button.game-phase {
  background: #b1b1ba;
  color: #1b1d21;
}
#battleground #game-phase-group button[data-state=active] {
  border-color: #00ffff;
  background: #00ffff;
}
#battleground #game-phase-group h2 {
  margin-right: 0.5rem;
}
#battleground #game-phase-group p {
  margin-left: 1rem;
  margin-right: auto;
  color: #00ffff;
}
#battleground .life-total {
  display: flex;
  flex: 0 1;
  align-self: flex-start;
  width: 100%;
}
#battleground #life-container {
  flex: 1;
  display: flex;
}
#battleground #life-counter {
  display: flex;
  align-items: center;
}
#battleground .life-pip {
  width: 100%;
}
#battleground .life-pip[data-state=empty] {
  background: #b1b1ba;
  opacity: 0.25;
}
#battleground .life-pip[data-state=full] {
  opacity: 1;
  background: #89f553;
}
#battleground .life-total-display {
  margin-right: 0.5rem;
}
#battleground .life-total-display::after {
  content: attr(data-value);
}
#battleground #player-hand {
  position: absolute;
  margin: 0.5rem;
  left: 0;
  bottom: -50%;
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  pointer-events: none;
}
#battleground #player-hand[data-state=true] {
  bottom: 0;
  z-index: 4;
  opacity: 1;
  max-height: unset;
  overflow: reset;
  pointer-events: initial;
}
#battleground #player-hand #hand-settings {
  min-width: 100%;
  flex: 1;
  background: #b1b1ba;
  color: #1b1d21;
  padding: 0 0.25rem;
  box-sizing: border-box;
}
#battleground #player-hand #hand-container {
  opacity: 1;
  width: 100%;
  overflow-x: unset;
  overflow-y: scroll;
  -ms-overflow-style: none;
  scrollbar-width: none;
  display: flex;
  align-items: flex-end;
  align-content: flex-end;
}
#battleground #player-hand #hand-container::-webkit-scrollbar {
  display: none;
}
#battleground #player-hand .card {
  flex: 0 0 10%;
  position: relative;
  overflow: unset;
  transition: all 0.2s;
  cursor: pointer;
}
#battleground #player-hand .card.is-selected img:not(.dummy) {
  width: 160%;
  top: -60%;
  z-index: 1000;
}
#battleground #player-hand img {
  position: absolute;
  width: 100%;
  transition: all 0.2s;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
}
#battleground #player-hand img.dummy {
  position: relative;
  opacity: 0;
  pointer-events: none;
}

.card-menu {
  position: relative;
  min-width: 0;
  width: 100%;
  flex-grow: 1;
  margin-top: -1.5rem;
  padding: 0.5rem 0;
  position: sticky;
  z-index: 0;
  position: relative;
  box-sizing: border-box;
}
.card-menu button {
  background: #b1b1ba;
  color: #1b1d21;
  font-size: 0.8rem;
}
.card-menu button:hover {
  background: #00ffff;
  border-color: #00ffff;
}
.card-menu .inner-group {
  background: #70035b;
  position: absolute;
  top: 0;
}

#mana-pool .main-view-content {
  display: flex;
  gap: 0.5rem;
}
#mana-pool .mana-pool-item {
  padding: 0rem 0.25rem;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
#mana-pool .mana-pool-item h2, #mana-pool .mana-pool-item p {
  font-size: 1rem;
  font-weight: bold;
  line-height: 0;
  display: flex;
  align-items: center;
}
#mana-pool .mana-pool-item .mana-heading {
  display: flex;
  gap: 0.5rem;
  justify-content: center;
}
#mana-pool .mana-pool-item .mana-qty::before {
  content: attr(data-available);
}
#mana-pool .mana-pool-item .mana-qty::after {
  content: attr(data-total);
}

#bg-actions {
  display: flex;
  justify-content: space-between;
}
#bg-actions .column {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  width: 100%;
  margin-top: 2%;
}
#bg-actions #sub-view-groups {
  text-wrap: balance;
  margin-bottom: 1rem;
}
#bg-actions .group {
  display: flex;
  flex-flow: row wrap;
  width: 100%;
  justify-content: center;
}
#bg-actions .crypt {
  margin-right: 0.5rem;
}
#bg-actions .card-image {
  min-width: 0;
  align-self: flex-start;
  flex: 0 0 auto;
  width: auto;
  height: 112px;
  max-width: none;
  -o-object-fit: contain;
     object-fit: contain;
}
#bg-actions img {
  width: auto;
  height: 112px;
  flex: 0 0 auto;
  max-width: none;
}

/* ---------------------------- WINDOWS -------------------------------- */
#discard-window, #deck-search-window, #deck-reveal-window {
  position: relative;
}
#discard-window:has(.selector[data-state=true][data-selector_name=select-random]) #discard-qty, #discard-window:has(#audience-type-row) #discard-qty, #deck-search-window:has(.selector[data-state=true][data-selector_name=select-random]) #discard-qty, #deck-search-window:has(#audience-type-row) #discard-qty, #deck-reveal-window:has(.selector[data-state=true][data-selector_name=select-random]) #discard-qty, #deck-reveal-window:has(#audience-type-row) #discard-qty {
  opacity: 1;
  pointer-events: unset;
}
#discard-window:has(.selector[data-state=true][data-selector_name=select-random]) #discard-heading, #discard-window:has(#audience-type-row) #discard-heading, #deck-search-window:has(.selector[data-state=true][data-selector_name=select-random]) #discard-heading, #deck-search-window:has(#audience-type-row) #discard-heading, #deck-reveal-window:has(.selector[data-state=true][data-selector_name=select-random]) #discard-heading, #deck-reveal-window:has(#audience-type-row) #discard-heading {
  background: #1b1d21;
  color: #b1b1ba;
}
#discard-window:has(.selector[data-state=true][data-selector_name=select-cards]) #discard-list, #discard-window:has(.selector[data-state=true][data-selector_name=select-cards]) #card-list, #discard-window:has(.selector[data-state=true][data-selector_name=select-cards]) #discard-heading, #deck-search-window:has(.selector[data-state=true][data-selector_name=select-cards]) #discard-list, #deck-search-window:has(.selector[data-state=true][data-selector_name=select-cards]) #card-list, #deck-search-window:has(.selector[data-state=true][data-selector_name=select-cards]) #discard-heading, #deck-reveal-window:has(.selector[data-state=true][data-selector_name=select-cards]) #discard-list, #deck-reveal-window:has(.selector[data-state=true][data-selector_name=select-cards]) #card-list, #deck-reveal-window:has(.selector[data-state=true][data-selector_name=select-cards]) #discard-heading {
  opacity: 1;
  pointer-events: unset;
}
#discard-window:has(.selector[data-state=true][data-selector_name=select-cards]) #discard-list img[data-state=selected], #discard-window:has(.selector[data-state=true][data-selector_name=select-cards]) #card-list img[data-state=selected], #deck-search-window:has(.selector[data-state=true][data-selector_name=select-cards]) #discard-list img[data-state=selected], #deck-search-window:has(.selector[data-state=true][data-selector_name=select-cards]) #card-list img[data-state=selected], #deck-reveal-window:has(.selector[data-state=true][data-selector_name=select-cards]) #discard-list img[data-state=selected], #deck-reveal-window:has(.selector[data-state=true][data-selector_name=select-cards]) #card-list img[data-state=selected] {
  scale: 1;
  filter: none;
  position: relative;
  border: 1px solid #f55373;
  border-radius: 0.2rem;
}
#discard-window #discard-heading, #deck-search-window #discard-heading, #deck-reveal-window #discard-heading {
  background: #00ffff;
  color: #1b1d21;
  text-indent: 0.5rem;
  display: flex;
  opacity: 0.5;
}
#discard-window #discard-heading[data-value="00"], #deck-search-window #discard-heading[data-value="00"], #deck-reveal-window #discard-heading[data-value="00"] {
  background: #1b1d21;
  color: #b1b1ba;
}
#discard-window #discard-heading::before, #deck-search-window #discard-heading::before, #deck-reveal-window #discard-heading::before {
  order: 0;
  text-indent: 0;
  color: #b1b1ba;
  background: #1b1d21;
  padding-right: 0.25rem;
  content: "[CARDS SELECTED:";
}
#discard-window #discard-heading::after, #deck-search-window #discard-heading::after, #deck-reveal-window #discard-heading::after {
  text-indent: 0.25rem;
  color: #b1b1ba;
  background: #1b1d21;
  content: "]";
}
#discard-window #discard-qty, #discard-window #discard-list, #discard-window #card-list, #deck-search-window #discard-qty, #deck-search-window #discard-list, #deck-search-window #card-list, #deck-reveal-window #discard-qty, #deck-reveal-window #discard-list, #deck-reveal-window #card-list {
  opacity: 0.2;
  pointer-events: none;
}
#discard-window .main-win-content, #deck-search-window .main-win-content, #deck-reveal-window .main-win-content {
  display: flex;
  flex-flow: row wrap;
  gap: 1rem;
}
#discard-window .row, #deck-search-window .row, #deck-reveal-window .row {
  flex: 1;
  min-width: 100%;
  display: flex;
  align-items: center;
}
#discard-window .row#discard-type-row h2, #discard-window .row#search-dest-row h2, #discard-window .row#audience-type-row h2, #deck-search-window .row#discard-type-row h2, #deck-search-window .row#search-dest-row h2, #deck-search-window .row#audience-type-row h2, #deck-reveal-window .row#discard-type-row h2, #deck-reveal-window .row#search-dest-row h2, #deck-reveal-window .row#audience-type-row h2 {
  margin-right: auto;
}
#discard-window .row:has(.button-group), #deck-search-window .row:has(.button-group), #deck-reveal-window .row:has(.button-group) {
  justify-content: space-between;
}
#discard-window #discard-list.row, #discard-window #card-list.row, #deck-search-window #discard-list.row, #deck-search-window #card-list.row, #deck-reveal-window #discard-list.row, #deck-reveal-window #card-list.row {
  display: flex;
  flex-flow: row wrap;
  gap: 0.25rem;
  max-height: 200px;
  width: 100%;
  overflow: scroll;
}
#discard-window #discard-list.row img, #discard-window #card-list.row img, #deck-search-window #discard-list.row img, #deck-search-window #card-list.row img, #deck-reveal-window #discard-list.row img, #deck-reveal-window #card-list.row img {
  min-width: 0;
  flex: 0 0 20%;
  box-sizing: border-box;
  filter: saturate(0.35) brightness(0.8);
  scale: 0.8;
}
#discard-window #discard-list.row img:not([data-state=selected]):hover, #discard-window #card-list.row img:not([data-state=selected]):hover, #deck-search-window #discard-list.row img:not([data-state=selected]):hover, #deck-search-window #card-list.row img:not([data-state=selected]):hover, #deck-reveal-window #discard-list.row img:not([data-state=selected]):hover, #deck-reveal-window #card-list.row img:not([data-state=selected]):hover {
  filter: saturate(0.5) brightness(1);
}
#discard-window .reset, #deck-search-window .reset, #deck-reveal-window .reset {
  position: absolute;
  bottom: 0;
}
#discard-window .button-group, #deck-search-window .button-group, #deck-reveal-window .button-group {
  display: flex;
  align-items: center;
}
#discard-window .button-group p, #deck-search-window .button-group p, #deck-reveal-window .button-group p {
  color: #00ffff;
  margin: 0 0.5rem;
}

#token-builder {
  position: relative;
}
#token-builder .token-type-ctr {
  display: flex;
  position: absolute;
  right: 0rem;
  top: -1rem;
  z-index: 900;
}
#token-builder .token-type-ctr button {
  color: #1b1d21;
  background: #b1b1ba;
  font-size: 0.8rem;
}
#token-builder .token-type-ctr button::before {
  all: unset;
}
#token-builder .token-type-ctr button[data-state=true] {
  background: #00ffff;
  border-color: #00ffff;
}
#token-builder .main-view {
  padding-left: 0;
  padding-right: 0;
}
#token-builder .main-win-content.content {
  display: block;
}
#token-builder .input-label {
  font-size: 0.8rem;
}

.token-builder-win {
  display: none;
}
.token-builder-win[data-state=true] {
  display: flex;
}
.token-builder-win .content {
  width: 100%;
  height: 100%;
  display: flex;
  padding: 0.5rem;
  padding-top: 0;
  box-sizing: border-box;
  gap: 0.5rem;
}
.token-builder-win .view-heading {
  margin-bottom: 1rem;
}
.token-builder-win .input-label {
  margin-right: 0.5rem;
}
.token-builder-win .input-label.margin-none {
  margin: 0;
}
.token-builder-win .group {
  max-height: 1.3rem;
}

#mana-token-ctr .direction {
  padding: 0.24rem 0.5rem;
}
#mana-token-ctr .content {
  gap: 0.5rem;
  flex-direction: column;
}
#mana-token-ctr .mana-token {
  display: flex;
  min-width: 100%;
  flex: 1;
  justify-content: center;
  align-items: center;
  margin-top: 0.5rem;
}
#mana-token-ctr .mana-token img {
  width: 100%;
  max-width: 2rem;
}
#mana-token-ctr .mana-token .mana-qty {
  color: #00ffff;
  font-size: 1rem;
  margin-right: 0.5rem;
}
#mana-token-ctr .mana-token .mana-qty::before {
  content: attr(data-value);
}
#mana-token-ctr .mana-token .btn-container {
  display: flex;
  gap: 0.5rem;
  width: 100%;
  position: relative;
  align-items: center;
  align-content: center;
  justify-content: flex-end;
}
#mana-token-ctr .mana-token .btn-container::before {
  content: "";
  border-bottom: 4px dotted #b1b1ba;
  width: 100%;
  margin-left: 1rem;
  margin-right: 0.5rem;
  opacity: 0.5;
}
#mana-token-ctr .reset {
  position: absolute;
  bottom: 0;
}

#generic-token-ctr .content {
  flex-flow: row wrap;
}
#generic-token-ctr .input-group {
  width: 100%;
  display: flex;
  align-items: center;
  align-content: center;
  flex-flow: row wrap;
  margin-bottom: 0.5rem;
}
#generic-token-ctr .input-group.required[data-state=false] .input-label {
  border-left: 0.5rem solid #f55373;
  padding-left: 0.5rem;
  box-sizing: border-box;
}
#generic-token-ctr .attributes-group {
  gap: 0;
  align-items: center;
}
#generic-token-ctr .attributes-group .input-label {
  margin-right: 0.25rem;
}
#generic-token-ctr .attributes-group .input-text {
  margin-right: 1rem;
  width: 2.5rem;
  text-align: center;
}
#generic-token-ctr .reset {
  position: absolute;
  bottom: 0;
}
#generic-token-ctr [data-group_name=token-style] {
  gap: 0 0.25rem;
}
#generic-token-ctr [data-group_name=token-style] .signal[data-state=true] {
  background: #00ffff;
  border-color: #00ffff;
}
#generic-token-ctr [data-group_name=token-style] .style-group {
  gap: 0;
  display: flex;
  min-width: 0;
  flex: 1;
}
#generic-token-ctr [data-group_name=token-color] .group {
  min-width: 0;
  flex: 1;
  gap: 0;
  flex-flow: row nowrap;
  align-items: center;
}
#generic-token-ctr [data-group_name=token-color] .color-selector {
  width: 100%;
  height: 1.5rem;
  min-width: 0;
  flex: 1;
  color: #00ffff;
  filter: saturate(0.5);
  opacity: 0.4;
}
#generic-token-ctr [data-group_name=token-color] .color-selector[data-state=true] {
  opacity: 1;
}
#generic-token-ctr [data-group_name=token-qty] .button-group {
  display: flex;
  min-width: 0;
  flex: 1;
  flex-flow: row wrap;
  align-items: center;
}
#generic-token-ctr [data-group_name=token-qty] .button-group button {
  align-self: flex-start;
  background: #b1b1ba;
  color: #1b1d21;
}
#generic-token-ctr [data-group_name=token-qty] .button-group p {
  min-width: 0;
  width: auto;
  margin: 0 0.5rem;
  color: #00ffff;
}
#generic-token-ctr .input-tip {
  min-width: 100%;
  font-size: 0.6rem;
  color: #00ffff;
  padding-top: 0.25rem;
}
#generic-token-ctr .signal {
  flex: 1;
  justify-content: center;
  align-items: center;
  padding: 0.2rem;
  background: #b1b1ba;
  color: #1b1d21;
  font-size: 0.7rem;
}
#generic-token-ctr .signal::before {
  display: none;
}

#destroy-card-window .header .content,
#return-card-window .header .content,
#return-deck-window .header .content {
  display: flex;
  flex-flow: row wrap;
}
#destroy-card-window .main-win-content,
#return-card-window .main-win-content,
#return-deck-window .main-win-content {
  flex-flow: row wrap;
  justify-content: center;
  gap: 1rem;
}
#destroy-card-window .subhead,
#return-card-window .subhead,
#return-deck-window .subhead {
  min-width: 100%;
  flex: 1;
  color: #00ffff;
}

#window-shell {
  background: rgba(0, 0, 0, 0.5);
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: 8;
  backdrop-filter: blur(0.3rem);
  display: none;
}
#window-shell.open {
  display: block;
}

#window-container {
  position: absolute;
  top: 36%;
  left: 50%;
  transform: translate(-50%);
  padding: 1rem;
  z-index: 9;
  background: #1b1d21;
  width: 25rem;
  max-width: 60%;
  border: 1px solid #b1b1ba;
  display: none;
}
#window-container.open {
  display: block;
}
#window-container .window {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
#window-container .header {
  width: 100%;
  display: flex;
  flex-flow: row wrap;
  margin-bottom: 2rem;
}
#window-container .header .content {
  display: flex;
  flex-flow: row wrap;
}
#window-container .header .content h2 {
  min-width: 100%;
}
#window-container .header .close {
  margin-bottom: 0.5rem;
  width: auto;
}
#window-container .header .close:hover {
  background: red;
}
#window-container .content {
  display: flex;
  width: 100%;
}
#window-container .content.column {
  flex-direction: row;
}
#window-container .content.row {
  flex-direction: column;
}
#window-container .content .content-column {
  width: 100%;
}
#window-container .footer {
  margin-top: 2rem;
}
#window-container .footer .content {
  justify-content: flex-end;
  display: flex;
  gap: 0.5rem;
}

#draw-card-window {
  display: flex;
  flex-flow: column;
}
#draw-card-window .content {
  display: flex;
  width: 100%;
  gap: 1rem;
  align-content: center;
}
#draw-card-window .content-column {
  display: flex;
  flex-flow: row wrap;
  min-width: 0;
}
#draw-card-window .content-column.inputs {
  width: 100%;
  align-content: center;
}
#draw-card-window .sub-heading {
  min-width: 100%;
  margin-top: 0.5rem;
  text-align: center;
}
#draw-card-window .sub-heading span::before {
  content: attr(data-deck_size);
}
#draw-card-window .sub-heading span::after {
  content: attr(data-deck_total);
}
#draw-card-window img {
  min-width: 0%;
  flex: 0 0 100%;
}
#draw-card-window .button-group {
  display: flex;
  width: 100%;
  align-items: center;
  padding-bottom: 0.5rem;
}
#draw-card-window .button-group p {
  margin: 0 0.5rem;
}
#draw-card-window .footer {
  align-self: flex-end;
}

#card-viewer {
  display: flex;
  flex-flow: column;
}
#card-viewer .content {
  display: flex;
  width: 100%;
  gap: 1rem;
  align-content: center;
}
#card-viewer .content-column {
  display: flex;
  flex-flow: row wrap;
  min-width: 0;
  width: 70%;
}
#card-viewer .content-column.inputs {
  flex-direction: column;
  width: 50%;
  align-content: flex-start;
  justify-content: center;
  gap: 1rem;
}
#card-viewer .sub-heading {
  min-width: 100%;
  margin-top: 0.5rem;
  text-align: center;
}
#card-viewer img {
  width: 100%;
}
#card-viewer .button-group {
  display: flex;
  width: 100%;
  align-items: center;
  padding-bottom: 0.5rem;
}
#card-viewer .button-group p {
  margin: 0 0.5rem;
}
#card-viewer .footer {
  align-self: flex-end;
}

/* ---------------------------- MOBILE -------------------------------- */
@media (max-width: 768px) {
  html, body {
    font-size: 12px;
  }
  #window-container {
    max-width: 80%;
  }
  #app-main {
    display: block;
  }
  #battleground #hand-container .card {
    min-width: 15%;
  }
  #battleground .main-view-content .group:last-of-type {
    margin-top: 1.5rem;
  }
  #battleground .battleground-container {
    box-sizing: border-box;
  }
  #battleground .player-bg#player-battleground {
    flex: 1.2;
  }
  #battleground .player-bg#player-battleground .battleground-container {
    margin-bottom: 1rem;
  }
  #battleground .player-bg .battleground-filters {
    top: calc(100% - 1rem);
    align-items: center;
  }
  #battleground .player-bg .battleground-filters h2 {
    font-size: 0.7rem;
    text-transform: uppercase;
    margin-right: 0.5rem;
  }
  #battleground .player-bg .battleground-filters button {
    font-size: 0.8rem;
    background: #b1b1ba;
    color: #1b1d21;
  }
  #sub-view-groups {
    max-width: 20rem;
    margin: 0 auto;
  }
}
/* ---------------------------- MOBILE -------------------------------- *//*# sourceMappingURL=codex_85.css.map */