@import url("https://fonts.googleapis.com/css?family=Fredoka+One|Rubik:300,400,400i,500,700&display=swap");
@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(359deg);
  }
}
@keyframes MoveUpDown {
  50% {
    transform: translateY(5px);
    will-change: transform;
  }
}
@keyframes MoveSideSide {
  5% {
    transform: rotate(0deg) translateY(0.1rem);
  }
  25% {
    transform: rotate(-3deg) translateY(0.1rem);
  }
  45% {
    transform: rotate(0deg) translateY(0.1rem);
  }
  55% {
    transform: rotate(0deg) translateY(0.1rem);
  }
  75% {
    transform: rotate(3deg) translateY(0.1rem);
  }
  95% {
    transform: rotate(0deg) translateY(0.1rem);
  }
}
@keyframes pulse {
  from {
    opacity: 1;
  }
  to {
    opacity: 0.5;
  }
}
*,
*:before,
*:after {
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

html {
  font-size: 14px;
}

html,
body {
  height: 100%;
}

body {
  display: flex;
  flex-direction: column;
  margin: 0;
  font-size: 1rem;
  color: #bbbbbb;
  overflow: hidden;
}

body,
input,
select,
textarea,
button {
  font-family: "Rubik", Helvetica, Arial, sans-serif;
}

h2 {
  font-size: 1.2rem;
  font-weight: 700;
  color: white;
}

a {
  color: #27B5C6;
  text-decoration: none;
  cursor: pointer;
}

[role=button] {
  cursor: pointer;
}

:focus {
  outline: none;
}

input:not([type=checkbox]):not([type=radio]),
select,
button {
  height: 2rem;
  padding: 0.25rem 0.5rem;
  font-size: 0.9rem;
  font-family: "Rubik", Helvetica, Arial, sans-serif;
  color: #eee;
  background-color: rgba(123, 123, 123, 0.15);
  border: 1px solid transparent;
  border-bottom-color: rgba(0, 0, 0, 0.85);
  border-top-color: rgba(255, 255, 255, 0.15);
  border-radius: 0.25rem;
}

input:not([type=checkbox]):not([type=radio]) {
  border-top-color: rgba(0, 0, 0, 0.85);
  border-bottom-color: rgba(255, 255, 255, 0.15);
  transform: translateY(-1px);
  box-shadow: none;
}

input[type=checkbox],
input[type=radio] {
  margin-right: 0.25rem;
}

input[type=checkbox] + label,
input[type=radio] + label {
  display: inline-block;
  margin-right: 1rem;
}

option {
  background-color: #333;
}

input:focus,
select:focus,
textarea:focus,
button:focus {
  outline: none;
}

code {
  display: inline-block;
  padding: 0.1em 0.2em;
  font: 12px Monaco, Consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
  color: #bbb;
  background-color: rgba(123, 123, 123, 0.5);
}

.simple-list li {
  padding-bottom: 5px;
}

.simplebar-scrollbar:before {
  background: #27B5C6;
}

.previewicon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  text-align: center;
  font-size: 1rem;
  color: white;
  background-color: black;
  border-radius: 999px;
  opacity: 0.66;
}

.track-warning {
  color: #902B14;
  cursor: pointer;
}

.track-warning:empty {
  display: none;
}

.utitle,
.prsnJoined {
  color: rgba(255, 255, 255, 0.4);
  font-size: 0.66rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.herecon {
  color: #0fb8ad;
  background-color: #282828;
  height: calc(0.75rem + 4px);
  width: calc(0.75rem + 4px);
  padding: 2px;
  font-size: 0.75em;
  display: block;
  position: absolute;
  bottom: 0;
  border-radius: 999px;
  right: -0.25rem;
}

.herecon.idle {
  color: #faa61a;
}

.notice {
  margin: 0;
  background-color: #222;
  overflow: hidden;
  height: 100%;
  padding: 1.5rem;
}

.notice#notice {
  display: block;
}

.notice p {
  margin-bottom: 15px;
  margin-top: 15px;
}

.flexpacer {
  flex: 1;
}

.tabs {
  display: flex;
}

.tab {
  flex: 1;
  margin: 0;
  padding: 0.5em;
  font-size: 0.85rem;
  color: white;
  text-align: center;
  background-color: #93a787;
  border: 0;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 0;
  transition: all 0.4s;
}

.tab:hover,
.tab:active,
.tab.on {
  color: #ffffff;
  background-color: #6c825f;
  font-weight: 500;
}

span.removemeIcon.material-icons {
  font-size: 1rem;
  vertical-align: middle;
}

.butt {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  color: white;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  text-decoration: none;
  background-color: #27B5C6;
  border-top: 1px solid rgba(255, 255, 255, 0.3);
  border-bottom: 1px solid black;
  transition: all 100ms ease-in-out;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}

.butt:hover {
  background-color: #93dae2;
}

.graybutt {
  color: #888;
  background: rgba(255, 255, 255, 0.066);
}

.graybutt:hover {
  background: #444;
}

.graybutt:focus {
  background: rgba(255, 255, 255, 0.1);
}

.redbutt {
  background: #c43;
}

.redbutt:hover {
  background: #b54;
}

.iconbutt {
  width: 2rem;
  padding: 0;
  font-size: 0.5rem;
}

.iconbutt.on {
  color: #0fb8ad !important;
  background: rgba(255, 255, 255, 0.033);
  border-top: 1px solid black;
  border-bottom: 1px solid rgba(15, 184, 173, 0.66) !important;
  box-shadow: inset 0 0 1rem rgba(15, 184, 173, 0.33) !important;
}

.iconbutt.on#cloud_with_rain {
  color: #902B14 !important;
  border-bottom: 1px solid rgba(144, 43, 20, 0.66) !important;
  box-shadow: inset 0 0 1rem rgba(144, 43, 20, 0.33) !important;
}

.iconbutt .material-icons {
  font-size: 1.43rem;
}

.scrollWrap {
  height: 100%;
  overflow: auto;
}

.pvbarWrap {
  display: flex;
}

.working .material-icons {
  animation: spin 3s infinite linear;
}

.ps {
  position: relative;
}

.ps__rail-x {
  display: none !important;
}

.ps__rail-y {
  z-index: 2;
}

.ps .ps__rail-y:focus,
.ps .ps__rail-y:hover,
.ps .ps__rail-y.ps--clicking {
  background-color: transparent;
  outline: none;
}

