/* QuickCal styles
----------------------------------------------------------------- */

/* Icons fix */

.booked-icon {
  padding-left: 1px;
}
/* Calendar */

.wp-widget-booked_calendar {
  max-width: 28.578rem;
  margin: auto;
}
.booked_calendar.widget .widget_title,
.wp-widget-booked_calendar .widget_title {
  font-size: 1.2857rem;
  font-weight: 600;
  text-align: center;
  margin: 0;
  padding: 0.7505em;
  position: relative;
  z-index: 2;
}
.booked_calendar.widget .widget_title:before,
.wp-widget-booked_calendar .widget_title:before {
  content: '';
  border: 11px solid;
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -11px;
}
/* Booked form */

body .booked-form .field .checkbox-radio-block label {
  padding-left: 2.75em;
}
body .booked-form .field .checkbox-radio-block label:before {
  top: -0.25em;
}
body .booked-form .cf-block select {
  visibility: visible;
}
body .booked-modal .bm-window {
  background: none;
}
body .booked-modal .bm-window p.booked-title-bar {
  padding: 15px 30px 15px 30px;
}
body .booked-modal .bm-window p small {
  font-size: 1.7143rem;
  text-transform: none;
  right: 25px;
}
body .booked-modal .bm-window .close {
  top: 0.8em;
  right: 29px;
}
body .booked-form input[type=submit],
body .booked-form button {
  margin-top: 10px;
}
#customerChoices {
  text-align: left;
  padding: 10px 0;
  margin: -10px 0 10px;
}
body .booked-form #newAppointmentForm p.status {
  padding: 0 0 10px;
}
body .booked-form .cf-block {
  margin: 0 0 10px;
}
/* Login form */

#booked-page-form .login-remember input {
  display: inline;
  vertical-align: middle;
}
#booked-profile-page i.fa {
  color: inherit;
}
/* User profile header */

#booked-profile-page div.booked-user-avatar {
  width: 50px;
  height: 50px;
}
#booked-profile-page div.booked-user-avatar img {
  -webkit-border-radius: 50%;
  -ms-border-radius: 50%;
  border-radius: 50%;
}
#booked-profile-page .booked-user h3 strong {
  font-weight: 400;
}
/* User profile content */

#booked-profile-page div.booked-tab-content {
  -webkit-border-radius: 0;
  -ms-border-radius: 0;
  border-radius: 0;
}
#profile-edit #booked-page-form .form-table {
  margin-bottom: 2em;
}
.booked-icon-arrow-right:before {
  content: '\e9ba';
  font-family: fontello;
}
.booked-icon-arrow-left:before {
  content: '\e9b9';
  font-family: fontello;
}
body .booked-calendar-wrap {
  margin-bottom: 0
}
/* Calendar */

