body {
    font-family: Georgia, Times, 'Times New Roman', serif;
    font-size: 16px;
    height: 100%;
}

* {
    margin: 0;
    padding: 0;
}

#wrap {
    padding: 0;
    position: relative;
    width: 100%
}

#header {
    /*background: url('/images/solar-logo.png') no-repeat scroll left center transparent;*/
    display: block;
    height: 65px;
    margin: 0 auto;
    width: 100%;
    float: left;
    text-align: left;
    font-size: 24px;
    font-family: Verdana, Arial, Helvetica, sans-serif;
    font-weight: bold;
    vertical-align: top;
}

#header span {
    /*background: url('/images/solar-logo.png') no-repeat scroll left center transparent;*/
    vertical-align: middle;
    margin-bottom: 60px;
    height: 145px;

}

#logoff {
    display: block;
    height: 16px;
    /*width: 350px*/;
    vertical-align: bottom;
    text-align: right;
    float: right;
    margin-top: 0;
    font-size: 12px;
}

#content {
    position: relative;
    width: 100%;
    border-top: 1px solid;
    border-left: 1px solid;
}

#footer {
    position: relative;
    text-align: left;
    border-top: 1px solid;
    font-size: 12px;
    color: #CCCCCC;
    float: left;
    width: 100%;
}

.spacer {
    position: relative;
    height: 500px;
    width: 1190px;
}

.menu ul {
    margin: 0;
    padding: 0;
    float: left;
    list-style: none;
    width: 100%;
}

.menu ul li {
    display: inline;
}

.menu ul li a {
    float: left;
    text-decoration: none;
    color: white;
    padding: 11px 11px;
    background-color: #333333;
}

.menu ul li a:visited {
    color: white;
}

.menu ul li a:hover, .menu ul li .current {
    color: white;
    background-color: #0b75b2;
}

.heading {
    font-size: 20px;
    font-weight: bold;
    margin-top: 20px;
}

p {
    margin-top: 10px;
}

.pagecontent {
    margin-left: 10px;
    position: relative;
}

.top-scroller {
    position: fixed;
    right: 20px;
    bottom: 20px;
    z-index: 99;
}

.companydetails {
    border: 1px solid #000000;
}

.companydetails td, th {
    border: 1px solid #000000;
    padding: 2px;
}

td {
    font-family: Verdana, Arial, Helvetica, sans-serif;
    font-size: 10px;
    font-weight: normal;
    padding: 5px;
}

table {
    border: #000000 solid thin;

}

.clearfloat {
    clear: both;
    height: 0;
    font-size: 1px;
    line-height: 0;
}

.error {
    font-family: Verdana, Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: normal;
    color: #FF0000;
}

.admin-action-success {
    font-family: Verdana, Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: normal;
    color: #52c256;
}

.admin-action-error {
    font-family: Verdana, Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: normal;
    color: #FF0000;
}

.minilink {
    color: #428bca;
    text-decoration: none;
    cursor: pointer
}

.ui-datepicker select.ui-datepicker-month, .ui-datepicker select.ui-datepicker-year {
    color: #333;
    font-weight: normal;
}

.ui-datepicker-used-date a {
    background: #ff0 !important;
}

.pre-screened-text {
    color: #aa3c39;
}

.pre-screened-text.screened {
    color: #26934c;
}

.companies-table tr:nth-child(even) {
    background: rgba(0, 0, 0, 0.05);
}

.companies-table .header {
    cursor: pointer;
}

.companies-table .header:after {
    display: inline-block;
    margin-left: 5px;
    margin-right: 5px;
    content: '\25b2 \25bc';
    letter-spacing: -0.5em;
    color: #888;
}

.companies-table .header.headerSortUp:after {
    content: '\25b2';
    color: #e59515;

}

.companies-table .header.headerSortDown:after {
    content: '\25bc';
    color: #e59515;
}

.filter-label {
    font-weight: normal;
    margin-left: 15px;
}

.filter-label.first {
    margin-left: 0;
}

.filter.plan-filter {
    max-width: 150px;
}

.crm-date-container {
    display: inline-block;
}

.submenu {
    margin: 30px 10px 10px;
    padding: 10px;
    border-radius: 3px;
}

.submenu a {
    display: inline-block;
    border-radius: 2px;
    vertical-align: top;
    font-size: 14px;
    margin-right: 3px;
    margin-bottom: 5px;
    padding: 2px 4px;
    background: #EEE;
    border: 1px solid rgba(0, 0, 0, 0.3);
    box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.1);
}

