@charset "utf-8";
/**
 * Coded by Joseph Mashauri <jaymash01@gmail.com>
 * , for GPITG Limited.
 */

@font-face {
    font-family: "Open Sans";
    src: url("../fonts/Open%20Sans.ttf");
}

@font-face {
    font-family: "Aclonica";
    src: url("../fonts/aclonica.ttf");
}

html body {
    font: 86% "Open Sans", sans-serif;
    color: #333333;
    background: #f5f5f5;
}

* {
    margin: 0;
    padding: 0;
    border: none;
    outline: none;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box !important;
}

*:disabled { cursor: not-allowed !important; }

::-moz-selection { background: #00ced1; }

::selection { background: #00ced1; }

h1, h2, h3, ol, p, ul { margin: 0.25em 0; }

ol, ul { list-style-position: inside; }

li.separator {
    padding: 0 !important;
    display: block;
}

li.separator.separator-h {
    height: 0 !important;
	border-top: 1px solid #059395;
    width: auto;
    margin: 0 3px;
}

a, a:visited {
    text-decoration: none;
    color: #9900cc;
}

a:hover, a:active {
    color: #cccccc;
    text-decoration: underline;
}

.fa {
    color: #059395;
    font-size: 110%;
}

.btn, a.btn:hover, a.btn:visited {
    color: #dddddd;
    display: inline-block;
    background: #9900cc;
    background: -webkit-linear-gradient(top, #9900cc, rgba(153, 0, 204, 0.75));
    background: -moz-linear-gradient(bottom, #9900cc, rgba(153, 0, 204, 0.75));
    background: linear-gradient(to bottom, #9900cc, rgba(153, 0, 204, 0.75));
    padding: 0.25em 0.5em;
    text-decoration: none !important;
    cursor: pointer;
    font-size: 100%;
}

.btn.btn-lg {
    padding: 0.5em 2em;
    -webkit-box-shadow: 0 1px 0 rgba(204, 204, 204, 0.7);
    -moz-box-shadow: 0 1px 0 rgba(204, 204, 204, 0.7);
    box-shadow: 0 1px 0 rgba(204, 204, 204, 0.7);
}

.btn.btn-sec,
a.btn.btn-sec:hover,
a.btn.btn-sec:visited { background: #555555; }

.btn:not(.btn-load-more):focus {
    -webkit-box-shadow: 0 0 3px #9900cc !important;
    -moz-box-shadow: 0 0 3px #9900cc !important;
    box-shadow: 0 0 3px #9900cc !important;
}

.btn.btn-load-more {
    display: block;
    width: 50%;
    min-width: 10em;
    padding-left: 0;
    padding-right: 0;
    margin: 0.25em auto;
}

.btn-dismiss { color: #990000; }

.btn-dismiss:hover {
    color: #000000 !important;
    text-decoration: none;
}

.btn.btn-input-file {
    display: inline-block;
	vertical-align: middle;
    overflow: hidden;
    position: relative;
}

.btn.btn-input-file input {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    cursor: pointer;
}

.align-center { text-align: center; }

.col { float: left; }

.rounded {
    -webkit-border-radius: 2px;
    -moz-border-radius: 2px;
    border-radius: 2px;
}

.rounded-2x {
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    border-radius: 8px;
}

.rounded-circle {
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    border-radius: 50%;
}

.overflow-auto { overflow: auto !important; }

.overflow-visible { overflow: visible !important; }

.input-string, select, input[type="file"] {
    width: 23.5em;
    height: 2.25em;
    padding: 0.5em;
    font-size: 92%;
    border: 1px solid #cccccc;
}

.input-string:focus, select:focus, input[type="file"]:focus {
    outline: 1px solid #9900cc;
}

textarea.input-string {
    width: 30em;
    height: 15em;
}

textarea { font-family: "Open Sans", sans-serif; }

select:disabled {
    color: #666666;
    background: #dddddd;
}

input[type="file"] { padding: 0; }

input[type="checkbox"], input[type="radio"] {
    position: relative;
    top: 0.175em;
}

.input-group {
    border: 1px solid #cccccc;
    width: 47%;
    height: 2.25em;
    display: inline-block;
    vertical-align: middle;
    overflow: hidden;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    border-radius: 4px;
    margin: 0 0.35em 0.35em 0;
    position: relative;
}

.input-group.ig-textarea { height: auto; }

.input-group .ig-label {
    padding: 0 0.5em;
    width: 30%;
    float: left;
    height: 2.25em;
    line-height: 2.15em;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.input-group.ig-textarea .ig-label {
    height: auto;
    line-height: normal;
}

.input-group .input-string, .input-group select, .input-group input[type="file"] {
    float: left;
    height: 100%;
    width: 70%;
    border: none;
    border-left: 1px solid #cccccc;
    -webkit-border-radius: 0 4px 4px 0;
    -moz-border-radius: 0 4px 4px 0;
    border-radius: 0 4px 4px 0;
}

.input-group.ig-focus-effect {
    position: relative;
    border: none;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
    height: 2.5em !important;
}

.input-group.ig-focus-effect .ig-label {
    float: none;
    height: 2.5em;
    line-height: 2.5em;
}
  
.input-group.ig-focus-effect .focus-border {
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 0;
    height: 2px;
    background: #9900cc;
    -webkit-transition: 0.4s;
    -moz-transition: 0.4s;
    transition: 0.4s;
}
  
.input-group.ig-focus-effect, .input-group.ig-focus-effect .input-string {
    background: transparent;
}

.input-group.ig-focus-effect .input-string {
    display: block;
    width: 100%;
    height: 100%;
    outline: none;
    line-height: 2.5em;
    padding: 0 0.5em;
    position: relative;
    z-index: 100;
}
    
.input-group.ig-focus-effect .input-string:focus ~ .focus-border {
    width: 100%;
    -webkit-transition: 0.4s;
    -moz-transition: 0.4s;
    transition: 0.4s;
    left: 0;
}
    
.input-group.ig-focus-effect .ig-label {
    position: absolute;
    left: 0;
    width: auto;
    top: 0;
    color: #059395;
    -webkit-transition: 0.3s;
    -moz-transition: 0.3s;
    transition: 0.3s;
}
    
.input-group.ig-focus-effect .input-string:focus ~ .ig-label,
.input-group.ig-focus-effect .input-string.has-content ~ .ig-label {
    top: -1.585em;
    font-size: 86%;
    -webkit-transition: 0.3s;
    -moz-transition: 0.3s;
    transition: 0.3s;
}
    
.input-group.ig-focus-effect .input-string:focus ~ .ig-label {
    color: #9900cc;
}

.input-group.ig-blocks {
    display: inline-block;
    height: auto;
}

.input-group.ig-blocks .ig-label {
    display: block;
    padding: 0.5em;
    float: none;
    height: auto;
    line-height: normal;
    width: 100% !important;
}

.input-group.ig-blocks .input-string,
.input-group.ig-blocks select,
.input-group.ig-blocks input[type="file"],
.input-group.ig-blocks .control-group {
    float: none;
    height: 2.75em;
    display: block;
    width: 100% !important;
    border: none;
    border-top: 1px solid #dddddd;
    -webkit-border-radius: 0 0 4px 4px;
    -moz-border-radius: 0 0 4px 4px;
    border-radius: 0 0 4px 4px;
}

.input-group textarea.input-string,
.input-group.ig-blocks textarea.input-string {
    height: 15em;
}

.input-group.ig-blocks .control-group {
    padding: 0.5em;
    height: auto;
    background: #eeeeee;
}

.input-group.ig-search {
    position: relative;
    overflow: visible;
    border: none;
}

.input-group.ig-search .input-group {
    width: 100% !important;
    margin: 0 !important;
}

.input-group.ig-search.ig-blocks .input-string {
    width: 100% !important;
}

.input-group.ig-search .autocomplete {
    width: 100% !important;
}

.autocomplete {
    position: absolute;
    top: 100%;
    left: 0;
    width: 160%;
    max-height: 18em;
    overflow: hidden;
    overflow-y: visible;
    z-index: 999;
    background: #f5f5f5;
    -webkit-box-shadow: 0 2px 3px #dddddd;
    -moz-box-shadow: 0 2px 3px #dddddd;
    box-shadow: 0 2px 3px #dddddd;
    border: 1px solid #059395;
    display: block;
}

.autocomplete a {
    display: block;
    padding: 0.5em;
    border-bottom: 1px dashed #cccccc;
    color: #666666;
}

.autocomplete a:last-child { border-bottom: none; }

.autocomplete a:hover {
    text-decoration: none;
    background: #dddddd;
}

.msg-autocomplete {
    display: block;
    padding: 0.5em;
    background: #dddddd;
}

.tabled-inputs .input-group {
    width: 80% !important;
    display: block;
    margin: 0 auto;
}

.display-flex > * {
    display: inline-block;
    width: 32%;
    margin-right: 0.25em;
}

.heading {
    padding: 0.5em;
    font-size: 110%;
    position: relative;
}

.heading.heading-section {
    background: #dddddd;
	border: 1px solid #cccccc;
	border-bottom: none;
    color: #9900cc;
    font-size: 100%;
    padding: 0.5em 0.35em;
    text-transform: uppercase;
}

.heading.heading-section.em {
    background: #cccccc;
    font-size: 110%;
}

.section, .notice-box {
    border: 1px solid #cccccc;
    padding: 0.5em;
}

.section.section-gray { background: #dddddd; }

.section.section-filters .btn.btn-lg {
    padding-top: 0.4em;
    padding-bottom: 0.4em;
}

.notice-box { background: rgba(255, 204, 51, 0.2); }

.section.tab-control {
	padding: 0;
	border-bottom: none;
}

.section.tab-control .btn {
	float: left;
	background: #cccccc;
	color: #333333;
    border-right: 1px solid #dddddd;
    text-transform: uppercase;
}

.section.tab-control .btn:focus {
	-webkit-box-shadow: none !important;
	-moz-box-shadow: none !important;
	box-shadow: none !important;
}

.section.tab-control .btn.current-tab,
.section.tab-control .btn:hover {
	background: #9900cc;
	color: #cccccc;
}

.panel {
    border: 1px solid #059395;
}

.panel.panel-unbordered {
    border: none;
    border-top: 1px solid #cccccc;
}

.panel.panel-basic {
    border-color: #cccccc;
    margin: 0;
}

.panel > .panel-header {
    color: #f5f5f5;
    border-bottom: 1px solid #059395;
    font-size: 110%;
    padding: 0.25em 0.35em;
    background: #059395;
    text-align: center;
}

.panel.panel-unbordered > .panel-header {
    background: #cccccc;
    border: none;
	color: #333333;
}

.panel.panel-basic > .panel-header {
    border-color: #cccccc;
    background: #dddddd;
    color: #9900cc;
    text-transform: uppercase;
    font-size: 100%;
    padding: 0.5em 0.35em;
}

.panel > .panel-header .fa {
    color: #9900cc;
    font-size: 100%;
}

.panel > .panel-body {
    position: relative;
    padding: 0.5em;
    overflow-x: auto;
}

.panel.panel-unbordered > .panel-body {
    padding-left: 0;
    padding-right: 0;
}

.panel.panel-basic > .panel-body {
    padding: 0.5em !important;
}

.panel > .panel-footer {
    border-top: 1px solid #059395;
    padding: 0.5em;
}

.panel.panel-unbordered > .panel-footer {
    border-color: #cccccc;
    padding-left: 0;
    padding-right: 0;
}

.panel.panel-basic > .panel-footer { border-color: #cccccc; }

.img-view { overflow: hidden; }

.img-view img { width: 100%; }

.img-view.img-view-upload {
    width: 10em;
    height: 10em;
    border: 1px dashed #cccccc;
}

.inline-text { display: inline-block; }

.inline-text.inline-text-sm { font-size: 86%; }

.alert {
    padding: 0.5em;
    border: 1px solid #990000;
    background: #ffcc33;
	color: #333333;
    width: 60%;
    margin: 0 auto;
    min-width: 14em;
    position: relative;
    margin-bottom: 1.75em;
}

.alert .alert-msg { margin-right: 2.5em; }

.alert .alert-msg-heading {
    font-size: 120%;
    display: block;
    margin-bottom: 0.5em;
}

.alert .alert-msg .fa {
    position: relative;
    top: -0.05em;
}

.alert.alert-dismissable .btn-dismiss {
    position: absolute;
    right: 0.35em;
    top: -0.025em;
    font-size: 1.75em;
    display: none;
}

.js .alert.alert-dismissable .btn-dismiss {
    display: block;
}

.clearfix::after {
    content: "";
    clear: both;
    display: block;
    font-size: 0;
}

.color-red { color: #ff0000 !important; }

.color-green { color: #059395 !important; }

.color-purple { color: #9900cc !important; }

.pagination-links a {
    background: transparent;
    border: 1px solid #059395;
    color: #666666;
}

.pagination-links a.btn:focus {
    -webkit-box-shadow: none !important;
    -moz-box-shadow: none !important;
    box-shadow: none !important;
}

.pagination-links .fa {
    font-size: 82% !important;
    vertical-align: baseline;
}

.pagination-links a:hover,
.pagination-links a.current-step {
    background: #9900cc;
    color: #cccccc;
    border-color: #9900cc;
}

canvas {
    -moz-user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
}

table {
    border-collapse: collapse;
    width: 100%;
    min-width: 40em;
    font-size: 92%;
}

td, th {
    padding: 0.25em 0.5em;
    text-align: left;
    max-width: 14em;
    min-width: 10em;
    border: 1px solid #cccccc;
    word-break: break-all;
}

th, tr:nth-child(odd) { background: #dddddd; }

.table-cell-sm {
    width: 5em !important;
    min-width: 5em !important;
}

body { display: none; }

.js body { display: block; }

#container {
    position: absolute;
    width: 100%;
    min-height: 100%;
    z-index: 1;
}

aside {
    width: 264px;
    padding: 0.5em;
    background: #dddddd;
    min-height: 100%;
    max-height: 100%;
    overflow-y: auto;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 1;
}

main {
    padding: 0.5em;
    width: calc(100% - 264px);
    position: absolute;
    left: 264px;
    z-index: 2;
}

.header {
    background: #eeeeee;
    background: -webkit-linear-gradient(top, #dddddd, #eeeeee);
    background: -moz-linear-gradient(bottom, #dddddd, #eeeeee);
    background: linear-gradient(to bottom, #dddddd, #eeeeee);
    border: 1px solid #dddddd;
    position: relative;
    z-index: 9999;
    padding: 0 0.25em;
}

.content { margin-top: 1.5em; }

.footer {
    padding: 1.5em 0;
    background: #dddddd;
    margin-top: 2em;
    font-size: 86%;
}

#menu {	list-style: none; }

#menu li { position: relative; }

#menu li .menu-li-pull-icon {
    position: absolute;
    right: 0.5em;
    top: 1.15em;
    width: 1em;
    height: 1em;
    line-height: 1em;
    cursor: pointer;
    font-size: 76%;
}

#menu a {
    display: block;
    padding: 0.5em;
    border-bottom: 1px solid #cccccc;
}

#menu li:last-child > a,
.sub-menu li:last-child a {
    border-bottom: none;
}

#menu a:hover, #menu a.current-page {
    text-decoration: none;
    background: #9900cc;
}

#menu a.current-page { color: #dddddd; }

#menu .fa {
    font-size: 100% !important;
    vertical-align: baseline;
}

#menu ul {
    list-style: none;
    margin-left: 1.25em;
    display: none;
}

#menu-pull-icon {
    position: absolute;
    right: 0.5em;
    top: 50%;
    height: 1em;
    width: 1em;
    line-height: 1em;
    margin-top: -0.5em;
    cursor: pointer;
    display: none;
}

#logo {
    width: 3.5em;
    height: 3.5em;
    padding: 0.25em;
    display: inline-block;
    vertical-align: middle;
}

#logo img { height: 100%; }

#header-text {
    display: inline-block;
    text-transform: uppercase;
    color: #9900cc;
}

#user-menu {
    height: 3.5em;
    position: absolute;
    z-index: 10000;
    right: 0.5em;
    top: 0;
}

#user-menu-pull-icon {
    padding: 0.5em;
    padding-right: 0.5em;
    text-align: right;
    display: none;
}

#user-menu-pull-icon a { background: none !important; }

#user-menu a, #menu a {
    -webkit-transition: background-color 0.2s ease-in;
    -moz-transition: background-color 0.2s ease-in;
    transition: background-color 0.2s ease-in;
}

#user-menu a:hover, #user-menu > li.active > a {
    background: #9900cc;
}

#user-menu > li.active > a { color: #dddddd; }

#user-menu-pull-icon .fa {
    font-size: 120% !important;
    color: #9900cc !important;
}

#user-menu, #user-menu ul {
    list-style: none;
    margin: 0;
}

#user-menu > li {
    float: right;
    position: relative;
    height: 3.5em;
    line-height: 3.5em;
}

#user-menu > li#li-user-privilege { padding: 0 1em; }

#user-menu > li > a {
    display: block;
    height: 100%;
    padding: 0 1em;
}

