body {
  font-family: Verdana, Geneva, sans-serif;
}

h2 {
  font-size: 18px;
  font-family: Georgia, Times, "Times New Roman", serif;
}

img {
  max-width: 100%;
}

.desktop,
.desktop-img {
  display: block;
}

.mobile,
.mobile-img {
  display: none;
}

#overlay {
  display: none;
  z-index: 99;
  background: rgba(0, 33, 71, 0.85);
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
}

#overlay__content {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 200px;
  height: 100px;
  margin-left: -100px;
  margin-top: -50px;
  text-align: center;
}

#overlay i,
#overlay h3 {
  color: #a9b3bd;
}

.register #email {
  width: 200px;
  display: inline-block;
  text-align: right;
  padding-right: 4px;
}

.my-booking {
  margin-bottom: 50px;
  width: 50%;
  padding: 20px;
}

header {
  background: url("/img/header.jpg") center center no-repeat #002147;
  background-size: cover;
  text-align: center;
}

.logo {
  max-width: 120px;
  margin: 10px;
}

.sub-header {
  background: #ceced1;
  color: #002147;
  font-family: Georgia, Times, "Times New Roman", serif;
  text-align: center;
  padding: 8px;
  font-size: 16px;
  position: relative;
}

.sub-header a:hover {
  text-decoration:none;
}

.logout-button {
  position: absolute;
  right: 20px;
}

.view-booking-button {
  position: absolute;
  left: 20px;
}

/* uol navy blue = #002147 */

.grey-section {
  background: #f5f5f5;
  min-height: 200px;
}

.grey-section.pad {
  padding: 20px 0;
}

.booking__form {
  max-width: 375px;
  margin: 15px auto;
}

.form__row {
  margin: 12px 0;
}

.booking__form-add {
  padding: 7px 0 0 0;
}

.booking__form-add a:hover,
.booking__form-add a:focus {
  text-decoration: none;
}

.remove-1px-border {
  border-left: 0;
  border-right: 0;
}

/*  This forcefully removes border radius on form-control selects by reseting it's appearance  */
.select-times select:not([multiple]) {
  -webkit-appearance: none;
  -moz-appearance: none;
  background-position: right 50%;
  background-repeat: no-repeat;
  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAA4AAAAMCAYAAABSgIzaAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMC1jMDYwIDYxLjEzNDc3NywgMjAxMC8wMi8xMi0xNzozMjowMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNSBNYWNpbnRvc2giIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6NDZFNDEwNjlGNzFEMTFFMkJEQ0VDRTM1N0RCMzMyMkIiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6NDZFNDEwNkFGNzFEMTFFMkJEQ0VDRTM1N0RCMzMyMkIiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDo0NkU0MTA2N0Y3MUQxMUUyQkRDRUNFMzU3REIzMzIyQiIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDo0NkU0MTA2OEY3MUQxMUUyQkRDRUNFMzU3REIzMzIyQiIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/PuGsgwQAAAA5SURBVHjaYvz//z8DOYCJgUxAf42MQIzTk0D/M+KzkRGPoQSdykiKJrBGpOhgJFYTWNEIiEeAAAMAzNENEOH+do8AAAAASUVORK5CYII=);
  padding: .5em;
  padding-right: 1.5em
}
.select-times.form-control:first-child {
  border-radius:0;
}

.hide-option { 
  display:none;
}

.btn { 
  outline:0 !important; 
}

