* {
	box-sizing: border-box;
}

html, body {
	margin: 0;
	padding: 0;
	height: 100%;
	overflow: hidden;
}

body {
  font-family: Verdana,Helvetica,sans-serif;
  background-color: #e7eaf3;
  color: #68a7f3;
}

#main {
	height: 100%;
	overflow: hidden;
}

a {
	text-decoration: none;
	/*color: inherit;*/
}
a:hover {text-decoration: none;}
.fade:not(.show) { pointer-events: none; }
h1,h2,h3,h4,h5,h6 { margin: 0; }

.fullheight { height: 100%; }
.fullwidth { width: 100%; }
.fl {	float: left; }
[direction=rtl] .fl { float: right; }
.fr { float: right; }
[direction=rtl] .fr { float: left; }
.oh { overflow: hidden; }
.ib, .inlineblock { display: inline-block; }
.center { text-align: center; }
.textstart { text-align: left; text-align: start; }
[direction=rtl] .textstart { text-align: right; }
.margintop { margin-top: 20px; }
.marginbottom { margin-bottom: 20px; }
.marginright { margin-right: 20px; }
[direction=rtl] .marginright { margin-left: 20px; }
.marginleft { margin-left: 20px; }
[direction=rtl] .marginleft { margin-right: 20px; }
.hidden { display: none !important; }
.invisible { visibility: hidden; }
.nomargin { margin: 0; }
.absolute { position: absolute; }
.ltr-bidi { direction: ltr; unicode-bidi: bidi-override; text-align: right; }
.appearance-none { -webkit-appearance: none; -moz-appearance: none; appearance: none; }
.cursor-pointer { cursor: pointer; }
.bold { font-weight: bold !important; }
.ul { text-decoration: underline; }
.justify-self-end { justify-self: end; }

.fixed-alert {
  position: fixed;
  top: 0;
  right: 0;
  margin: 10px 50px;
}

.flex-center { 
	display: flex; 
	flex-direction: column;
	text-align: center;
	align-items: center;
	justify-content: center;
	height: 100%; 
}

.flex-0 { flex: 0 0 auto; }
.flex-1 { flex: 1; min-height: 0; }
.text-small { font-size: 0.65em; }
.text-medium { font-size: 0.85em; }

.pb-0 { padding-bottom: 0 !important; }
.w-5em { width: 5em; }
.gap-md { gap: 30px; }
.pl-6, .px-6 { padding-left: 3.3rem !important; }
.pr-6, .px-6 { padding-right: 3.3rem !important; }
.pl-7, .px-7 { padding-left: 3.7rem !important; }
.pr-7, .px-7 { padding-right: 3.7rem !important; }
.pl-8, .px-8 { padding-left: 4rem !important; }
.pr-8, .px-8 { padding-right: 4rem !important; }
.pl-9, .px-9 { padding-left: 4.5rem !important; }
.pr-9, .px-9 { padding-right: 4.5rem !important; }
.pl-10, .px-10 { padding-left: 5rem !important; }
.pr-10, .px-10 { padding-right: 5rem !important; }
@media (min-width: 576px) {
	.pl-sm-10, .px-sm-10 { padding-left: 5rem !important; }
	.pr-sm-10, .px-sm-10 { padding-right: 5rem !important; }
}

.cursor-pointer { cursor: pointer; }
.cursor-default { cursor: default; }
.btn.disabled, .btn:disabled, .input:disabled {
  opacity: .4;
}
.btn-xs {
	padding: .15rem .3rem;
	font-size: .675rem;
	line-height: 1.3;
	border-radius: .2rem;
}

.spinner-overlay {
  background-color: rgba(7, 6, 22, 0.8);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: .25rem;
  position: absolute;
  top: 0; bottom: 0;
  left: 0; right: 0;
}
.spinner-lg {
	width: 4rem;
	height: 4rem;
}

.table-brand {
	background-color: #0e1d2d;
}

.playlist-row {
	display: flex;
	overflow: hidden;
	cursor: pointer;
	user-select: none;
	align-items: center;
	padding-left: 15px;
	font-size: 1.3em;
	height: 80px;
}