#user-menu > li a:hover, #user-menu > li.active a {
    text-decoration: none;
}

#user-menu > li ul {
    position: absolute;
    background: #f5f5f5;
    border: 1px solid #9900cc;
    width: 120%;
    padding: 0.25em !important;
    padding-top: 0 !important;
    display: none;
    top: 100%;
    left: -20%;
}

#user-menu > li > ul li {
    height: auto;
    line-height: normal;
}

#user-menu > li > ul li a {
    display: block;
    padding: 0.25em 0.35em;
}

#li-usharika-panel {
    font-size: 92%;
    background: #f5f5f5 !important;
    width: 25em !important;
    left: -14em !important;
    -webkit-box-shadow: 0 2px 3px #cccccc;
    -moz-box-shadow: 0 2px 3px #cccccc;
    box-shadow: 0 2px 3px #cccccc;
    max-height: 30em;
    overflow: hidden;
    overflow-y: visible;
}

#li-usharika-panel li {
    display: block;
    border: none;
    padding: 0.25em;
    cursor: default;
}

#li-usharika-panel li div {
    margin: 0.5em 0;
}

#li-usharika-panel li div span[data-bind] {
    color: #059395;
}

#formLogin {
    width: 30%;
    margin: 0 auto;
    border: 1px solid #059395;
    position: relative;
    padding: 0.75em 5%;
    -webkit-box-shadow: 0 2px 0 #dddddd;
    -moz-box-shadow: 0 2px 0 #dddddd;
    box-shadow: 0 2px 0 #dddddd;
    background: #ffffff;
    padding-top: 11em;
}

