body {
    background-color: #fafafa;
}
body.hide-right-sidebar #main-tabs-container,
body[data-page="app"] #main-tabs-container,
body[data-page="appList"] #main-tabs-container,
body[data-page="details_route"] #main-tabs-container,
body[data-page="confirm_route"] #main-tabs-container,
body[data-page="editForm_route"] #main-tabs-container,
body[data-page="contactEvents_route"] #main-tabs-container,
body[data-page="documents_route"] #main-tabs-container,
body[data-page="setting-e-form-tab"] #main-tabs-container,
body[data-page="portalLogin_route"] #main-tabs-container,
body[data-page="map_route"] #main-tabs-container,
body[data-page="documents2_route"] #main-tabs-container,
body[data-page="emails_route"] #main-tabs-container,
body[data-page="emailView_route"] #main-tabs-container,
body[data-page="contactSettings_route"] #main-tabs-container,
body[data-page="setting-practice-tab"] #main-tabs-container,
body[data-page="con"] #main-tabs-container,
body[data-page="ins"] #main-tabs-container,
body[data-page="store"] #main-tabs-container,
body[data-page="ehrs_route"] #main-tabs-container,
body[data-page="reset_route"] #main-tabs-container,
body[data-page="new_account_route"] #main-tabs-container,
body[data-page="invoices2_route"] #main-tabs-container,
body[data-page="editFormPublic_route"] #main-tabs-container,
body[data-page="register_route"] #main-tabs-container,
body[data-page="activate_route"] #main-tabs-container
{
    width:100% !important;
}
body.hide-right-sidebar #business-view,
body[data-page="app"] #business-view,
body[data-page="appList"] #business-view,
body[data-page="details_route"] #business-view,
body[data-page="confirm_route"] #business-view,
body[data-page="editForm_route"] #business-view,
body[data-page="contactEvents_route"] #business-view,
body[data-page="setting-e-form-tab"] #business-view,
body[data-page="portalLogin_route"] #business-view,
body[data-page="documents_route"] #business-view,
body[data-page="documents2_route"] #business-view,
body[data-page="emails_route"] #business-view,
body[data-page="emailView_route"] #business-view,
body[data-page="contactSettings_route"] #business-view,
body[data-page="map_route"] #business-view,
body[data-page="con"] #business-view,
body[data-page="ins"] #business-view,
body[data-page="store"] #business-view,
body[data-page="ehrs_route"] #business-view,
body[data-page="new_account_route"] #business-view,
body[data-page="register_route"] #business-view,
body[data-page="activate_route"] #business-view,
body[data-page="reset_route"] #business-view,
body[data-page="invoices2_route"] #business-view,
body[data-page="editFormPublic_route"] #business-view,
body[data-page="setting-practice-tab"] #business-view{
    display:none !important;
}
body[data-page="app"] #map-tab-li,
body[data-page="appList"] #map-tab-li,
body[data-page="details_route"] #map-tab-li,
body[data-page="confirm_route"] #map-tab-li,
body[data-page="editForm_route"] #map-tab-li,
body[data-page="contactEvents_route"] #map-tab-li,
body[data-page="setting-e-form-tab"] #map-tab-li,
body[data-page="portalLogin_route"] #map-tab-li,
body[data-page="documents_route"] #map-tab-li,
body[data-page="documents2_route"] #map-tab-li,
body[data-page="emails_route"] #map-tab-li,
body[data-page="emailView_route"] #map-tab-li,
body[data-page="contactSettings_route"] #map-tab-li,
body[data-page="map_route"] #map-tab-li,
body[data-page="new_account_route"] #map-tab-li,
body[data-page="register_route"] #map-tab-li,
body[data-page="activate_route"] #map-tab-li,
body[data-page="reset_route"] #map-tab-li,
body[data-page="setting-practice-tab"] #map-tab-li{
    display:inline !important;
}
body.hide-right-sidebar #map-tab-li{
    display:none !important;
}

body:not(.has-payment-provider) .pp-required{
    display:none;
}

#map-tab-li {
    display:none;
}

.dim,#dim,#dim2,.loading,.next-loading {
    backgound-color:#fff !important;
}
input, button, select, textarea {
    font-family: 'Open Sans', Helvetica, Arial, sans-serif;
}

#main-content {
	padding: 25px 30px 0px 25px;
	width: 80%;
	margin: 20px auto 0;
	position: relative;
/*	min-width: 700px;*/
	min-height: 350px;
	background: #fff;
	border-radius: 8px;
	box-shadow: 0px 1px 8px 0px rgba(0, 0, 0, 0.1);
	overflow: hidden;
}


.navbar .nav > li > a {
    padding: 0px 5px 0px;
}

#main-pracitce-logo {
    max-height: 100px;
    vertical-align: top;
    max-width: 170px;
    margin-bottom: 20px;
}
#main-pracitce-logo.centered {
	max-height: 34vh;
	margin-bottom: 5px;
	max-width: 100%;
}
#language-div {
    float: right;
    margin: -10px 10px;
    z-index: 6;
    text-align: right;
}

#profile-text-div{
    text-align:center
}

.dim {
	background-image: url("/images/ajax-loader.gif");
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
	background-position: 50% 50%;
	background-repeat: no-repeat;
}

