body > * {
    margin: 0 !important;
    padding: 0 !important;
}

body {
	margin: 0;
    padding: 0;
	background-color: #333;
	color: #fff;
	font-family: Monospace;
	font-size: 13px;
	line-height: 24px;
	overscroll-behavior: none;
}

a {
	color: #ff0;
	text-decoration: none;
}

a:hover {
	text-decoration: underline;
}

button {
	cursor: pointer;
	text-transform: uppercase;
}

#info {
	position: absolute;
	top: 0px;
	width: 100%;
	padding: 10px;
	box-sizing: border-box;
	text-align: center;
	-moz-user-select: none;
	-webkit-user-select: none;
	-ms-user-select: none;
	user-select: none;
	pointer-events: none;
	z-index: 1; /* TODO Solve this in HTML */
}

a, button, input, select {
	pointer-events: auto;
}

.lil-gui {
	z-index: 2 !important; /* TODO Solve this in HTML */
}

@media all and ( max-width: 640px ) {
	.lil-gui.root { 
		right: auto;
		top: auto;
		max-height: 50%;
		max-width: 80%;
		bottom: 0;
		left: 0;
	}
}

#overlay {
	position: absolute;
	font-size: 16px;
	z-index: 2;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	background: rgba(0,0,0,0.7);
}

	#overlay button {
		background: transparent;
		border: 0;
		border: 1px solid rgb(255, 255, 255);
		border-radius: 4px;
		color: #ffffff;
		padding: 12px 18px;
		text-transform: uppercase;
		cursor: pointer;
	}

#notSupported {
	width: 50%;
	margin: auto;
	background-color: #f00;
	margin-top: 20px;
	padding: 10px;
}

#view3d {
    grid-column-start: 1;
    grid-row-start: 1;
    grid-row-end: span 4;
}

.header {
    width: 100%;
    height: 5rem;
    background-color: #1d1d26;
    margin: 0;
    padding: 0;
    position: relative;
}

.hioid {
    position: absolute;
    display: inline;
    top: 50%;
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
}

H1 {
    margin: 0;
    padding: .5rem;
}

.grid-container {
  display: grid;
  grid-template-columns: 5fr 4fr 1fr;
  grid-template-rows: 1fr 1fr 1fr 1fr;
  height: 50vh;
  gap: 1rem;
  justify-content: space-around;
  width: 100%;
}

.battery_chart {
  grid-column-start: 2;
  grid-row-start: 3;
  grid-row-end: span 2;
}

.waterlevel_chart {
  grid-column-start: 2;
  grid-row-start: 1;
  grid-row-end: span 2;
}

#waterlevel_hint {
  grid-column-start: 3;
  grid-row-start: 1;
}

#batterylevel_hint {
  grid-column-start: 3;
  grid-row-start: 2;
}

#update_hint {
  grid-column-start: 3;
  grid-row-start: 3;
}

.hint {
  background-color: #222;
  text-align: center;
  border-radius: 5px;
  border: 1px solid white;
}

@media screen and (min-width: 650px){
    .logo_small {
        display: none;
    }
}

@media screen and (max-width: 650px){
    .logo_full {
        display: none;
    }
}

@media screen and (max-width: 650px){
    .grid-container {
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-template-rows: 1fr 1fr 0.5fr 0.5fr 1fr;
        height: 200vh;
    }

    .waterlevel_chart {
        grid-column-start: 1;
        grid-column-end: span 2;
        grid-row-start: 1;
        grid-row-end: span 1;
    }

    .battery_chart {
        grid-column-start: 1;
        grid-column-end: span 2;
        grid-row-start: 2;
        grid-row-end: span 1;
    }

    #view3d {
        display: inline !important;
        grid-column-start: 1;
        grid-column-end: span 2;
        grid-row-start: 5;
    }

    #waterlevel_hint {
        grid-column-start: 1;
        grid-row-start: 3;
    }

    #batterylevel_hint {
        grid-column-start: 2;
        grid-row-start: 3;
    }

    #update_hint {
        grid-column-start: 1;
        grid-row-start: 4;
    }
}


H3 {
  text-align: center;
}

.floating {
    right: 1rem;
    top: 1rem;
    background-color: #333 !important;
    padding: 1rem;
    margin: 1rem;
}

a {
    color: #CCC !important;
    font-size: 12pt;
}.

a > .darklink {
    color: #333 !important !important;
}

.darklink:after {
  content: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAoAAAAKCAYAAACNMs+9AAAAQElEQVR42qXKwQkAIAxDUUdxtO6/RBQkQZvSi8I/pL4BoGw/XPkh4XigPmsUgh0626AjRsgxHTkUThsG2T/sIlzdTsp52kSS1wAAAABJRU5ErkJggg==);
  margin: 0 3px 0 5px;
}

.logout {
    position: absolute;
    display: inline;
    top: 50%;
    right: 1rem;
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
}

.loginbox {
    margin: auto !important;
    margin-top: 1rem !important;
    padding: 1rem !important;
    width: 50%;
    background-color: #1d1d26;
}

.parameters {
    width: 100vw;
    background-color: #444;
    padding-top: .3rem !important;
    padding-bottom: .3rem !important;
}