.submenu a:hover {
    text-decoration: none;
    color: #333;
}

.submenu a.active {
    background: #0b75b2;
    color: #FFF;
}

.form-inline {
    display: inline-block;
}

/* This can be used on non-button elements as well as buttons to create a consistent style between them. */
.generic-button {
    font-family: sans-serif;
    display: inline-block;
    padding: 3px 5px;
    border: 1px solid rgba(0, 0, 0, 0.2);
    box-shadow: 0 1px 1px rgba(0, 0, 0, 0.2);
    border-radius: 3px;
    background: #0b75b2;
    font-size: 14px;
    color: #FFF;
}

.generic-button:hover,
.generic-button:focus {
    color: #FFF;
    text-decoration: none;
    background: #0b91d2;
}

.generic-button:active {
    box-shadow: 0 1px 1px rgba(0, 0, 0, 0.3) inset;
}

.generic-button.danger {
    background: #FF3333;
    color: #FFF;
}

.generic-button.danger:hover,
.generic-button.danger:focus {
    background: #ff5e52;
}

.generic-form {
    max-width: 600px;
    margin-bottom: 15px;
}

.generic-form input {
    border: 1px solid #666;
    padding: 5px;
    width: 100%;
}

.generic-form label {
    display: block;
    margin-top: 15px;
}

.generic-form select {
    padding: 5px;
    width: 100%;
}

.generic-form textarea {
    padding: 10px;
    border: 1px solid #666;
    width: 100%;
    min-height: 300px;
}

.generic-form button {
    margin-top: 15px;
    padding: 10px;
}

.generic-form input[type=date] {
    line-height: normal;
}

.generic-table {
    margin-bottom: 30px;
}

.generic-table td {
    text-align: center;
    border-right: 1px solid #CCC;
}

.generic-table td:last-of-type {
    border-right: #000 solid 1px;
}

.generic-table tr:nth-child(even) {
    background: rgba(0, 0, 0, 0.05);
}

table.undersold-report.sticky-header {
    position: sticky;
    top: 10px;
    margin: 10px 0 -1px 0;
    background: #FFF;
    box-shadow: 0 0 3px rgba(0, 0, 0, 0.4);
    border: none;
}

table.undersold-report.sticky-header ~ table.undersold-report {
    margin-top: 0;
}

table.undersold-report td,
table.undersold-report thead th {
    min-width: 150px;
    width: 150px;
    text-align: center;
}

table.undersold-report th:first-of-type,
table.undersold-report th:last-of-type,
table.undersold-report td:first-of-type,
table.undersold-report td:last-of-type {
    min-width: 80px;
    width: 80px;
}

table.undersold-report thead th {
    font-size: 12px;
    font-weight: 600;
}

table.undersold-report .county-row td:first-of-type {
    text-align: left;
}

table.undersold-report .county-row {
    line-height: 0.7em;
    background: #EEE;
    border-bottom: 1px dashed #CCC;
}

table.undersold-report.loading {
    transition: ease all 0.3s;
    opacity: 0.5;
    cursor: wait;
}

.filter-container {
    background: #f1f1f1;
    padding: 10px;
    display: inline-block;
    margin-right: 10px;
    margin-bottom: 5px;
    vertical-align: top;
}

.filter-container:after {
    content: '';
    display: block;
    clear: both;
}

.filter-container .filter-heading {
    font-weight: bold;
    font-size: 14px;
    display: block;
    margin-bottom: 10px;
}

.filter-container label {
    margin-bottom: 0;
}

.filter {
    margin-bottom: 10px;
}

.filter label {
    margin-right: 10px;
}

.filter select, .filter input,
.filter .input-container {
    float: right;
    width: 100%;
    max-width: 200px;
}

.filter [type=radio] {
    margin-right: 3px;
    float: none;
    width: auto;
}

.filter [type=radio]:not(:first-child) {
    margin-left: 20px;
}

.filter [type=checkbox] {
    width: auto;
    float: none;
}

.filter-container hr {
    margin: 10px 0 10px;
    border-color: #CCC;
    border-style: solid;
}

.filter-container .filter-submit {
    display: block;
    padding: 5px 10px;
}

.filter-column {
    display: inline-block;
    width: 430px;
    margin-right: 20px;
    padding-right: 20px;
    border-right: 1px #CCC solid;
    vertical-align: top;
}

