﻿* {
	font-family: 'Amble', Arial, sans-serif;
	font-size: 14px;
}

.btn, .form-control {
	font-size: 14px;
}

.center-block {
	float: none;
}

.form-control {
	-webkit-border-radius: 0px;
	-moz-border-radius: 0px;
	border-radius: 0px;
}

.control-label {
	font-weight: bold;
}

.adduser {
	box-shadow: none;
	padding-bottom: 8px;
	padding-left: 6px;
	padding-right: 16px;
}

.adduser.small {
	max-width: 110px;
}

.addFeedback { /* used to show ajax feedback for the inline add practitioner and add client forms */
	position: absolute;
	padding-left: 10px;
	z-index: 2000;
}

.favourite {
	color: green;
}

.field-validation-error {
	color: #a94442;
}

.btn-danger {
    background-color: #D43F3A;
}

.btn-info {
    background-color: #207FA2;
    border-color: #1F7C9E;
}

.btn-info:hover, .btn-info:focus, .btn-info:active, .btn-info.active, .open > .dropdown-toggle.btn-info {
    background-color: #1A6C89;
    border-color: #1A6C89;
}

a {
    color: #3777C3;
}

.progress-bar {
    background-color: #3777C3;
}

#fileTable > table {
    background-color: white;
}

.color-swatch {
	border-radius: 3px;
	height: 20px;
	width: 50px;
}

.InRoomConference {
	color: #8a6d3b;
}

.InRoomReady {
	color: #3c763d;
    vertical-align: top;
}

.NotInRoom {
	color: #555;
}

.InRoomNotReady {
	color: #a94442;
}


body {
	background-color: #F2F3F8;
}

label {
	font-weight: bold;
}

.form-inline label {
	color: rgb(70, 70, 70);
	font-weight: normal;
}

.form-inline input {
	border: 0;
}

.h5 {
	font-weight: bold;
}



.disabledbutton {
	pointer-events: none;
	opacity: 0.4;
}

/* Cms Page */

#page, #page-account {
	padding-top: 40px;
	background-color: white;
	border-top: 0;
}

#page-account {
	padding-bottom: 50px;
}

#page {
	padding-left: 40px;
	padding-right: 40px;
}

	#page h2 {
		color: #25620b;
		font-weight: bold;
	}

		#page h2 small {
			color: #25620b;
		}

	#page h4 {
		color: rgb(76, 76, 76);
		font-weight: bold;
	}

.h4table {
	padding-left: 6px;
}

#page-top, #page-account-top {
	background-color: #253765;
	height: 100px;
	padding-left: 40px;
	padding-top: 0px;
}

#layout-nav h1,	#page-top h1, #page-account-top h1 {
font-size: 16px;
    color: white;
    line-height: 100px;
    margin: 0;

	}
#layout-nav h1.with-image {
    line-height: 60px;
}



#page-top .logout  {
    background-color: #F2F3F8;
    height: 100px;
	padding-right: 0;
	padding-left: 0;
	overflow: hidden;
	text-align: center;
    padding-top: 25px;
    font-size: 16px;
    color: rgb(70, 70, 70);
}

#page-top .logout:active,
#page-top .logout:focus,
#page-top .logout:hover {
    text-decoration: none;
    background-color: #FEC72E;
}



.clientsearch {
	margin: 15px 15px 15px 0;
	padding: 5px 20px;
	border-radius: 15px;
	border: #CCD0DB solid 1px;
	box-shadow: none;
}

	.clientsearch:focus {
		outline-style: none;
	}

/*Navigation menu*/
#layout-nav li img {
	margin-right: 25px;
    width: 22px;
    vertical-align: text-bottom;
}

#layout-nav li svg {
	margin-right: 25px;
    width: 22px;
    height: inherit;
    vertical-align: text-bottom;
    fill:#253765;fill-opacity:1
}

#layout-nav {
	background-color: white;
	border-right: #CCD0DB solid 1px;
	
	padding-left: 0;
	padding-right: 0;
    color:rgb(37, 55, 101)
}