.ps__thumb-y,
.ps__rail-y:hover > .ps__thumb-y,
.ps__rail-y:focus > .ps__thumb-y,
.ps__rail-y.ps--clicking .ps__thumb-y {
  width: 0.5rem;
  background-color: rgba(123, 123, 123, 0.5);
  border-radius: 0.2rem;
}

/*------------------------------------ MAIN BODY THINGS */
#mainGrid {
  grid-area: main;
  flex: 1;
  display: grid;
  grid-template-rows: auto auto auto 1fr;
  grid-template-columns: 1fr;
  grid-template-areas: "stage" "main" "main" "main";
  overflow: hidden;
}

#mainGrid.mmusrs {
  grid-template-areas: "stage" "theme" "mmopts" "users";
}

#mainGrid.mmusrs #queuebox,
#mainGrid.mmusrs #thehistoryWrap,
#mainGrid.mmusrs #actualChat,
#mainGrid.mmusrs #login {
  display: none;
}

#mainGrid.mmqueue {
  grid-template-areas: "stage" "theme" "mmopts" "queues";
}

#mainGrid.mmqueue #usersbox,
#mainGrid.mmqueue #thehistoryWrap,
#mainGrid.mmqueue #actualChat,
#mainGrid.mmqueue #login {
  display: none;
}

#mainGrid.mmchat {
  grid-template-areas: "stage" "theme" "mmopts" "chat";
}

#mainGrid.mmchat #usersbox,
#mainGrid.mmchat #queuebox,
#mainGrid.mmchat #thehistoryWrap,
#mainGrid.mmchat #login {
  display: none;
}

#mainGrid.login {
  grid-template-rows: auto 1fr;
  grid-template-areas: "stage" "login";
}

#mainGrid.login #usersbox,
#mainGrid.login #queuebox,
#mainGrid.login #history,
#mainGrid.login #thehistoryWrap,
#mainGrid.login #themebox,
#mainGrid.login #actualChat,
#mainGrid.login #voteActions,
#mainGrid.login #minimodeoptions {
  display: none;
}

/* About page */
body.blog {
  overflow: auto;
}

div#blog {
  flex: 1;
  padding: 4rem;
  background-color: #282828;
}

/* Top Bar / Site Header */
#topbar {
  display: flex;
  align-items: center;
  padding: 0;
  color: #fff;
  background-color: #2B2B2B;
  padding: 0 35px;
  margin-bottom: 5px;
}

.ftlogo {
  padding-right: 7.5px;
  border-right: 1px solid #d8d8d8;
  margin: 0;
  color: white;
  font-size: 1.5rem;
  font-weight: 700;
  font-family: "Fredoka One", Helvetica, Arial, sans-serif;
}

#idtitle {
  padding-left: 7.5px;
  padding-right: 15px;
  font-family: "Rubik", Helvetica, Arial, sans-serif;
  font-size: 16px;
  color: white;
  font-weight: normal;
  margin: 15px 0;
}

#topbar button {
  box-shadow: none;
}

#loggedInName {
  margin: 0 0.5rem;
  cursor: pointer;
  text-decoration: none;
}

#loggedInName:hover {
  text-decoration: underline;
}

.header_icon {
  margin: 0.2rem 0.2rem 0 0.2rem;
  padding: 0;
  font-size: 0;
  line-height: 0;
  background: none;
  border: 0;
}

.header_icon .material-icons {
  font-size: 1.2rem;
  color: #888;
}

/* MiniMode Nav */
#minimodeoptions {
  grid-area: mmopts;
}

#minimodeoptions .tab {
  background-color: #1b1b1b;
}

#minimodeoptions .tab.on {
  background-color: #222;
}

/* Users Lists */
#usersbox {
  grid-area: users;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-right: 1px solid #C6C6C6;
}

#userslist {
  flex: 1;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

#usertabs {
  padding-top: 0.5rem;
}

.usersWrap {
  overflow: auto;
}

#allusers,
#justwaitlist {
  padding-top: 1rem;
}

#allusersWrap,
#justwaitWrap {
  height: 100%;
}

.prson {
  display: flex;
  align-items: center;
  min-width: 0;
  padding: 0.25rem 1.5rem;
}

#allusersWrap .prson {
  cursor: pointer;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
}

.prsnName {
  flex: 1;
  font-size: 0.9rem;
  font-weight: 700;
  line-height: 1.5;
  white-space: nowrap;
  overflow-x: hidden;
  text-overflow: ellipsis;
}

#userslist .utitle {
  margin-left: auto;
}

#userslist .prson .prsnJoined {
  display: none;
}

#userslist .prson:hover .prsnJoined {
  display: block;
}

#userslist .prson.blockd .prsnName,
#userslist .prson.blockd .prsnJoined,
#userslist .prson.blockd .utitle {
  opacity: 0.5;
}

.botson {
  background-color: #000;
  background-size: auto 100%;
  border-radius: 999px;
  background-position: center 55%;
  background-repeat: no-repeat;
  border-bottom: 1px solid #888;
}

#userslist .botson {
  margin-right: 0.75rem;
  width: 2rem;
  height: 2rem;
  position: relative;
}

span.block {
  width: 2rem;
  height: 2rem;
  font-size: 2rem;
  background-color: rgba(0, 0, 0, 0.5);
  color: #27B5C6;
  border-radius: 999px;
}

span.block:empty {
  display: none;
}

/* Own adjustments */
#allusers > div .prson .botson .herecon {
  padding: 0.75px;
  height: calc(0.75rem + 2px);
  width: calc(0.75rem + 2px);
}
#allusers > div .prson .prsnName {
  font-size: 0.9rem;
}
#allusers > div .prson .utitle {
  font-size: 0.7rem;
}
#allusers > div .prson:hover .utitle {
  display: none;
}

#usersbox .simplebar-content-wrapper {
  background-repeat: no-repeat;
  background-size: 90%;
  background-position: 50% 90%;
}

#queue-buttons {
  padding: 2.5px;
}
#queue-buttons button {
  cursor: pointer;
  margin: 2.5px;
  border-radius: 0;
  border: none;
  background-color: #ffcf00;
  color: #2B2B2B;
  font-weight: 500;
  transition: all 0.4s;
}
#queue-buttons button:hover {
  background-color: #cca600;
}
#queue-buttons button .material-icons {
  font-size: 1rem;
  position: relative;
  top: 2px;
}

#allusersWrap {
  position: relative;
}
#allusersWrap .disco-monkey {
  position: absolute;
  width: 100%;
  left: 0;
  bottom: 0;
}

/* The Stage */
#stage {
  grid-area: stage;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}

