.studyplan {
  background: #fff;
  color: black;
}
.studyplan__title {
  margin-bottom: 15px;
  display: flex;
  justify-content: center;
}
.studyplan__title h2 {
  font-family: Oswald;
  font-size: 37.5px;
  line-height: 50px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: #e50c3e;
}
.tt_event_responsive_image,
.tt_event_page_left .attachment-event-post-thumb {
  width: 100%;
  height: auto;
}
@media (max-width: 1009px) {
  .tt_event_theme_page .textwidget p:first-child {
    margin-top: 23px;
  }
  .tt_event_theme_page h2 {
    font-size: 30px;
  }
  .tt_event_theme_page h3 {
    font-size: 22px;
  }
  .tt_event_theme_page h4 {
    font-size: 18px;
  }
  .tt_event_theme_page h5 {
    font-size: 16px;
  }
  .tt_event_theme_page p,
  .tt_event_items_list li {
    font-size: 14px;
  }
  .tt_event_theme_page {
    padding: 20px;
    width: 710px;
  }
  .tt_event_page_left {
    width: 480px;
  }
  .tt_event_page_right {
    width: 210px;
  }
  .tt_event_column_left {
    margin-right: 10px;
  }
  .rtl .tt_event_column_left {
    margin-right: 0px;
    margin-left: 10px;
  }
  .tt_event_column_left,
  .tt_event_column_right {
    width: 235px;
  }
  .tt_event_hours li {
    width: 184px;
    margin: 0 23px 23px 0;
    padding: 15px 20px;
  }
  .rtl .tt_event_hours li {
    margin: 0 0px 23px 23px;
  }
  .tt_upcoming_events li {
    width: 210px;
  }
  .tt_upcoming_events li a {
    padding: 10px;
  }
  .tt_event_items_list li.type_info {
    padding: 5px 0;
  }
  .tt_event_margin_top_27 {
    margin-top: 20px !important;
  }
  .tt_event_theme_page h3 {
    margin-top: 15px;
  }
  /* --- timetable --- */
  .tt_responsive .tt_timetable th,
  .tt_responsive .tt_timetable .event_container,
  .tt_responsive .tt_tooltip .tt_tooltip_content {
    padding: 4px 4px 5px;
    padding-left: 30px;
    padding-right: 30px;
  }
  .tt_responsive .tt_timetable td {
    height: 18px;
  }
  .tt_timetable
    .event
    span.available_slots
    + .event_hour_booking_wrapper.always {
    margin-bottom: 0;
  }
  .tt_timetable td .event_hour_booking_wrapper.always {
    margin-bottom: 0;
  }
  .tt_timetable td.tt_single_event .event_hour_booking_wrapper.always {
    padding: 0 4px;
    margin-bottom: 5px;
  }
  .timetable_sidebar_box {
    margin-top: 40px;
  }
}
@media (max-width: 767px) {
  .tt_event_theme_page,
  .tt_event_page_left,
  .tt_event_page_right,
  .tt_upcoming_events li {
    width: 422px;
  }
  .tt_event_page_right {
    margin-top: 50px;
  }
  .tt_event_column_left,
  .tt_event_column_right {
    width: 206px;
  }
  .tt_event_hours li {
    width: 368px;
    margin: 0 0 23px;
    padding: 15px 25px;
  }
  .tt_event_hours li:last-child {
    margin-bottom: 0;
  }
  .tt_upcoming_events li a {
    padding: 10px 20px;
  }
  /* --- timetable --- */
  .tt_responsive .tt_timetable {
    display: none;
  }
  .tt_responsive .tt_timetable.small {
    display: block;
  }
  /* --- navigation wrapper --- */
  .tt_double_buttons .tt_navigation_cell:first-child {
    margin: 0 0 10px 0 !important;
    width: 100%;
  }
  .tt_double_buttons .tt_navigation_cell:last-child {
    margin: 0 0 30px 0 !important;
  }
  .tt_tabs .tt_navigation_cell:first-child {
    margin: 0 0 30px 0 !important;
  }
  /* --- tabs box navigation --- */
  .tt_double_buttons .sf-timetable-menu:first-of-type {
    margin-right: 10px !important;
  }
  .tt_double_buttons .sf-timetable-menu:last-of-type {
    margin-right: 0 !important;
  }
  .rtl .tt_double_buttons .sf-timetable-menu:first-of-type {
    margin-left: 10px !important;
    margin-right: 0 !important;
  }
  .rtl .tt_double_buttons .sf-timetable-menu:last-of-type {
    margin-left: 0 !important;
  }
  .tt_double_buttons
    .tabs_box_navigation.sf-timetable-menu
    .tabs_box_navigation_selected {
    padding: 15px 15px !important;
    width: 174px;
  }
  .tt_double_buttons .sf-timetable-menu li ul {
    width: 204px;
  }
  .tt_double_buttons .sf-timetable-menu li ul li {
    width: 194px;
  }
  .tt_double_buttons .tabs_box_navigation label {
    font-size: 16px !important;
  }
  /* --- booking --- */
  .tt_booking .tt_booking_message_wrapper {
    width: auto;
  }
  .tt_booking .tt_booking_message {
    margin: 10px 10px 15px;
  }
  .tt_booking .tt_booking_message h2 {
    font-size: 22px;
    line-height: 33px;
    margin-bottom: 12px;
  }
  .tt_booking .tt_booking_message p {
    font-size: 14px;
    line-height: 21px;
    margin-top: 15px;
  }
  .tt_booking .event_details_wrapper {
    padding: 9px 13px 10px;
  }
  .tt_booking p.event_details {
    margin-top: 0;
    margin-bottom: 0;
  }
  .tt_booking a {
    font-size: 14px;
    line-height: 21px;
  }
  .tt_booking .tt_btn_wrapper {
    margin-top: 15px;
  }
  .tt_booking a.tt_btn {
    min-width: 150px;
  }
  .tt_event_url {
    padding: 12px;
    font-size: 13px;
  }
  .tt_booking form.tt_booking_form {
    margin-top: 15px;
  }
  .tt_booking form.tt_booking_form .tt_field_wrapper .tt_field {
    font-size: 14px;
    line-height: 21px;
    padding-top: 5px;
    padding-bottom: 5px;
  }
  .tt_booking form.tt_booking_form .tt_field_wrapper textarea.tt_field {
    height: 64px;
  }
  .tt_booking
    form.tt_booking_form
    .tt_field_wrapper
    .tt_slots_number_wrapper
    input[type='button'] {
    margin-top: 0px;
  }
}
@media (max-width: 479px) {
  .tt_event_theme_page,
  .tt_event_page_left,
  .tt_event_page_right,
  .tt_upcoming_events li,
  .tt_event_column_left,
  .tt_event_column_right {
    width: 280px;
  }
  .tt_event_hours li {
    width: 236px;
    padding: 15px 20px;
  }
  .tt_event_theme_page {
    padding: 10px;
  }
  .tt_event_column_left {
    margin-right: 0;
  }
  .rtl .tt_event_column_left {
    margin-left: 0;
  }
  .tt_event_column_right {
    margin-top: 23px;
  }
  .tt_event_column_left .tt_event_items_list {
    padding-bottom: 0;
  }
  /* --- timetable --- */
  .tt_responsive .tt_timetable.small .tt_items_list div.event_container {
    width: 148px;
  }
  .tt_responsive .tt_timetable.small .tt_items_list div.value {
    width: 112px;
  }
  .tt_responsive .tt_timetable.small.use_colors .tt_items_list li {
    padding: 12px 5px !important;
  }
  .tt_responsive
    .tt_timetable.small.use_colors
    .tt_items_list
    div.event_container {
    width: 138px;
  }
  .tt_responsive .tt_timetable.small .box_header {
    font-size: 14px !important;
  }
  /* --- navigation wrapper --- */
  .tt_navigation_cell {
    margin-right: 0 !important;
  }
  .tt_navigation_cell:first-child {
    margin-bottom: 10px !important;
    width: 100%;
  }
  .tt_navigation_cell:last-child {
    margin-bottom: 30px !important;
  }
  /* --- tabs box navigation --- */
  .tt_responsive.tabs_box_navigation.sf-timetable-menu
    .tabs_box_navigation_selected {
    width: 220px;
  }
  .tt_responsive.tabs_box_navigation.sf-timetable-menu li ul {
    width: 258px;
  }
  .sf-timetable-menu li ul li {
    width: 248px;
  }
  .tt_double_buttons .tabs_box_navigation,
  .tt_double_buttons .sf-timetable-menu:first-of-type {
    margin-right: 0 !important;
  }
  .rtl .tt_double_buttons .tabs_box_navigation,
  .rtl .tt_double_buttons .sf-timetable-menu:first-of-type {
    margin-right: 0 !important;
    margin-left: 0 !important;
  }
  .tt_double_buttons .sf-timetable-menu:first-of-type {
    margin-bottom: 10px !important;
  }
  .tt_double_buttons
    .tt_responsive.tabs_box_navigation.sf-timetable-menu
    .tabs_box_navigation_selected {
    width: 220px;
    padding: 15px 19px !important;
  }
  .tt_double_buttons
    .tt_responsive.tabs_box_navigation.sf-timetable-menu
    li
    ul {
    width: 258px;
  }
  .tt_double_buttons .sf-timetable-menu li ul li {
    width: 248px;
  }
  .tt_double_buttons .tabs_box_navigation label {
    font-size: 18px !important;
  }
  /* --- booking --- */
  .tt_booking .tt_booking_message h2 {
    font-size: 20px;
    line-height: 30px;
  }
  .tt_booking p.event_details {
    font-size: 14px;
    line-height: 22px;
  }
  .tt_booking p {
    margin-top: 0;
    margin-bottom: 0;
  }
  .tt_booking .tt_btn_wrapper {
    margin-top: 10px;
    margin-bottom: 15px;
  }
  .tt_booking a.tt_btn {
    font-size: 14px;
    min-width: 110px;
    padding-left: 10px;
    padding-right: 10px;
    margin: 10px 5px 0;
  }
}
@media (max-height: 479px) {
  .tt_booking .tt_booking_message_wrapper {
    margin-top: 0;
    margin-bottom: 0;
  }
}