@media (min-width: 768px) {
    #layout-nav {
        min-height: 100vh;
        padding-bottom: 53px;
    }

    #settings {
        width: 100%;
        display: inline-block;
        position: absolute;
        bottom: 0;
        border-top: 1px solid #CCD0DB;
        border-bottom: none;
    }
}

	#layout-nav .img-responsive {
		width: 100%;
	}

	#layout-nav p {
		/*font-size: 14px;*/
	}

	#layout-nav .layout-provider-info {
		text-align: center;
background-color: #253765;
/*		padding-bottom: 15px;*/
	}

		#layout-nav .layout-provider-info h2 {
			font-size: 16px;
			color: #ffffff;
		}

	#layout-nav ul li a {
		color: rgb(37, 55, 101);
		height: 53px;
		border-radius: 0;
		padding-left: 25px;
	}

	#layout-nav .nav-stacked > li + li {
		margin-top: 0;
	}

	#layout-nav ul li {
		border-bottom: 1px solid #CCD0DB;
	}

		#layout-nav ul li:first-of-type {
			border-top: 1px solid #CCD0DB;
		}

		#layout-nav ul li i:first-child {
font-size: 22px;
    margin-right: 25px;
    vertical-align: middle;
    line-height: 33px;
		}



		#layout-nav ul li.active a, #layout-nav ul li.active a:hover {
			background-color: #FEC72E;
		}

		#layout-nav ul li a p {
			width: 160px;
			line-height: 33px;
		}

			#layout-nav ul li a p.no-icon {
				padding-left: 37px;
			}







/*	Tables 	*/

.table {
	border-left: 0px;
	border-right: 0px;
}
table.table th {color:rgb(70, 70, 70)}
table.table td {color:rgb(37, 55, 101)}

.usagetable td:last-child {
	background-color: #F2F3F8;
	text-align: right;
}

/*.table label {
	padding-left: 20px;
}*/

.progress {
	border-radius: 0px;
	background-color: transparent;
	box-shadow: none;
	border: 1px solid #CCD0DB;
	margin-bottom: 0px;
}

.table th {
	border: 0px;
	color: black;
	background-color: #DFDFDF;
}

.table tr td.addRow {
	background-color: #1e2a5a;
	color: white;
	border-bottom: #1e2a5a solid 1px;
	border-collapse: separate;
}

	.table tr td.addRow a {
		color: white;
	}

	.table tr td.addRow span {
		width: 20px;
	}

.table tr:last-child td {
	border-bottom: #dbd8d8 solid 1px;
}

.table > thead > tr > th, .table > tbody > tr > th, .table > tfoot > tr > th, .table > thead > tr > td, .table > tbody > tr > td, .table > tfoot > tr > td {
	vertical-align: middle;
}


/*Buttons*/

.btn {
	border-radius: 6px;
}

.bootstrap-touchspin .btn .glyphicon {
	padding-left: 0px;
}

.btn-primary {
    background-color: #3777C3;
}

.btn-warning {
    background-color: #A76711;
    border-color: #9C6C0D;
}

.btn-warning:hover, .btn-warning:focus, .btn-warning:active, .btn-warning.active, .open > .dropdown-toggle.btn-warning {
    background-color: #9C6C0D;
    border-color: #9C6C0D;
}

.table .btn {
	border: 0;
	color: white;
	background-color: #757575;
	border-radius: 0px;
	margin-right: 1px;
}

.table .btn.startSession {
	background-color: #4C8235;
	border-radius: 5px;
	padding-top: 7px;
	padding-left: 18px;
	padding-right: 18px;
	padding-bottom: 7px;
}


.filebuttons .btn {
	margin-right: 20px;
}
	.table .btn.emailClient, .table .btn.pushClient, .table .btn.emailGroup, .table .btn.pushGroup {
		color: #696C96;
		background-color: transparent;
	}

	.table .btn.emailClient, .table .btn.emailGroup {
		padding-left: 0px;
	}


.pushClient .glyphicon, .pushGroup .glyphicon, .emailClient .glyphicon, .emailGroup .glyphicon {
	font-size: 18px;
}