#stage::before {
  content: "";
  position: absolute;
  z-index: 1;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: linear-gradient(rgba(0, 0, 0, 0.75), rgba(0, 0, 0, 0.55));
}

#stage > div:not(#screenBox) {
  position: relative;
  z-index: 2;
}

#djStage {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

#nowplaying {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto;
  grid-template-rows: auto auto 1fr;
  grid-template-areas: "art track timr" "art artist artist" "art plays plays";
  margin-bottom: auto;
  padding: 1.5rem;
}

#nowplaying::before {
  content: "";
  position: absolute;
  top: 3rem;
  left: 3rem;
  width: 15rem;
  height: 5rem;
  background-color: rgba(0, 0, 0, 0.25);
  box-shadow: 0 0 10rem 10rem rgba(0, 0, 0, 0.25);
}

#albumArt {
  grid-area: art;
  margin: 0.25rem 1rem 0 0.25rem;
  width: 4rem;
  height: 4rem;
  background-size: cover;
  background-position: center center;
}

#track {
  grid-area: track;
  font-size: 1.25rem;
  color: white;
}

#timr {
  grid-area: timr;
  padding-top: 0.15em;
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-align: right;
}

#artist {
  grid-area: artist;
  margin-bottom: 0.5rem;
  font-size: 1rem;
  font-weight: 400;
  overflow: hidden;
  color: white;
  white-space: nowrap;
  text-overflow: ellipsis;
}

#source,
#plays {
  font-size: 0.75rem;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.8);
}

#plays {
  grid-area: plays;
}

#playCount,
#firstPlay {
  margin-right: 0.5rem;
}

#playCount:empty,
#firstPlay:empty,
#lastPlay:empty {
  display: none;
}

#deck {
  grid-area: deck;
  display: flex;
  max-width: 100vw;
}

#deck.dance .avtr:not(.animate) {
  transform-origin: bottom;
  animation: MoveSideSide 2s linear infinite;
}

.spot {
  flex: 1;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  margin-right: 0.5rem;
  margin-left: 0.5rem;
  min-width: 0;
  height: 1.5rem;
}

.spot.empty .djplaque {
  flex-direction: column;
  color: rgba(255, 255, 255, 0.5);
}

.avtr {
  display: none;
  position: absolute;
  z-index: 0;
  bottom: 1.4rem;
  width: 100%;
  height: 8rem;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center bottom;
}

.avtr.animate {
  animation: MoveUpDown 1s linear infinite;
}

.djplaque {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: space-between;
  min-width: 0;
  padding: 0 1rem;
  font-size: 0.75rem;
  line-height: 1.5rem;
  text-align: center;
  background-color: #151515;
  border-top-left-radius: 0.5rem;
  border-top-right-radius: 0.5rem;
}

.djname {
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
  padding-right: 5px;
}

.djname .remove-me {
  color: white;
  margin-right: 5px;
}

.playcount {
  white-space: nowrap;
}

#prgbar {
  width: 100%;
  height: 0.5rem;
  border-bottom: 1px solid #333;
  margin-bottom: 0;
}

#volandthings,
#queueControls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.4rem 0.5rem;
  white-space: nowrap;
}

#volandthings {
  position: relative;
  background-color: #151515;
  border-bottom: 1px solid #333;
}

#songthings,
#voteActions,
#songActions,
#playerControls {
  display: flex;
  white-space: nowrap;
}

#songthings,
#playerControls {
  flex: 1;
}

#songthings .iconbutt {
  margin-right: 0.25rem;
}

#voteActions {
  margin-right: 1rem;
}

#playerControls {
  margin-left: 1rem;
}

#volplace {
  flex: 1;
  display: flex;
  align-items: center;
  padding-left: 0.25rem;
  padding-right: 0.25rem;
  white-space: nowrap;
}

#volstatus {
  cursor: pointer;
}

#volplace .material-icons {
  font-size: 16px !important;
}

#shareinfo {
  text-align: right;
}

#stealContain {
  display: none;
  position: fixed;
  z-index: 59;
  top: 50%;
  left: 50%;
  box-shadow: 0 0.25rem 1rem -0.25rem black;
}

#stealBox {
  width: 16rem;
  padding: 1rem;
  background-color: #333;
  border-radius: 5px;
}

#stealArrow {
  margin-top: -0.5rem;
  margin-left: 1.15rem;
  width: 0;
  height: 0;
  border-left: 1rem solid transparent;
  border-right: 1rem solid transparent;
  border-bottom: 1rem solid #333;
}

select#stealpicker {
  width: 100%;
  font-size: 1rem;
  border: none;
  font-family: "Rubik", Helvetica, Arial, sans-serif;
  background-color: #222;
  padding-left: 0.25rem;
  color: #eee;
  white-space: nowrap;
}

#addToQueueBttn {
  margin-left: 1em;
  color: white;
  background-color: #27B5C6 !important;
  border-right: 1px solid black;
  border-left: 1px solid black;
  border-radius: 5px;
}

#slider {
  margin-right: 0.5rem;
  width: 100%;
  max-width: 10rem;
}

.ui-slider {
  position: relative;
  text-align: left;
}

.ui-slider .ui-slider-handle {
  position: absolute;
  z-index: 2;
  width: 1.25rem;
  height: 1.25rem;
  cursor: grab;
  background-color: #bbb;
  border: 0.2rem solid #666;
  border-radius: 999px;
  touch-action: none;
}

.ui-slider .ui-slider-range {
  position: absolute;
  z-index: 1;
  font-size: 0.7em;
  display: block;
  border: 0;
  background-position: 0 0;
}

.ui-slider-horizontal .ui-slider-range-min {
  left: 0;
  background-color: #27B5C6;
}

.ui-slider-horizontal {
  height: 3px;
}

.ui-slider-horizontal .ui-slider-handle {
  top: -0.6rem;
  margin-left: -0.6em;
}

.ui-slider-horizontal .ui-slider-range {
  top: 0;
  height: 100%;
}

.ui-slider-horizontal .ui-slider-range-min {
  left: 0;
  background-color: #27B5C6 !important;
}

.ui-slider-horizontal .ui-slider-range-max {
  right: 0;
}

.ui-state-default,
.ui-widget-content .ui-state-default,
.ui-widget-header .ui-state-default,
.ui-button,
html .ui-button.ui-state-disabled:hover,
html .ui-button.ui-state-disabled:active {
  font-weight: normal;
}

.ui-widget.ui-widget-content {
  border: none;
  background-color: rgba(204, 204, 204, 0.431372549);
}