.tt_tabs .tt_timetable,
.sf-timetable-menu.tabs_box_navigation label,
.sf-timetable-menu li:hover ul a,
.sf-timetable-menu li.submenu:hover ul a,
.tt_booking .tt_booking_message,
.tt_booking_message h2,
form.tt_generate_pdf input[type='submit'],
.tt_responsive .tt_timetable.small .tt_items_list a,
.tt_responsive .tt_timetable.small .tt_items_list span,
.tt_responsive .tt_timetable.small .box_header {
  font-family: Lato !important;
}
.tt_event_padding_top_0 {
  padding-top: 0 !important;
}
.tt_event_padding_bottom_0 {
  padding-bottom: 0 !important;
}
.tt_event_padding_0 {
  padding: 0 !important;
}
.tt_event_margin_top_13 {
  margin-top: 13px !important;
}
.tt_event_margin_top_27 {
  margin-top: 27px !important;
}
.tt_event_theme_page * {
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
}
.tt_event_theme_page {
  width: 930px;
  background: #ffffff;
  padding: 30px;
  margin: 0 auto 30px;
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
}
.tt_event_page_left {
  float: left;
  width: 630px;
}
.rtl .tt_event_page_left {
  float: right;
}
.tt_event_page_right {
  float: right;
  width: 270px;
}
.rtl .tt_event_page_right {
  float: left;
}
.tt_event_page_left .attachment-event-post-thumb {
  margin-bottom: 17px;
}
.tt_event_theme_page h2,
.tt_event_theme_page h3,
.tt_event_theme_page h4,
.tt_event_theme_page h5 {
  font-family: 'Lato';
  line-height: 120%;

  margin: 0;
  padding: 0;
}
.tt_event_theme_page h2 {
  font-size: 40px;
  font-weight: 700;
  margin-bottom: 5px;
}
.tt_event_theme_page h3 {
  font-size: 29px;
  font-weight: 700;
}
.tt_event_theme_page h4 {
  font-size: 24px;
  font-weight: 400;
}
.tt_event_theme_page h5 {
  font-size: 18px;
  font-weight: 400;
  line-height: 140%;
}
.tt_event_hours_count {
  color: #798795;
  margin-left: 5px;
  font-weight: 400;
}
.rtl .tt_event_hours_count {
  margin-left: 0;
  margin-right: 5px;
}
.tt_event_theme_page p {
  font-size: 15px;
  font-family: 'Lato';
  font-weight: 400;

  margin: 0;
  padding: 1em 0;
  line-height: 140%;
}
.tt_event_theme_page .textwidget p:first-child {
  margin-top: 30px;
}
.tt_event_theme_page .textwidget p {
  padding: 0;
}
.tt_event_items_list {
  list-style: none;
  padding: 20px 0;
  margin: 0;
}
.tt_event_items_list li {
  background: url('../images/bullet.png') left center no-repeat;
  padding-left: 20px;
  font-size: 15px;
  font-family: 'Lato';
  font-weight: 400;

  line-height: 160%;
}
.rtl .tt_event_items_list li {
  background-position: right center;
  padding-left: 0;
  padding-right: 20px;
}
.tt_event_items_list li.type_info {
  background: none;
  padding: 0;
  border-bottom: 1px solid #efefef;
  padding: 8px 0;
}
.tt_event_items_list li label {
  float: left;
  width: 115px;
  font-weight: 700 !important;
  font-size: 15px !important;
}
.rtl .tt_event_items_list li label {
  float: right;
}
.tt_event_items_list li .tt_event_text {
  float: left;
  width: 185px;
}
.rtl .tt_event_items_list li .tt_event_text {
  float: right;
}
.tt_event_columns {
}
.tt_event_column_left,
.tt_event_column_right {
  width: 300px;
}
.tt_event_column_left {
  float: left;
  margin-right: 30px;
}
.rtl .tt_event_column_left {
  float: right;
  margin-right: 0;
  margin-left: 30px;
}
.tt_event_column_right {
  float: right;
}
.rtl .tt_event_column_right {
  float: left;
}
.tt_event_hours {
  clear: both;
  padding: 0;
  margin: 0;
  list-style: none;
}
.tt_event_hours li {
  float: left;
  width: 246px;
  border: 1px solid #efefef;
  border-left: 3px solid #00a27c;
  margin: 0 30px 30px 0;
  padding: 15px 25px;
}
.rtl .tt_event_hours li {
  float: right;
  margin: 0 0 30px 30px;
  border-left: 1px solid #efefef;
  border-right: 3px solid #00a27c;
}
.tt_event_hours li.event_hours_right {
  margin-right: 0;
}
.rtl .tt_event_hours li.event_hours_right {
  margin-left: 0;
}
.tt_event_url {
  font-size: 14px;
  text-decoration: none;
  border: none;
  display: inline-block;
  background: #f0f0f0;
  padding: 12px 25px 13px 25px;
  margin: 0px 10px 10px 0px;
  color: #444;
  text-transform: uppercase;
  text-decoration: none;
  position: relative;
  -webkit-transition: background-color 0.2s, color 0.2s; /* Safari and Chrome */
  -moz-transition: background-color 0.2s, color 0.2s; /* Firefox */
  -o-transition: background-color 0.2s, color 0.2s; /* Opera */
  transition: background-color 0.2s, color 0.2s;
}