.InRoomReady .glyphicon, .InRoomConference .glyphicon, .NotInRoom .glyphicon {
	font-size: 18px;
}

.emailClient .glyphicon, .emailGroup .glyphicon {
	padding-left: 0px;
}

.btn .glyphicon {
	padding-left: 5px;
}

#addclient, #addPractitioner {
	padding-left: 25px;
	padding-right: 25px;
}

.btn.edit, .btn.cancel, .btn.add, .btn.change-password, .btn.return {
	background-color: #4C8235;
	border: 0;
	color: #ffffff;
}

.btn.block {
	background-color: #F2F3F8;
	color: rgb(76, 76, 76);
	border: 0;
}


/*Sign in forms*/

.form-signin {
	margin: 0 auto;
	max-width: 330px;
	/*padding: 15px;*/
}

.form-horizontal .help-block {
	margin-bottom: 0px;
	padding-left: 5px;
}

.help-block {
    color: #771A77;
}

.progress-bar[aria-valuenow="0"] {
    color: #771A77;
}

.form-reset, .form-register {
	margin: 0 auto;
	max-width: 600px;
	/*padding: 15px;*/
}

.login-menu {
	/*margin-top: 20px;*/
}

/*Edit settings page*/
img.logo-upload {
	/*margin-top: 20px;*/
}

img.logo-settings, img.logo-upload {
	max-width: 278px;
	max-height: 278px;
	border: #dbd8d8 1px solid;
}

/*Bootstrap js Modal dialogs*/
.modal-content {
	/*border-color: #6eb94f;
	border-width: 2px;*/
}

.modal-header {
	background-color: #DFDFDF;
	font-weight: bold;
	border-bottom: 1px #000000 solid;
	border-radius: 2px;
	padding-left: 30px;
}


.modal-body .checkbox label {
	padding-left: 0px;
	font-weight: bold;
}

.modal-body input[type="checkbox"] {
	margin: 0px;
}

.close {
	opacity: 1;
}

.close .glyphicon-remove {
	font-size: 18px;
}

.recording-time {
	position: absolute;
	top: 4px;
}

.modal-body {
	padding: 30px;
}

.form-horizontal .control-label {
	text-align: left;
}

/*Nag help pop up*/
#nag-help-popup {
	position: absolute;
	display: none;
	z-index: 100000;
	width: 100%;
}

	#nag-help-popup .inner-restriction {
		max-width: 550px;
	}

	#nag-help-popup button {
		background-color: #f5f5f5;
		cursor: text;
	}

		#nag-help-popup button:hover {
			background-color: #f5f5f5;
			cursor: text;
		}

	#nag-help-popup .panel {
		max-width: 300px;
		float: right;
		margin-top: 5px;
		margin-right: 10px;
	}

	#nag-help-popup img {
		height: 40px;
		margin-left: auto;
		margin-right: auto;
		width: 150px;
		display: block;
		margin-top: 5px;
	}


/* Appointments */
#AppointmentList .apptIndividual, #AppointmentList .apptGroup {
	border-top: 1px double #BBBBBB;
}

#AppointmentList .apptGroupClient {
	border-top: 1px dotted #BBBBBB;
}

#AppointmentList .appt-left-border {
	border-left: 1px solid #BBBBBB;
	padding-left: 46px;
}

#AppointmentList .table tr td:first-child {
	text-align: center;
}

#navMonth1.active .btn, #navMonth2.active .btn, #navMonth3.active .btn {
	background-color: #757575;
}

.appNavPills .glyphicon {
	color: #5C5C5C;
}

.appNavPills a.btn {
	padding-top: 3px;
	padding-bottom: 3px;
}

.panel {
	border: 0px;
}

.panel-title {
	padding-left: 30px;
	min-height: 30px;
	padding-top: 7px;
}

.panel-title a {
	vertical-align: middle;
}

.today .startSession {
	display: inline !important;
}

.appButtonGroup {
	padding-top: 14px;
}

.appButtonGroup .btn {
	margin-right: 17px;
	margin-bottom: 5px;
	min-width: 20ch;
}