.filter-column:last-of-type {
    margin-right: 0;
    padding-right: 0;
    border-right: none;
}

.date-range-container {
    display: inline-block;
}

.date-range-container input[type=date] {
    height: auto;
    line-height: normal;
    margin-right: 10px;
    padding: 2px 10px;
}

.date-range-container button {
    padding: 3px 10px;
}

.quick-date-buttons button {
    padding: 3px 10px;
}

.quick-date-buttons button.active {
    position: relative;
    /*top: -1px;*/
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.2);
    border: 1px rgba(0, 0, 0, 0.3) solid;
    padding: 4px 10px;
    border-radius: 2px;
}

.has-tooltip {
    position: relative;
    padding-right: 27px;
}

.has-tooltip:hover:after {
    display: block;
}

.has-tooltip:before {
    display: block;
    position: absolute;
    right: 7px;
    top: 5px;
    border-radius: 100%;
    height: 15px;
    width: 15px;
    content: '?';
    color: #FFF;
    background: #56aad5;
    text-align: center;
    line-height: 16px;
    font-size: 12px;
    z-index: 10;
}

.has-tooltip:after {
    background: #56aad5;
    border-radius: 2px;
    box-shadow: 1px 1px 2px rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(0, 0, 0, 0.1);
    padding: 8px;
    font-size: 14px;
    font-weight: 200;
    color: #FFF;
    display: none;
    position: absolute;
    width: 100%;
    right: 11px;
    top: 11px;
    z-index: 11;
    content: attr(data-tooltip);

}

.reports.submenu {
    padding: 10px;
    clear: both;
}

.reports.submenu a {
    display: inline-block;
    border-radius: 2px;
    vertical-align: top;
    font-size: 12px;
    margin-right: 3px;
    margin-bottom: 5px;
    padding: 2px 4px;
    background: #EEE;
    border: 1px solid rgba(0, 0, 0, 0.3);
    box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.1);
}

.reports.submenu a.active {
    background: rgb(70, 125, 204);
    color: #FFF;
}

.report {
    padding: 10px;
}

.counties-link {
    cursor: pointer;
}

.billing-invoice-pdf-form a {
    cursor: pointer;
}

.toggle-control {
    cursor: pointer;
    display: inline-block;
    vertical-align: middle;
    line-height: 1em;
    position: relative;
    margin-right: 10px;
    width: 36px;
    height: 18px;
    border-radius: 18px;
    background: #EEE;
    box-shadow: 0 0 2px rgba(0, 0, 0, 0.1) inset;
    border: 1px solid #CCC;
}

.toggle-control:before {
    transition: 0.2s cubic-bezier(0.86, 0, 0.07, 1) all;
    position: absolute;
    content: '✗';
    color: #FFF;
    text-align: center;
    line-height: 14px;
    left: 2px;
    top: 1px;
    width: 14px;
    height: 14px;
    border-radius: 14px;
    border: 1px solid rgba(0, 0, 0, 0.1);
    background: #A66;
    user-select: none;
}

.toggle-control.active:before {
    content: '✓';
    left: 18px;
    background: #6A6;
}

.alert-log {
    position: relative;
    background: #EEE;
    padding: 5px;
    height: 23px;
    overflow: hidden;
    cursor: pointer;
}

.alert-log.active {
    height: auto;

}

.alert-log + .alert-log {
    margin-top: 5px;
}

.alert-log:before {
    display: inline-block;
    content: '✗';
    background: #d23c2a;
    color: #FFF;
    text-align: center;
    line-height: 15px;
    border-radius: 100%;
    width: 13px;
    height: 13px;
}


.alert-log:after {
    display: block;
    position: absolute;
    right: 5px;
    top: -4px;
    font-size: 18px;
    content: '⌄';
}

.alert-log.active:after {
    content: '⌃';
    top: 5px;
}

.alert-log .timestamp, .alert-log .method {
    color: red;
    font-weight: bold;
    text-transform: uppercase;
}

.alert-log .message {
    border-top: 1px solid #CCC;
    margin-top: 4px;
}

.flash-messages {
    position: absolute;
    top: 40px;
    width: 100%;
}

.flash-messages .message {
    display: none;
    position: relative;
    margin: 0 auto;
    width: auto;
    background: #ffe000;
    max-width: 600px;
    border-radius: 3px;
    font-weight: bold;
    padding: 8px 0 8px 3em;
    box-shadow: 1px 0 3px rgba(0, 0, 0, 0.3);
}