.ui-widget-content {
  border: 1px solid #dddddd;
  background: #ffffff;
  color: #333333;
}

#screenBox {
  position: absolute;
  top: -100%;
  width: 100%;
  height: 100%;
  z-index: 0;
  transition: top 2s ease-in-out;
  pointer-events: none;
}

#scScreen,
#playerArea {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
}

#screenover {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(rgba(0, 0, 0, 0.5), rgba(255, 255, 255, 0.1));
}

/* Queues / Playlists */
#queuebox {
  grid-area: queues;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}

input#queueFilter {
  width: 100%;
}

div#filterMachine {
  padding: 0.5rem;
}

#mainqueue .material-icons {
  margin: 0 pad1;
  font-size: 1.2rem;
}

#queuelist .pvbar {
  padding: 0.5rem 0.5rem;
  background-color: #222;
  border-bottom: 1px solid black;
  cursor: move;
  /* fallback if grab cursor is unsupported */
  cursor: grab;
  cursor: -webkit-grab;
}

#queuelist .pvbarWrap {
  align-items: center;
}

#queuelist .pvbar.editing .edittags {
  display: none;
}

#queuelist .pvbar.editing .closeeditor {
  display: block;
}

#queuelist .listwords {
  flex: 1;
  margin-left: 0.5rem;
}

#listpickerWrap {
  flex: 1;
}

select#listpicker {
  width: 100%;
  background-color: #333;
  padding-left: 0.5rem;
}

#queueControls,
#filterMachine {
  background-color: #222;
}

#qControlButtons {
  display: flex;
}

button#cancelqsearch {
  display: none;
  margin-left: 0.5rem;
}

#addbox,
#plmanager {
  display: none;
  flex-direction: column;
  height: 100%;
  background-color: #222;
  overflow: hidden;
}

#plmanager {
  padding: 0.5rem;
}

.ortxt {
  padding: 0.25rem;
  text-align: center;
}

input#qsearch {
  margin: 0.5rem;
}

#queuelist {
  flex: 1;
  height: 100%;
  background-color: #181818;
  overflow: auto;
}

#searchResults {
  flex: 1;
  background-color: #282828;
}

#mergeContain {
  display: none;
  position: absolute;
  z-index: 15;
  width: calc(100% - 30px);
  margin: 0.5rem 15px 0 15px;
  box-shadow: 0 0.25rem 0.5rem -0.125rem black;
}

#mergeArrow {
  position: absolute;
  bottom: 100%;
  right: 1.85rem;
  width: 0;
  height: 0;
  border-left: 1rem solid transparent;
  border-right: 1rem solid transparent;
  border-bottom: 1rem solid #333;
}

#mergeBox {
  background-color: #333;
  padding: 15px;
  border-radius: 5px;
}

#mergeSetup {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

#mergeHappening {
  display: none;
}

select#mergepicker,
#mergepicker2 {
  width: calc(50% - 50px);
  font-size: 14px;
  border: none;
  font-family: "Rubik", Helvetica, Arial, sans-serif;
  background-color: #222;
  padding-left: 5px;
  color: #eee;
  height: 24px;
  white-space: nowrap;
}

#mergeBox i.material-icons {
  font-size: 17px !important;
  font-weight: 700;
  cursor: default;
  vertical-align: middle;
}

#mergeCompleted {
  display: none;
}

.importResult {
  display: flex;
  align-items: center;
  padding: 0.25rem 0;
  border-bottom: 1px solid #111;
}

.importResult .material-icons {
  margin-left: 0.5rem;
  font-size: 1rem;
}

a.importLinkCheck {
  color: #eee;
  line-height: 0;
}

.imtxt {
  flex: 1;
  padding-right: 0.5rem;
}

.tagPromptBox {
  padding: 1rem 0 0.25rem 0.5rem;
  font-size: 0.875rem;
}

.tagPromptBox .closebutt {
  float: right;
}

.closeeditor {
  display: none;
}

.tagsNlink {
  display: flex;
}

.tagsNlink input.tagMachine {
  flex: 1;
  margin: 0;
}

.tagSongLink {
  padding: 0.25rem 0.25rem 0.25rem 0.5rem;
}

#mainqueue .material-icons.tracklink {
  font-size: 1.5rem;
}

/* History */
#thehistoryWrap {
  position: absolute;
  z-index: 15;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #222;
  overflow: auto;
}

#thehistory .pvbar {
  padding: 0.5rem 0.5rem 0.5rem 0.5rem;
  border-bottom: 1px solid black;
}

.histmoreinfo {
  font-size: 0.8rem;
  color: #888;
}

.histart {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 0.5rem;
  height: 2.5rem;
  width: 2.5rem;
  background-size: cover;
  background-position: center;
}

.histlink {
  color: #bbb;
}

.qtxt {
  flex: 1;
}

/* Own adjustments */
#prgbar {
  border-bottom: lightgray;
}

#volandthings .butt {
  border: none;
  border-radius: 0;
  font-size: 0.4rem;
}
#volandthings .butt.greenbutt {
  font-weight: 500;
  margin-left: 0.25rem;
}
#volandthings #volplace {
  padding-left: 10px;
}
#volandthings #togglefullscreen {
  margin-left: 0.25rem;
}

#queuebox .butt {
  border: none;
  border-radius: 0;
  font-size: 0.4rem;
}
#queuebox #queueControls, #queuebox #filterMachine {
  background-color: transparent;
}
#queuebox #queuelist {
  background-color: transparent;
}
#queuebox #queuelist .pvbarWrap .bumpsongs, #queuebox #queuelist .pvbarWrap .bottomsongs, #queuebox #queuelist .pvbarWrap .edittags, #queuebox #queuelist .pvbarWrap .closeeditor, #queuebox #queuelist .pvbarWrap .deletesong {
  margin: 0 2.5px;
}

/* Theme */
#themebox {
  grid-area: theme;
  z-index: 15;
  padding: 0.5rem;
  font-size: 1rem;
  text-align: center;
  white-space: nowrap;
  text-overflow: ellipsis;
  background-color: #333;
  border-bottom: 1px solid #111;
  overflow: hidden;
}

#currentTheme {
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
  width: 100%;
}

/* Chat */
#actualChat {
  grid-area: chat;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background-color: #181818;
}

#chatsWrap {
  flex: 1;
  height: 100%;
  overflow: auto;
}

#newchat {
  width: 100%;
}

#newchatForm {
  flex: 1;
  margin-right: 0.25rem;
}