ul,li {
    list-style:none;
}
[data-notify='container'] li {
        list-style:disc;
}
.formList ul,ul.formList {
    margin:0;
}
.li-right-tools {
    margin: -5px -15px;
}
.li-right-tools + .li-right-tools{
     margin: -5px 20px;
}
.intro-item {
    max-height: 280px;
    min-height: 225px;
}


/* chrome and safari only */
@media screen and (-webkit-min-device-pixel-ratio:0) {
    #patientLoginForm input[type="email"],#patientLoginForm input[type="password"],#password3,#email3{
        font-size:16px;
    }
}

#portal-tabs-content {
    min-height: 150px;
    clear: both;
    margin-top: 20px;
}
#main-title{
    float: left;
    font-size: 35px;
    font-style: normal;
    font-weight: bold;
}
.main-panel {
    position:relative;
}

#access-portal-docs,
#shared-docs {
    width: auto;
    height: auto;
}
.alert:empty,
#access-portal-docs:empty,
#shared-docs:empty{
    display:none;
}

.access-portal-docs {
    width: auto;
    height: 100%;
    overflow-y: hidden;
    border: 0 none;
    padding: 0;
    background: transparent;
    border: 0 none;
    height: auto;
}
#access-portal-docs div,
#event-view {
    padding: 0;
    width: auto;
}
.nav-tabs > .active > a, .nav-tabs > .active > a:hover, .nav-tabs > .active > a:focus {
    background-color: #eee;
}
.nav-tabs li a {
    font-size: 15px;
}

#appointment-instructions {
	padding: 10px 10px;
	text-align: center;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	height: 150px;
	background: #fff;
	margin: 0px 0 0;
}
#event-list-date-title {
    font-size: 14px;
    font-weight: bold;
    margin: 23px 0 10px;
    color: #666;
}

#confirm-welcome-user-access,#confirm-welcome-user-access-waitlisted{
    margin:0 0 15px;
}

.fa-star {
    color: gold;
}

#dim2 {
	position: absolute;
	left: -8px;
	right: -8px;
	top: -8px;
	bottom: -8px;
	background-color: rgba(255, 255, 255, .7);
	z-index: 9;
	min-height: 0;
}
#dim2.fullWhite {
    background-color: #fff;
    margin: -75px -10px 0;
}

#dim2.spinner {
    background: #fff url("/images/ajax-loader.gif") no-repeat scroll 50% 50% !important;
}

#portal-tabs ul li a i{
    vertical-align: middle;
}
#portal-tabs ul li a span {
    vertical-align: middle;
}
#portal-tab{
    position:relative;
}
.custom-table{
    border:1px solid #ccc
}

.setting-settings-tab .password label {
    float: left;
    padding-top: 5px;
    width: 100%;
}

#business-view {
    overflow:hidden;
}
#business-view > table td:first-child{
    width:40px
}
#business-view > table td:last-child {
    width: auto;
}

#profile-view {
    position: relative;
    margin: 0;

}
#profile-view .pfv-inner {
    margin: 0px 0 15px;
    clear: both;
}
#wifi-icon-div{
    overflow: visible;
    width: 45px;
    display: inline-block;
    text-align: center;
    min-height: 30px;
    margin: -10px 0 0 -20px;
    float: left;
}

#profile-text-div{
    text-align:center
}
#business-view table td {
    font-size:95%;
    padding: 3px 0;
    vertical-align: top;
}
#business-view table td:first-child {
    padding-right: 8px;
    font-weight: bold;
    font-size:100%;
}
#business-view table td:nth-child(3) {
    padding:3px 2px;
}

#hrs-table {
    border: 0 none !important;
    margin: -3px 0px 0 -9px;
}
#hrs-table td:first-child {
    padding: 3px 9px;
}
#hrs-table tr:nth-child(2) td {
    padding-top: 3px !important;
}
#hrs-table td:last-child {
    text-align:right
}
#service-div ul {
    list-style:none outside none !important;
    padding:0;
}
li.li-select {
    margin: 15px 0 10px;
}
#login-profile-select-div li {
    margin: 15px 0 10px;
}

#service-div {
    font-size: 12px;
}

#hrs-table  td:first-child {
    font-weight: normal !important;
}

#appointment-timer {
    font-size: 11px;
    text-align: right;
    margin-right: 5px;
}
#appointment-timer-reset {
    text-align: right;
    margin-bottom: 15px;
}
#appointment-timer:empty,
#appointment-timer-reset:empty{
    display:none;
}

#dim {
    position:absolute;
    top:0;
    bottom:0;
    right:0;
    left:0;
    background-color:#fff;
    border-radius:30px;
    background-image:none;
}

#event-list {
    margin-top: 15px;
    text-align: left;
}

#event-list .col-md-4{
    overflow:hidden;
}

#event-list ul {
    margin: 5px 0px 10px 0;
    padding: 0;
}
#event-list li {
    list-style-type: none;
    margin: 0 5px 5px 0;
    text-align: center;
    width: auto;
    display: inline-block;
    vertical-align: top;
}
#event-list li a {
    border-radius: 3px !important;
    line-height: 20px;
    font-size: 12px;
    display: inline-block;
    min-width: 65px;
    padding: 3px 3px 2px;
}

