
.book {
  padding: 100px 0;
  position: relative;
  background-color: #f0f0f0; }
  .book h1 {
    margin-bottom: 30px; }
    .book h1:after {
      display: block;
      content: '';
      width: 120px;
      height: 5px;
      margin: 20px 0;
      background-color: #000; }
  .book .side-image {
    position: absolute;
    top: 0;
    width: 50%;
    left: -15px;
    display: block;
    height: 100%; }
  .book .box {
    border-radius: 5px;
    background-color: white;
    box-shadow: 0px 3px 20px 0px rgba(0, 0, 0, 0.35);
    padding: 40px;
    line-height: 30px;
    width: 80%;
    position: absolute;
    top: 150px; }
    .book .box h5 {
      color: #000;
      font-weight: 600;
      font-size: 18px; }
    .book .box ul {
      font-size: 18px;
      margin-bottom: 20px; }
  .book .form-control {
    margin-bottom: 20px;
    border: none; }
  .book textarea {
    resize: none; }

@media (max-width: 767px) {
  .book {padding: 50px 0; text-align: center; }
  .book h1 {font-size: 24px; }
  .book h1:after {margin-left: auto;margin-right: auto; }
  .book .text-right {text-align: center; margin-bottom: 20px;}
  .book .box {
    position: static;
    width: 100%;
    box-shadow: none;
    text-align: center;
    padding: 20px 0 0 0;
  }
  
  .booking_overlay {left: 0}
}
@media (min-width: 768px) and (max-width: 991px) {
  .book .text-right {text-align: center; margin-bottom: 20px;}
  .booking_overlay {left: 0}
  .services {
    padding: 50px 0; }

  .blog {
    padding: 50px 0; }

  .team {
    padding: 50px 0; }
  .book h1:after {margin-left: auto;margin-right: auto; }
  .book {padding: 50px 0; text-align: center}
    .book .map {
      display: none; }
    .book .box {
      position: static;
      width: 100%;
      box-shadow: none;
      text-align: center;
      padding: 20px 0 0 0; }

  .nav > li > a {
    padding: 15px 10px; }
  .team {text-align: center;}
  .team h1::after {display: none}
}

@media (min-width: 992px) and (max-width: 1199px) {
  .book .row {display: flex;}
  .book .box {top: 50%!important; transform: translateY(-50%); transition: 0.3s all linear}
  /* .book .box:hover {opacity: 0;} */
  .book .map {
    position: absolute;
    top: 0;
    width: 50%;
    left: -15px;
    display: block;
    height: 100%; }
}
@media (min-width: 1200px) {
  .book .row {display: flex;}
  .book .box {top: 50%!important; transform: translateY(-50%); transition: 0.3s all linear}
  /* .book .box:hover {opacity: 0;} */
  

.book {
  padding: 100px 0;
  position: relative;
  border-bottom: 1px solid #ddd; }
.book .map {
  position: absolute;
  top: 0;
  width: 50%;
  left: -15px;
  display: block;
  height: 100%; }
.book .box {
  border-radius: 5px;
  background-color: white;
  box-shadow: 0px 3px 20px 0px rgba(0, 0, 0, 0.35);
  padding: 40px;
  line-height: 30px;
  width: 80%;
  position: absolute;
  top: 150px; }
.book .box h5 {
  color: #67819d;
  font-weight: 600;
  font-size: 18px; }
.book .box ul {
  font-size: 18px;
  margin-bottom: 20px; }
.book .form-control {
  margin-bottom: 20px; }
.book textarea {
  resize: none; }

.book .box {
  box-shadow: none;
   }
}
.datepicker .disabled {
  opacity: 0.3;
}

.slot-title {
  font-weight: 300;
  color: #333333;
  font-size: 18px;
  margin-top: 10px;
  margin-bottom: 10px;
}
.slot-message {
  font-weight: 300;
  color: #505050;
  font-size: 14px;
  margin-top: 10px;
}
.slot_item {
  padding: 6px 12px;
  height: unset;
  width: unset;
  line-height: unset;
  font-weight: unset;
}
.slot_item.disabled, .slot_item.disabled:hover {
  cursor: not-allowed;
  pointer-events:inherit !important;
  background-color: #777;
  color: white;
}
.margin-top-10 {
  margin-top: 10px;
}
#appointment_date {
  background-color: #f5f5f5;
}
#slot_selected {
  color: #aaa;
  display: block;
  font-size: 32px;
  text-align: center;
  padding: 12px 0px;
}
#slot_selected.active {
  color: #333;
}