#formLogin .input-group {
    margin-bottom: 1.5em;
    overflow: visible;
    width: 100%;
}

#formLogin .input-group .input-string {
    border: none;
    border-bottom: 1px solid #059395;
    display: block;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
}

#formLogin-logo {
    margin-bottom: 1em;
    height: 10em;
    width: 10em;
    position: absolute;
    top: -1em;
    left: 50%;
    margin-left: -5em;
    border: inherit;
    padding: 0.25em;
    background: inherit;
}

#formLogin-logo img { height: 100%; }

.profile-summary {
    padding: 0.5em;
    position: relative;
    background: #dddddd;
    background: -webkit-linear-gradient(top, #059395, #dddddd);
    background: -moz-linear-gradient(bottom, #059395, #dddddd);
    background: linear-gradient(to bottom, #059395, #dddddd);
}

.profile-photo {
    width: 10em;
    height: 10em;
    display: inline-block;
    vertical-align: baseline;
    margin-right: 0.5em;
}

.profile-photo img {
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    border-radius: 50%;
}

.profile-summary-info > span {
    display: block;
    margin-bottom: 0.25em;
    font-size: 86%;
}

.profile-summary-info > span:first-child {
    font-size: 120%;
}

.profile-info {
    background: #dddddd;
    padding: 0.5em;
    border: 1px solid #cccccc;
}

.profile-info-row {
    padding: 0.5em;
    border-bottom: 1px solid #cccccc;
    font-size: 110%;
}

.profile-info-row:last-child {
    border-bottom: none;
}

.profile-info-row span {
    font-size: 90%;
    color: #059395;
}

#msharika-header, #mtumiaji-header {
	position: relative;
	height: 10em;
	margin-bottom: 2.25em;
	background: #dddddd;
	background: -webkit-linear-gradient(top, #059395, #dddddd);
    background: -moz-linear-gradient(bottom, #059395, #dddddd);
    background: linear-gradient(to bottom, #059395, #dddddd);
}

#msharika-header .img-view,
#mtumiaji-header .img-view {
	position: absolute;
	left: 2.25%;
	bottom: -1.75em;
	height: 10em;
	width: 10em;
	border: 1px solid #dddddd;
	background: #f5f5f5;
	padding: 0.25em;
}

#msharika-htnb,
#mtumiaji-htnb {
	color: #333333;
	position: absolute;
	left: 13.5em;
	bottom: 0.5em;
}

#msharika-htnb > span,
#mtumiaji-htnb > span {
	display: block;
	font-size: 86%;
	padding: 0.25em 0;
}

#msharika-htnb > span.btn,
#mtumiaji-htnb > span.btn {
	display: inline-block;
	vertical-align: middle;
	margin-right: 0.25em;
	padding: 0.25em 0.35em;
}

#msharika-htnb > span:first-child,
#mtumiaji-htnb > span:first-child {
	font-size: 140%;
	text-transform: uppercase;
}