.event-alert {
    position: relative;
}

[contenteditable] {
    outline: none;
}
.testimonial {
    border: 1px solid #e6e6e6;
    margin: 20px auto;
    padding: 0;
    text-align: left;
}
.testimonial .inner {
    border: 1px solid #ffffff;
    margin: 0;
    padding: 20px;
}
.testimonial .heading {
    background: url("/images/quotes.png") no-repeat scroll left center transparent;
    height: 24px;
    margin-top: 0;
    padding-left: 40px;
    text-align: left;
    display: inline-block;
}
.testimonial .body {
    float: none;
    font-style: italic;
    padding-top: 0;
}
.testimonial .client {
    margin-top: 1em;
    text-align: right;
}
.testimonial .client .name {
    color:grey
}
.testimonial .fa-star {
    color:gold;
}
.testimonial .star-text{
    color: #939393;
    font-size:12px;
}
.title-div {
    display: block;
}

.cover-img {
    display: inline-block;
    height: 330px;
}
.carousel-inner > .item {
    text-align: center;
}
.carousel-caption {
    background:none;
    text-align:center
}
.carousel-caption h4, .carousel-caption p {
    color:inherit;
}
.carousel-control i {
    color: #444444;
    display: block;
    font-size: 34px;
    margin: 13px 14px 0;
    background-image: none;
}
.carousel-control i:hover {
    color:#bbb;
}
.carousel-control {
    background: none repeat scroll 0 center rgba(0, 0, 0, 0);
}
@media screen and (-webkit-min-device-pixel-ratio:0) {
    .carousel-control i {
        margin: 12px 14px 0;
    }
}
.cover-img:empty {
    height: 90px;
}
.carousel-control.right {
    left: auto;
    right: -30px;
}
.carousel-control.left {
    right: auto;
    left: -30px;
}
#calendar.loading,#calendar-container-row.loading {
    background: url(/images/ajax-loader.gif) no-repeat 50% 50%;
    max-height:357px;
    height:357px;
    overflow:hidden;
}
#calendar.loading.init .pika-single{
    visibility: hidden;
}
#calendar-container-row {
    min-height:357px;
}

#email-container.loading{
    min-height:200px;
}
.next-loading {
    background: url("/images/ajax-loader.gif") no-repeat scroll 50% 50%;
    z-index: 999;
    min-height: 275px;
}
.ajaxSpinner {
	background-image: url("/images/ajaxSprites.png");
	display: none;
	height: 16px;
	margin: 0px 0 -2px 10px;
	width: 16px;
	background-repeat: no-repeat;
}
img.loadingImg-xs {
    z-index: 9999999999999;
    position: absolute;
    top: calc(50% - 11px);
    left: calc(50% - 13px);
    height: 24px;
}

#available-tab-list li{
    margin-bottom:10px;
}
#available-tab-list li a {
    text-decoration:none !important;
    color:#666666;
}
#available-tab-list li:hover  {
    cursor:pointer;
}
.profile-select{
    margin:0 0 10px
}
.profile-select select{
    width:100%
}
.welcome-user-access {
    display: inline-block !important;
    margin: 3px;
}
a.disabled:not(.user-file),a.disabled:not(.user-file):hover {
    background: rgb(236, 236, 236) none repeat scroll 0 0 !important;
    border: 1px solid rgb(215, 215, 215) !important;
    cursor: default !important;
}

.btn.loading i::before {
    content: "\f110";
    display:inline-block;
    -moz-animation: spin 2s infinite linear;
    -o-animation: spin 2s infinite linear;
    -webkit-animation: spin 2s infinite linear;
    animation: spin 2s infinite linear;
}

.li-select.selected .alert{
    background-color:#eee;
    cursor:default;
    border-color:#eee;
}
#ie-alert {
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
    position:absolute;
    top:0;
    left:0;
    right:0;
    bottom:0;
    z-index:100;
    text-align:center;
    background: none repeat scroll 0 center rgba(255,255,255,.7);

}
#private-alert {
    margin:-10px 0 15px;
}
.alert-area:empty{
    border: 0 none;
}
.timezone-alert:empty{
    display:none;
}
h8 {
    font-size: 10px;
    text-transform: uppercase;
    line-height: 15px;
}

.remove-form-btn {
    text-decoration: none !important;
    z-index: 1;
}
.email-header th {
    text-decoration:none !important;
}
#form-content{
    position:relative;
    font-size:14px
}

#contact-credit-card-modal .modal-body {
    max-height: calc(100vh - 170px);
    overflow: auto;
}
.form-group{
    position:relative;
}
.image-remove-btn {
    margin: 25px 0;
}

.one-third {
    float: left;
    width: calc(33.33% - 25px);
    margin-right: 25px;
    display: inline-table;
    vertical-align: top;
}
.contact-form-booking-reg .form-group input[type=text],
.contact-form-booking-reg .form-group input[type=password],
.contact-form-booking-reg .form-group input[type=tel],
.contact-form-booking-reg .form-group input[type=email],
.contact-form-booking-reg .form-group input[type=date],
.contact-form-booking-reg .form-group select,
.contact-form-booking-reg .form-group textarea
{
    width:100%
}
.selected-appointment {
    min-height: 72px;
    border-radius: 3px;
    border:1px solid #ccc;
}