body table.booked-calendar {
  border-bottom-width: 0px !important;
  border-collapse: separate;
  border-spacing: 0 5px;
}
body table.booked-calendar,
body table.booked-calendar thead,
body table.booked-calendar body {
  background-color: transparent !important;
}
body table.booked-calendar th .monthName a {
  font-size: 16px;
  line-height: 20px;
  display: block;
  padding: 0;
}
table.booked-calendar,
table.booked-calendar tr {
  border-width: 0 !important;
}
table.booked-calendar tr th,
table.booked-calendar tr td {
  border-width: 0 !important;
  border-style: solid !important;
  background-color: transparent !important;
  -webkit-transition: color 0.3s ease, border-color 0.3s ease, background-color 0.3s ease;
  -ms-transition: color 0.3s ease, border-color 0.3s ease, background-color 0.3s ease;
  transition: color 0.3s ease, border-color 0.3s ease, background-color 0.3s ease;
}
body table.booked-calendar tr.days {
  transform: translateY(-5px);
  background-color: transparent !important;
}
table.booked-calendar tbody tr td {
  -webkit-transition: background-color 0.3s ease;
  -ms-transition: background-color 0.3s ease;
  transition: background-color 0.3s ease;
}
table.booked-calendar tr td .date,
table.booked-calendar tr td:hover .date,
table.booked-calendar tr td:hover .date span,
table.booked-calendar tr td.prev-date .date,
table.booked-calendar tr td.prev-date:hover .date,
table.booked-calendar tr td.prev-date:hover .date span,
table.booked-calendar tr td.today .date,
table.booked-calendar tr td.today .date span,
table.booked-calendar tr td.prev-month .date,
table.booked-calendar tr td.prev-month .date span,
table.booked-calendar tr td.next-month .date,
table.booked-calendar tr td.next-month .date span,
table.booked-calendar tr td .booked-appt-list {
  color: inherit !important;
  background: transparent !important;
}
body table.booked-calendar td .date .number {
  line-height: 46px;
}
body table.booked-calendar td.today:hover .date span {
  background: transparent !important;
}
body .booked-calendar-wrap table.booked-calendar td.today .date:before,
body .booked-calendar-wrap.small table.booked-calendar td.today .date:before {
  content: "";
  position: absolute;
  top: 4px;
  bottom: 4px;
  left: 50%;
  width: 41px;
  margin-left: -20.5px;
}
body .booked-calendar-wrap.large table.booked-calendar td.today .date:before {
  width: 50px;
  height: 50px;
  margin-left: 0;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
body .booked-calendar-wrap.small table.booked-calendar tr.week td.active .date .number {
  transform: none;
}
rs-slide .booked-calendar-wrap table.booked-calendar thead th,
body .booked-calendar-wrap.small table.booked-calendar thead th,
body .booked-calendar-wrap:not(.large) table.booked-calendar thead th {
  padding: 1.8rem 0 !important;
}
rs-slide .booked-calendar-wrap table.booked-calendar th .monthName,
body .booked-calendar-wrap.small table.booked-calendar th .monthName,
body .booked-calendar-wrap:not(.large) table.booked-calendar th .monthName {
  font-size: 1.7143rem;
  line-height: 1em;
}
body .booked-calendar-wrap.small table.booked-calendar th .monthName a {
  display: none;
}
rs-slide .booked-calendar-wrap table.booked-calendar thead tr.days th,
body .booked-calendar-wrap.small table.booked-calendar thead tr.days th,
body .booked-calendar-wrap:not(.large) table.booked-calendar thead tr.days th {
  font-size: 14px;
  line-height: 1em;
  font-weight: 600;
  padding: 0.77rem 0 !important;
}
rs-slide .booked-calendar-wrap table.booked-calendar thead th .page-left,
body .booked-calendar-wrap.small table.booked-calendar thead th .page-left,
body .booked-calendar-wrap:not(.large) table.booked-calendar thead th .page-left {
  left: 17px;
  top: 50%;
  font-size: 2.6rem;
  margin-top: -1.3rem;
}
rs-slide .booked-calendar-wrap table.booked-calendar thead th .page-right,
body .booked-calendar-wrap.small table.booked-calendar thead th .page-right,
body .booked-calendar-wrap:not(.large) table.booked-calendar thead th .page-right {
  right: 17px;
  top: 50%;
  font-size: 2.6rem;
  margin-top: -1.3rem;
}
rs-slide .booked-calendar-wrap table.booked-calendar td,
body .booked-calendar-wrap.small table.booked-calendar td,
body .booked-calendar-wrap:not(.large) table.booked-calendar td {
  font-size: 1.572rem;
  line-height: 2.22em;
  height: 3.5rem !important;
  line-height: 3.5rem !important;
}
rs-slide .booked-calendar-wrap table.booked-calendar td .date,
rs-slide .booked-calendar-wrap table.booked-calendar td .date .number,
body .booked-calendar-wrap.small table.booked-calendar td .date,
body .booked-calendar-wrap.small table.booked-calendar td .date .number,
body .booked-calendar-wrap:not(.large) table.booked-calendar td .date,
body .booked-calendar-wrap:not(.large) table.booked-calendar td .date .number {
  line-height: 3.5rem !important;
  text-align: center!important;
  border: none !important;
  position: relative;
}
body .booked-calendar-wrap.large table.booked-calendar td .date,
body .booked-calendar-wrap.large table.booked-calendar td .date .number {
  text-align: center!important;
  border: none !important;
  position: relative;
}
body .booked-calendar-wrap table.booked-calendar tr.week td.active .date .number {
  -webkit-transform: scale(1);
  -ms-transform: scale(1);
  transform: scale(1);
}
body .booked-calendar-wrap.small table.booked-calendar tr.entryBlock td {
  padding: 0 !important;
}
body .booked-calendar-wrap.small .booked-appt-list h2,
body .booked-calendar-wrap.small .booked-appt-list .timeslot .timeslot-people button .button-timeslot,
body .booked-calendar-wrap.small .booked-appt-list .timeslot .timeslot-people button .spots-available {
  text-align: center !important;
}
body .booked-calendar-wrap .booked-appt-list h2 {
  letter-spacing: 0;
}
body .booked-calendar-wrap .booked-appt-list .timeslot:hover {
  background: transparent !important;
}
.booked-calendar-wrap .booked-appt-list .timeslot .timeslot-people button,
body table.booked-calendar button {
  line-height: 1em!important;
}
body .booked-calendar-wrap .booked-appt-list .timeslot .timeslot-people button .button-timeslot,
body .booked-calendar-wrap .booked-appt-list .timeslot .spots-available {
  text-transform: none;
  font-size: 14px !important;
}
body .booked-calendar-wrap .booked-appt-list .timeslot .spots-available {
  color: inherit !important;
}
body .booked-calendar-wrap .booked-appt-list .timeslot .timeslot-people {
  height: auto;
  padding: 6px 0 0 0;
}
rs-slide .booked-calendar-shortcode-wrap {
  width: 400px;
  max-width: 100%;
}
/* Normal Calendar */

.elementor-widget-trx_sc_booked_calendar table.booked-calendar span.monthName {
  height: auto;
}
.elementor-widget-trx_sc_booked_calendar .booked-calendar thead tr:not(.days) th {
  padding: 1.8rem 0 !important;
}
.elementor-widget-trx_sc_booked_calendar .booked-calendar a.page-right {
  right: 17px;
  top: 50%;
  font-size: 2.6rem;
  margin-top: -1.3rem;
}
.elementor-widget-trx_sc_booked_calendar .booked-calendar a.page-left {
  left: 17px;
  top: 50%;
  font-size: 2.6rem;
  margin-top: -1.3rem;
}
.elementor-widget-trx_sc_booked_calendar table.booked-calendar thead tr.days th {
  font-weight: 600;
  padding: 0.77rem 0 !important;
}

/*Version 2.4*/
body div.booked-calendar-wrap div.booked-calendar,
body .booked-appt-list{
	box-shadow: none;
	border-radius: 5px;
}

body div.booked-calendar-wrap div.booked-calendar .bc-head .bc-row.top .bc-col{
  padding: 1.8rem 0!important;
  margin-top: 5px;
  border: 0;
  border-radius: 5px 5px 0 0;
}
body div.booked-calendar-wrap div.booked-calendar .bc-head{
  margin-bottom: 10px;
  border-radius: 5px;
  overflow: hidden;
  background-color: transparent !important;
}

body div.booked-calendar-wrap div.booked-calendar .bc-head .bc-row .bc-col .monthName,
body div.booked-calendar-wrap.small div.booked-calendar .bc-head .bc-row .bc-col .monthName {
  font-size: 1.7143rem;
  font-weight: 400;
  line-height: 1em;
  text-transform: capitalize;
  height: auto;
}
body div.booked-calendar-wrap div.booked-calendar .bc-head .bc-row .bc-col .page-right, 
body div.booked-calendar-wrap div.booked-calendar .bc-head .bc-row .bc-col .page-left{
  font-size: 2.6rem;
  margin-top: -1.2rem;
}
body div.booked-calendar-wrap div.booked-calendar .bc-head .bc-row .bc-col .monthName a{
  display: none;
}
body div.booked-calendar-wrap div.booked-calendar .bc-head .bc-row .bc-col .page-right i, 
body div.booked-calendar-wrap div.booked-calendar .bc-head .bc-row .bc-col .page-left i{
  font-weight: 400;
}
.bc-head .bc-row .bc-col .page-left i:before{
  content: '\e9b9';
  font-family: fontello;
}
.bc-head .bc-row .bc-col .page-right i:before{
  content: '\e9ba';
  font-family: fontello;
}
body div.booked-calendar-wrap div.booked-calendar .bc-head .bc-row.days{
  background: transparent !important;
}
body div.booked-calendar-wrap div.booked-calendar .bc-head .bc-row.days .bc-col{
  border: 0;
  font-size: 14px;
  line-height: 1em;
  font-weight: 600;
  padding: 0.77rem 0!important;
  text-transform: capitalize;
}
body div.booked-calendar-wrap div.booked-calendar .bc-body .bc-row.week .bc-col{
  border: none;
}
body div.booked-calendar-wrap div.booked-calendar .bc-body .bc-row.week .bc-col .date .number,
body div.booked-calendar-wrap.small div.booked-calendar .bc-body .bc-row.week .bc-col .date .number{
  font-size: 1.572rem;
  height: 3rem!important;
  line-height: 3rem!important;
  width: 3rem !important;
  margin: 0;
  transform: translate(-50%, -50%);
  border-radius: 5px;
}
body div.booked-calendar-wrap div.booked-calendar .bc-body .bc-row{
  border-radius: 5px;
  overflow: hidden;
}
body div.booked-calendar-wrap div.booked-calendar .bc-body .bc-row + .bc-row{
  margin-top: 5px;
}
body div.booked-calendar-wrap div.booked-calendar .bc-body .bc-row.week .bc-col.prev-date .date,
body div.booked-calendar-wrap div.booked-calendar .bc-body .bc-row.week .bc-col .date,
body div.booked-calendar-wrap div.booked-calendar .bc-body .bc-row.week .bc-col.prev-date .date span,
body div.booked-calendar-wrap div.booked-calendar .bc-body .bc-row.week .bc-col.prev-date .date, 
body div.booked-calendar-wrap div.booked-calendar .bc-body .bc-row.week .bc-col.prev-date .date span, 
body div.booked-calendar-wrap div.booked-calendar .bc-body .bc-row.week .bc-col.prev-date:hover .date, 
body div.booked-calendar-wrap div.booked-calendar .bc-body .bc-row.week .bc-col.prev-date:hover .date span, 
body div.booked-calendar-wrap div.booked-calendar .bc-body .bc-row.week .bc-col.blur .date,
body div.booked-calendar-wrap div.booked-calendar .bc-body .bc-row.week .bc-col.blur .date span, 
body div.booked-calendar-wrap div.booked-calendar .bc-body .bc-row.week .bc-col.blur:hover .date, 
body div.booked-calendar-wrap div.booked-calendar .bc-body .bc-row.week .bc-col.blur:hover .date span,
body div.booked-calendar-wrap div.booked-calendar .bc-body .bc-row.week .bc-col.active{
  background: transparent !important;
}

/* Shortcodes */
body #booked-profile-page .appt-block .booked-cal-buttons .google-cal-button {
  background: none;
}