.panel.content-dashboard {
    background: #eeeeee;
}

.panel.content-dashboard .panel-body {
    padding: 0 0.5em !important;
}

.db-card {
    float: left;
    height: auto;
    width: 24.625%;
    margin-right: 0.5%;
    margin-bottom: 0.5em;
    margin-top: 0.5em;
    border: 1px solid #dddddd;
    background: #f5f5f5;
    min-width: 16em;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    border-radius: 4px;
}

.db-card:last-child { margin-right: 0; }

.db-card-header, .db-card-footer {
    background: #dddddd;
    height: 2.5em;
    line-height: 2.5em;
    padding: 0 0.5em;
    -webkit-border-radius: 3px 3px 0 0;
    -moz-border-radius: 3px 3px 0 0;
    border-radius: 3px 3px 0 0;
    position: relative;
}

.db-card-body {
    position: relative;
    height: 8em;
}

.db-card-body .fa {
    font-size: 36px !important;
    position: absolute;
    left: 5px;
    top: 50%;
    margin-top: -0.5em;
}

.db-card:nth-child(2) > .db-card-body .fa {
    color: #ffcc33;
}

.db-card:nth-child(3) > .db-card-body .fa {
    color: #9900cc;
}

.db-card:nth-child(4) > .db-card-body .fa {
    color: #990000;
}