.selected-appointment:not(.confirmed):not(.waitlisted) {
	border: 2px solid #FEC431 !important;
	border-radius: 3px !important;
	box-shadow: none;
}
.selected-appointment:not(.confirmed):not(.waitlisted) * {
	color: #000 !important;
	box-shadow: none;
}
.selected-appointment .unconfirmed-banner {
	display: none;
	background: #FEC431;
	padding: 5px;
	color: #fff !important;
	font-size: 17px;
        clear:both
}
.event-alert.mini-box.log-ali.selected-appointment.alert.alert-danger{
    background-color: #ffde7e !important
}
.selected-appointment .unconfirmed-banner *, .selected-appointment:not(.confirmed):not(.waitlisted) .unconfirmed-banner *{
    color:#fff !important;
}
.selected-appointment:not(.confirmed):not(.waitlisted) .unconfirmed-banner{
    display:block;
}
.day-closed {
    color:#bbb;
}
.event-details-area .event-time {
    margin-top: 5px;
    max-width: calc(100% - 100px);
}


.custom-table th:hover {
    text-decoration: none;
}
#insurance-list li {
    display: inline-block;
    margin: 5px 5px 0 0;
    min-width: 80px;
}

.swap-language.btn{
    margin:2px;
}

.bus-hrs-row{
    overflow:hidden;
}
#business-view-table .col-md-2 {
    display: inline-block;
    text-align: right;
    width: 55px;
    margin-right: 8px;
}

#business-view-table .col-md-10 {
    width:auto !important;
    display:inline !important;
}

#appointment-tab-content{
    margin-top:20px;
    min-height:150px;
}

/*  navbar */
.step-tabs {
    width:100%;
}

.step-tabs .store-checkout-line{
    position: relative;
    line-height: 30px;
    width:25% !important;
}

.step-tabs .progress-bar_element {
    position: relative;
    line-height: 30px;
    width: 25% !important;
    display: inline-block;
}
.navbar {
    max-height: 100%;
    min-height: auto;
    height: auto;
    color: #666;
    box-shadow: none;
    border: 1px solid #ccc !important;
    /* box-shadow: rgba(0, 0, 0, 0.14) 0px 3px 8px 0px, rgba(0, 0, 0, 0.08) 0px 0px 1px 0px; */
}
.select-shipping-btn[disabled]{
    pointer-events:none;
    cursor:pointer;
    opacity:1;
}
.select-shipping-btn[disabled]:hover{
    pointer-events:none;
    cursor:pointer;
    opacity:1;
    border:0 none;
}
.step-tabs .completed a {
    background: #eee;
    color: #777;
    box-shadow: none;
}

.ml-0{
    margin-left: 0!important;
}
.m-5-percent{
    margin: 5%!important;
}

.alignContent .item {
    min-height: 100px;
}

.flex-layout{
    display: flex;
}
.add-three-dots{
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}



.flex-wrap{
    flex-wrap: wrap;
}

.p10{
    padding: 10px;
}

.item-flex-1-shipping-option{
    height: auto;
    border: 2px solid white;
    align-items: center;
    border: 1px solid #dddddd;
    border-radius: 3px;
    margin: 1%;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}
.item-flex-1-shipping-option__selected {
    outline: 1px solid #08c;
    border: 1px solid #08c;
}

#checkout-shipping-error {
    padding: 45px;
    background-color: rgba(246, 83, 83, 0.6);
    ;
    border: 3px solid #aa0212;
    border-radius: 10px;
    color: white;
}

#checkout-shipping-error_wrap {
    display: flex;
    justify-content: space-around;
    align-items: center;
    flex-direction: column;
}
#checkout-shipping-error_wrap>i {
    font-size: 86px;
    color: #aa0212;
    margin: 30px;
}
#checkout-shipping-error_wrap>strong {
    margin-bottom: 20px;
    text-align: center;
    color: black;
    font-size: 18px;
    font-style: italic;
}

.m-0{
    margin:0px !important;
}

#store-checkout-container-loading {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 500;
    background-color:rgba(255, 255, 255, 0.5);
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
}

.shipping-cost-container {
    display : flex;
    justify-content: space-around;
    align-items: center;
    width: 100%;
    height: 100%;
    padding-left: 10px;
    padding-right: 10px;
    cursor: pointer;
}

.labl {
    display : block;
    margin-left: 20px;
    margin-top: 5px;
    cursor:pointer;
    padding-bottom: 5px;
}

.price-shipping-option{
    width: 50%;
    text-align:right;
    font-weight: bold;
}

.inline-block{
    display: inline-block;
}

.type-shipping-option{
    padding-left: 20px;
    width: 40%;
}

.item-flex-2{
    height: auto;
    border: 2px solid white;
    align-items: center;
    border: 1px solid #dddddd;
    border-radius: 3px;
    margin: 1%;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}
.border-red{
    border-color: red !important;
}