body #booked-profile-page .appt-block .booked-cal-buttons .google-cal-button .addeventatc_icon {
  display: none;
}

body .booked-upload-wrap,
body #booked-profile-page .booked-profile-appt-list button.button-primary,
body #booked-profile-page .booked-profile-appt-list .appt-block .booked-cal-buttons a,
body #booked-profile-page .appt-block .booked-cal-buttons .google-cal-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0.292em 1.58em;
  border-style: solid !important;
  border-width: 3px !important;
  border-radius: 0;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  text-align: center;
}

body .booked-upload-wrap span {
  font-size: 16px;
  line-height: 22px;
}

body #booked-profile-page .booked-tabs {
  border-top: 1px solid !important;
}

body #booked-profile-page .booked-tabs li a {
  font-size: 12px;
}

body #booked-profile-page .booked-tabs li a {
  min-height: 40px;
  line-height: 1.2em;
}

body #booked-profile-page .booked-tabs li a .counter {
  font-size: 10px;
  border-radius: 0;
}

body #booked-profile-page .booked-profile-appt-list .appt-block .booked-fea-buttons > a.delete,
body #booked-profile-page .booked-profile-appt-list .appt-block .booked-fea-buttons > button.delete {
  position: relative;
  font-size: 14px;
  border-style: solid !important;
  border-width: 3px !important;
  height: 60px;
  width: 60px;
  box-sizing: border-box;
}
body #booked-profile-page .booked-profile-appt-list .appt-block .booked-fea-buttons > a.delete i,
body #booked-profile-page .booked-profile-appt-list .appt-block .booked-fea-buttons > button.delete i {
  position: absolute;
  top: 51%;
  left: 51%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