.dbcbc {
    font-size: 28px;
    position: absolute;
    right: 5px;
    bottom: 40%;
}

.dbcbl {
    position: absolute;
    right: 5px;
    bottom: 20%;
}

.db-card-footer {
    background: #ffcc33;
    -webkit-border-radius: 0 0 3px 3px;
    -moz-border-radius: 0 0 3px 3px;
    border-radius: 0 0 3px 3px;
    text-align: left;
}

.dbcfl {
    font-size: 100%;
    bottom: 20%;
}

.db-card-footer .fa {
    position: absolute;
    right: 5px;
    top: 50%;
    width: 1em;
    height: 1em;
    margin-top: -0.5em;
}

.db-card-footer a { color: #9900cc; }

#db-charts {
    background: #dddddd;
    margin-bottom: 0.5em;
}

#db-charts .db-card {
    width: 48%;
    margin: 0.5em 0.5%;
    display: inline-block;
    min-width: 25em;
    float: none;
    vertical-align: middle;
}

#db-charts .db-card .db-card-header {
    background: #e8e8e8;
    height: auto;
    line-height: normal;
    padding: 0.5em 0.35em;
}

#db-charts .db-card .db-card-body { height: auto; }

.chart-area { padding: 0.5em; }

.db-breadcumb {
    float: left;
    width: 33.3%;
    border-right: 2px solid #f5f5f5;
    text-align: center;
    position: relative;
}