.display-shipping-info > ul > li {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.flex-wrap > .item-flex-2 {
    flex: 0 0 47.7%;
}
.flex-wrap > .item-flex-1-shipping-option {
    flex: 0 0 100%;
}

.w-10{
    width: 10%;
}

.store-padding-add-new-shipping{
    padding:10px;
}
.display-shipping-info ul {
    margin:0;
    padding:0;
}

.flex-content-between{
    justify-content: space-between;
}

.checkout-title{
    font-size: 1.4857142857em;
    line-height: 1.3em;
}

.button-continue{
    cursor: pointer;
    display: inline-block;
    background-color: #2681bf;
    background-clip: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    border: 1px transparent solid;
    border-radius: 3px;
    color: white;
    font-weight: 500;
    padding: 1.4em 1.7em;
    text-align: center;
    position: relative;
    -webkit-transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out, -webkit-box-shadow 0.2s ease-in-out;
    transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out, -webkit-box-shadow 0.2s ease-in-out;
    transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
    transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out, box-shadow 0.2s ease-in-out, -webkit-box-shadow 0.2s ease-in-out;
}

.w-55-percent{
    width:55%;
}

.w-49-percent{
    width:49%;
}

.w-100{
    width: 100%;
}

.step-tabs li {
    width: 25%;
    text-align: center;
    display: inline-block;
}

.step-tabs .shopping{
    width:33%;
    text-align:center;
}

.step-tabs.checkout-progress-bar li{
    width:33.3% !important;
}
#store-tab.skippShipping .step-tabs.checkout-progress-bar li{
    width:50% !important;
}
#store-tab.skippShipping #checkout-shipping-step{
    display:none
}
#product-detail .image-main img {
    max-height:425px;
    margin-bottom:20px
}
#product-detail .card-text {
	font-size: inherit;
	/* max-width: 50%; */
	min-width: 400px;
	margin: 0 auto 25px;
        text-align:left;
}
.step-tabs .active a {
    background: #4a89dc;
    color: #fff;
    box-shadow: none;
}
ul.nav-pills li.active a {
    background-color: #4a89dc;
}
.nav-pills > li.active > a, .nav-pills > li.active > a:hover, .nav-pills > li.active > a:focus {
    background-color: #2972d2;
}
.nav-pills > li > a {
    color: #666;
}

.progress-bar_element {
    white-space: nowrap;
    background: white;
}


.store-checkout-line.active:not(#checkout-payment-step)::after,
.progress-bar_element.active:not(.no-arrow-tab)::after {
    content: '';
    position: absolute;
    left: 100%;
    top: 0%;
    width: 0;
    height: 0;
    border-top: 15px solid transparent;
    border-bottom: 15px solid transparent;
    border-left: 10px solid #4a89dc;
    z-index: 1;
    clear: both;
}

.progress-bar_element.completed:not(.no-arrow-tab)::after, .store-checkout-line.completed::after {
    content: '';
    position: absolute;
    left: 100%;
    top: 0%;
    width: 0;
    height: 0;
    border-top: 15px solid transparent;
    border-bottom: 15px solid transparent;
    border-left: 10px solid #efefef;
    z-index: 1;
    clear: both;
}

.scheduling-description, 
.scheduling-description * {
	font-size: 11.5px !important;
}
.scheduling-description:empty{
    display:none
}
.step-tabs .disabled a {
    background: #fff;
    cursor: default;
    box-shadow:none;
}
.step-tabs .disabled.active a {
    background: #08c;
    color: #fff !important;
}
.step-tabs .disabled.completed a {
    background: #eee;
}
.step-tabs .disabled a,.step-tabs .done a {
    color: #777 !important;
}
.step-tabs .done a {
    background: #eee;
    cursor: pointer;
}
.step-tabs a {
    text-shadow:none
}
.step-tabs .unclickable a{
    cursor: default;
}


#appointment-overview .alert-warning,
.appointment-overview .alert-warning,
.li-select .alert-warning {
    background-color: #F0F0F0;
}

.selected-appointment.alert-danger {
    border: 3px solid red !important;
    background-color:#fff
}

.selected-appointment.waitlisted {
    background-image: none !important;
    border-left-color: #ccc !important;
}

.selected-appointment.confirmed {
    min-height: 72px;
    border-left: 6px solid #52bf43;
}
.selected-appointment.confirmed * {
    color: #468847 !important;
}
.selected-appointment .confirmed-banner {
    display:none;
}
.selected-appointment.confirmed .confirmed-banner {
	display: block;
	background: #52bf43;
	padding: 5px;
	color: #fff !important;
	font-size: 17px;
}
.selected-appointment.confirmed .confirmed-banner *{
    color:#fff !important;
}
#required-msg:empty{
    display:none;
}
#reviews-tab{
    overflow-x:hidden;
}


#calendar {
    max-width: 300px;
    margin: auto;
}

#waitlisted-ul .btn-primary,
#waitlisted-ul .btn-primary:hover{
    border-color: #ccc !important;
}
#event-list .btn-primary[disabled]:hover {
    color: #333 !important;
}
.btn-default:not(.grey-btn) {
    border: 1px solid #ccc;
    background: #fff;
}
.btn-default:not(.grey-btn):hover {
    background: #eee;
}

#wifi-3-icon{
    left: 13px;
    top: 0;
    z-index: 5;
    text-align: center;
    cursor: default !important;
    text-decoration: none !important;
    position: relative;
    width: 40px;
}
#big-box {
    padding-top:0
}


