/*
	Website for Garage Blaser/ Camper rent

	Author: Damian Heini, VIZUAL <dh@vizual.ch>

	Additional styles for the camper rent site.
*/
.viz-camperrent {
  margin: 0 auto;
  max-width: 80rem;
}
.ui-datepicker {
  font-family: inherit;
  z-index: 20 !important;
  font-size: 1rem;
}
.ui-datepicker a {
  border: none;
}
.ui-datepicker .ui-datepicker-prev,
.ui-datepicker .ui-datepicker-next {
  top: auto;
  border-radius: 50%;
  background-color: #4c4c4c;
}
.ui-datepicker .ui-datepicker-prev span,
.ui-datepicker .ui-datepicker-next span {
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  background-image: url("../Icons/arrow-left.svg");
}
.ui-datepicker .ui-datepicker-prev:hover,
.ui-datepicker .ui-datepicker-next:hover {
  cursor: pointer;
}
.ui-datepicker .ui-datepicker-next span {
  background-image: url("../Icons/arrow-right.svg");
}
.ui-datepicker select {
  padding: 0;
  font-family: inherit;
  background-repeat: no-repeat;
  background-position: 64% center;
  background-size: contain;
  background-image: url("../Icons/arrow-down-dark.svg");
}
.ui-datepicker select:hover {
  cursor: pointer;
}
.ui-datepicker select.ui-datepicker-month,
.ui-datepicker select.ui-datepicker-year {
  border: none;
  margin: 0;
  line-height: 1.5em;
}
.viz-camperrent {
  position: relative;
  display: flex;
}
.viz-camperrent.inactive {
  opacity: 0.3;
}
.viz-camperrent #viz-camperrent-booking-calendar-container {
  flex: 1 1 50%;
  margin: 0 0 0 3rem;
}
.viz-camperrent #viz-camperrent-hide-calendar-button {
  display: none;
}
.viz-camperrent #viz-camperrent-rental-form-container {
  position: relative;
  flex: 1 1 50%;
  max-width: 36rem;
}
.viz-camperrent #viz-camperrent-rental-form-container.inactive {
  opacity: 0.3;
}
.viz-camperrent #viz-loading-ani-container {
  display: none;
  position: absolute;
  left: 0;
  width: 100%;
  bottom: 4rem;
}
.viz-camperrent #viz-loading-ani-container.active {
  display: block;
}
.viz-camperrent #viz-loading-ani-container .loading-ani {
  display: block;
  margin: 0 auto;
}
.viz-camperrent #viz-camperrent-client-num-of-people {
  width: 9rem;
}
.viz-camperrent .viz-camperrent-field-row {
  display: flex;
  margin-left: -1.5rem;
  margin-bottom: 1rem;
}
.viz-camperrent .viz-camperrent-field-row .viz-camperrent-form-field-wrapper {
  flex: 1 1 auto;
  margin-left: 1.5rem;
  box-sizing: border-box;
}
.viz-camperrent .viz-camperrent-field-row .viz-camperrent-form-field-wrapper.narrow-field {
  max-width: 6em;
}
.viz-camperrent .viz-camperrent-field-row .viz-camperrent-form-field-wrapper.full-size-field {
  width: 100%;
}
.viz-camperrent .viz-camperrent-field-row.viz-camperrent-extras {
  flex-wrap: wrap;
  margin: 0 0 0 -1.5rem;
}
.viz-camperrent .viz-camperrent-field-row.viz-camperrent-extras .extra-field {
  flex: 0 1 50%;
  margin: 0;
  padding: 0 0 1.5rem 1.5rem;
}
.viz-camperrent .viz-camperrent-field-row.viz-camperrent-extras .viz-camperrent-extras-container {
  display: flex;
  flex-direction: column;
  padding: 1em;
  height: 100%;
  border: 1px solid #fff;
  border-radius: 4px;
  box-sizing: border-box;
}
.viz-camperrent .viz-camperrent-field-row.viz-camperrent-extras .viz-camperrent-extras-price-checkbox-wrapper {
  display: flex;
  margin-bottom: 0.25rem;
}
.viz-camperrent .viz-camperrent-field-row.viz-camperrent-extras .viz-camperrent-extras-price-checkbox-wrapper label {
  width: auto;
  margin-top: 2px;
  padding: 0;
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 1.33em;
}
.viz-camperrent .viz-camperrent-field-row.viz-camperrent-extras .viz-camperrent-extras-short-descr {
  flex: 1 1 auto;
  font-size: 0.95rem;
  line-height: 1.33em;
}
.viz-camperrent .viz-camperrent-field-row.viz-camperrent-extras .viz-camperrent-extras-price-info {
  align-self: flex-end;
  font-size: 1rem;
  margin-top: 0.75rem;
}
.viz-camperrent .viz-camperrent-field-row.viz-camperrent-extras .viz-camperrent-extras-price-info span {
  display: block;
}
.viz-camperrent .viz-camperrent-field-row.viz-camperrent-extras .viz-camperrent-extras-price-info .viz-camperrent-extras-price-per {
  font-size: 0.9em;
  line-height: 1em;
}
.viz-camperrent .viz-camperrent-user-data-container {
  margin-top: 3rem;
}
.viz-camperrent .viz-camperrent-extras-title {
  display: block;
  margin-top: 3rem;
  margin-bottom: 1rem;
}
.viz-camperrent .viz-camperrent-additional-infos-container {
  margin-top: 2rem;
}
.viz-camperrent label {
  display: block;
  margin-bottom: 0.25em;
}
.viz-camperrent label.required-field:after {
  display: inline-block;
  margin-left: 0.25em;
  content: '*';
  font-size: 1.25em;
  line-height: 0.5em;
}
.viz-camperrent label.viz-form-label-show-on-change {
  transition: opacity 0.3s ease-in;
  opacity: 0;
}
.viz-camperrent label.viz-form-label-show-on-change.visible {
  opacity: 1;
}
.viz-camperrent input[type="submit"] {
  width: auto;
  padding: 0.6em 2em 0.6em 2em;
  margin-top: 0.75em;
  color: #003e51;
  text-align: center;
  border: 1px solid #fff;
  border-radius: 0;
  background-color: #b4bdb4;
  transition: all 300ms ease;
  margin-left: 0;
  width: 100%;
  font-weight: normal;
  color: #fff;
  background-color: var(--camperRentMainColorLight);
}
.viz-camperrent input[type="submit"]:hover {
  cursor: pointer;
  color: #fff;
  background-color: #003e51;
}
.viz-camperrent input[type="submit"]:hover {
  cursor: pointer;
  background-color: var(--camperRentMainColor);
}
.viz-camperrent input[type="submit"]:disabled {
  background-color: #b5b8ba;
}
.viz-camperrent input[type="submit"]:disabled:hover {
  cursor: default;
}
.viz-camperrent .viz-form-field-radio-title {
  margin-bottom: 0.5em;
}
.viz-camperrent .viz-form-field-radio-wrap input[type="radio"] {
  margin-top: 0.05em;
}
.viz-camperrent .viz-form-field-radio-wrap .checkbox-checkmark {
  float: left;
  margin-top: 0.25em;
}
.viz-camperrent .viz-form-field-radio-wrap label {
  display: inline-block;
  width: auto;
}
.viz-camperrent .viz-camperrent-date-field,
.viz-camperrent .viz-camperrent-std-textfield,
.viz-camperrent .viz-camperrent-textarea {
  width: 100%;
  box-sizing: border-box;
}
.viz-camperrent .viz-camperrent-date-field {
  font-size: 1.25rem;
  border-radius: 5px;
  padding: 0.33em 0.5em;
  background-repeat: no-repeat;
  background-position: 97% center;
  background-size: 1.33em;
  background-image: url("../Icons/calendar_white.svg");
}
.viz-camperrent #viz-camperrent-show-calendar {
  display: none;
}
.viz-camperrent #viz-camperrent-rentalobjects-list-container {
  margin-bottom: 2rem;
}
.viz-camperrent #viz-camperrent-rentalobjects-list-container ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
.viz-camperrent #viz-camperrent-rentalobjects-list-container ul:hover {
  cursor: pointer;
}
.viz-camperrent #viz-camperrent-rentalobjects-list-container ul li.viz-camperrent-rentalobject {
  display: flex;
  align-items: center;
  visibility: hidden;
  margin: 0;
  padding: 0 0.5em 0 0;
  height: 0;
  font-size: clamp(1rem, 3vw, 1.125rem);
  line-height: 1.25em;
  font-weight: 500;
  border: none;
  border-radius: 4px;
  box-sizing: border-box;
  overflow: hidden;
  opacity: 0.5;
  transition: height 0.5s ease, border 0.3s ease, background-color 0.3s ease, opacity 0.3s ease;
}
.viz-camperrent #viz-camperrent-rentalobjects-list-container ul li.viz-camperrent-rentalobject.selected,
.viz-camperrent #viz-camperrent-rentalobjects-list-container ul li.viz-camperrent-rentalobject.selected:hover {
  visibility: visible;
  height: 4.125rem;
  border: 2px solid #e3e3e3;
  background-color: var(--camperRentMainColor);
  opacity: 1;
}
.viz-camperrent #viz-camperrent-rentalobjects-list-container ul li.viz-camperrent-rentalobject:hover {
  color: #fff;
  background-color: var(--camperRentMainColorLight);
  opacity: 1;
}
.viz-camperrent #viz-camperrent-rentalobjects-list-container ul li.viz-camperrent-rentalobject .viz-camperrent-rentalobject-image {
  height: 100%;
  width: auto;
  margin-right: 1rem;
}
.viz-camperrent #viz-camperrent-rentalobjects-list-container ul li.viz-camperrent-rentalobject .viz-camperrent-rentalobject-image img {
  height: 100%;
  width: auto;
}
.viz-camperrent #viz-camperrent-rentalobjects-list-container ul.open li {
  visibility: visible;
  height: 4.125rem;
  border: 1px solid #e3e3e3;
  margin-bottom: 0.5rem;
}
.qtip {
  box-shadow: 1px 1px 10px 4px rgba(0,0,0,0.5);
}
.qtip.viz-camperrent-date-range-tooltip {
  font-size: 1rem;
  line-height: inherit;
}
.qtip-default {
  font-size: 1rem;
  line-height: inherit;
  color: #fff;
  background-color: var(--camperRentMainColor);
}
.qtip-content {
  padding: 0.5rem 1rem;
}
.fc-unthemed td.fc-today {
  background-color: #888;
}
.viz-camperrent-camper-descr-list-container .viz-thumbnail-image-gallery-container {
  margin: 2rem 0 2rem 0;
}
@media (max-width: 1000px) {
  .viz-camperrent {
    display: block;
  }
  .viz-camperrent #viz-camperrent-booking-calendar-container {
    position: absolute;
    top: 0;
    right: calc(100vw * (-1));
    width: calc(90vw);
    margin: 0 -1.5rem 0 0;
    padding: 1rem;
    background-color: #4c4c4c;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    border: 1px solid #000;
    box-shadow: -3px -1px 8px 3px rgba(0,0,0,0.7);
    z-index: 20;
    transition: right 300ms ease;
  }
  .viz-camperrent #viz-camperrent-booking-calendar-container.active {
    right: 0;
  }
  .viz-camperrent #viz-camperrent-show-calendar {
    display: flex;
    justify-content: flex-end;
  }
  .viz-camperrent #viz-camperrent-show-calendar-button,
  .viz-camperrent #viz-camperrent-hide-calendar-button {
    margin-top: 0;
    padding-right: 3rem;
    background-repeat: no-repeat;
    background-position: right center;
    background-size: contain;
    background-image: url("../Icons/showCalendar.svg");
    line-height: 1.25em;
  }
  .viz-camperrent #viz-camperrent-show-calendar-button:hover,
  .viz-camperrent #viz-camperrent-hide-calendar-button:hover {
    cursor: pointer;
  }
  .viz-camperrent #viz-camperrent-hide-calendar-button {
    display: block;
    width: 2rem;
    height: 2rem;
    padding: 0;
    margin-bottom: 0.5rem;
    background-image: url("../Icons/close_light.svg");
    transition: all 0.2s ease-in-out;
  }
  .viz-camperrent #viz-camperrent-hide-calendar-button:hover {
    transform: scale(1.05);
  }
}
@media (max-width: 600px) {
  .viz-camperrent #viz-camperrent-booking-calendar-container {
    margin: 0 -1rem 0 0;
  }
  .fc-toolbar.fc-header-toolbar {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
  }
  .fc-toolbar.fc-header-toolbar .fc-right button,
  .fc-toolbar.fc-header-toolbar .fc-right .fc-button-group {
    margin: 0 0.75rem 0 0;
  }
  .fc-toolbar.fc-header-toolbar .fc-right .fc-button-group:last-child {
    margin-top: 0.5rem;
  }
  .fc-toolbar.fc-header-toolbar .fc-center,
  .fc-toolbar.fc-header-toolbar .fc-clear {
    display: none;
  }
}
@media (max-width: 480px) {
  .viz-camperrent {
    flex-wrap: wrap;
  }
  .viz-camperrent .viz-camperrent-field-row {
    flex: 1 1 100%;
    flex-wrap: wrap;
  }
  .viz-camperrent .viz-camperrent-field-row.viz-camperrent-extras .extra-field {
    flex: 1 1 100%;
  }
  .viz-camperrent .viz-camperrent-field-row .viz-camperrent-form-field-wrapper {
    flex: 1 1 100%;
  }
  .viz-camperrent .viz-camperrent-field-row .viz-camperrent-form-field-wrapper.narrow-field {
    max-width: 100%;
  }
  .viz-camperrent .viz-camperrent-field-row .viz-camperrent-form-field-wrapper #viz-camperrent-client-zip,
  .viz-camperrent .viz-camperrent-field-row .viz-camperrent-form-field-wrapper #viz-camperrent-client-email,
  .viz-camperrent .viz-camperrent-field-row .viz-camperrent-form-field-wrapper #viz-camperrent-client-firstname {
    margin-bottom: 1rem;
  }
}