.tt_event_theme_page .tt_event_url {
  margin: 0;
}
/* --- upcoming events --- */
.tt_upcoming_events_wrapper {
  clear: both;
  float: left;
  width: 100%;
}
.rtl .tt_upcoming_events_wrapper {
  float: right;
}
.tt_upcoming_events_wrapper .caroufredsel_wrapper {
  margin: 0 !important;
  overflow: hidden;
  width: 100% !important;
}
.tt_upcoming_events_wrapper * {
  box-sizing: content-box;
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
}
.tt_upcoming_events_wrapper p.message {
  padding: 0;
}
.tt_upcoming_events {
  padding: 0 !important;
  margin: 0 !important;
  list-style: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  border: none !important;
}
.tt_upcoming_events li {
  width: 270px;
  padding: 0 0 10px !important;
  margin: 0 !important;
  border: none !important;
  list-style: none !important;
  background: none !important;
}
.tt_upcoming_events li:before,
.tt_upcoming_events li:after {
  content: none !important;
  background: none !important;
  border: none !important;
}
.tt_upcoming_events li .tt_upcoming_events_event_container {
  display: block !important;
  border: 1px solid #efefef;

  padding: 10px 20px;
  text-decoration: none;

  font-family: 'Lato';
  font-size: 14px;
  font-weight: 700;
  line-height: 140%;
  height: 40px;
  overflow: hidden;
  outline: none;
  transition: none !important;
  box-sizing: content-box;
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
}
.rtl .tt_upcoming_events li .tt_upcoming_events_event_container {
  border-left: 1px solid #efefef;

  text-align: right;
}
.tt_upcoming_events li .tt_upcoming_events_event_container:hover {
  height: auto;
  overflow: visible;
}

.tt_upcoming_events
  li
  .tt_upcoming_events_event_container
  .tt_upcoming_events_arrow {
  display: block;
  float: right;
  width: 11px;
  height: 11px;
  background: url('../images/arrow_widget_expand.png') no-repeat;
  margin-top: 13px;
}
.rtl
  .tt_upcoming_events
  li
  .tt_upcoming_events_event_container
  .tt_upcoming_events_arrow {
  float: left;
}
.tt_upcoming_events
  li
  .tt_upcoming_events_event_container:hover
  .tt_upcoming_events_arrow {
  background-position: 0 -11px;
}
.tt_upcoming_events
  li
  .tt_upcoming_events_event_container
  .tt_upcoming_events_hours {
  display: block;
  font-weight: 400;
  font-size: 13px;
}
.tt_upcoming_events li .tt_upcoming_events_event_container img.wp-post-image {
  max-width: 100%;
  height: auto;
  margin-top: 10px;
}
.tt_calendar_icon {
  display: block;
  float: left;
  width: 11px;
  height: 11px;
  background: url('../images/calendar.png') no-repeat;
  margin-right: 8px;
  margin-top: 5px;
}
.rtl .tt_calendar_icon {
  float: right;
  margin-right: 0;
  margin-left: 8px;
}
.tt_upcoming_events
  li
  .tt_upcoming_events_event_container:hover
  .tt_calendar_icon {
  background-position: 0 -11px;
}
.tt_upcoming_events
  li
  .tt_upcoming_events_event_container
  .tt_event_hours_description {
  display: block;
  font-size: 13px;
  margin-top: 10px;
  font-weight: 400;
}
.tt_upcoming_event_controls a {
  border: 1px solid #efefef;
  display: block;
  float: left;
  padding: 6px;
  outline: none;
}
.rtl .tt_upcoming_event_controls a {
  float: right;
}
.tt_upcoming_event_controls a#upcoming_event_prev {
  margin-right: 2px;
}
.rtl .tt_upcoming_event_controls a#upcoming_event_prev {
  margin-right: 0;
  margin-left: 2px;
}
.tt_upcoming_event_controls span {
  display: block;
  width: 11px;
  height: 11px;
}
.tt_upcoming_event_controls .tt_upcoming_event_prev_arrow {
  background: url('../images/arrow_scroll_up.png') no-repeat;
}
.tt_upcoming_event_controls .tt_upcoming_event_next_arrow {
  background: url('../images/arrow_scroll_down.png') no-repeat;
}

.tt_upcoming_event_controls a:hover span {
  background-position: 0 -11px;
}