#main-tabs-container{
    margin-bottom:25px;
}
#portal-tabs {
    clear:both;
}


#appointment-instructions-top{
    display:none;
}

[data-field-type="form_title"] {
    background: #f0f0f0;
    width: 100%;
    padding: 10px 12px 8px;
    border-radius: 3px;
    margin-bottom: 10px !important;
    font-size: 15px;
}
/*[data-form-group-type="form_title"] {
    width: calc(100% - 25px) !important;
    margin-right: 0 !important;
}*/
.form-group[data-width="20"],.form-box[data-width="20"] {
    clear:none;
    width:calc(20% - 15px) !important;
    margin-right:10px;
    display:inline-block;
    vertical-align:top;
}
.form-group[data-width="25"],.form-box[data-width="25"] {
    clear:none;
    width:calc(25% - 15px) !important;
    margin-right:10px;
    display:inline-block;
    vertical-align:top;
}
.form-group[data-width="33"],.form-box[data-width="33"] {
    clear:none;
    width:calc(33% - 15px) !important;
    margin-right:10px;
    display:inline-block;
    vertical-align:top;
}
.form-group[data-width="40"],.form-box[data-width="40"] {
    clear:none;
    width:calc(40% - 15px) !important;
    margin-right:10px;
    display:inline-block;
    vertical-align:top;
}
.form-group[data-width="50"],.form-box[data-width="50"] {
    clear:none;
    width:calc(50% - 15px) !important;
    margin-right:10px;
    display:inline-block;
    vertical-align:top;
}
.form-group[data-width="60"],.form-box[data-width="60"] {
    clear:none;
    width:calc(60% - 15px) !important;
    margin-right:10px;
    display:inline-block;
    vertical-align:top;
}
.form-group[data-width="66"],.form-box[data-width="66"] {
    clear:none;
    width:calc(66% - 15px) !important;
    margin-right:10px;
    display:inline-block;
    vertical-align:top;
}
.form-group[data-width="75"],.form-box[data-width="75"] {
    clear:none;
    width:calc(75% - 15px) !important;
    margin-right:10px;
    display:inline-block;
    vertical-align:top;
}
.form-group[data-width="80"],.form-box[data-width="80"] {
    clear:none;
    width:calc(80% - 15px) !important;
    margin-right:10px;
    display:inline-block;
    vertical-align:top;
}
.form-box[data-form-group-type="form_title"] {
    width: 100% !important;
    margin-right: 0 !important;
}
.form-box.signature-box {
    overflow: hidden;
}
.form-box.signature-box:not([data-width]) {
    width: 100% !important;
}
.form-box.panel-box {
    padding:0;
}
#form-view .form-box.panel-box {
    padding:10px 0;
}
.panel-left{
    float:left;
    clear:left !important;
}
.panel-right{
    float:right;
    clear:right !important;
}
.panel-left + .panel-right
{
    clear:none !important;
}
.logo-center {
    margin: 0 0 20px 0 !important;
    display: block !important;
}
.access-portal-docs div {
    width: auto !important;
}

#logout-info .countdown {
    position: relative;

    height: 40px;
    width: 40px;
    text-align: center;
}

#logout-info .countdown-number {
    color: #ccc;
    display: inline-block;
    line-height: 41px;
    font-size: 11px;
}

#logout-info  svg {
    position: absolute;
    top: 0;
    right: 0;
    width: 40px;
    height: 40px;
    transform: rotateY(-180deg) rotateZ(-90deg);
}

#logout-info svg circle {
    stroke-dasharray: 113px;
    stroke-dashoffset: 0px;
    stroke-linecap: round;
    stroke-width: 2px;
    stroke: #ccc;
    fill: none;
}

@keyframes countdown {
    from {
        stroke-dashoffset: 0px;
    }
    to {
        stroke-dashoffset: 113px;
    }
}



/*store*/

.no-gutters {
    margin-right: 0;
    margin-left: 0;
}

.category-section{
    margin-bottom:10px
}

.category-section.expandable .category-section-title span::after {
    content: '\f0d7';
    font-size: 14px;
    margin-left: 10px;
    font-family: 'fontawesome';
}
.category-section.expandable.open .category-section-title span::after {
    content: '\f0d8';
}

.category-section.expandable .category-section-title {
    cursor:pointer
}
.category-section.expandable:not(.noBox) li.li-select {
    display:none
}
.category-section.expandable.open li.li-select {
    display:list-item
}

.category-section-title {
	font-size: 13px;
	font-weight: bold;
	margin: 20px 0 -10px;
}
#product-list .category-section-title {
	margin: 20px 15px 10px;
	clear: both;
}
#product-list .category-section-title:first-child {
	margin: 0px 15px 10px;
}