.newChat {
  position: relative;
  display: flex;
  justify-content: space-between;
  margin: 1rem;
  color: #ddd;
  word-break: break-word;
  background-color: #181818;
}

.newChat .botson {
  position: relative;
  z-index: 2;
  margin: 0.15rem 1rem 0 0;
  width: 2rem;
  height: 2rem;
  cursor: pointer;
}

#actualChat.avatarsOff .botson {
  display: none;
}

.nowplayn {
  position: relative;
  background-color: transparent;
}

.newChat.nowplayn,
.nowplayn + .newChat {
  border: 0;
}

.npmsg,
.lcrsp {
  position: relative;
  z-index: 2;
  width: 100%;
  padding: 0.25rem;
  color: #888;
  font-size: 0.75rem;
  text-align: center;
  background-color: #282828;
  border-radius: 0.25rem;
}

.chatContent {
  flex: 1;
  padding: 0 1.5rem 0 0;
}

.chatContent .utitle {
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.25);
}

.chatHead {
  display: flex;
}

.chatName {
  margin-right: 0.5rem;
  font-size: 0.75rem;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.4);
  cursor: pointer;
}

.modDelete {
  position: absolute;
  right: 0;
  top: 0;
  font-size: 1rem;
  padding-left: 0.25rem;
  font-weight: 400;
  padding-right: 0.25rem;
  background-color: #333;
  cursor: pointer;
  display: none;
  color: #999;
}

.modDelete:hover {
  background-color: #902B14;
  color: #ddd;
}

.chatText {
  position: relative;
}

.chatText.deleteMe:hover {
  background-color: #282828;
}

.chatText.deleteMe:hover .modDelete {
  display: block;
}

.chatText a {
  position: relative;
  display: block;
}

.chatText .inlineImage {
  display: block;
  max-width: 100%;
}

.chatText .hideImage {
  position: absolute;
  z-index: 2;
  top: 0.5rem;
  right: 0.5rem;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 1.5rem;
  height: 1.5rem;
  font-size: 1.25rem;
  color: white;
  background-color: rgba(255, 0, 0, 0.5);
  border-radius: 999px;
}

.chatText.hideImg .inlineImage {
  position: relative;
  height: 2.5rem;
  opacity: 0;
  visibility: hidden;
}

.chatText.hideImg a.inlineImgLink::after {
  content: "image hidden";
  position: absolute;
  z-index: 1;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 0.66rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255, 255, 255, 0.5);
  background-color: black;
}

.chatText.hideImg .hideImage {
  background-color: #444;
  transform: rotate(45deg);
}

.badoop::before {
  content: "";
  display: flex;
  align-items: flex-start;
  justify-content: center;
  position: absolute;
  z-index: 1;
  top: -1rem;
  left: -1rem;
  bottom: -1rem;
  width: 0;
  padding: 0.2rem;
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 3.2;
  color: #777;
  background-color: #444;
  border-top-right-radius: 999px;
  border-bottom-right-radius: 999px;
}

.chatTime {
  position: relative;
  z-index: 2;
  font-weight: 400;
  font-size: 0.66rem;
  color: rgba(255, 255, 255, 0.47);
  white-space: nowrap;
}

.chatCard {
  display: block;
  margin: 0.5rem 0;
}

#chatbottom {
  position: relative;
  display: flex;
  align-items: center;
  padding: 0.25rem;
  background-color: #282828;
}

#pickerResults {
  overflow-y: auto;
  height: 33vh;
  overflow-x: hidden;
  text-align: center;
}

.pickerSecSelected {
  color: #fff;
  border-bottom: 2px solid #fff;
}

#pickerResults span {
  margin-right: 0.5rem;
  display: inline-block;
  margin-bottom: 0.5rem;
}

#pickerResults h3 {
  margin-bottom: 1rem;
  margin-top: 0.5rem;
  text-align: center;
}

#emojiPicker {
  position: absolute;
  z-index: 99;
  left: 0;
  bottom: 100%;
  width: 100%;
  padding: 1rem;
  background-color: #2d2d2d;
  box-shadow: 0 -0.25rem 0.5rem black;
}

#pickerNav {
  overflow: hidden;
  white-space: nowrap;
}

input#pickerSearch {
  width: 100%;
  margin: 0.5rem 0;
}

#pickerNav i {
  margin-right: 0.5rem;
  cursor: pointer;
}

#pickerNav .on {
  color: #27B5C6;
}

img.emoji {
  height: 1.25em;
  width: 1.25em;
  margin: 0 0.05em 0 0.1em;
  vertical-align: -0.1em;
}

#morechats {
  position: absolute;
  bottom: 100%;
  display: none;
  justify-content: center;
  width: 100%;
  pointer-events: none;
}

#morechats.show {
  display: flex;
}

#morechats .butt {
  height: auto;
  padding: 0.2em;
  font-size: 0.7rem;
  background-color: #222;
  border-bottom-color: #222;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  box-shadow: none;
  pointer-events: auto;
}

#morechats .butt i {
  margin: 0 0.25em;
  font-size: 0.85rem;
  font-weight: bold;
}

#atPicker {
  display: none;
  position: absolute;
  z-index: 2;
  bottom: 100%;
  left: 1.5rem;
  padding: 0.25rem;
  background: #222;
  box-shadow: 0 -0.25rem 0.5rem black;
}

#atPicker.show {
  display: block;
}

#atPicker .butt {
  margin: 0.25rem;
  height: auto;
  padding: 0.25em 0.5em;
  text-transform: none;
  letter-spacing: 0;
}

#atPicker i {
  margin: 0.25rem;
  padding: 0.25em 0.5em;
  font-size: 0.75rem;
  color: #888;
}

/* Login */
#welcomeInfo {
  padding-bottom: 1.5rem;
}

#login {
  grid-area: login;
  padding: 4rem;
  background: #151515;
  overflow: auto;
  height: 100%;
}

#login h4 {
  font-size: 1.25rem;
  font-weight: 300;
}

#login h4 a {
  font-size: 1rem;
}

#login .butt {
  width: auto;
}

.inputline {
  display: flex;
  flex-direction: column;
  margin-top: 1rem;
  max-width: 20rem;
}

.inputline > * {
  margin: 0.25rem 0;
}

.formlinks {
  margin-top: 1rem;
}

#login .formlinks a {
  margin-right: 15px;
  cursor: pointer;
}

#login .formlinks a:last-child {
  margin-right: 0;
}

#login .formlinks .selected {
  display: none;
}