.appNavPills {
	padding-top: 15px;
}

	.appNavPills li {
		margin-right: 2px;
	}

	.appNavPills .btn {
		padding-top: 6px;
		padding-bottom: 6px;
		margin-right: 5px;
		min-width: 14ch;
		border-radius: 2px;
	}

	.appNavPills .navMonth {
		background-color: #DFDFDF;
		color: black;
	}

#AppointmentList {
	margin-top: -8px;
}

#AppointmentList .panel-body {
	padding: 0px;
	border-top: none;
}

#AppointmentList tr, #AppointmentList td {
	border-color: #F1F1F1;
}

.panel-body > .table {
	padding-bottom: 0px;
	margin-bottom: 0px;
}

.panel-group .panel + .panel {
	margin-top: 0px;
	padding-top: 1px;
}

#AppointmentList .panel-heading {
	background-color: #DFDFDF;
}


.table .priority {
	padding-left: 0px;
}

.table .priority img:first-child {
	margin-left: -6px;
}

.form-group-sm {
	margin-bottom: 0px;
}

/* used to setup different background colours for the #page rows*/
.row-background {
	background-color: #F2F3F8;
	margin-top: 15px;
	margin-left: -40px;
	padding-left: 40px;
	padding-right: 25px;
	padding-top: 40px;
	margin-right: -40px;
	border-top: 1px solid #CCD0DB;
	border-bottom: 0px;
}

	.row-background.onlyrow { /* where the "background" row is not preceeded by a foreground row*/
		padding-top: 40px;
		margin-top: -40px;
		background-color: #F2F3F8;
	}

.row-foreground {
	background-color: white;
}

/* letter index on client pages */
.index {
    position: fixed;
    top: 282px;
    left: 25%;
    line-height: 15px;
    border: 0;
	background-color: #757575;
    color: #aaa;
    width: 25px;
    padding: 5px 0;
}

.index a {
    color: white;
    width: 25px;
    display: block;
    text-align: center;
    margin: 0;
    padding: 0;
}

.index ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
    text-align: center;
}

.index li {
    margin: 0;
    padding: 0; 
}

.hours-select, .minutes-select {
    width: 60px;
    display: inline-block;
}

/* chosen plugin drop-downs */
.chosen-container .chosen-results {
    white-space: nowrap;
    overflow: hidden;
}

table.settings td:first-child {
    width: 40%;
}
table.settings td:last-child {
    width: 60%;
}

input[readonly].default-cursor {
    cursor: default;
}

tr.adminRow { /* highlights practitioners that are also admins */
    font-weight: bold;
}


.bdp-block {
     width: 33%;
 }


/* allow hidden text for screen readers */
.offscreen {
    border: 0;
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    padding: 0;
    height: 1px;
    overflow: hidden;
    position: absolute;
    white-space: nowrap;
    width: 1px;
}


/* 	definitions to just keep vs quiet about non-defined classes */
.tempTable, .practitioners, .clients, .subscriptions, .appointments, .settings, .files, .top-section, 
.PageColourGroup, .TintColourGroup, .imports .impersonation .superadminpasswords .practitionerImpersonate 
.adminLogin .superadmintemplates {
}

/* skip links for keyboard users and screen readers */
.bypass ul {
    margin-bottom: 0;
}


.bypass ul a {
    background-color: #BF1722;
    border-bottom: 1px solid white;
    border-bottom-right-radius: 0.8rem;
    border-right: 1px solid white;
    color: #fff;
    left: 0;
    padding: 0.6rem;
    position: absolute;
    top: -4rem;
    -webkit-transition: top 1s ease-out, background 1s linear;
    -o-transition: top 1s ease-out, background 1s linear;
    transition: top 1s ease-out, background 1s linear;
    z-index: 200;
}

.bypass ul a:focus {
    background-color: #BF1722;
    left: 0;
    outline: 0;
    position: absolute;
    top: 0;
    -webkit-transition: top .1s ease-in, background .5s linear;
    -o-transition: top .1s ease-in, background .5s linear;
    transition: top .1s ease-in, background .5s linear;
}