.playlist-now-playing {
	font-weight: bold;
	color: #445ef5;
}

.action-icon {
	margin-right: 15px;
	margin-left: 15px;
	font-size: 50px;
	cursor: pointer;
	transition: color .1s linear;
}

.action-icon:hover, .action-icon:active {
	color: #445ef5;
}


.fullscreen-icon {
	font-size: 25px;
	color: #9f9f9f;
}

header {
	display: grid;
	height: 70px;
	align-items: center;
	background-color: #fff;	
}

header > * {
	grid-column-start: 1;
	grid-row-start: 1;
	justify-self: center;
}

header h2 { font-size: 1.6rem; }
@media (min-width: 576px) {
	header h2 { font-size: 2rem; }
}

.menu-button > .dropdown-toggle {
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	border-radius: 5px;
	cursor: pointer;
}

.menu-button > .dropdown-toggle > .menu-line {
	width: 20px;
	height: 3px;
	margin: 2px 0;
	background-color: #9cc7d8;
	border-radius: 5px;
}

.dropdown-menu.brand { background-color: #224; }
.dropdown-menu.brand .dropdown-item { color: #9cc7d8; }
.dropdown-menu.brand .dropdown-item:hover, .dropdown-menu.brand .dropdown-item:focus { background-color: #336; }
.dropdown-toggle.no-chevron::after { display: none; }
.menu-button > .dropdown-toggle:hover, .menu-button > .dropdown-toggle:focus, .menu-button.show > .dropdown-toggle { background-color: #224; }
.menu-button { width: 40px; height: 40px; }

.admin-section {
	background-color: #111626;
}

.inner-section {
	background-color: #222737;
}

.brand-color { color: #68a7f3; }

.btn-brand {
  color: #fff;
  background-color: #52daff;
  border-color: #52daff;
}
.btn-brand:hover {
  color: #fff;
  background-color: #52caef;
  border-color: #52badf;
}

.btn-outline-brand {
  color: #52daff;
  border-color: #52daff;
}
.btn-outline-brand:hover {
  color: #fff;
  background-color: #52caef;
  border-color: #52badf;
}

.icon-button {
	display: inline-block;
	width: 20px;
	text-align: center;
	font-size: 1.1em;
}

.player-block {
	background-color: #1a2938;
	color: #ddd;
	margin: 16px 0;
	padding: 7px 8px;
	border-radius: 5px;
}

.player-block .player-props {
	font-size: 0.78rem;
	margin-top: 4px;
}

.app-footer {
	display: flex;
	height: 80px;
	border-radius: 2px 2px 0 0;
	border: 1px solid #adadad;
	border-bottom: 0;	
}

.footer-icon {
	display: flex;
	flex-direction: column;
	font-size: 37px;
	width: 100px;
	height: 100%;
	margin: 0 10px;
	/* background: #2b2853; */
	text-align: center;
	cursor: pointer;
	color: #66a8f3;
}
.footer-icon.active {
	color: #32aaef
}
.footer-icon-img {
	display: flex;
	justify-content: center;
	align-items: center;
}
.footer-icon-text {
	text-align: center;
	font-size: 0.8rem;
	line-height: 1.05;
	padding-bottom: 7px;
}
.playlist-block {
	min-width: 200px;
	text-align: center;
	border-radius: 3px;
	cursor: pointer;
}

.buttons-grid {
	display: flex;
	justify-content: center;
	align-items: center;
	align-content: safe center;
	flex-wrap: wrap;
	overflow: auto;
	max-width: 650px;
}

.command-button {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 10px;
	width: 100px;
	height: 100px;
	background: rgb(102,168,243);
	background: linear-gradient(58deg, rgba(102,168,243,1) 0%, rgba(65,148,234,1) 100%);
	color: white;
	border-radius: 6px;
	box-shadow: 1px 4px 8px rgba(100, 100, 120, 0.3);
	cursor: pointer;
	font-size: 26px;
	font-weight: bold;
}
.command-button:hover, .command-button:focus {
	background: rgb(99,97,98);
	background: linear-gradient(58deg, rgba(99,97,98,1) 0%, rgba(43,43,43,1) 100%);
}