.card-text{
    font-size:12px;
}
.card-product-grid {
    margin-bottom: 20px;
}
.card-product-grid:hover {
    border: 1px solid #ccc !important;
    box-shadow: rgba(0, 0, 0, 0.14) 0px 3px 8px 0px, rgba(0, 0, 0, 0.08) 0px 0px 1px 0px;
    transition: 0.3s;
}
.card {
    position: relative;
    display: flex;
    flex-direction: column;
    min-width: 0;
    word-wrap: break-word;
    background-color: #fff;
    background-clip: border-box;
    border: 1px solid #ccc;
    border-radius: 0.37rem;
}
.card-body {
    flex: 1 1 auto;
    padding: 1.25rem;
}
.product-item:hover {
    cursor:pointer
}
.card-img-wrap {
    overflow: hidden;
    border-radius: 0.2rem 0.2rem 0 0;
    height: 220px;
    text-align: center;
}
.card-img-wrap img{
    height:100%
}
.card-product-grid .info-wrap {
    overflow: hidden;
    padding: 18px 20px;
}
#image-product-thumbs .thumbs .img-thumb {
    border: 1px solid #ccc;
    padding: 5px;
    border-radius: 3px;
    display: inline-block;
}
[class*="card-product"] .img-wrap img {
    height: 100%;
    max-width: 100%;
    width: auto;
    display: inline-block;
    -o-object-fit: cover;
    object-fit: cover;
}

[class*="card-product"] .badge {
    top: 10px;
    left: 10px;
    position: absolute;
}
.label-success {
    background-color:#5cb85c;
}
.card-product-list {
    margin-bottom: 20px;
}
.card-product-list .info-main {
    padding: 1.5rem 1rem;
}
.card {
    word-wrap: break-word;
}
[class*="card-product"] a.title {
    color: #212529;
    display: block;
}
#store-section cart .table-shopping-cart.table td, .table-shopping-cart.table th {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
}
#store-section cart .table-borderless th, .table-borderless td, .table-borderless thead th, .table-borderless tbody + tbody {
    border: 0;
}
#store-section cart .table thead th {
    vertical-align: bottom;
    border-bottom: 2px solid #dee2e6;
}
#store-section .small {
    font-size: 80%;
    font-weight: 400;
}

.table-shopping-cart th, .table-shopping-cart td {
    padding: 8px;
    line-height: 20px;
    text-align: left;
    vertical-align: top;
    border-top: 1px solid #dddddd;
}
.text-right {
    text-align:right !important;
}
.itemside {
    position: relative;
    display: flex;
    width: 100%;
}
.itemside .aside {
    position: relative;
    flex-shrink: 0;
}
.img-sm {
    width: 80px;
    height: 80px;
}
.img-xs, .img-sm, .img-md, .img-lg {
    -o-object-fit: cover;
    object-fit: cover;
    flex-shrink: 0;
    flex-grow: 0;
}
.itemside .title {
    display: block;
    margin-bottom: 5px;
}

.itemside .info {
    padding-left: 15px;
    padding-right: 7px;
}
.itemside p {
    margin-bottom: 0;
}
.dlist-align dt {
    width: 150px;
    word-wrap: break-word;
    font-weight: normal;
}
dt {
    font-weight: 600;
}
.dlist-align {
    display: flex;
}
[class*="dlist-"] {
    margin-bottom: 5px;
}
dl {
    margin-top: 0;
    margin-bottom: 1rem;
}



@media screen and (min-width: 900px) {
    .responsive-store-padding {
        padding: 1.25rem;
    }
}

@media screen and (max-width: 899px) {
    .responsive-store-padding {
        padding: 0.60rem;
    }
}
@media screen and (max-width: 600px) {
    .mini-box-tools:not(.shorter-len) {
        min-width: 172px !important;
    }
}
@media screen and (max-width: 700px) {
    .mini-box-tools.shorter-len {
	min-width: 65px !important;
}
}
.additional-info-div {
	/* border: 1px solid #ccc !important; */
	width: 100%;
	/* border-radius: 3px; */
	padding: 0 0 12px;
	margin-bottom: 20px;
	text-align: center;
}
.additional-info-div.long{
    text-align:left !important;
}
.additional-info-div p:last-child{
    margin-bottom:0
}

.additional-info-div:empty {
    display:none;
}
#main-tabs {
    margin: 0 0 25px;
}

#store-cart-btn {
    position: absolute;
    right: 0;
    top: -61px;
}

.store-cart-counter {
    font-size: 12px;
    text-align: center;
    font-weight: bold;
    border-radius: 50%;
    height: 20px;
    width: 20px;
    float: right;
    line-height: 1;
    background: #eee;
    padding: 3px;
    margin: -5px;
}
#store-cart.cart-is-empty .col-md-9{
    width:100% !important;
}
#store-cart.cart-is-empty .norows {
    display: table !important;
}
#login-form-checkout .loginForm .col-md-6 {
    width: 100% !important;
    padding: 0;
    margin: 0;
}

@media screen and (max-width: 1100px) {

    input {
        margin-bottom:10px;
    }
    .form-horizontal .help-span {
        margin: 10px 0 0 20px;
    }

}

.incomplete input,
.incomplete textarea,
.incomplete select,
.incomplete .contentEditableArea,
.incomplete [contenteditable],
.incomplete .signature-line,
.incomplete .image-box,
.incomplete .photo-container,.incomplete input[type="checkbox"], 
.incomplete input[type="radio"] {
    outline: 3px solid red !important;
    outline-offset: -3px;
}


.incomplete.signature-box {
    width:calc(100% - 25px) !important;
}
.sig-info-area {
    display: none;
}