.btn-uol {
  background: #002147;
  color: #fff;
  width: 100%;
  border: 0;
  padding: 15px 0;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.btn-uol:hover {
  background: #1a3b5d;
  color: #fff;
}

.btn-default {
  background: #fff;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.btn-default.focus,
.btn-default:focus {
  color: #333;
  background-color: #fff;
  border-color: #ccc;
}

.btn-default.active,
.btn-default:active,
.btn-default.active.focus {
  color: #fff;
  background-color: #002147;
  border-color: #002147;
  outline: 0;
}

.btn.active,
.btn:active {
  background-image: none;
  outline: 0;
  -webkit-box-shadow: none;
  box-shadow: none;
}

.btn.make-booking {
  color: #3b763d;
}

.btn.edit-booking {
  color: #3b763d;
}

.btn.cancel-booking {
  color: #ce2a26;
}

.booking__form-faq--title {
  font-size: 18px;
  font-family: Georgia, Times, "Times New Roman", serif;
  text-align: center;
}

.booking__form-faqs i {
  font-size: 13px;
}

.booking__form-faqs .panel {
  border-radius: 0;
  -webkit-box-shadow: none;
  box-shadow: none;
  border-color: #eee;
}

.booking__form-faqs .panel-default > .panel-heading {
  padding: 0;
  border-radius: 0;
  color: #212121;
  background-color: #fafafa;
  border-color: #eee;
}

.booking__form-faqs .panel-title {
  font-size: 14px;
}

.booking__form-faqs .panel-title > a {
  display: block;
  padding: 15px;
  text-decoration: none;
}

.booking__form-faqs .more-less {
  float: right;
  color: #212121;
}

.booking__form-faqs .panel-default > .panel-heading + .panel-collapse > .panel-body {
  border-top-color: #eee;
}

.more-options {
  max-width:375px;
  margin:15px auto 25px;
  text-align:center;
}

.home-map { 
  background:white;
  margin-bottom:15px;
  text-align:center;
}

.help-block,
.invalid-feedback {
  margin-top: 5px;
  color: red;
  font-size: 11px;
  text-align: center;
}

.alert-success p:first-child {
  font-size: 16px;
  font-weight: bold;
}

.alert-success p {
  font-size: 14px;
  font-weight: normal;
}

#booking-list thead tr td {
  background: #002147;
  color: #fff;
}

#booking-list .desktop table {
  border: 1px solid #ddd;
  background: #fff;
  -webkit-box-shadow: 0 1px 8px rgba(0, 0, 0, 0.08);
          box-shadow: 0 1px 8px rgba(0, 0, 0, 0.08);
}

#desk-results table {
  border: 1px solid #ddd;
  background: #fff;
}

.map-img {
  background: #fff;
  text-align: center;
  padding: 15px;
  margin-bottom: 15px;
  -webkit-box-shadow: 0 1px 8px rgba(0, 0, 0, 0.08);
          box-shadow: 0 1px 8px rgba(0, 0, 0, 0.08);
}

.map-img img {
  width: 750px;
}

.filter-hide-building, .filter-hide-day { 
  display:none; 
}
.filter-results-container { 
  background:#fff; 
  padding:15px; 
  -webkit-box-shadow: 0 1px 8px rgba(0, 0, 0, 0.08);
          box-shadow: 0 1px 8px rgba(0, 0, 0, 0.08);
}

.filter-results-container p {
  margin-bottom:20px;
}

.day-toggle {
  overflow: hidden;
  text-overflow: ellipsis;
}

@media (max-width: 767px) {
  .filter-results-container div { 
    margin-bottom:20px;
  }
}

.login-title {
  font-family: Georgia, Times, "Times New Roman", serif;
  font-size: 19px;
  text-align: center;
}

.form-control {
  background-clip: padding-box;
}

.switch input {
  position: absolute;
  opacity: 0;
}

.switch {
  display: inline-block;
  font-size: 20px;
  /* 1 */
  height: 1em;
  width: 2em;
  background: #ccc;
  border-radius: 1em;
}

.switch div {
  height: 1em;
  width: 1em;
  border-radius: 1em;
  background: #FFF;
  -webkit-box-shadow: 0 0.1em 0.3em rgba(0, 0, 0, 0.3);
  box-shadow: 0 0.1em 0.3em rgba(0, 0, 0, 0.3);
  -webkit-transition: all 300ms;
  transition: all 300ms;
}

.switch input:checked + div {
  -webkit-transform: translate3d(100%, 0, 0);
  transform: translate3d(100%, 0, 0);
  background: #3b98fc;
}

label.day {
  text-overflow: ellipsis;
  overflow: hidden;
}

