/*
 * Apollo Appointment Form v4.7
 */

.k-calendar .k-calendar-table.k-calendar-content,
.k-calendar .k-calendar-table.k-content,
.k-calendar table.k-calendar-content,
.k-calendar table.k-content {
  color: blue;
}

.k-calendar .k-other-month {
  color: blue;
}

.k-calendar .k-calendar-content .k-state-disabled,
.k-calendar .k-content .k-state-disabled {
  color: grey;
  opacity: .65;
}

.attribute-item {
  margin: 0 20px 0 0;
}

.attribute-label {
    display: block;
    margin: 0 0 5px;
    white-space: nowrap;
    font-weight: bold;
    color: #444;
    font-size: 15px;
}

.variant-overview .cart-info {
    overflow: hidden;
    font-size: 12px;
    display: inline-block;
}

.variant-picture {
  vertical-align: top;
}

.btn {
  display: inline-block;
  font-weight: 400;
  color: #212529;
  text-align: center;
  vertical-align: middle;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  background-color: transparent;
  border: 1px solid transparent;
  padding: 0.375rem 0.75rem;
  font-size: 1rem;
  line-height: 1.5;
  border-radius: 0.25rem;
  transition: color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;
}

.appointmentTimeSelect .btn {
    background-color: lightgray;
    border-width: 1px;
    border-style: outset;
    border-image: initial;
    margin: 3px;
    padding: 5px;
    width: 80px;
    text-align: center;
    text-decoration: none;
    color: black;
    display: inline-block;
    font-size: 14px;
    cursor: pointer;
}

    .appointmentTimeSelect .btn:active {
        background-color: orange;
    }

.appointmentTimeSelect .btn-unselect {
    background-color: lightgray;
}

.appointmentTimeSelect .btn-select {
    background-color: orangered;
}

@media all and (min-width: 500px) {

    .appointmentTimeSelect {
        display: inline-block;
        width: 100%;
        padding: 20px 0 0 0;
    }

    .appointmentSelectPeriod {
        margin: 10px;
    }
}

@media all and (min-width: 501px) and (max-width: 768px) {

    .appointmentTimeSelect {
        display: inline-block;
        width: 100%;
        padding: 20px 0 0 0;
    }

    .appointmentSelectPeriod {
        margin: 10px;
    }
}

@media all and (min-width: 769px) and (max-width: 1024px) {

    .appointmentTimeSelect {
        display: inline-block;
        width: 100%;
        padding: 20px 0 0 0;
    }

    .appointmentSelectPeriod {
        margin: 10px;
    }
}

@media all and (min-width: 1025px) {

    .appointmentTimeSelect {
        display: inline-block;
        width: 100%;
                padding: 20px 0 0 0;
    }

    .appointmentSelectPeriod {
        margin: 10px;
    }
}

@media all and (min-width: 1281px) {

    .appointmentTimeSelect {
        display: inline-block;
        width: 100%;
        padding: 20px 0 0 0;
    }

    .appointmentSelectPeriod {
        margin: 10px;
    }
}

@media all {

    .appointmentTimeSelect {
        display: inline-block;
        width: 100%;
        padding: 20px 0 0 0;
    }

    .appointmentSelectPeriod {
        margin: 10px;
    }
}
