@import url(//fonts.googleapis.com/css?family=Source+Sans+Pro:400,600);

.choose-date-time .date{
    display: inline-block;
    vertical-align: top;
    margin-right: -5px
}

.choose-date-time .date-heading{
    background: #f9f9f9;
    text-align: center;
    padding: 15px
}

.choose-date-time .day-of-week{
    font-weight: 700
}

.choose-date-time .date-secondary{
    color: #686868;
    font-size: 14px
}

.choose-date-time .choose-time{
    position: relative;
    text-align: left;
    padding-left: 20px;
}
.close-href-time-action-wrapper{
    width: 20px;
    margin-top: -18px;
    z-index: 9999;
    color: #FFF;
}

.choose-time{
    /*
    border-left: solid 1px #DDDDDD;
    border-bottom: solid 1px #DDDDDD;

     */
    padding-right: 5px;
}

.choose-time-last{
    /*
    border-right: solid 1px #DDDDDD;

     */
}

.choose-date-time .choose-time .time-selection {
    display: none
}

.choose-date-time .choose-time label{
    font-weight: 400;
    color: #4f4f4f;
    padding: 7.5px 15px;
    margin: 7.5px 0;
    cursor: pointer;
    position: relative;
}

.choose-date-time .choose-time input[type=radio] + label{
    border: 2px solid transparent
}


.choose-date-time .choose-time input[type=radio]:checked + label:after{
    content: ' ';
    display: block;
    width: 100%;
    height: 4px;
    background: #fff;
    position: absolute;
    left: 0;
    bottom: -1px
}


.choose-date-time .choose-time .choose-time-actions .btn{
    z-index: 1000;
}

.choose-date-time .choose-time .choose-time-actions .btn{
    text-align: left;
    overflow: hidden;
    white-space: pre-line
}


.choose-date-time .calendar-prev-next{
    padding-bottom: 30px
}

.choose-date-time .calendar-prev-next a{
    color: #686868;
    text-transform: uppercase;
    letter-spacing: .05em;
    font-weight: 700;
    font-size: 14px
}

.choose-date-time .calendar-next{
    float: right
}

.choose-date-time .calendar-previous{
    float: left
}

.choose-date-time .loading-container{
    font-size: 100%;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    text-align: center;
    color: #9b9b9b;
    margin-top: 45px;
    margin-bottom: 30px;
    min-height: 300px
}


.wrapper{
    background: #F4F4F4;
}
.acc-v1 .panel-heading a {
    font-size: 20px;
}
.acc-v1 .panel-heading a:hover {
    text-decoration: none;
}

.appointment-durations{
    display: none;
    padding-left:5px;
    margin-bottom: 15px;
}
.staff-duration-button{
    margin: 5px 10px 5px 0;
}
.duration_available_staff_wrapper{
    margin-top: 5px;
    display: none;
}

.appointment-wrapper{
    margin-bottom:10px;
}
.appointment-type-header{
}

.appointment-image{
    display: block;
}
.duration-button{
    margin: 5px 10px 5px 0;
}
.header-hover{
    background: #f7f4f4;
}
.panel-title{
    font-size: 20px;
}
.date{
    padding-left: 0;
    padding-right: 0;
}
.date-heading{
    border-bottom: solid 1px #DFDFDF;
}
.calendar-prev-next{
    display:block;
}
.choose-date-time .choose-time label{
    line-height: 1.3;
}
.time_label_coach_name{
    font-size: 10px;
    max-width: 75px;
}

.sorting{
    background-image: none;
}
table.dataTable thead th, table.dataTable thead td {
    border-bottom: none;
}
table.dataTable.no-footer {
    border-bottom: none;
}
.choose-date-time .choose-time label{
    padding: 3px 7px;
    margin: 3px 0;
}

.choose-date-time .choose-time .choose-time-actions {
    margin-top: -5px;
    width: 150px;
    min-width:150px;
    border-radius: 7.5px;
}

caption {
    font-size:16px;
}

p.recurring-modal{
    margin: 10px 0 0 0;
}

table.dataTable tfoot th, table.dataTable tfoot td {
    padding: 8px;
}
table.dataTable thead th, table.dataTable thead td {
    padding: 8px;
}

#id_previous_dates{
    display: block;
}


#id_available_schedule_wrapper{
    max-height: 375px;
    min-height: 375px;
    height: 375px;
    display: none;
}
.not-available-span{
    text-decoration: line-through;
    color:#a94442;
}

#id_limit_checkbox_wrapper{
    display:none;
}

.headline{
    margin: 0 0 10px 0;
}
.content{
    padding-top: 15px;
}

.appointment_duration_header{
    margin-bottom: 0;
    font-weight: bold;
}

.label-time-selected{
    background-color: #f0ad4e !important;
    border-color: #eea236 !important;
    color: #FFF !important;
    border-radius: 7.5px !important;
}


/*latest*/
.bio{
    margin-bottom: 0 !important;
    font-size:12px !important;
    line-height: 16px;
}
.bio *{
    font-size:12px !important;
    line-height: 16px;
}

.policy{
    margin-bottom: 0 !important;
    font-size:12px !important;
    line-height: 16px;
    text-align: left;
}
.policy *{
    font-size:12px !important;
    line-height: 16px;
    text-align: left;
}
.policy-main{
    margin-bottom: 0 !important;
    font-size:14px !important;
    line-height: 18px;
    font-weight:600;
    text-align: left;
}

.call-action-v1 .call-action-v1-box{
    padding: 5px 0;
}
.StripeElement--invalid{
    background-color: #f2dede;
    border-color: #ebccd1;
}
#card-errors{
    color: #e74c3c;
    font-weight: bold;
}

.panel-heading h4 {
    display: block;
    font-size: 20px;
    padding: 5px 15px;
    background: #fefefe;
}
.sigWrapper{
    width:400px;
    height:210px;
    border: none;
}
.alert-danger {
    padding: 15px;
    border-radius: 7px;
}
.hidden-form-container{
display:none;
}
.tag-box{
border: solid 1px #ddd;
margin-bottom: 0;
}
.panel{
margin-bottom: 20px !important;
}
.tag-box{
padding: 15px;
}
.panel-body{
padding-top:0;
}

@media (max-width: 992px) {
    .call-action-v1 .call-action-v1-in, .call-action-v1 .call-action-v1-in.inner-btn {
        text-align: left;
    }
}

.less-padding-col{
    padding-left: 5px;
    padding-right: 5px
}