@media screen and (max-width: 870px) {
    .navtext2 {
        display: none !important;
    }
}
@media screen and (max-width: 700px) {
    .navtext2 {
        display: none !important;
    }
     #main-content-wrapper{
        padding: 0;
    }
    #main-content {
        padding: 20px 20px 0px 15px;
        margin: 0px auto;
        position: relative;
        border-radius: 0;
        box-shadow: none;
        width:100%
    }
}
@media screen and (max-width: 1200px) {
    .one-third{
        float:none;
        width:100%;
        margin-right:0;
        display:inline-block;
    }
}
@media ( max-width: 768px) {
    .flex-wrap > .item-flex-2 {
        flex-basis: 100%;
    }
}

#product-list .category-section .col-md-3.product-item{
    width: calc(25% - 10px) !important;
    margin: 0 13px 0 0 !important;
}
#product-list .category-section .col-md-3.product-item:nth-child(4n){
    margin-right:0 !important;
}

.centered-frame {
    margin: 20px auto;
    width: 60%;
}
.centered-frame-sm {
	min-width: 285px;
	max-width: 320px;
}
.centered-frame-lg {
    width:70%;
    min-width: 700px;
    max-width: 800px;
}

@media (max-width: 990px) {
    #calendar-container,
    #event-list-container {
        display: block;
        float: none;
        margin-left: 0;
        width: auto;
    }
    #appointment-instructions{
        display:none;
    }
    #appointment-instructions-top{
        display:block;
    }
    #event-list{
        margin-left:0;
    }
    .centered-frame {
        width:100% !important;
        max-width:100% !important;
        min-width:auto !important;
    }
}
@media (max-width:1267px){
    #product-list .category-section .col-md-3.product-item{
        width: calc(33.3% - 10px) !important;
        margin: 0 15px 0 0 !important;
    }
    #product-list .category-section .col-md-3.product-item:nth-child(4n) {
        margin-right: 15px !important;
    }
    #product-list .category-section .col-md-3.product-item:nth-child(3n){
        margin-right:0 !important;
    }
}
@media (max-width: 950px){
    #product-list .category-section .col-md-3.product-item{
        width: calc(50% - 10px) !important;
        margin: 0 20px 0 0 !important;
    }
    #product-list .category-section .col-md-3.product-item:nth-child(2n){
        margin-right:0 !important;
    }
    #email-list th:nth-child(4),
    #email-list td:nth-child(4){
        display:none
    }
    #email-list th:nth-child(2),
    #email-list td:nth-child(2){
        max-width:115px !important;
    }
    #email-list th:nth-child(5),
    #email-list td:nth-child(5){
        max-width:115px !important;
    }
}
@media (max-width: 768px){
    #product-list .category-section .col-md-3.product-item{
        width: 100% !important;
        margin: 0 0 0 0 !important;
    }
}
#content {
    min-height: 300px;
}

#event-view .mini-panel {
	box-shadow: none !important;
	border: 1px solid #ccc;
	border-radius: 3px;
	margin-bottom: 15px;
	padding: 5px 5px 5px 10px;
}
#login-form-checkout .mini-panel{
    box-shadow:none !important;
}
#login-form-checkout .contact-form-booking-reg .centered-frame {
	margin: 0 !important;
	width: 100% !important;
	min-width: 0 !important;
}
.mini-box {
	box-sizing: border-box;
	padding: 10px 10px;
	border: 1px solid #ddd;
	min-height: 42px;
	display: table;
	width: 100%;
}
.mini-box-title {
    display: inline-block;
    font-weight: bold;
}
.mini-box-tools,.mini-box-left {
    display:table-cell;
    vertical-align:middle;
}
.mini-box-left{
    width:100%
}
.mini-box-tools {
    min-width: 200px;
    text-align: right;
}
.mini-box-tools.shorter-len{
    min-width: 140px;
}

.mini-box-subtitle {
    display: block;
}
.formula-ingredient-footer-row {
    display:none;
}
#unread-emails  {
    margin: -6px -4px 2px 3px;
    float: right;
}
.practitioner-names{
    font-size:9px;
    line-height: 12px;
    display: inline-block;
}
.package-progress.progress {
    cursor: default !important;
}
.user-photo-container {
	width: 120px;
	float: left;
	margin: 0 10px 0 0;
}
#services-container-1 .user-photo-container {
    width: 100px;
}
.user-photo-container:empty{
    display:none;
}
.nav-pills > li + li {
	margin-right: 7px;
	margin-left: 0 !important;
}
.footer-text {
    color: #ccc !important;
    padding-bottom:40px
}

.reveal-password-btn,.hide-password-btn {
    position: absolute;
    right: 10px;
    top: 36px;
}
.login-form input[type="text"],
.login-form input[type="password"] {
    min-height: 35px;

}
[data-f-id="pbf"]{
    display:none
}
.custom-table td {
    overflow: hidden;
}
#email-list th:nth-child(4),
#email-list td:nth-child(4){
    max-width:200px;
}
#email-list th:nth-child(3),
#email-list td:nth-child(3){
    max-width:200px;
}
#email-list th:nth-child(2),
#email-list td:nth-child(2){
    max-width:95px !important;
}
.fr-tooltip{
    cursor:pointer
}