/* Unauthenticated state */
#reconnecting {
  display: none;
  padding: 0.25rem 0.5rem;
  background-color: #bb4433;
  animation: pulse 500ms infinite linear alternate;
}

body.disconnected #queuebox,
body.disconnected #newchat {
  opacity: 0.5;
  pointer-events: none;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}

body.disconnected #reconnecting {
  display: block;
}

body.disconnected #logOutButton {
  display: none;
}

/* Modals */
#overlay {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.85);
  overflow: hidden;
}

#overlay.show {
  display: flex;
}

.modalThing {
  display: none;
  flex-direction: column;
  max-width: 80vw;
  max-height: 80vh;
  background-color: #111;
  overflow: hidden;
}

.modalThing.show {
  display: flex;
}

.modalHeader {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.5rem;
  color: #eee;
  background-color: #222;
}

.closeModal {
  margin-left: 1rem;
}

.modalContent {
  flex: 1;
  display: flex;
  padding: 1.5rem;
  overflow: auto;
}

#settingsBox .modalContent,
#accountSettingsBox .modalContent {
  min-width: 320px;
}

#cardsBox .modalContent {
  width: 80vw;
  height: 80vh;
}

.settingline {
  margin-bottom: 0.5rem;
}

#cardsMain {
  display: grid;
  grid-gap: 10px;
  grid-template-columns: repeat(auto-fill, minmax(225px, 1fr));
}

.caseCard {
  margin: 0.5rem;
}

.caseCardSpot {
  position: relative;
}

.caseCardSpot canvas {
  border: 1px solid #333;
}

span.cardShareChat {
  position: absolute;
  right: 85px;
  bottom: 160px;
  font-size: 14px;
  background-color: #000;
  padding: 5px;
  border-radius: 5px;
  display: none;
}

span.cardGiftChat {
  position: absolute;
  right: 100px;
  bottom: 200px;
  font-size: 14px;
  background-color: #000;
  padding: 5px;
  border-radius: 5px;
  display: none;
}

span.cardGiftChat:hover,
span.cardShareChat:hover {
  background-color: #27B5C6;
  color: #000;
}

.caseCardSpot:hover .cardShareChat,
.caseCardSpot:hover .cardGiftChat {
  display: block;
}

#importDubContent {
  display: none;
}

input.tagMachine,
#supercopSearch,
#changeUsername {
  width: 100%;
  padding: 5px;
  margin-bottom: 15px;
}

#songlink {
  border-radius: 0.25rem;
}

#songlink svg {
  width: 100%;
  height: 100%;
  padding: 4px;
}

#importSources {
  padding: 0;
  background: none;
}

#importContent,
#importDubContent {
  padding: 0.5rem 1rem;
  background-color: #282828;
}

#dubimportButton {
  margin-top: 10px;
  display: none;
}

#byId {
  display: flex;
  align-items: center;
}

#byId .butt:disabled {
  opacity: 0.4;
}

input#plMachine,
input#plMachineById {
  line-height: 30px;
  width: 100%;
  padding: 5px;
}

input#plMachineById {
  padding-right: 40px;
}

.responseBox {
  background-color: #27B5C6;
  margin: 10px;
  padding: 5px;
  color: #000;
  border-radius: 0.25rem;
}

.responseBox:empty {
  display: none;
}

#mergeLists,
#shuffleQueue {
  margin-left: 1em;
}

body.darkmode {
  background: #454545;
  color: white;
}
body.darkmode #usersbox {
  border-color: #121212;
}
body.darkmode #usersbox #disco-monkey-dark {
  display: block;
}
@media (max-width: 1199px) {
  body.darkmode #usersbox #disco-monkey-dark {
    display: none;
  }
}
body.darkmode #usersbox #disco-monkey-light {
  display: none;
}
body.darkmode .tab {
  background-color: #93a787;
}
body.darkmode .tab:hover, body.darkmode .tab:active, body.darkmode .tab.on {
  background-color: #607355;
}
body.darkmode #allusers > div .prson {
  border-bottom: 1px solid #a0a0a0;
}
body.darkmode #allusers > div .prson .prsnName {
  color: white;
}
body.darkmode #allusers > div .prson .utitle {
  color: white;
}
body.darkmode #allusers > div .prson .prsnJoined {
  color: white;
}
body.darkmode #allusers > div:nth-child(even) .prson {
  background-color: #525252;
}
body.darkmode #allusers > div:nth-child(odd) .prson {
  background-color: #454545;
}
body.darkmode #queue-buttons button {
  background-color: #d2ae0f;
  color: #2B2B2B;
}
body.darkmode #queue-buttons button:hover {
  background-color: #a2870c;
}
body.darkmode #deck .spot .djplaque {
  background-color: #93a787;
  color: white;
}
body.darkmode #deck .spot.empty .djplaque {
  background-color: #607355;
}
body.darkmode #prgbar {
  border-bottom: #2c2c2c;
}
body.darkmode #volandthings {
  background-color: #2B2B2B;
  border-bottom-color: #121212;
}
body.darkmode #volandthings .butt {
  background-color: #454545;
  color: #a0a0a0;
}
body.darkmode #volandthings .butt.greenbutt {
  background-color: #607355;
  color: white;
}
body.darkmode #queuebox {
  border-left: 1px solid #121212;
  border-right: 1px solid #121212;
}
body.darkmode #queuebox .butt {
  background-color: #454545;
  color: #ECECEC;
}
body.darkmode #queuebox #listpicker {
  background-color: #454545;
  color: white;
  border: 1px solid #a0a0a0;
}
body.darkmode #queuebox #listpicker option {
  background-color: #454545;
  color: white;
}
body.darkmode #queuebox #queueFilter {
  background-color: #454545;
  color: white;
  border: 1px solid #a0a0a0;
}
body.darkmode #queuebox #queuelist {
  color: white;
}
body.darkmode #queuebox #queuelist .pvbar {
  background-color: #454545;
  color: white;
  border-color: #a0a0a0;
}
body.darkmode #queuebox #queuelist .pvbar:nth-child(even) {
  background-color: #525252;
}
body.darkmode #thehistoryWrap {
  border-left: 1px solid #121212 !important;
  background: #454545;
  color: white;
}
body.darkmode #thehistoryWrap .pvbar {
  border-bottom: 1px solid #a0a0a0;
}
body.darkmode #thehistoryWrap .histlink {
  color: white;
}
body.darkmode #minimodeoptions .tab {
  background-color: #607355;
  color: white;
}
body.darkmode #minimodeoptions .tab.on {
  background-color: #93a787;
  font-weight: 500;
}
body.darkmode #addbox {
  background-color: #454545;
}
body.darkmode #addbox input#qsearch {
  background-color: #454545;
  color: white;
  border: 1px solid #a0a0a0;
}
body.darkmode #themebox {
  background-color: #2B2B2B;
  color: white;
  font-weight: 500;
  border: none;
}
body.darkmode #actualChat {
  background-color: transparent;
  border-left: 1px solid #a0a0a0;
}
body.darkmode #actualChat .newChat {
  margin: 0.5rem 1rem;
  padding: 0.5rem 0;
  color: white;
  background-color: transparent;
  border-bottom: 1px solid #a0a0a0;
}
body.darkmode #actualChat .chatName, body.darkmode #actualChat .utitle {
  color: #ECECEC;
}
body.darkmode #actualChat #chatbottom {
  background-color: transparent;
}
body.darkmode #actualChat #chatbottom input {
  background-color: #454545;
  color: white;
  border: 1px solid #a0a0a0;
}
body.darkmode #actualChat #chatbottom .butt {
  background-color: #454545;
  color: #ECECEC;
  border: none;
  border-radius: 0;
  font-size: 0.4rem;
}
body.darkmode #actualChat .chatText.deleteMe:hover {
  background-color: #a0a0a0;
}
body.darkmode #actualChat .chatText.deleteMe:hover .modDelete {
  background-color: transparent;
  color: white;
}
body.darkmode #actualChat .npmsg {
  background: #2B2B2B;
  color: white;
}
body.darkmode #actualChat .chatTime {
  color: #ECECEC;
}