.db-breadcumb:last-child { border-right: none; }

.db-breadcumb span {
    display: block;
    color: #333333;
    background: #059395;
    padding: 0.5em;
}

.db-breadcumb span:first-child {
    font-size: 110%;
    background: #dddddd;
}

.db-breadcumb.has-bullet::after {
    content: "";
    position: absolute;
    right: -1em;
    top: 50%;
    width: 2em;
    height: 2em;
    border: 3px solid #f5f5f5;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    border-radius: 50%;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    background: #059395;
    margin-top: -1em;
    z-index: 99;
}

.panel-dashboard {
    margin-top: 0.5em;
}

#db-viongozi { background: #dddddd; }

#db-viongozi .db-card {
    float: none;
    display: inline-block;
    margin: 0.5em 0.5%;
    width: 31%;
    vertical-align: middle;
}

#db-viongozi .db-card .db-card-header {
    background: #eeeeee;
    height: auto;
    line-height: normal;
    padding: 0.5em 0.35em;
}

#db-viongozi .db-card > .db-card-body {
    padding: 0.5em;
    height: auto;
}

#db-viongozi .db-card > .db-card-body .img-view {
    width: 70%;
    min-width: 12em;
    max-height: 15em;
    min-height: 12em;
    display: inline-block;
}

#db-viongozi .db-card > .db-card-footer {
    background: #eeeeee;
    height: auto;
    padding: 0 0.25em;
}

#db-viongozi .db-card > .db-card-footer span {
    display: block;
    margin: 0.25em 0;
    text-align: center;
}

.footer a { color: inherit; }

.footer > span {
    display: inline-block;
    margin-right: 0.25em;
}

#kpi-data select {
	width: 60%;
	min-width: 14em;
	height: 2.25em;
    line-height: 2.25em;
    padding: 0 0.5em;
}

