html {
  background: linear-gradient(315deg, #22252f 20%, #2e3039 100%);
  background-repeat: no-repeat;
  background-attachment: fixed;
}
a { text-decoration: none; color: white; }
a:visited { text-decoration: none; color:white; }
a:hover { text-decoration: none; color:white; }
a:focus { text-decoration: none; color:white; }
a:hover, a:active { text-decoration: none; color:white }
body {
  color: #9b9b9b;
  margin: 0 auto;
  font-family: sans-serif;
  outline: none;
  font-weight: 16px;
  color-scheme: dark;
}
*:focus {
    outline: none;
}
input[type='text'],
input[type='number'] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
ul {
  display: flex;
  padding: 0;
  list-style: none;
}
ul > li {
  padding: 10px;
}
th {
  padding: 4px;
  background-color: #00000050;
  font-size: small;
}
.maint th {
  background-color: #00000060;
  text-align: center;
}
td {
  background-color: #00000050;
  font-family: monospace;
}
.login {
  background-color: #00000050;
  width: 220px;
  margin: 40px auto;
  padding: 40px;
  display: flex;
  flex-direction: column;
  border-radius: 10px;
  box-shadow: 0 0 5px 0px #000000b0;
}
.text-input {
  background-color: #2e353e;
  color: #9b9b9b;
  border: 0 solid #313b4b;
  border-radius: 20px;
  padding: 10px;
  margin: 5px;
  box-shadow: 0 0 5px 0 #00000030;
}
.text-input:focus {
  box-shadow: 0 0 5px 0 #00000040;
}
.btn-input {
  background: none;
  color: #9b9b9b;
  border: 2px solid #2e353e;
  border-radius: 5px;
  padding: 10px;
  margin: 5px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.btn-input:hover {
  border: 2px solid #ee2a24;
  transition: 0.5s;
}
.note-text {
  background-color: #2e353e;
  color: #9b9b9b;
  border: 0 solid #313b4b;
  border-radius: 5px;
  padding: 6px;
  margin: 5px 0;
  box-shadow: 0 0 5px 0 #00000030;
  width: 100%;
  box-sizing: border-box;
}
.nav {
  justify-content: center;
  display: flex;
  flex-direction: row;
}
.nav-list {
  display: flex;
  flex-direction: row;
  padding: 0px;
}
.nav-list li {
  display: flex;
  align-items: center;
}
.nav img{
  width: 100px;
}
.nav-links {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
.nav-btn {
  background: none;
  color: #9b9b9b;
  border: 0;
}
.nav-btn:hover, .nav-btn:active{
  color: #fff;
  resize: none;
}
.container {
  max-width: 1280px;
  margin: 0 auto;
}
.scrollable {
  overflow-x: scroll;
}
.container-maint { 
  max-width: 1280px;
  margin: 0 auto;
  overflow-x: scroll;
}
.sticky-col {
  position: sticky;
  left: 0;
  background-color: #1b1d23f4;
  backdrop-filter: blur(5px);
}
.maint {
  width: 100%;
  text-align: justify;
}
#burger {
  display: none;
  overflow: hidden;
  height: 20px;
  transition: 0.6s;
}
.key-card {
  display: flex;
  background-color: #00000050;
  margin: 2px 0 0px 2px;
  padding: 4px;
}
.key-box {
  padding: 4px;
  min-width: 20px;
  text-align: center;
  font-family: monospace;
  margin: 1px;
}
.D {
  background-color: #18aa28;
  color: #000;
}
.C {
  background-color: #ffe300;
  color: #000;
}
.L {
  background-color: #f00;
  color: #000;
}
.S {
  background-color: #a16424;
  color: #000;
}
.T {
  background-color: #008eff;
  color: #000;
}
.F {
  background-color: #00e7ff;
  color: #000;
}
.O {
  background-color: #ff00e3;
  color: #000;
}
.servicing {
  background-color: #ff7474;
  color: #000;
}
.weekend, .bank-holiday {
  background-color: #747474;
  color: #000;
}
.today {
  border: 2px solid #ee2a24;
  border-radius: 4px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
.maint {
  width: 100%;
}
#planner {
  width: 100%;
}
.planner-table td {
  padding: 4px;
  min-width: 20px;
  height: 20px;
  text-align: center;
}
.table-heading {
  padding: 4px;
  background-color: #00000070;
  margin: 0 2px;
  text-align: center;
  font-weight: bold;
  font-size: small;
  text-transform: capitalize;
  border-radius: 6px 6px 0 0;
  margin-top: 10px;
}
@media only screen and (max-width: 400px) {
.nav {
  flex-direction: column;
}
.nav-list {
  flex-direction: column;
  margin: 0 auto;
  padding-left: 10px;
  overflow: hidden;
  transition: 0.5s;
}
#nav-list
{
  height: 0;
}
.nav-list li {
  padding: 5px;
}
.nav img {
  margin: 0 auto;
}
.container {
  width: auto;
}
#burger {
  display: block;
  opacity: 100;
}
#key {
  width: 100%;
}