body.lightmode {
  background: white;
}
body.lightmode #usersbox {
  border-color: #C6C6C6;
}
body.lightmode #usersbox #disco-monkey-dark {
  display: none;
}
body.lightmode #usersbox #disco-monkey-light {
  display: block;
}
@media (max-width: 1199px) {
  body.lightmode #usersbox #disco-monkey-light {
    display: none;
  }
}
body.lightmode .tab {
  background-color: #6c825f;
}
body.lightmode .tab:hover, body.lightmode .tab:active, body.lightmode .tab.on {
  background-color: #93a787;
}
body.lightmode #allusers > div .prson {
  border-bottom: 1px solid #ECECEC;
}
body.lightmode #allusers > div .prson .prsnName {
  color: #2B2B2B;
}
body.lightmode #allusers > div .prson .utitle {
  color: #454545;
}
body.lightmode #allusers > div .prson .prsnJoined {
  color: #2B2B2B;
}
body.lightmode #allusers > div:nth-child(even) .prson {
  background-color: #fbfbfb;
}
body.lightmode #allusers > div:nth-child(odd) .prson {
  background-color: white;
}
body.lightmode #queue-buttons button {
  background-color: #ffcf00;
  color: #2B2B2B;
}
body.lightmode #queue-buttons button:hover {
  background-color: #cca600;
}
body.lightmode #deck .spot .djplaque {
  background-color: #6c825f;
  color: white;
}
body.lightmode #deck .spot.empty .djplaque {
  background-color: #93a787;
}
body.lightmode #prgbar {
  border-bottom: lightgray;
}
body.lightmode #volandthings {
  background-color: white;
  border-bottom-color: #ECECEC;
}
body.lightmode #volandthings .butt {
  background-color: #ECECEC;
  color: #2B2B2B;
}
body.lightmode #volandthings .butt.greenbutt {
  background-color: #6c825f;
  color: white;
}
body.lightmode #queuebox {
  border-left: 1px solid #ECECEC;
  border-right: 1px solid #ECECEC;
}
body.lightmode #queuebox .butt {
  background-color: #ECECEC;
  color: #2B2B2B;
}
body.lightmode #queuebox #listpicker {
  background-color: white;
  color: #2B2B2B;
  border: 1px solid #ECECEC;
}
body.lightmode #queuebox #listpicker option {
  background-color: white;
  color: #2B2B2B;
}
body.lightmode #queuebox #queueFilter {
  background-color: white;
  color: #2B2B2B;
  border: 1px solid #ECECEC;
}
body.lightmode #queuebox #queuelist {
  color: #2B2B2B;
}
body.lightmode #queuebox #queuelist .pvbar {
  background-color: white;
  color: #2B2B2B;
  border-color: #ECECEC;
}
body.lightmode #queuebox #queuelist .pvbar:nth-child(even) {
  background-color: #fbfbfb;
}
body.lightmode #thehistoryWrap {
  border-left: 1px solid white !important;
  background: white;
  color: #2B2B2B;
}
body.lightmode #thehistoryWrap .pvbar {
  border-bottom: 1px solid #ECECEC;
}
body.lightmode #thehistoryWrap .histlink {
  color: #012735;
}
body.lightmode #minimodeoptions .tab {
  background-color: #93a787;
  color: white;
}
body.lightmode #minimodeoptions .tab.on {
  background-color: #6c825f;
  font-weight: 500;
}
body.lightmode #addbox {
  background-color: white;
}
body.lightmode #addbox input#qsearch {
  background-color: white;
  color: #2B2B2B;
  border: 1px solid #ECECEC;
}
body.lightmode #themebox {
  background-color: #c6c6c6;
  color: #6b6b6b;
  font-weight: 500;
  border: none;
}
body.lightmode #actualChat {
  background-color: transparent;
  border-left: 1px solid #ECECEC;
}
body.lightmode #actualChat .newChat {
  margin: 0.5rem 1rem;
  padding: 0.5rem 0;
  color: #2B2B2B;
  background-color: transparent;
  border-bottom: 1px solid #ECECEC;
}
body.lightmode #actualChat .chatName, body.lightmode #actualChat .utitle {
  color: #5e5e5e;
}
body.lightmode #actualChat #chatbottom {
  background-color: transparent;
}
body.lightmode #actualChat #chatbottom input {
  background-color: white;
  color: #2B2B2B;
  border: 1px solid #ECECEC;
}
body.lightmode #actualChat #chatbottom .butt {
  background-color: #ECECEC;
  color: #2B2B2B;
  border: none;
  border-radius: 0;
  font-size: 0.4rem;
}
body.lightmode #actualChat .chatText.deleteMe:hover {
  background-color: #ECECEC;
}
body.lightmode #actualChat .chatText.deleteMe:hover .modDelete {
  background-color: transparent;
  color: #2B2B2B;
}
body.lightmode #actualChat .npmsg {
  background: #ECECEC;
}
body.lightmode #actualChat .chatTime {
  color: #515151;
}