.msg-receiver {
	display: inline-block;
	margin: 0.25em 0.5em;
	margin-left: 0;
	padding: 0.35em 1em;
	background: #059395;
	color: #f5f5f5;
	-webkit-border-radius: 1em;
	-moz-border-radius: 1em;
	border-radius: 1em;
}

.player {
    width: 60%;
    margin-bottom: 0.5em;
}

.pickmeup {
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
    position: absolute;
    z-index: 9999;
}

.pickmeup nav {
    border-top: 1px solid #9900cc;
    border-bottom: 1px solid #059395;
}

.pmu-button:hover { color: #9900cc !important; }

.pmu-selected { background: #059395 !important; }

.pmu-today {
    color: #ffffff !important;
    background: #990000 !important;
}

.wickedpicker {
    background: #f5f5f5;
    border: 1px solid #dddddd;
    -webkit-box-shadow: none;
    -moz-box-shadow: none;
    box-shadow: none;
    z-index: 9999;
}

.wickedpicker__title { background: #dddddd; }

.wickedpicker__controls__control .fa:hover {
    cursor: pointer;
}

.wickedpicker__close {
    font-size: 20px;
    color: #9900cc;
}

.wickedpicker__close:hover { color: #000000; }

#overlay {
    position: absolute;
    top: 0;
    left: 0;
    min-height: 100%;
    width: 100%;
    background: rgba(153, 153, 153, 0.6);
    z-index: 2;
}

#overlay .btn-dismiss {
    position: absolute;
    right: 0.35em;
    top: 50%;
    font-size: 36px;
    width: 0.55em;
    height: 0.5em;
    margin-top: -0.25em;
    line-height: 0.45em;
    color: #9900cc;
}

#overlay-content {
    position: relative;
    width: 80%;
    margin: 2.5em auto;
    margin-top: 5em;
    min-height: 100%;
    background: #f5f5f5;
    -webkit-box-shadow: 0 0 0.75em #333333;
    -moz-box-shadow: 0 0 0.75em #333333;
    box-shadow: 0 0 0.75em #333333;
}

#overlay-header {
    position: relative;
    padding: 1em 0.5em;
    border-bottom: 1px solid #9900cc;
    background: inherit;
    text-transform: uppercase;
}

#overlay-title { font-size: 120%; }

#overlay-main { padding: 0.5em; }

.alert.alert-global {
    position: fixed;
    top: 2.5em;
    left: 50%;
    width: 40%;
    margin-left: -20%;
    height: auto;
    padding: 0.5em;
    z-index: 3;
}

.alert.alert-global.alert-loading {
    z-index: 4;
    text-align: center;
}

.alert-loading .spinner {
    display: inline-block;
    vertical-align: middle;
    margin: 0;
    margin-right: 0.5em;
}

.alert-loading .alert-msg {
    padding: 0;
    display: inline-block;
}

#preloader {
    display: block;
    position: fixed;
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
    background: #f5f5f5;
    z-index: 6;
}

#preloader .spinner {
    position: absolute;
    top: 30%;
    left: 50%;
    margin-left: -20px;
    background: #9900cc;
}

/************************************************************\
 * ANIMATIONS                                               *
\************************************************************/
.spinner {
    width: 40px;
    height: 40px;
    margin: 100px auto;
    background-color: #333;
    -webkit-border-radius: 100%;
    -moz-border-radius: 100%;
    border-radius: 100%;
    -webkit-animation: sk-scaleout 1.0s infinite ease-in-out;
    animation: sk-scaleout 1.0s infinite ease-in-out;
}

@-webkit-keyframes sk-scaleout {
    0% { -webkit-transform: scale(0) }
    100% {
        -webkit-transform: scale(1.0);
        opacity: 0;
    }
}

@keyframes sk-scaleout {
    0% { 
        -webkit-transform: scale(0);
        transform: scale(0);
    } 100% {
        -webkit-transform: scale(1.0);
        transform: scale(1.0);
        opacity: 0;
    }
}

.linear-spinner {
    width: 100%;
    height: 5px;
    overflow: hidden;
}

.linear-spinner .indicator {
    width: 30%;
    height: inherit;
    background: #9900cc;
    position: relative;
    -webkit-animation: linearSpinner 1.2s infinite linear;
    -moz-animation: linearSpinner 1.2s infinite linear;
    animation: linearSpinner 1.2s infinite linear;
}

@-webkit-keyframes linearSpinner {
    0% { left: -10%; }
    60% { left: 40%; width: 0; }
    100% { left: 100%; width: 30%; }
}