@media (min-width: 720px) {
  .timeslot-mobile-title {
    display: none;
  }
}
@media (max-width: 720px) {
  .booked-calendar-wrap .booked-appt-list .timeslot:hover {
    background-color: transparent !important;
  }
  body .booked-calendar .booked-appt-list .timeslot .timeslot-time, body .booked-calendar .booked-appt-list .timeslot .timeslot-count {
    display: none;
  }
  body .booked-calendar .booked-appt-list .timeslot .timeslot-people, body .booked-calendar .booked-appt-list .timeslot .timeslot-people:hover, body .booked-calendar .booked-appt-list .timeslot.timeslot-count-hidden .timeslot-people, body .booked-calendar .booked-appt-list .timeslot.timeslot-count-hidden .timeslot-people:hover {
    width: 100%;
    padding: 0;
    height: auto;
  }
  body .booked-calendar .booked-appt-list .timeslot .timeslot-mobile-title, body .booked-calendar-wrap .booked-calendar .booked-appt-list .timeslot .timeslot-mobile-title {
    padding: 0 10px;
  }
}
@media (max-width: 860px) {
  body #booked-profile-page .booked-profile-appt-list .appt-block .status-block {
    float: none;
    display: inline-block;
    margin-top: 0;
    margin-right: 15px;
  }
  body .booked-upload-wrap,
  body #booked-profile-page .booked-profile-appt-list .appt-block .booked-cal-buttons a,
  body #booked-profile-page .appt-block .booked-cal-buttons .google-cal-button {
    font-size: 14px !important;
    line-height: 1.2em!important;
    padding: 0.66em 1em;
  }
  body #booked-profile-page .booked-profile-appt-list button.button-primary,
  body .booked-upload-wrap span {
    font-size: 14px;
  }
}