body.fullscreen #stage {
  position: static;
}
body.fullscreen #stage:before {
  width: 0;
  height: 0;
  display: none;
}
body.fullscreen #stage .stage-container {
  position: fixed !important;
  left: 0;
  top: 54px;
  width: 100vw;
  height: calc(100vh - 54px);
  z-index: 99;
}
body.fullscreen #stage .stage-container #djStage {
  height: calc(100% - 49px);
}
body.fullscreen #thehistoryWrap, body.fullscreen #queuebox.show, body.fullscreen #actualChat.show {
  position: fixed;
  height: calc(100vh - 94.2px);
  right: 0;
  left: auto;
  width: 40vw;
  overflow-x: hidden;
  z-index: 100;
  display: block;
}
body.fullscreen #themebox {
  display: none;
}
body.fullscreen #thehistoryWrap {
  width: 30vw;
  display: none !important;
}

/* Initially hidden stuff */
#ftSuperCopButton,
#audilert,
#sc-widget,
#justwaitWrap,
.notice,
#emojiPicker,
#overlay {
  display: none;
}

/*------------------------------------ Media Queries -*/
@media only screen and (max-width: 1199px) {
  #stage {
    min-height: 45vh;
  }
  #stage .stage-container {
    height: 100%;
  }
  #stage .stage-container #djStage {
    height: calc(100% - 47.19px);
  }
  #stage .stage-container #djStage #nowplaying {
    height: 100%;
  }
}
@media only screen and (max-width: 799px) {
  #allusersWrap .prson {
    cursor: none;
    pointer-events: none;
  }
}
@media only screen and (min-width: 800px) {
  body.screen #albumArt {
    display: none;
  }
  body.screen #screenBox {
    top: 0;
  }
  #mainGrid {
    gap: 0 5px;
  }
  #importPromptBox .modalContent {
    width: 480px;
  }
  #mainGrid,
  #mainGrid.mmchat {
    grid-template-rows: auto auto auto 1fr;
    grid-template-columns: 60vw 40vw;
    grid-template-areas: "stage theme" "stage chat" "mmopts chat" "users chat";
  }
  #mainGrid.mmusrs {
    grid-template-areas: "stage theme" "stage chat" "mmopts chat" "users chat";
  }
  #mainGrid.mmqueue {
    grid-template-areas: "stage theme" "stage chat" "mmopts chat" "queues chat";
  }
  #mainGrid.mmchat #usersbox,
  #mainGrid.mmqueue #actualChat,
  #mainGrid.mmusrs #actualChat {
    display: flex;
  }
  #mainGrid.login {
    grid-template-areas: "stage queues" "login queues";
  }
  #mainGrid.login #queuebox,
  #mainGrid.login #thehistoryWrap {
    display: block;
  }
  #mainGrid.login .histeal,
  #mmchat {
    display: none;
  }
  #idtitle {
    display: block;
  }
  #thehistoryWrap {
    grid-area: queues;
    display: block;
    position: relative;
    top: auto !important;
    bottom: auto;
  }
  #mainGrid.mmqueue #thehistoryWrap {
    grid-area: mmopts/queues;
  }
}
@media only screen and (min-width: 1200px) {
  #mainGrid,
  #mainGrid.mmqueue,
  #mainGrid.mmchat,
  #mainGrid.mmusrs {
    grid-template-rows: auto auto 1fr;
    grid-template-columns: minmax(16rem, 20rem) minmax(40vw, 100vw) minmax(24rem, 36rem);
    grid-template-areas: "users stage theme" "users stage chat" "users queues chat";
  }
  #mainGrid.mmusrs #queuebox,
  #mainGrid.mmusrs #actualChat,
  #mainGrid.mmchat #usersbox,
  #mainGrid.mmchat #queuebox,
  #mainGrid.mmqueue #usersbox,
  #mainGrid.mmqueue #actualChat {
    display: flex;
  }
  #mainGrid.login {
    grid-template-areas: "stage stage queues" "login login queues";
  }
  #mainGrid #minimodeoptions {
    display: none;
  }
  #usertabs {
    padding-top: 0;
  }
  #djStage {
    height: 30vh;
    min-height: 15rem;
  }
  .avtr {
    display: block;
  }
  #albumArt {
    height: 6.5rem;
    width: 6.5rem;
  }
  #deck {
    margin-left: 5vw !important;
    margin-right: 5vw !important;
  }
  .djplaque {
    justify-content: space-between;
  }
  #thehistoryWrap {
    grid-area: queues !important;
  }
}
@media only screen and (min-width: 1680px) {
  #mainGrid,
  #mainGrid.mmqueue,
  #mainGrid.mmchat,
  #mainGrid.mmusrs {
    grid-template-columns: minmax(16rem, 20rem) minmax(50vw, 100vw) minmax(24rem, 36rem);
  }
  #mainGrid.login {
    grid-template-areas: "stage stage queues" "login login queues";
  }
  #mainGrid.login #queuebox {
    display: none;
  }
  #mainGrid.login #thehistoryWrap {
    width: 100%;
  }
  #history {
    position: absolute;
    left: 60%;
    bottom: -1px;
    width: auto;
    padding: 0 0.5rem;
    border-left: 0.25rem solid #151515;
    border-bottom-color: #222;
    border-radius: 0;
    pointer-events: none;
  }
  #history::after {
    content: "Recent Plays";
    margin-left: 0.25rem;
    font-size: 0.85rem;
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
  }
  #queuebox {
    width: 60%;
  }
  #thehistoryWrap {
    display: block !important;
    grid-area: queues;
    justify-self: flex-end;
    z-index: auto;
    width: 40%;
    border-left: 0.25rem solid #151515;
  }
}
@media only screen and (min-width: 2100px) {
  html {
    font-size: calc(0.4em + 0.4vw);
  }
  #mainGrid,
  #mainGrid.mmqueue,
  #mainGrid.mmchat,
  #mainGrid.mmusrs {
    grid-template-columns: minmax(24rem, 36rem) minmax(40vw, 100vw) minmax(24rem, 36rem);
  }
  #usersbox .tab {
    color: #ffffff;
    background-color: #282828;
    box-shadow: 0 -0.2rem 0.5rem -0.2rem black;
  }
  #userslist {
    display: flex;
  }
  .usersWrap {
    display: block !important;
    flex: 1;
  }
  #allusersWrap {
    border-right: 5px solid black;
  }
}