#feedback {
  min-height: 200px;
}

.feedback-form {
  margin: 0 15px;
}

.feedback-box {
  width: 600px;
  max-width: 100%;
  margin: 0 auto;
}

.edit-select {  
  margin-bottom: 8px;
}

.edit-booking-form .input-group {  
  margin-bottom:8px;
}

@media (min-width:768px) { 
  .edit-select {  
    display: inline-block !important;
    width: 40% !important;
  }
}

.edit-booking-form .row {
  line-height: 26px;
}

.edit-booking-form {
  background: #fff;
  padding: 8px;
  -webkit-box-shadow: 0 1px 8px rgba(0, 0, 0, 0.08);
          box-shadow: 0 1px 8px rgba(0, 0, 0, 0.08);
}

a.disabled {
   pointer-events: none;
   cursor: default;
}

#ui-datepicker-div {
  z-index: 2!important;
}

.slide {
  display: none;
  margin-top: 20px;
}

.booking-person {
  width: auto;
  margin-right: 10px;
}

.booking-person-label {
  line-height: 34px;
  margin-right: 10px;
}

#booking-gridview .red { background:#ccc; color:white }
#booking-gridview .green { background:#09711F; color:#045214 }
#booking-gridview table { font-size:10px; background:white; }
#booking-gridview table thead td { padding:14px 0 29px !important; }
#booking-gridview table thead td div { transform: rotate(-90deg); }
#booking-gridview table thead td:nth-child(even) { background:#e6e6e6; }
#booking-gridview table tbody td { cursor: help; }
.mytooltip {
  position: relative;
}

/* Tooltip text */
.mytooltip .tooltiptext {
  visibility: hidden;
  width: 120px;
  background-color: black;
  color: #fff;
  text-align: center;
  padding: 5px 0;
  border-radius: 6px;
 
  /* Position the tooltip text - see examples below! */
  position: absolute;
  z-index: 1;
  top: -20px;
}

.right-tooltip.mytooltip .tooltiptext {
  left: -70px;
}

/* Show the tooltip text when you mouse over the tooltip container */
.mytooltip:hover .tooltiptext {
  visibility: visible;
}

@media (min-width: 768px) {
  .mobile-booking {
    min-height: 180px;
  }

  .logo {
    max-width: 180px;
    margin: 15px;
  }
}

@media (max-width: 767px) {
  .mobile-img {
    display: block;
    /*width:350px;*/
    margin:0 auto;
  }

  .desktop-img {
    display: none;
  }
  .site-title {
    display: block;
    margin-bottom:5px;
  }

  .logout-button {
    position: relative;
    display: inline-block;
    right: 0;
  }

  .view-booking-button {
    position: relative;
    display: inline-block;
    left: 0;
    margin-right: 10px;
  }
}

@media (max-width: 1023px) {
  .mobile {
    display: block;
  }

  .desktop {
    display: none;
  }

  .mobile-booking {
    margin-bottom: 20px;
    padding: 8px;
    font-size: 13px;
    -webkit-box-shadow: 0 1px 8px rgba(0, 0, 0, 0.08);
            box-shadow: 0 1px 8px rgba(0, 0, 0, 0.08);
  }

  .mobile-booking .edit-buttons {
    margin-top: 10px;
  }

  .mobile-booking:nth-of-type(odd) {
    background-color: #fff;
  }

  .mobile-booking hr {
    margin: 10px 0 10px 0;
  }
}

canvas#chart-area {
    background: white;
    padding: 6px 0 8px 6px;
    margin-top: 15px;
    border: 1px solid #e4e4e4;
}

#desk-occupancy {
  text-align: center;
  max-width: 375px;
  margin:0 auto;
}

#desk-occupancy span {
  display: block;
  font-size: 22px;
  width:40px;
  height:40px;
  line-height:40px;
  background: #002147;
  color: white;
  border-radius: 20px;
  margin: 15px auto 10px auto;
}

.availability-link {
  margin-top:10px;
  font-size: 12px;
}