.timetable_sidebar_box {
  clear: both;
  margin-top: 50px;
}
.timetable_sidebar_box:first-child {
  margin-top: 0;
}
.page_margin_top {
  margin-top: 30px;
}
.timetable_clearfix:after {
  font-size: 0px;
  content: '.';
  display: block;
  height: 0px;
  visibility: hidden;
  clear: both;
}
div.rtl {
  direction: rtl;
}
.tt_hide {
  display: none !important;
}
/* --- lists --- */
.tt_tabs_navigation,
.tt_items_list {
  padding: 0;
  margin: 0;
  list-style: none;
}
div.tt_tabs {
  border: none !important;
  position: static;
  padding: 0;
}
.tt_tabs .ui-tabs-panel {
  padding: 0 !important;
  clear: both;
}
/* --- timetable --- */
table.tt_timetable {
  width: 100%;
  font-size: 11px;

  border: none;
  letter-spacing: normal;
  font-size: 11px;
  line-height: normal;
  font-family: 'Lato', Helvetica, Arial, sans-serif;
  border-collapse: separate !important;
  border-spacing: 2px !important;
  background: #fff !important;
}
table.tt_timetable * {
  box-sizing: content-box;
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
}
.tt_timetable th,
.tt_timetable td {
  font-size: 14px;
  font-weight: normal;
  font-style: normal;
  line-height: normal;

  text-transform: none;
  border: none !important;
}
.tt_timetable th,
.tt_timetable td.tt_hours_column {
  text-align: center;
  vertical-align: middle;
}
.tt_timetable th {
  width: 13.4%;
  padding: 10px 15px 12px;
  letter-spacing: normal;
}
.tt_timetable .event_container {
  padding: 7px 10px;
  position: relative;
}
/* Tooltips are handled differently in RTL mode. */
body.rtl .tt_timetable .event_container {
  position: static;
}
.tt_timetable td {
  width: 12.5%;
  vertical-align: top;
  height: 31px;
  border: none;
  padding: 0;
  position: relative;
}
/* On Firefox there are problems with RTL mode when table cell uses relative position. */
body.rtl .tt_timetable td {
  position: static;
}
.tt_timetable td .event_hour_booking_wrapper,
.tt_timetable td .event_hour_booking_wrapper *,
.tt_event_hours .event_hour_booking_wrapper,
.tt_event_hours .event_hour_booking_wrapper * {
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  overflow: hidden;
}
.tt_timetable td .event_hour_booking_wrapper.always {
  margin: 15px 0 3px;
}
.tt_timetable td.tt_single_event .event_hour_booking_wrapper.always {
  padding: 0 10px;
  margin: 9px 0 10px;
}
.tt_timetable .event span.available_slots + .event_hour_booking_wrapper.always {
  margin: 16px 0 3px 0;
}
.tt_timetable td .event_hour_booking_wrapper.on_hover {
  position: absolute;
  top: auto;
  right: 0;
  bottom: 0;
  left: 0;
  height: 50px;
}
/* In RTL mode TD cell is static, so booking wrapper must be hidden.
** Otherwise it will overlap entire table. */
body.rtl .tt_timetable td.event .event_hour_booking_wrapper.on_hover {
  right: auto;
  bottom: auto;
  left: auto;
  visibility: hidden;
  opacity: 0;
}
body.rtl .tt_timetable td.event .event_hour_booking_wrapper.on_hover {
  visibility: visible;
  opacity: 1;
}

.tt_timetable .event {
  line-height: 140%;
  text-align: center;
  padding: 0 !important;
  vertical-align: top;
}
.tt_timetable .event a,
.tt_timetable .event .event_header {
  display: block;
  font-size: 14px;
  font-weight: bold;
  margin-bottom: 2px;
  text-decoration: none;
  outline: none;
  transition: none !important;
  border: none;
}
.tt_timetable .event a:hover,
.tt_timetable .event a.event_header:hover {
  text-decoration: underline;
}
.tt_timetable .event span.available_slots {
  display: block;
  color: #ffd544;
  margin-top: 3px;
}
.tt_event_hours .available_slots_wrapper {
  padding-bottom: 0;
}
.tt_event_hours .available_slots_wrapper span.available_slots {
  display: block;
}
.tt_timetable .event a.event_hour_booking,
.tt_responsive .tt_timetable.small .tt_items_list .value a.event_hour_booking,
.tt_event_hours a.event_hour_booking {
  display: block;
  margin: 0;
  padding: 11px 5px 11px;
  width: 100%;
  font-size: 14px;
  line-height: 18px;
  height: auto;
  font-weight: normal;
  text-decoration: none;
  -webkit-transition: background-color 0.2s, bottom 0.2s, top 0.2s !important; /* Safari and Chrome */
  -moz-transition: background-color 0.2s, bottom 0.2s, top 0.2s !important; /* Firefox */
  -o-transition: background-color 0.2s, bottom 0.2s, top 0.2s !important; /* Opera */
  transition: background-color 0.2s, bottom 0.2s, top 0.2s !important;
  -webkit-border-radius: 2px;
  -moz-border-radius: 2px;
  border-radius: 2px;
  text-align: center;
}
.tt_event_hours .event_hour_booking_wrapper {
  margin-top: 1em;
}
.tt_responsive .tt_timetable.small .tt_items_list .value a.event_hour_booking {
  margin-top: 10px;
  float: none;
}
.tt_timetable .event .event_hour_booking_wrapper.on_hover a.event_hour_booking {
}

