@import url("https://fonts.googleapis.com/css2?family=Roboto:wght@100;300;400;500&display=swap");

:root {
  --primary: #355c7d;
  --secondary: #ebebeb;
  --success: #22ad29;
  --warning: #be6338;
  --caution: #b90808;
}

* {
  margin: 0;
  padding: 0;
  font-family: "Roboto", "open-sans";
  color: var(--primary);
}

nav {
  height: 70px;
  width: 100vw;
  top: 0;
  background-color: var(--primary);
  display: flex;
  justify-content: space-between;
  position: fixed;
}

a {
  text-decoration: none;
  color: var(--secondary);
}

.nav {
  display: flex;
  flex-direction: row;
  margin: auto 15px;
  padding: 2px;
}

.nav li {
  margin: auto 5px;
}

ul {
  list-style: none;
  display: flex;
}

h2 {
  margin: 20px 0;
}

#logo {
  margin: auto 20px;
  font-size: 18px;
}

#logo h2 {
  color: var(--secondary);
  font-weight: 400;
}

nav p {
  color: var(--secondary);
}

.action {
  padding: 5px 7px;
  border: 1px solid var(--secondary);
  background-color: var(--primary);
  color: var(--secondary);
  border-radius: 5px;
}

.action:hover {
  border: 1px solid var(--secondary);
  background-color: var(--secondary);
  color: var(--primary);
  border-radius: 5px;
}

.bad-action {
  padding: 5px 7px;
  border: 1px solid var(--caution);
  background-color: var(--caution);
  color: var(--secondary);
  border-radius: 5px;
}

.bad-action:hover {
  border: 1px solid var(--secondary);
  background-color: var(--caution);
  color: var(--secondary);
  border-radius: 5px;
}

.container {
  width: 80vw;
  margin: 100px auto auto auto;
}

.center {
  margin-top: 5vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.center h2 {
  margin: 0 auto;
}

.center h3 {
  margin: 10px 0;
}

.center h4 {
  margin: 10px 0;
}

.center a {
  margin: 10px 0;
  background-color: var(--primary);
  color: var(--secondary);
  padding: 5px 15px;
  border-radius: 5px;
}

form {
  display: flex;
  flex-direction: column;
}

input {
  width: 25vw;
  margin: 10px 0;
  border: 2px solid var(--primary);
  padding: 5px;
  border-radius: 10px;
}

input:focus {
  outline: none;
}

button {
  margin: 10px 0;
  border: 1px solid var(--primary);
  padding: 7px;
  font-weight: 300;
  border-radius: 10px;
  color: var(--secondary);
  background-color: var(--primary);
  cursor: pointer;
}

.roomSelect {
  display: flex;
  flex-direction: row;
}

.btn {
  margin: 0 15px 0 0;
  padding: 5px 10px;
  background-color: var(--primary);
  color: var(--secondary);
  border-radius: 5px;
}

.calendar {
  width: 98%;
  margin: auto;
  font-size: 13px;
  padding-bottom: 50px;
}

.calendar tr,
.calendar td {
  border: 1px solid rgba(53, 92, 125, 0.4);
  border-radius: 5px;
}

.sun,
.mon,
.tue,
.wed,
.thu,
.fri,
.sat {
  padding: 10px;
  text-align: center;
  font-size: 18px;
}

.calendar td {
  width: 200px;
  height: 150px;
  padding: 20px 0px 0px 0px;
}

.month {
  font-size: 28px;
  margin: auto;
  padding-left: 0.65vw;
}

.date {
  font-size: 16px;
  font-weight: bold;
}

ul {
  height: 100%;
  padding: 5px 3px 0px 0px;
}

a {
  color: #17a2b8;
}

.left {
  float: left;
}

.right {
  float: right;
}

.btn {
  outline: none;
  color: black;
  background-color: transparent;
  box-shadow: 0 0 0 0;
}

.clearfix {
  margin: 15px;
}

.calDay {
  display: flex;
  flex-direction: column;
}

.item {
  font-size: 14px;
  color: var(--secondary);
  margin-bottom: 3px;
  padding: 0 3px;
}

.bookingForm {
  width: 400px;
}

.bookingForm label {
  margin: auto 0;
}

.bookingForm input,
.bookingForm select {
  width: 200px;
  margin: 7px 0;
  border: 2px solid var(--primary);
  padding: 5px;
  border-radius: 10px;
}

.bookingForm p {
  display: flex;
  justify-content: space-between;
}

.bookingForm button {
  font-weight: 500;
}

.centered {
  align-items: center;
}

.title {
  text-align: center;
}

.legend {
  align-items: center;
  display: flex;
  flex-direction: column;
  position: fixed;
  right: 3.25vw;
  top: 47vh;
}

.legend-title {
  padding-bottom: 5px;
}

.card {
  width: 100%;
  display: flex;
  align-items: center;
  padding: 20px;
  border: 1px solid var(--primary);
  border-radius: 10px;
  margin: 10px 0;
  justify-content: space-between;
}

.card .action {
  border: 1px solid --primary;
}

.card .action,
.card .bad-action {
  margin-left: 10px;
}

.big {
  padding: 5px;
}

#loginForm p {
  margin: 10px 0;
}

#loginForm button {
  font-size: 16px;
  font-weight: 400;
}

#loginForm input {
  min-width: 450px;
}

#logout {
  margin-right: 10px;
}

#id_bookingDate {
  width: 186px;
}

.date_div {
  text-align: center;
}

.errorlist {
  display: none;
}

.helptext ul {
  display: flex;
  flex-direction: column;
  position: relative;
  bottom: 20px;
  list-style: initial;
  
}

.helptext ul li {
  color: var(--caution);
}

.success {
  width: 100%;
  align-items: center;
  padding: 20px;
  border: 1px solid var(--success);
  background-color:rgba(34, 173, 41, 0.5);;
  color: var(--secondary);
  border-radius: 10px;
  margin: 10px 0;
}

.warning {
  width: 100%;
  align-items: center;
  padding: 20px;
  border: 1px solid var(--warning);
  background-color: rgba(190, 99, 56,0.5);
  color: var(--warning);
  border-radius: 10px;
  margin: 10px 0;
}

.error {
  width: 100%;
  align-items: center;
  padding: 20px;
  border: 1px solid var(--caution);
  background-color:rgba(185, 8, 8,0.5);
  color: var(--secondary);
  border-radius: 10px;
  margin: 10px 0;
  
}