@keyframes linearSpinner {
    0% { left: -10%; }
    60% { left: 40%; width: 0; }
    100% { left: 100%; width: 30%; }
}

/********************************************************\
 * MEDIA QUERIES FOR RESPONSIVENESS                     *
\********************************************************/
@media screen and (max-width: 1080px) {
    
    .input-group { width: 48%; }
    
    #user-menu { position: static; }
    
    #user-menu > li { float: left; }

    #formLogin { width: 50%; }
	
	.alert.alert-global {
        width: 60%;
        margin-left: -30%;
    }
}

@media screen and (max-width: 992px) {
}

@media screen and (max-width: 780px) {
    #container { min-height: auto; }
    
    html body { font-size: 92%; }

    aside {
        position: static;
        width: 100%;
        min-height: auto;
        max-height: none;
        padding: 0;
    }

    main {
        position: static;
        width: 100%;
        padding: 0.35em;
    }
    
    .panel.panel-basic > .panel-header, .heading {
        text-align: left !important;
    }
    
    .input-group { width: 70% !important; }
    
    .display-flex > * { width: 45%; }
    
    #user-menu > li ul { left: 0 !important; }

    #li-usharika-panel { width: 272% !important; }
    
    #menu {
        display: none;
        padding-bottom: 0.075em;
        max-height: none;
    }
    
    #menu-bars-icon { display: none; }

    #menu-pull-icon { display: block; }
    
    .autocomplete { width: 100%; }

    #formLogin { width: 60%; }
    
    #msharika-htnb, #mtumiaji-htnb { left: 12em; }
	
	#msharika-htnb span:first-child,
    #mtumiaji-htnb span:first-child { font-size: 120%; }

    .db-box {
        float: none;
        display: inline-block;
        vertical-align: middle;
    }
    
    .player { width: 100%; }
}

@media screen and (max-width: 650px) {
    html body { font-size: 86%; }

    .input-group { width: 100% !important; }
    
    .profile-summary { text-align: center; }
    
    .profile-photo { margin: 0; }
    
    .profile-summary-info {
        display: block;
        position: static;
    }

    #overlay-content {
        width: 90%;
        margin-top: 1em;
    }

    #overlay-content .btn-dismiss { right: 0.2em; }

    .alert.alert-global {
        width: 85%;
        margin-left: -42.5%;
    }
}

@media screen and (max-width: 520px) {
    .header {
        padding: 0 0.15em;
        text-align: center;
    }
    
    #logo {
        width: 5em;
        height: 5em;
    }
    
    #header-text {
        display: block;
        margin: 0.15em 0;
    }
    
    .display-flex > * {
        width: 100%;
        margin: 0.25em 0;
        display: block;
    }

    #user-menu-pull-icon { display: inline-block; }
    
    #user-menu {
        height: auto;
        display: none;
        text-align: left;
    }

    #user-menu > li {
        float: none;
        position: static;
        height: auto;
        line-height: normal;
    }
    
    #user-menu > li#li-user-privilege { display: none; }

    #user-menu li a { padding: 0.25em; }

    #user-menu > li ul {
        position: static;
        margin-left: 1.5em;
        width: auto !important;
    }

    #formLogin {
        width: 90% !important;
        padding-left: 0.5em;
        padding-right: 0.5em;
    }
    
    .profile-info-row span { display: block; }
    
    #msharika-header, #mtumiaji-header {
		text-align: center;
		height: auto;
	}
	
	#msharika-header .img-view,
    #mtumiaji-header .img-view {
		position: static;
		display: inline-block;
		width: 8em;
		height: 8em;
	}
	
	#msharika-htnb,
    #mtumiaji-htnb { position: static; }
    
    .db-card {
        float: none;
        width: 70%;
        display: block;
        margin: 0.5em auto !important;
    }
    
    #db-charts .db-card {
        width: 94%;
        margin: 0.5em;
        min-width: auto;
    }
    
    .db-breadcumb {
        float: none;
        display: block;
        width: 100%;
        margin: 0;
        border: none;
        border-bottom: 2px solid #f5f5f5;
    }
    
    .db-breadcumb span { font-size: 86%; }
    
    .db-breadcumb.has-bullet::after {
        content: none;
    }

    .alert.alert-global {
        width: 94%;
        margin-left: -47%;
    }
}

@media screen and (max-width: 360px) {
    #formLogin { width: 94% !important; }
    
    .db-card { width: 100% !important; }
}