.tt_timetable .event .event_hour_booking_wrapper.on_hover a.event_hour_booking {
  margin: 0;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -50px;
  top: auto;
  cursor: pointer;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  border-radius: 0;
  padding-top: 16px;
  padding-bottom: 16px;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.tt_timetable
  .event.tt_single_event:hover
  .event_hour_booking_wrapper.on_hover
  a.event_hour_booking,
.tt_timetable
  .event_container:hover
  .event_hour_booking_wrapper.on_hover
  a.event_hour_booking {
  bottom: 0;
}
.tt_timetable .event a.tt_inactive {
  opacity: 0.5;
}
.tt_timetable .event span.event_hour_places {
  margin-left: 5px;
}
.tt_timetable .event .before_hour_text,
.tt_timetable .event .after_hour_text {
  font-size: 13px;
}

.tt_timetable .row_gray {
  background-color: #ffe9ee !important;
}

.tt_timetable .event .hours_container {
  margin: 15px 0;
}
.tt_timetable .event .top_hour {
  margin-top: 15px;
}
.tt_timetable .event .bottom_hour,
.event_layout_4 .tt_timetable .event .top_hour {
  margin-bottom: 15px;
}
.tt_timetable .event hr {
  background: #ffffff;
  border: none;
  height: 1px;
  margin: 0;
  opacity: 0.4;
}
.tt_timetable.small {
  display: none;
  font-size: 13px;
}
.tt_timetable.small.desktop {
  display: block;
}
.tt_responsive .tt_timetable.small .box_header {
  font-size: 16px !important;

  font-family: 'Lato';
}
.rtl .tt_responsive .tt_timetable.small .box_header {
  text-align: right;
}
.tt_responsive .tt_timetable.small .tt_items_list div.event_container {
  width: 302px;
  padding: 0;
}
.tt_responsive
  .tt_timetable.small.use_colors
  .tt_items_list
  div.event_container {
  width: 282px;
}
.tt_responsive .tt_timetable.small .tt_items_list div.value {
  width: 120px;
}
.tt_responsive .tt_timetable.small .tt_items_list a,
.tt_responsive .tt_timetable.small .tt_items_list span {
  font-family: 'Lato';

  text-decoration: none;
  outline: none;
}
.tt_responsive .tt_timetable.small .tt_items_list div.value span {
  font-family: inherit;
}

.rtl .tt_responsive .tt_timetable.small .tt_items_list a,
.rtl .tt_responsive .tt_timetable.small .tt_items_list span {
  text-align: right;
}
.tt_responsive .tt_timetable.small .tt_items_list span.event_description {
  color: #6e7a87 !important;
}

.tt_responsive .tt_timetable.small .tt_items_list span.available_slots,
.tt_responsive
  .tt_timetable.small
  .tt_items_list
  span.available_slots
  span.count {
  color: #ff8400 !important;
}
.tt_responsive .tt_timetable.small .tt_items_list a:hover {
  text-decoration: underline;
}

.tt_responsive
  .tt_timetable.small
  .tt_items_list
  .value
  a.event_hour_booking:hover {
  text-decoration: none;
}
.tt_timetable.small .box_header {
  position: relative;
  cursor: pointer;
  margin: 30px 0 0 0;
}
.tt_timetable.small.use_colors .box_header {
  margin-bottom: 30px;
}
.tt_timetable.small .box_header:first-child {
  margin-top: 0;
}
.tt_timetable.small .box_header:after {
  visibility: visible;
  position: absolute;
  right: 0;
  font-size: 20px;
  line-height: 1;
}
.rtl .tt_timetable.small .box_header:after {
  visibility: visible;
  position: absolute;
  right: auto;
  left: 0;
  font-size: 20px;
  line-height: 1;
}
.tt_timetable.small .plus.box_header:after {
  content: '+';
}
.tt_timetable.small .minus.box_header:after {
  content: '-';
}
h3.box_header.plus + ul.tt_items_list {
  display: none;
}
/* --- tip/tooltip/qtip --- */
.tt_tooltip {
  cursor: pointer;
}
.tt_tooltip .tt_tooltip_text {
  display: block;
  /*padding-bottom: 15px;*/
  visibility: hidden;
  opacity: 0;
  position: absolute;
  z-index: 1000;
  left: -19px;
  bottom: 100%;
  line-height: 1;
  text-align: center;
  /* CSS3 Transitions */
  -webkit-transition-duration: 0.25s;
  -moz-transition-duration: 0.25s;
  -o-transition-duration: 0.25s;
  -ms-transition-duration: 0.25s;
  transition-duration: 0.25s;
  -webkit-transition-timing-function: cubic-bezier(0.35, 0, 0.35, 1);
  -moz-transition-timing-function: cubic-bezier(0.35, 0, 0.35, 1);
  -o-transition-timing-function: cubic-bezier(0.35, 0, 0.35, 1);
  -ms-transition-timing-function: cubic-bezier(0.35, 0, 0.35, 1);
  transition-timing-function: cubic-bezier(0.35, 0, 0.35, 1);
  /* CSS3 Transitions */
  -webkit-transition-property: opacity, visibility;
  -moz-transition-property: opacity, visibility;
  -o-transition-property: opacity, visibility;
  -ms-transition-property: opacity, visibility;
  transition-property: opacity, visibility;
  /*background: url('images/tooltip_arrow.png') no-repeat 15px bottom;*/
}
.rtl .tt_tooltip .tt_tooltip_text {
  left: auto;
  /*right: -19px;*/
}
.tt_tooltip .tt_tooltip_content {
  background: #1f736a;

  -webkit-border-radius: 4px;
  -moz-border-radius: 4px;
  border-radius: 4px;
  padding: 7px 10px 10px;
  line-height: 150%;
  font-size: 11px;
  text-align: left;
}
.rtl .tt_tooltip .tt_tooltip_content {
  text-align: right;
}
.tt_tooltip:hover .tt_tooltip_text {
  visibility: visible;
  opacity: 1;
}
.tt_tooltip .tt_tooltip_arrow {
  content: '';
  position: relative;
  border-color: #1f736a transparent;
  border-style: solid;
  border-width: 5px 5px 0;
  bottom: -6px;
  left: 0;
  display: inline;
}
.rtl .tt_tooltip .tt_tooltip_arrow {
  left: auto;
  right: 0;
}
/* --- navigation wrapper --- */
.tt_navigation_wrapper {
  width: 100%;
  display: -webkit-box; /* OLD - iOS 6-, Safari 3.1-6, BB7 */
  display: -ms-flexbox; /* TWEENER - IE 10 */
  display: -webkit-flex; /* NEW - Safari 6.1+. iOS 7.1+, BB10 */
  display: flex; /* NEW, Spec - Firefox, Chrome, Opera */
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  -moz-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-content: stretch;
  -ms-flex-line-pack: stretch;
  align-content: stretch;
  -webkit-align-items: flex-end;
  -ms-flex-align: end;
  align-items: flex-end;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.tt_navigation_cell {
  display: inline-block;
  max-width: 100%;
  margin: 0 30px 30px 0 !important;
}
.tt_navigation_cell:nth-child(2) {
  margin-right: 0 !important;
}
.rtl .tt_navigation_cell {
  margin: 0 0 30px 30px !important;
}
.tt_navigation_cell:nth-child(2) {
  margin-left: 0 !important;
}
/* --- tabs box navigation --- */
.tabs_box_navigation.sf-timetable-menu {
  float: none;
  clear: both;
}
.tabs_box_navigation li:after {
  content: none !important;
}
.tabs_box_navigation.sf-timetable-menu * {
  box-sizing: content-box;
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  line-height: 1;
}
.tabs_box_navigation.sf-timetable-menu li.submenu:hover:after {
  background: none;
}
.tabs_box_navigation.sf-timetable-menu .tabs_box_navigation_selected {
  width: 256px;
  height: auto;
  padding: 13px 12px !important;
  background: #00a27c;

  cursor: pointer;
  margin: 0 !important;
}
.tabs_box_navigation.sf-timetable-menu .tabs_box_navigation_selected:hover {
  background-color: #1f736a;
}
.tabs_box_navigation.sf-timetable-menu li:hover ul,
.tabs_box_navigation.sf-timetable-menu li.sfHover ul {
  top: 38px;
  border: 1px solid #1f736a;
}
/* --- menu --- */
.sf-timetable-menu {
  padding: 0 !important;
  margin: 0 30px 0 0 !important;
  list-style: none !important;
}
.rtl .sf-timetable-menu {
  margin: 0 0 0 30px !important;
}
.sf-timetable-menu a {
  text-decoration: none !important;
}
.sf-timetable-menu li,
.sf-timetable-menu li:hover,
.sf-timetable-menu li.sfHover,
.sf-timetable-menu a:focus,
.sf-timetable-menu a:hover,
.sf-timetable-menu a:active {
  background: none #fff;
}

.sf-timetable-menu li ul {
  display: block;
  width: 228px;
  background: #fff;
  border: 1px solid #e8e8e8;
  padding: 0 0 5px !important;
  list-style: none !important;
  margin: 0 !important;
}
.sf-timetable-menu li ul.tabs_box_navigation_hidden {
  display: none;
}
.sf-timetable-menu li:hover ul,
.sf-timetable-menu li.sfHover ul {
  top: 44px;
}
.sf-timetable-menu li ul li {
  width: 218px;
  height: auto;

  padding: 0 5px !important;
  list-style: none !important;
  margin: 0 !important;
}
.sf-timetable-menu li:hover {
  background: transparent;
}
.sf-timetable-menu li:hover ul a,
.sf-timetable-menu li.submenu:hover ul a {
  display: block;
  width: auto;
  border: none;

  background: #fff;
  padding: 12px 14px;
  font-size: 15px;
  font-family: 'Lato', Helvetica, Arial, sans-serif;
  transition: none !important;
}
.sf-timetable-menu li ul li a:hover,
.sf-timetable-menu li ul li.selected a:hover {
  background-color: #00a27c;

  font-weight: normal;
}
.sf-timetable-menu li ul li.selected a {
  background-color: #f0f0f0;

  font-weight: normal;
}
/* --- items list --- */
.tt_items_list {
  padding: 0 !important;
  margin: 0 !important;
  list-style: none !important;
}
.tt_items_list.margin_top {
  margin-top: 8px;
}
.tt_items_list li {
  padding: 12px 0 !important;
  margin: 0 !important;
  list-style: none !important;
  border-bottom: 1px solid #e0e0e0;
  background-position: left center;
  background-repeat: no-repeat;
  line-height: 120%;
}
.use_colors .tt_items_list li {
  padding: 12px 10px !important;
  background-color: #00a27c;
}
.rtl .tt_items_list li {
  background-position: left center;
}
.tt_items_list li:first-child {
  padding-top: 0;
}
.tt_items_list .event_container {
  float: left;
}
.rtl .tt_items_list .event_container {
  float: right;
}
.tt_items_list a,
.tt_items_list span {
  outline: none;
}
.tt_items_list.thin a,
.tt_items_list.thin span {
  font-weight: normal;
}
.tt_items_list.thin span.event_description {
  display: block;
  margin-top: 10px;
}
.tt_items_list.thin span.available_slots {
  display: block;
  margin-top: 9px;
  float: none;
}
.tt_items_list.thin a.event_hour_booking.tt_inactive {
  opacity: 0.5;
}
.tt_items_list .value {
  float: right;
  text-align: right;
}

.tt_items_list .value a.event_hour_booking {
  display: block;
  text-align: center;
}
.rtl .tt_items_list .value {
  float: left;
}

.tt_items_list.opening_hours li {
  border-color: #4468b2;
}
.home_box .tt_items_list li:first-child {
  padding-top: 12px;
}
.tt_items_list li a {
  border: none;
}
.tt_items_list li a:hover {
  text-decoration: underline;
}

.tt_tabs .ui-tabs-panel p {
  padding: 24px 0 25px;
}
/* --- tabs navigation --- */
.tt_tabs_navigation,
.ui-tabs .tt_tabs_navigation {
  float: left !important;
  clear: both;
  vertical-align: bottom;
  width: auto !important;
  padding: 0;
  margin: 0;
  list-style: none !important;
  box-sizing: content-box;
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  background: none !important;
  border: none !important;
}
.rtl .tt_tabs_navigation,
.rtl .ui-tabs .tt_tabs_navigation {
  float: right !important;
}
.tt_tabs_navigation li,
.ui-tabs .tt_tabs_navigation li {
  float: left;
  margin: 0 20px 0 0 !important;
  padding: 0 !important;
  font-size: 18px !important;
  background: none !important;
  border: none !important;
  list-style: none !important;
}
.rtl .tt_tabs_navigation li,
.rtl .ui-tabs .tt_tabs_navigation li {
  float: right;
  margin: 0 0 0 20px !important;
}
.tt_tabs_navigation li:last-child {
  margin-right: 0 !important;
}
.rtl .tt_tabs_navigation li:last-child {
  margin-left: 0 !important;
}
.tt_tabs_navigation li a {
  width: auto !important;
  display: block;
  text-align: center;

  padding: 8px 0 !important;
  border: none !important;
  border-bottom: 1px solid #e5e5e5 !important;
  line-height: normal;
  outline: none;
  text-decoration: none;
  font-size: 15px !important;
  font-family: 'Lato', Helvetica, Arial, sans-serif;
  transition: none !important;
  margin-bottom: 1px;
}
.tt_tabs_navigation li a:hover,
.tt_tabs_navigation li a.selected,
.tt_tabs_navigation li.ui-tabs-active a {
  border-bottom-width: 3px !important;
  padding-bottom: 7px !important;
  border-color: #00a27c !important;
  color: #000 !important;
  margin-bottom: 0;
}
.sf-timetable-menu a:hover,
.tt_tabs_navigation li a:hover,
.tt_tabs_navigation li a:focus,
.tt_tabs_navigation li a:active {
  text-decoration: none;
}
/* --- tabs box navigation --- */
.tabs_box_navigation.sf-timetable-menu {
  float: left;
  clear: none;
  font-family: 'Lato', Helvetica, Arial, sans-serif;
  font-size: 18px;
}
.rtl .tabs_box_navigation.sf-timetable-menu {
  float: right;
}
.tabs_box_navigation.sf-timetable-menu li.submenu:hover:after {
  background: none;
}
.tabs_box_navigation .tabs_box_navigation_icon {
  float: right;
  background: url('../images/arrow_menu_expand.png') no-repeat scroll 0 0
    transparent;
  width: 11px;
  height: 11px;
  margin-top: 3px;
}
.rtl .tabs_box_navigation .tabs_box_navigation_icon {
  float: left;
}
.tabs_box_navigation.sf-timetable-menu .tabs_box_navigation_selected {
  width: 190px;
  height: auto;
  padding: 15px 19px !important;
  margin: 0 !important;
  list-style: none !important;

  cursor: pointer;
  border: 1px solid #00a27c;
}
.tabs_box_navigation.sf-timetable-menu .tabs_box_navigation_selected:hover {
  box-shadow: 0px 6px 8px 0px rgba(0, 0, 0, 0.1);
  border: 1px solid rgba(0, 0, 0, 0.1);
}
.tabs_box_navigation.sf-timetable-menu
  .tabs_box_navigation_selected:hover
  .tabs_box_navigation_icon {
  background-position: 0 -11px;
}
.rtl
  .tabs_box_navigation.sf-timetable-menu
  .tabs_box_navigation_selected:hover
  .tabs_box_navigation_icon {
  background-position: 0 -11px;
}
.tabs_box_navigation.sf-timetable-menu li:hover ul,
.tabs_box_navigation.sf-timetable-menu li.sfHover ul {
  top: 48px !important;
  left: -1px;
  box-shadow: 0px 6px 8px 0px rgba(0, 0, 0, 0.1);
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-top: none;
}
.rtl .tabs_box_navigation.sf-timetable-menu li:hover ul,
.tabs_box_navigation.sf-timetable-menu li.sfHover ul {
  left: auto;
  right: -1px;
}
.tabs_box_navigation label {
  display: inline !important;
  font-size: 18px !important;
  font-weight: normal !important;
}
.tabs_box_navigation_hidden {
  display: none;
}
/* --- generate pdf --- */
form.tt_generate_pdf {
  display: block;
  float: right;
}
form.tt_generate_pdf textarea.tt_pdf_html {
  display: none;
}
form.tt_generate_pdf input[type='submit'] {
  background-image: none;

  font-size: 14px;
  line-height: 24px;
  font-family: 'Lato', Helvetica, Arial, sans-serif;
  padding: 13px 20px;
  -webkit-transition: background-color 0.2s, bottom 0.2s !important; /* Safari and Chrome */
  -moz-transition: background-color 0.2s, bottom 0.2s !important; /* Firefox */
  -o-transition: background-color 0.2s, bottom 0.2s !important; /* Opera */
  transition: background-color 0.2s, bottom 0.2s !important;
  -webkit-border-radius: 2px;
  -moz-border-radius: 2px;
  border-radius: 2px;
  border: none;
  cursor: pointer;
  -webkit-appearance: none;
}
form.tt_generate_pdf input[type='submit']:hover {
  background-color: #07b38a;
}
/* --- booking --- */
.tt_booking_overlay {
  position: absolute;
  background-color: rgba(85, 85, 85, 0.2);
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 999998;
}
.tt_booking {
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  position: absolute;
  z-index: 999999;
  width: 500px;

  margin: 0 50px;
  overflow: hidden;
  font-family: 'Lato', Helvetica, Arial, sans-serif;
  text-align: center;
  -webkit-box-shadow: 0px 20px 30px -5px rgba(0, 0, 0, 0.15);
  -moz-box-shadow: 0px 20px 30px -5px rgba(0, 0, 0, 0.15);
  box-shadow: 0px 20px 30px -5px rgba(0, 0, 0, 0.15);
}
.tt_booking,
.tt_booking * {
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
}
.tt_booking .tt_booking_message {
  margin: 40px 20px 37px;
}
.tt_center {
  text-align: center;
}
.tt_booking .tt_booking_message h2 {
  font-family: 'Lato', Helvetica, Arial, sans-serif;
  font-size: 24px;
  line-height: 36px;
  color: #111111;
  color: #333333;
  margin: 0 0 25px 0;
  font-weight: 400;
}
.tt_booking .tt_booking_message p {
  font-size: 16px;
  margin: 33px 10px 0;
  line-height: 24px;
  padding: 0;
  font-weight: 400;
}
.tt_booking .tt_booking_message p.error-info {
  margin-top: 20px;
  margin-bottom: 0;
}
/* WP filter is adding empty <p> tag which needs to be hidden. */
.tt_booking p:empty {
  display: none;
}
.tt_booking .event_details_wrapper {
  padding: 14px 13px 15px;
  border: 1px solid #e9e9e9;
  margin: 0 10px;
}
.tt_booking p.event_details {
  font-size: 16px;
  line-height: 24px;
  margin: 0;
  color: #333333;
  font-weight: 400;
}
.tt_booking p.event_details.bold {
  font-weight: 700;
}
.tt_booking a {
  font-size: 16px;
  font-weight: 400;
  color: #27ae61;
  text-decoration: none;
}
.tt_booking a:hover {
  cursor: pointer;
  text-decoration: none;
  color: #27ae61;
}
.tt_booking .tt_btn_wrapper {
  margin-top: 35px;
}
.tt_booking a.tt_btn {
  display: inline-block;
  text-decoration: none;
  height: 50px;
  line-height: 50px;
  padding: 0 20px;
  font-size: 16px;
  min-width: 160px;
  margin: 0 10px 0;
  -webkit-border-radius: 2px;
  -moz-border-radius: 2px;
  border-radius: 2px;
  -webkit-transition: background-color 0.2s;
  -moz-transition: background-color 0.2s;
  -o-transition: background-color 0.2s;
  transition: background-color 0.2s;
}

.tt_booking a.tt_btn:hover {
  background-color: #239c57;
}
.tt_booking a.tt_btn.cancel {
  background-color: #eeeeee;
  color: #333;
}
.tt_booking a.tt_btn.cancel:hover {
  background-color: #e5e5e5;
}
/* --- booking guest form --- */
.tt_booking form.tt_booking_form {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: row;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin: 35px 0 -15px;
}
.tt_booking form.tt_booking_form .tt_field_wrapper {
  flex-grow: 1;
  flex-basis: 191px;
  text-align: left;
  border: none;
  border-bottom: 1px solid #e9e9e9;
  margin-bottom: 15px;
  margin: 0 10px 15px;
}
.tt_booking form.tt_booking_form .tt_field_wrapper.wide {
  flex-basis: 100%;
}
.tt_booking form.tt_booking_form .tt_field_wrapper.terms_checkbox_wrapper {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-align: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  align-items: center;
  border-bottom: 0;
}
.tt_booking form.tt_booking_form .tt_field_wrapper label {
  text-transform: uppercase;
  color: #999;
  font-size: 12px;
  line-height: 18px;
  font-weight: 400;
  display: block;
  margin: 0;
  padding: 0;
}
.tt_booking form.tt_booking_form .tt_field_wrapper .tt_field {
  width: 100%;
  border: 0;
  outline: none;
  font-family: 'Lato', Helvetica, Arial, sans-serif;
  font-size: 18px;
  font-weight: 700;
  line-height: 30px;
  color: #333;
  display: inline-block;
  padding: 8px 0 15px;
  margin: 0;
}
.tt_booking form.tt_booking_form .tt_field_wrapper .tt_field[type='checkbox'] {
  width: auto;
  cursor: pointer;
  -webkit-appearance: checkbox;
  -moz-appearance: checkbox;
  appearance: checkbox;
}
.tt_booking
  form.tt_booking_form
  .tt_field_wrapper
  .tt_field[type='checkbox']
  + label {
  cursor: pointer;
  margin-left: 10px;
}
.tt_booking
  form.tt_booking_form
  .tt_field_wrapper
  .tt_field[type='checkbox']
  + label
  a {
  font-size: 12px;
}
.tt_booking form.tt_booking_form .tt_field_wrapper textarea.tt_field {
  resize: none;
  height: 83px;
}
.tt_booking form.tt_booking_form .tt_field_wrapper .tt_slots_number_wrapper {
  width: 100%;
}
.tt_booking
  form.tt_booking_form
  .tt_field_wrapper
  .tt_slots_number_wrapper
  input[type='number'].tt_field {
  width: 138px;
  appearance: textfield;
  -moz-appearance: textfield;
  -webkit-appearance: textfield;
}
.tt_booking
  form.tt_booking_form
  .tt_field_wrapper
  .tt_slots_number_wrapper
  input[type='number'].tt_field::-webkit-inner-spin-button,
.tt_booking
  form.tt_booking_form
  .tt_field_wrapper
  .tt_slots_number_wrapper
  input[type='number'].tt_field::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.tt_booking form.tt_booking_form .tt_field_wrapper .tt_slots_number_wrapper {
  float: right;
}
.tt_booking
  form.tt_booking_form
  .tt_field_wrapper
  .tt_slots_number_wrapper
  input[type='button'] {
  float: right;
  border: none;
  display: inline-block;
  width: 25px;
  background-color: #e9e9e9;
  cursor: pointer;
  margin-left: 5px;
  margin-top: 11px;
  padding: 0;
  color: #333;
  font-size: 17px;
  font-family: Arial;
  -webkit-appearance: none;
}
.tt_booking
  form.tt_booking_form
  .tt_field_wrapper
  .tt_slots_number_wrapper
  input[type='button']:focus {
  outline: none;
}
.tt_booking
  form.tt_booking_form
  .tt_field_wrapper
  .tt_slots_number_wrapper
  input[type='button'].tt_slots_number_minus {
  margin-left: 0;
  padding-top: 11px;
  padding-bottom: 13px;
  line-height: 1px;
}
.tt_booking
  form.tt_booking_form
  .tt_field_wrapper
  .tt_slots_number_wrapper
  input[type='button'].tt_slots_number_plus {
  padding-top: 10px;
  padding-bottom: 8px;
  line-height: 7px;
}
/* --- booking preloader --- */
.tt_preloader {
  margin: 50px auto 50px;
  width: 70px;
  text-align: center;
}
.tt_preloader > div {
  width: 18px;
  height: 18px;
  background-color: #e5e5e5;
  border-radius: 100%;
  display: inline-block;
  -webkit-animation: sk-bouncedelay 1.4s infinite ease-in-out both;
  animation: sk-bouncedelay 1.4s infinite ease-in-out both;
}
.tt_preloader .bounce1 {
  -webkit-animation-delay: -0.32s;
  animation-delay: -0.32s;
}
.tt_preloader .bounce2 {
  -webkit-animation-delay: -0.16s;
  animation-delay: -0.16s;
}
/* --- qTip2 --- */
.qtip-default {
  background: none;
  border-color: transparent;
}
.qtip.tt-qtip2 {
  z-index: 9999999 !important;
}
.qtip.tt-qtip2 .qtip-content {
  border: none;
  padding: 7px 10px 10px 10px;
  line-height: 150%;
}
.qtip.tt-qtip2.ui-tooltip-success .qtip-content {
  background-color: #00a27c;
}
.qtip.tt-qtip2.ui-tooltip-error .qtip-content {
  background-color: #f0acb0;
}
.qtip.tt-qtip2 .qtip-content h2,
.qtip.tt-qtip2 .qtip-content p {
  margin: 0;
  padding: 0;
}
.qtip.tt-qtip2 .qtip-content h2 {
  font-size: 14px;
  font-weight: bold;
  margin-bottom: 2px;
}
.qtip.tt-qtip2 .qtip-content p {
  font-size: 11px;
}

@-webkit-keyframes sk-bouncedelay {
  0%,
  80%,
  100% {
    -webkit-transform: scale(0);
  }
  40% {
    -webkit-transform: scale(1);
  }
}
@keyframes sk-bouncedelay {
  0%,
  80%,
  100% {
    -webkit-transform: scale(0);
    transform: scale(0);
  }
  40% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}
@media (min-width: 767px) {
  .tt_timetable {
    display: block !important;
  }
  .small {
    display: none !important ;
  }
}

@media (max-width: 767px) {
  .tt_timetable {
    display: none !important;
  }
  .small {
    display: block !important ;
    color: white !important;
  }
}
.tt_timetable {
  padding-left: 50px;
  padding-right: 50px;
}
@media (max-width: 767px) {
  .tt_timetable {
    padding-left: 30px;
    padding-right: 30px;
  }
}
.event_container {
  color: #fff !important;
}
.box_header {
  color: black;
  font-size: 22px;
}
table.tt_timetable {
  width: 100%;
  table-layout: fixed; /* Равномерное распределение ширины столбцов */
  border-collapse: collapse; /* Убираем зазоры между ячейками */
}

table.tt_timetable th, table.tt_timetable td {
  width: 12.5%; /* 100% делим на 8 столбцов, чтобы каждый был одинаковым */
  padding: 10px;
  text-align: center;
  border: 1px solid #ddd;
}

.tt_hours_column {
  width: 12.5%; /* Часовой столбец также занимает 12.5% */
}

.event_container {
  padding: 10px;
  color: #fff;
}

/* Для больших экранов */
@media screen and (min-width: 1500px) {
  table.tt_timetable th, table.tt_timetable td {
    font-size: 18px; /* Увеличиваем шрифт на больших экранах */
  }
}

/* Для маленьких экранов */
@media screen and (max-width: 600px) {
  table.tt_timetable th, table.tt_timetable td {
    font-size: 12px; /* Уменьшаем шрифт на небольших экранах */
  }
}
table.tt_timetable {
  width: 100%;
  table-layout: fixed; /* Равномерное распределение ширины столбцов */
  border-collapse: collapse; /* Убираем зазоры между ячейками */
}

table.tt_timetable th, table.tt_timetable td {
  width: 12.5%; /* 100% делим на 8 столбцов, чтобы каждый был одинаковым */
  padding: 10px;
  text-align: center;
  border: 1px solid #ddd;
  box-sizing: border-box; /* Для корректного расчета ширины вместе с отступами */
}

.tt_hours_column {
  width: 12.5%; /* Часовой столбец также занимает 12.5% */
}

thead, tbody {
  width: 100%; /* Расширяем заголовок и тело на всю ширину */
  display: table; /* Чтобы заголовок и тело таблицы следовали стилю таблицы */
  table-layout: fixed; /* Обеспечиваем одинаковое поведение с таблицей */
}

.event_container {
  padding: 10px;
  color: #fff;
}

/* Для больших экранов */
@media screen and (min-width: 1500px) {
  table.tt_timetable th, table.tt_timetable td {
    font-size: 16px; /* Увеличиваем шрифт на больших экранах */
  }
}

/* Для маленьких экранов */
@media screen and (max-width: 600px) {
  table.tt_timetable th, table.tt_timetable td {
    font-size: 12px; /* Уменьшаем шрифт на небольших экранах */
  }
}