.flash-messages .message.active {
    display: block;
}

.flash-messages .message:before {
    position: absolute;
    content: '!';
    left: 10px;
    text-align: center;
    line-height: 1.5em;
    border-radius: 100%;
    width: 1.4em;
    height: 1.4em;
    background: #333;
    color: #ffe000;
}

.flash-messages .message:after {
    display: block;
    position: absolute;
    right: 10px;
    top: 5px;
    font-size: 18px;
    content: '×';
    cursor: pointer;
}

.flash-messages .message.s-message {
    background: #2c9c5d;
    color: #FFF;
}

.flash-messages .message.s-message:before {
    display: block;
    content: '✓';
    background: #FFF;
    color: #ff4b33;
}

.flash-messages .message.e-message {
    background: #ff4b33;
    color: #FFF;
}

.flash-messages .message.e-message:before {
    display: block;
    content: '✗';
    background: #FFF;
    color: #ff4b33;
}

.flash-messages .message + .flash-messages .message {
    margin-top: 5px;
}

.blog-admin-content {
    padding: 20px;
}

.blog-admin-content .generic-table td {
    font-size: 14px;
}

.blog-admin-content .generic-button {
    margin-bottom: 20px;
}

.blog-admin-content .generic-table .generic-button {
    margin-bottom: 0;
}

.blog-post-table {
    width: 100%;
}

.blog-post-table td:last-child {
    width: 180px;
}

.expandable-image {
    max-width: 200px;
    max-height: 200px;
    margin: 0 0 10px;
    padding: 5px;
    border: 1px solid #888;
    border-radius: 3px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
    transition: 0.3s ease all;
    cursor: zoom-in;
}

.expandable-image.active {
    max-width: 100%;
    max-height: none;
    cursor: zoom-out;
}

.author-form .author-thumbnail {
    margin-bottom: 20px;
}

.quotes-company-preselected {
    padding: 2px 6px;
    background: #2c9c5d;
    color: #FFF;
    font-size: 10px;
    border-radius: 3px;
}

.admin-quote-view .quotes-company-preselected {
    margin: 10px 0;
    font-size: 12px;
}

.admin-quote-view .quotes-company-preselected .company-name {
    font-weight: bold;
}

.user-management {
    padding: 10px;
    max-width: 1200px;
    width: 100%;
}

.user-display-container {
    padding: 10px 64px;
    width: 100%;
    max-width: 1200px;
}

.user-display-container.new-user-display {
    max-width: 700px;
}

.user-management .form-control, .user-management .form-group, .user-management .input-group-btn {
    display: inline-block;
    width: auto;
}

.user-management .form-select {
    padding-right: 10px;
}

.user-management .heading {
    margin-bottom: 0;
}

.subtitle {
    margin: 0 0 5px 0;
    font-size: 14px;
}

.user-search-results table, .user-display table {
    border: none;
    width: 100%;
}

.user-search-results table th, .user-display table th {
    border: none;
    font-size: 14px;
}

.user-search-results table.table-condensed th, .user-search-results table.table-condensed td {
    padding: 5px;
}

.user-display .title-row {
    height: 40px;
    line-height: 40px;
    font-size: 20px;
    margin-bottom: 20px;
}

.user-display .info-row {
    margin-bottom: 10px;
}

.user-display .info-row .info-label {
    font-size: 12px;
    color: rgb(107, 119, 140);
    font-weight: 600;
}

.user-display .info-row .info-value {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.user-display .info-row .info-value.allow-overflow {
    white-space: normal;
}

.user-display .info-row.panel-display-row {
    margin-top: 20px;
}

.user-display .flag-icon {
    height: 15px;
    width: auto;
}

.user-display .panel table th {
    font-size: 12px;
}

.user-display .table-one-line-disabled td {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.user-display .dropdown-menu li button {
    display: block;
    padding: 3px 20px;
    clear: both;
    font-weight: 400;
    line-height: 1.42857143;
    color: #333;
    white-space: nowrap;
    background: transparent;
    border: none;
    width: 100%;
    text-align: left;
}

.user-display .dropdown-menu li button:hover {
    background-color: #f5f5f5;
}

.modal.center-modal {
    transform: translate(-50%, -50%);
    top: 50%;
    left: 50%;
}

.user-display.edit-display .info-value {
    line-height: 32px;
}

.table-condensed input[type="radio"], .table-condensed input[type="checkbox"] {
    margin: 0;
    -ms-transform: scale(0.8);
    -moz-transform: scale(0.8);
    -webkit-transform: scale(0.8);
    -o-transform: scale(0.8);
}

.flag-table.table-condensed td {
    padding: 2px;
    vertical-align: middle;
}

.user-display .help-block {
    display: block;
    margin-top: 0;
    margin-bottom: 0;
    color: #737373;
    font-size: 12px;
}


.unstructured-form {
    padding: 40px;
}

.unstructured-form .dual-input > .input {
    box-sizing: border-box;
    display: inline-block;
    width: 49%;
    max-width: 230px;
}

.unstructured-form label {
    display: block;
}

.unstructured-form input {
    display: block;
    max-width: 300px;
    padding: 3px 10px;
    margin-bottom: 15px;
}

.unstructured-form select {
    padding: 3px 10px;
    margin-bottom: 15px;
}

.unstructured-form textarea {
    margin-bottom: 15px;
}

.unstructured-form [type=button], .unstructured-form [type=submit] {
    display: inline-block;
    margin-right: 10px;
}

.bounced-email-report {
    padding: 10px;
}

.bounced-email-report .report-submit-form {
    display: inline-block;
    background: #f1f1f1;
    padding: 10px;
    margin-right: 10px;
    max-width: 1000px;
    width: 100%;
}

.bounced-email-report .report-submit-form #bounced_email_file {
    margin-bottom: 10px;
}

.bounced-email-report .report-error-container {
    max-width: 1000px;
    margin: 10px 0;
    width: 100%;
}

.bounced-email-report .report-result-container {
    max-width: 1200px;
    width: 100%;
}

.bounced-email-report .table {
    margin: 10px 0;
    width: 100%;
    background: transparent;
    border-collapse: collapse;
    border: none;
}

.bounced-email-report .table tr {
    border: none;
}

.bounced-email-report .table thead th {
    vertical-align: middle;
    border: none;
    border-bottom: 2px solid #dee2e6;
    padding: .35rem;
    border-top: 1px solid #dee2e6 !important;
}

.bounced-email-report .table td {
    vertical-align: middle;
    padding: .35rem;
    border-top: 1px solid #dee2e6;
}

.bounced-email-report .table tbody tr:nth-child(odd) {
    background-color: rgba(0, 0, 0, 0.05);
}

.pending-email-verification-container {
    padding: 10px 20px;
}

.review-filter-container {
    background: #f1f1f1;
    padding: 10px;
    margin: 5px 10px 5px 0;
    display: inline-block;
    max-width: 1600px;
    width: 100%;
}

.flex-row {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
}

.review-filter-container label, .review-filter-container input, .review-filter-container select, .review-filter-container option {
    height: 32px;
    line-height: 32px;
}

.review-error-container {
    width: 1000px;
}

.review-filter-container h5 {
    font-weight: bold;
    font-size: 16px;
}

.flex-center-vertically {
    display: flex;
    align-items: center;
}

.review-filter-container input {
    padding: 0;
    margin: 0;
}

.review-filter-container input[type="radio"] {
    margin: 0 10px 0 0;
}

.review-filter-container label {
    padding: 0;
    margin: 0;
    font-weight: inherit;
}

.review-filter-container .company-filters {
    display: flex;
    flex-direction: column;
}

.review-filter-container .company-filters .form-group {
    margin: 0 0 5px;
}

.email-verification-results thead th, .center-headers thead th {
    text-align: center;
}

.email-verification-results .btn {
    margin-bottom: 5px;
    width: 140px;
}

.pagination-container {
    margin: 10px 0;
}

.pagination-container .pagination {
    margin: 5px 0;
}

.tab-container {
    margin: 10px 0;
    padding-right: 20px;
}

.tab-container ul a {
    outline: 0;
}

.tab-container .tab-content {
    padding: 10px 20px;
    border: 1px solid #ddd;
    border-top: none;
}

.bootstrap-table {
    border: none;
}

.bootstrap-table th {
    border: none;
}

table td .panel-group {
    text-align: left;
}

.panel-group.small .panel-title {
    font-size: 12px;
}

.multi-actions {
    margin: 10px 0;
}

.ul-container-no-margin ul {
    margin: 0 0 !important;
}

.budget-utilization-report td {
    font-size: 14px;
}

.budget-utilization-report .comparison {
    font-size: 12px;
    color: #666;
}

.budget-utilization-report .comparison.worse {
    color: #b4332f;
}

.budget-utilization-report .comparison.worse:after {
    content: '↘';
    display: inline;
    font-weight: bold;
}

.budget-utilization-report .comparison.better {
    color: #4f9d4f;
}

.budget-utilization-report .comparison.better:after {
    content: '↗';
    display: inline;
    font-weight: bold;
}

.budget-utilization-report .comparison.no-change {
    display: none;
}

.account-manager-performance-report td {
    border: 1px solid #EFEFEF;
    font-size: 14px;
}

.account-manager-performance-report .temporal-report {
    background: #EFEFEF;
    font-size: 0;
}

.account-manager-performance-report .temporal-report span {
    border-right: 1px solid #CCC;
    font-size: 10px;
    padding: 2px 8px;
    display: inline-block;
}

.account-manager-performance-report .temporal-report span:last-of-type {
    border-right: none;
}

/* allows a table thead th to be fixed to the top of a table */
.table-fixedhead th {
    position: sticky;
    top: 0;
    background: #eee;
}

table.table.attachment-table {
    max-width: 1600px;
}

.attachment-container {
    background: #EFEFEF;
    padding: 20px;
    border-radius: 5px;
    max-width: 1600px;
    margin: 30px 0;
}

.no-margin {
    margin: 0;
}

.attachment-object {
    width: 100%;
    max-width: 400px;
    height: auto;
}

.config-page {
    padding: 30px 0;
    max-width: 1600px;
}

.config-page .route-table {
    margin-bottom: 20px;
}

.config-page .redirect-manager-table {
    max-width: 1600px;
    padding-right: 20px;
}

.actions-container {
    margin: 10px 0;
}

.search-filter-container {
    background: #f1f1f1;
    padding: 10px;
    margin-bottom: 20px;
    width: 100%;
    max-width: 1600px;
}

.admin-menu-list {
    list-style-type: none;
    border: 1px solid #eee;
    display: inline-flex;
    border-radius: 5px;
}

.admin-menu-list li {
    display: inline-block;
    border-right: 1px solid #eee;
}

.admin-menu-list li:last-child {
    border-right: none;
}

.admin-menu-list li a {
    padding: 10px 20px;
    display: block;
}

.admin-menu-list li a.active {
    font-weight: bold;
}

.confidence-overview {
    display: flex;
    justify-content: space-between;
    margin-bottom: 5px;
}

.confidence-meter {
    max-width: 450px;
}

.confidence-meter-bar {
    width: 100%;
    height: 25px;
    position: relative;
    border-radius: 25px;
    margin-top: 30px;
    margin-bottom: 10px;
}

.bar-child {
    width: 100%;
    height: 100%;
}

.bar-marker {
    position: absolute;
    width: 7px;
    height: 35px;
    background: #f7f7f7;
    top: -5px;
    border: 1px solid #777;
}

.bar-marker span {
    position: absolute;
    top: -25px;
    transform: translate(-50%, 0);
    left: 50%;
}

.bar-child.progress-meter {
    background: #2ecc71;
    background: -moz-linear-gradient(right, #2ecc71 0%, #f39c12 50%, #e74c3c 100%);
    background: -webkit-linear-gradient(right, #2ecc71 0%,#f39c12 50%,#e74c3c 100%);
    background: linear-gradient(to left, #2ecc71 0%,#f39c12 50%,#e74c3c 100%);
    -moz-box-shadow:    inset 0 0 10px #555555;
    -webkit-box-shadow: inset 0 0 10px #555555;
    box-shadow:         inset 0 0 10px #555555;
    border-radius: 25px;
}

.results-overview {
    margin-top: 10px;
    max-width: 450px;
}

.results-overview .panel-heading {
    padding: 0;
}

.results-overview .panel-heading a {
    display: flex;
    width: 100%;
    height: 100%;
    padding: 10px;
    font-size: 12px;
    justify-content: space-between;
    align-items: center;
}
.results-overview table {
    margin-bottom: 0;
    border: 0;
}

.results-overview table.table td {
    vertical-align: middle;
    padding-left: 5px;
    padding-right: 5px;
}

.results-overview table.table td img {
    height: 16px;
    width: auto;
}

.results-overview .badges {
    display: flex;
    align-items: center;
}

.results-overview .badges img {
    height: 15px;
    width: auto;
}

.results-overview .badges > div {
    padding: 0 5px;
}

.results-overview td:nth-child(2) {
    text-align: center;
}

.results-overview .panel-body {
    padding: 0;
}
.confidence-score {
    font-size: 15px;
}

.badge.badge-success {
    background-color: #2ecc71!important;
}

.badge.badge-danger {
    background-color: #e74c3c!important;
}

.badge.badge-warning {
    background-color: #f39c12!important;
}

/**
 * These are styles from bootstrap 4
 */
.d-flex {
    display: flex!important;
}

.p-3 {
    padding: 1rem!important;
}
.px-4 {
    padding-left: 2rem !important;
    padding-right: 2rem !important
}
.p-4 {
    padding: 2rem!important;
}
.pt-3 {
    padding-top: 1rem!important;
}

.pb-3 {
    padding-bottom: 1rem!important;
}

.p-5 {
    padding: 3rem!important;
}

.pt-5 {
    padding-top: 3rem!important;
}

.pb-5 {
    padding-bottom: 3rem!important;
}

.pt-0 {
    padding-top: 0!important;
}

.pb-0 {
    padding-bottom: 0!important;
}

.mb-3 {
    margin-bottom: 1rem!important;
}

.mb-5 {
    margin-bottom: 3rem!important;
}

.mt-3 {
    margin-top: 1rem!important;
}

.mt-5 {
    margin-top: 3rem!important;
}

.ml-3 {
    margin-left: 1rem!important;
}

.ml-auto {
    margin-left: auto !important;
}

.bg-light {
    background-color: #f1f1f1!important;
}

.w-33 {
    width: 33%;
}

.w-50 {
    width: 50%;
}

.w-100 {
    width: 100%;
}

.w-auto {
    width: auto!important;
}

.w-50 {
    width: 50% !important;
}

.mw-100 {
    max-width: 100% !important;
}

.d-inline-block {
    display: inline-block !important;
}

.align-items-center {
    align-items: center;
}

.justify-content-center {
    justify-content: center;
}

.history-table table {
    table-layout: fixed;
}

.history-table table td {
    word-wrap: break-word;
}

.history-table table thead td {
    width: auto;
}

.solar-panels-card {
    max-width: 1400px;
    border: 1px solid #efefef;
    border-radius: 10px;
}

.font-14 {
    font-size: 14px !important;
}

.font-16 {
    font-size: 16px;
}

.font-24 {
    font-size: 24px !important;
}

.font-20 {
    font-size: 20px;
}

.font-weight-bold {
    font-weight: bold !important;
}

.cursor-pointer {
    cursor: pointer !important;
}

.disabled {
    opacity: 0.2;
    cursor: default;
}

.multi-select-container {
    position: relative;
    max-width: 230px;
    display: inline-block;
    width: 100%;
}

.multi-select-container .dropdown button {
    text-align: left;
    text-overflow: ellipsis;
    overflow: hidden;
    border: 1px solid #adb5bd;
    font-weight: 600;
}
.multi-select-container .dropdown button::after {
    position: absolute;
    right: 0.5em;
    top: 1em;
}
.multi-select-container .dropdown-menu {
    min-width: 230px;
}
.multi-select-container .dropdown-menu .search-box {
    margin: 0.5em;
}
.multi-select-container .dropdown-menu .list-state-group {
    max-height: 10em;
    overflow-y: auto;
    overflow-x: hidden;
    margin-bottom: 0.5em;
}
.multi-select-container .dropdown-menu .list-state-group .list-group-item {
    border: none;
    cursor: pointer;
}
.multi-select-container .dropdown-menu .list-state-group .list-group-item:first-child {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
}

.pl-0 {
    padding-left: 0 !important;
}

.mb-0 {
    margin-bottom: 0;
}

.mt-0 {
    margin-top: 0;
}

.mx-2 {
    margin: 0 10px 0 10px;
}

.m-1 {
    margin: 5px !important;
}

.mb-1 {
    margin-bottom: 5px;
}

.ml-1 {
    margin-left: 5px;
}

.ml-0 {
    margin-left:0;
}

.mr-1 {
    margin-right: 5px;
}

.mr-2 {
    margin-right: 10px;
}

.mx-auto {
    margin: 0 auto;
}

.max-h-xl {
    height: 924px;
}

.max-w-1400 {
    max-width: 1400px;
}

.border-black {
    border: 2px solid #000000;
}