﻿:root {
  --project-status-color-requested: #333;
  --project-status-color-new: #4a7fd4;
  --project-status-color-noBid: #c15700;
  --project-status-color-estimating: #042cdd;
  --project-status-color-bidPending: #3955a2;
  --project-status-color-bidLost: #ff0000;
  --project-status-color-bidWon: #13a171;
  --project-status-color-active: #057a55;
  --project-status-color-closed: #03543b;
  --project-status-color-customerCancelled: #800000;
  --row-delete-background-color: #fed1d177;
  --row-add-background-color: #cbd9cd67;
  --row-modify-background-color: #8fadef57;
  --row-spliter-background-color: #5cd1e98f;
  --row-splitee-background-color: #5cd1e954;
  --financials-background-color: #eef4fc;
  --list-view-sticky-buffer: 235px;
  --pageOrientation: portrait;
}

.icon-img {
    height: 1em;
    vertical-align: middle;
}

/** Status Text Colors for Projects/users */
.text-color-status-deleted,
.text-color-status-requested {
  color: var(--project-status-color-requested) !important;
}


.text-color-status-disabled,
.text-color-status-inactive,
.text-color-status-new {
  color: var(--project-status-color-new) !important;
}

.text-color-status-estimating {
  color: var(--project-status-color-estimating) !important;
}

.text-color-status-pending,
.text-color-status-nobid {
  color: var(--project-status-color-noBid) !important;
}

.text-color-status-bidwon,
.text-color-status-awarded {
  color: var(--project-status-color-bidWon) !important;
}

.text-color-status-bidpending,
.text-color-status-bidsubmitted {
  color: var(--project-status-color-bidPending) !important;
}

.text-color-status-bidlost {
  color: var(--project-status-color-bidLost) !important;
}

.text-color-status-draft,
.text-color-status-active,
.text-color-status-enabled,
.text-color-status-planning,
.text-color-status-installation,
.text-color-status-closure {
  color: var(--project-status-color-active) !important;
}

.text-color-status-closed,
.text-color-status-completed {
  color: var(--project-status-color-closed) !important;
}

.text-color-status-customercancelled {
  color: var(--project-status-color-customerCancelled) !important;
}

/** Status Border Colors for Projects */
.border-color-status-requested,
.border-color-status-deleted {
  border-color: var(--project-status-color-requested);
}

.border-color-status-new {
  border-color: var(--project-status-color-new);
}

.border-color-status-estimating {
  border-color: var(--project-status-color-estimating);
}

.border-color-status-nobid {
  border-color: var(--project-status-color-noBid);
}

.border-color-status-bidwon,
.border-color-status-awarded {
  border-color: var(--project-status-color-bidWon);
}

.border-color-status-bidlost {
  border-color: var(--project-status-color-bidLost);
}

.border-color-status-bidpending,
.border-color-status-bidsubmitted {
  border-color: var(--project-status-color-bidPending);
}

.border-color-status-active {
  border-color: var(--project-status-color-active);
}

.border-color-status-closed,
.border-color-status-completed {
  border-color: var(--project-status-color-closed);
}

.border-color-status-customercancelled {
  border-color: var(--project-status-color-customerCancelled);
}

/** Status Background Colors for Projects */
.background-color-status-requested,
.background-color-status-deleted {
    background-color: var(--project-status-color-requested) !important;
}

.background-color-status-new {
    background-color: var(--project-status-color-new) !important;
}

.background-color-status-estimating {
    background-color: var(--project-status-color-estimating) !important;
}

.background-color-status-nobid {
    background-color: var(--project-status-color-noBid) !important;
}

.background-color-status-bidwon,
.background-color-status-awarded {
    background-color: var(--project-status-color-bidWon) !important;
}

.background-color-status-bidlost {
    background-color: var(--project-status-color-bidLost) !important;
}

.background-color-status-bidpending,
.background-color-status-bidsubmitted {
    background-color: var(--project-status-color-bidPending) !important;
}

.background-color-status-planning,
.background-color-status-installation,
.background-color-status-closure,
.background-color-status-active {
    background-color: var(--project-status-color-active) !important;
}

.background-color-status-closed,
.background-color-status-completed {
    background-color: var(--project-status-color-closed) !important;
}

.background-color-status-customercancelled {
    background-color: var(--project-status-color-customerCancelled) !important;
}
/* ends here */

.card:has(.card-body-grid:not(.show)) .card-header {
    border-bottom: 0;
    transition: border-bottom 300ms ease;
}

.card:has(.card-body-grid.show) .card-header {
    transition: border-bottom 300ms ease;
}

.card .card-body-grid {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows 100ms; /* 400ms when overflow hidden below is turned back on*/
}

    .card .card-body-grid.show {
        grid-template-rows: 1fr;
    }

/*.card .card-body-grid > div {
   overflow:hidden;
}*/

.card-border-left {
  border-left-style: solid;
  border-left-width: 1.5rem;
}

.card-rounded-corners {
  border-radius: 16px;
}

.CardHeaderAttention {
  background-color: #4DA22A;
  color: white;
}

html, body {
  font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
  min-height: 100vh;
}

#app {
  display: grid;
  grid-template-rows: auto 1fr auto;
  grid-template-columns: 100%;
  min-height: 100vh;
}

.toolbar-logo {
  height: 3.75rem;
}

.version-logo {
  max-height: 3.75rem;
  max-width: 4rem;
  margin-right: 10px;
}

.valid.modified:not([type=checkbox]):not([type=radio]) {
  outline: 1px solid #26b050;
}

.invalid {
  outline: 1px solid red;
}

.validation-message {
  color: red;
}

.previous-observed {
  color: blue !important;
}

.current-observed {
  color: green !important;
}

/*Blazored Toast overrides*/
.position-topright {
  top: 5px !important;
}

.blazored-toast-container {
  z-index: 10000 !important;
}

.blazored-toast-message {
    overflow-wrap: normal !important;
    word-break: normal !important;
    word-wrap: normal !important;
    hyphens:none !important;
}

#blazor-error-ui {
  background: lightyellow;
  bottom: 0;
  box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
  display: none;
  left: 0;
  padding: 0.6rem 1.25rem 0.7rem 1.25rem;
  position: fixed;
  width: 100%;
  z-index: 1000;
}

  #blazor-error-ui .dismiss {
    cursor: pointer;
    position: absolute;
    right: 0.75rem;
    top: 0.5rem;
  }

.blazor-error-boundary {
  background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
  padding: 1rem 1rem 1rem 3.7rem;
  color: white;
}

  .blazor-error-boundary::after {
    content: "An error has occurred."
  }

.canSelect {
  cursor: pointer;
}

.unsorted::before {
  display: inline-block;
  width: .8rem;
  margin-right: .1rem;
  content: url(images/unsorted.svg)
}

.hover:hover {
  background-color: lightgray !important;
}

/*********************  Navigation ********************/
.nav-item {
  font-size: 0.9rem;
}

.expandable-menu-header {
  color: white;
  padding: var(--bs-nav-link-padding-y) var(--bs-nav-link-padding-x);
  position: relative;
}

  .expandable-menu-header i:last-child {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
  }

  .expandable-menu-header.open {
    border-right: solid black 2px;
  }

.submenu {
  border-right: solid black 2px;
}

  .submenu > :last-child {
    padding-bottom: 0 !important;
  }

.submenu-item {
  font-size: 0.8em !important;
}
/********************** Tables *************************/
.table-logo {
  height: 3rem;
}

.paging-input-width-form-control {
  width: 80px;
}

.totals-row {
  font-size: 1.1em;
}

/* container based css **********************************************************/
@container (min-width: 576px) {
  .dci-text-sm-start {
    text-align: start;
  }

  .dci-text-sm-end {
    text-align: end;
  }

  .dci-text-sm-center {
    text-align: center;
  }

  .dci-d-sm-none {
    display: none !important;
  }

  .dci-d-sm-block {
    display: block !important;
  }
}

@container (min-width: 768px) {
  .dci-text-md-start {
    text-align: start;
  }

  .dci-text-md-end {
    text-align: end;
  }

  .dci-text-md-center {
    text-align: center;
  }

  .dci-d-md-none {
    display: none !important;
  }


  .dci-d-md-block {
    display: block !important;
  }
}

@container (min-width: 992px) {
  .dci-text-lg-start {
    text-align: start;
  }

  .dci-text-lg-end {
    text-align: end;
  }

  .dci-text-lg-center {
    text-align: center;
  }

  .dci-d-lg-none {
    display: none !important;
  }

  .dci-d-lg-block {
    display: block !important;
  }
}

@container (min-width: 1200px) {
  .dci-text-xl-start {
    text-align: start;
  }

  .dci-text-xl-end {
    text-align: end;
  }

  .dci-text-xl-center {
    text-align: center;
  }

  .dci-d-xl-none {
    display: none !important;
  }

  .dci-d-xl-block {
    display: block !important;
  }
}

@container (min-width: 1400px) {
    .dci-text-xxl-start {
        text-align: start;
    }

    .dci-text-xxl-end {
        text-align: end;
    }

    .dci-text-xxl-center {
        text-align: center;
    }

    .dci-d-xxl-none {
        display: none !important;
    }

    .dci-d-xxl-block {
        display: block !important;
    }
}

/********************** Buttons Grid *************************/
.buttons-grid {
    display: grid;
    grid-template-columns: max-content;
    gap: 0.5rem;
}

@media (min-width: 672px) {
    .buttons-grid {
        justify-content: end;
    }
}

@media (min-width: 992px) {
    .buttons-grid {
        grid-template-columns: repeat(2, max-content);
    }
}

@media (min-width: 1250px) {
    .buttons-grid {
        grid-template-columns: repeat(4, max-content);
    }
}

/********************** Table DCI Dashboard Styles *************************/
.DCITableWrapper {
  border: 1px solid rgba(224, 224, 224, 1);
  border-radius: 5px;
}

  .DCITableWrapper .smartPager {
    margin: 10px;
    font-size: 0.9em;
  }

.DCIstyled-table,
.DCIstyled-table-double-row {
  font-size: 0.9em;
  min-width: 400px;
  color: rgba(0, 0, 0, 0.87);
  margin-bottom: 0px !important;
}

  .DCIstyled-table tr.add-new-row {
    --bs-table-bg: transparent !important;
    background-color: rgb(245 255 245);
  }

  .DCIstyled-table-double-row .filters-row,
  .DCIstyled-table .filters-row {
    --bs-table-bg: transparent !important;
    background-color: rgb(242 253 255);
  }

  .DCIstyled-table thead tr td {
    border: none;
  }

  .DCIstyled-table thead tr,
  .DCIstyled-table-double-row thead tr {
    background-color: #fafafa;
    box-shadow: 0 2px 2px -1px #dddddd;
    border: none;
  }

  .DCIstyled-table tbody tr {
    border-bottom: thin solid #dddddd;
  }

    .DCIstyled-table tbody tr:nth-of-type(even) {
      background-color: #f3f3f3;
    }

  .DCIstyled-table th,
  .DCIstyled-table-double-row th {
    position: sticky;
    top: 0;
    box-shadow: 0 2px 2px -1px #dddddd;
  }

  .DCIstyled-table-double-row tbody tr:nth-child(4n+1) {
    border-bottom: thin solid #dddddd;
  }

  .DCIstyled-table-double-row tbody tr:nth-child(4n+2) {
    border-bottom: thin solid #cccccc;
  }

  .DCIstyled-table-double-row tbody tr:nth-child(4n+3) {
    background-color: #f3f3f3;
  }

  .DCIstyled-table-double-row tbody tr:nth-child(4n) {
    background-color: #e3e3e3;
  }

/* DO NOT USE THESE are being phased out, ask JS if you need help ***********************************/
.colExtraSmall {
  width: 100px;
}

.colSmall {
  min-width: 135px;
}

.colMed {
  min-width: 200px;
}

.colMediumExact {
  width: 225px;
}

.colNumeric {
  min-width: 135px;
  text-align: right;
}
/* DO NOT USE THESE are being phased out, ask JS if you need help ***********************************/

/******** Busy indicator ******************************/
.busy-indicator-wrapper {
  padding: 4rem;
}

.busy-indicator {
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 10000;
  opacity: 1;
}

  .busy-indicator img {
    max-height: 100px;
    animation: rotation 2s infinite linear;
    margin-right: 10px;
  }

@keyframes rotation {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(359deg);
  }
}
/***** end busy indicator **********************/

/***** whole app loader *************************/
.blazor-app-loader {
  display: flex;
  min-height: 100vh;
  justify-content: center;
  align-items: center;
  background-color: #ddd;
}

  .blazor-app-loader img {
    max-height: 200px;
    animation: rotation 2s infinite linear;
    margin: 1rem;
  }

@keyframes rotation {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(359deg);
  }
}

/*  Section Header Styles */
.sectionheader {
  border-bottom: 3px solid #9f9c9c;
  font-size: 1.25rem;
}


/*Screen Size Specific*/

@media (min-width: 768px) {

  .sticky-md-undernavbar {
    top: 70px;
  }
}

@media (min-width: 768px) {

  .sticky-md-under-form-header {
    top: 130px;
  }
}

.project-sticky {
  background-color: white;
  padding-top: .5rem;
  padding-bottom: .5rem;
  z-index: 9; /*Need to make sure this is smaller than the main navigation dropdown, also less than typeahead*/
}

.project-status-card {
  padding: .5rem;
  border-width: 2px;
  border-style: solid;
  font-size: 18pt;
  border-radius: 12px;
  margin-bottom: .5rem;
}

  .project-status-card:hover {
    font-weight: bold;
    background-color: #f2f2f2;
  }

.financials-sticky {
  /* below project-sticky height */
  top: 54px;
}

.list-view-sticky {
  /* below financials-sticky height */
  top: var(--list-view-sticky-buffer);
}

/* for awarded to active modal */
.modal .list-view-sticky {
  top: 0;
}

.list-view-sticky-no-totals {
  top: calc(var(--list-view-sticky-buffer) - 100px);
}


@media (min-width: 768px) {
  /* sticky-md-undernavbar + project-sticky height */
  .financials-sticky {
    top: calc(70px + 54px);
  }

  .financials-sticky-with-status {
    top: calc(70px + 114.5px);
  }

  .list-view-sticky {
    top: calc(50px + var(--list-view-sticky-buffer));
  }

  .list-view-sticky-no-totals {
    top: calc(var(--list-view-sticky-buffer) - 50px);
  }
}

.financials-sticky, .financials-sticky-with-status {
  background-color: white;
  z-index: 7; /*Need to make sure this is smaller than the main navigation dropdown, also less than typeahead*/
  padding-bottom: .5rem;
}

.list-view-sticky, .list-view-sticky-no-totals {
  background-color: white;
  z-index: 7; /*Need to make sure this is smaller than the main navigation dropdown, also less than typeahead*/
  padding-bottom: .5rem;
}

.project-card-truncate-text-button {
  overflow: hidden;
}

.project-card-truncate-text-text {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
  width: calc(100% - 30px);
}

.project-cards {
  max-height: 35rem;
  overflow-y: auto;
}

.header-container {
  padding: 20px 10px 5px 10px;
  border-bottom: 2px ridge deepskyblue;
}

.subdetail-text {
  color: #5c5c5c;
}

.nice-box-shadow {
  box-shadow: rgba(0, 0, 0, 0.2) 0px 1px 3px 3px;
}

  .nice-box-shadow:hover {
    box-shadow: rgba(0, 0, 0, 0.5) 0px 1px 3px 5px;
  }

.chart-container {
  display: flex;
}

.chart {
  height: 100%;
  width: 100%;
}

.line-chart {
  height: fit-content;
  min-height: 500px;
}

.line-chart-container-height {
  min-height: 500px;
}

.watermark {
  position: absolute;
  width: 110px;
  opacity: .15;
  z-index: 0;
}

.watermark-top-right-amcharts {
  margin-top: 4rem;
  right: 9rem;
}

.smaller-text {
  font-size: smaller !important;
}

.approval-box {
  background-color: #fff3d9 !important;
}

.btn-expandcollapse:hover {
  background-color: #9c9ea0;
  border-color: #9c9ea0;
}

.btn-expandcollapse {
  color: rgb(33, 37, 41);
  background-color: #c4c6c9;
  border-color: #c4c6c9;
  font-size: smaller;
}

  .btn-expandcollapse:focus {
    box-shadow: none !important;
    outline: 0px !important;
  }



.project-action {
  color: red;
  cursor: pointer;
}

.project-warning {
  color: #ffc107;
  cursor: pointer;
}

.project-success {
  color: #198754;
}

.color-swatch {
  width: 25px;
  height: 25px;
}

/* logo sizes ****************************************************************************************/
.logo-line-item {
  width: 1.1rem;
}

/* bootstrap overrides ********************************************************************************/
.modal-dialog {
  z-index: 1050 !important;
}

.btn-xs {
  --bs-btn-padding-y: .25rem;
  --bs-btn-padding-x: .5rem;
  --bs-btn-font-size: .75rem;
}

.btn-icon {
  --bs-btn-font-size: .75rem;
  --bs-btn-padding-y: .25rem;
  --bs-btn-padding-x: .25rem;
}

/* row colors for UI feedback ***************************************************/
.row-delete {
  background-color: var(--row-delete-background-color) !important;
}

.row-add {
  background-color: var(--row-add-background-color) !important;
}

.row-modify {
  background-color: var(--row-modify-background-color) !important;
}

.row-spliter {
  background-color: var(--row-spliter-background-color) !important;
}

.row-splitee {
  background-color: var(--row-splitee-background-color) !important;
}

/* USED BY Print function ONLY *************************************************************************/
@media print {
  @page {
    size: var(--pageOrientation);
  }
}

.hide-for-print {
}

/* dropdown component ***********************************************/
.dci-menu-dropdown .dropdown-menu {
  top: 100%;
}

/* table row highlight for validation ***********************************/
.row-warning {
  --bs-table-bg: #fff3cd;
}

.data-qualtity-flag {
  color: darkorange;
  cursor: pointer;
}

.input-field-side-button {
  margin-top: 1.5rem;
  margin-bottom: 1rem;
}

.chart-EAE {
  min-height: 600px !important;
}

.global-search-project-status-box {
  width: 6rem;
  height: calc(1.5em + .75rem + calc(var(--bs-border-width) * 2));
  padding: .5rem
}

.global-search-results-card {
  padding: .5rem;
  border: var(--bs-border-width) solid var(--dci-grid-border-color);
  font-size: 12pt;
  border-radius: 12px;
  margin-bottom: .5rem;
}

.global-search-result-card {
  border: var(--bs-border-width) solid var(--dci-grid-border-color);
  border-radius: 8px;
  margin-bottom: .5rem;
}

.global-search-result-project-card {
  border: var(--bs-border-width) solid;
  border-radius: 8px;
  margin-bottom: .5rem;
}

.global-search-result-card-text, .global-search-result-card-header {
  font-size: .875rem;
}

  .global-search-result-card-header:hover {
    cursor: pointer
  }

.global-search-result-subcategory-text {
  font-size: .875rem;
}


.mt-n3 {
  margin-top: -1rem;
}

.tooltip-trigger {
  position: relative;
  cursor: pointer;
  display: inline-block;
  border-bottom: 1px dotted black;
}


  .tooltip-trigger:focus {
    outline: 2px solid #555;
    outline-offset: 2px;
  }


  .tooltip-trigger:hover {
    text-decoration: underline dotted;
  }

.tooltip-text {
  position: fixed;
  z-index: 99999;
  display: block;
  visibility: visible;
  background: #fff;
  color: black;
  padding: 8px 10px;
  border-radius: 6px;
  max-width: 360px;
  word-wrap: break-word;
  box-sizing: border-box;
  font-size: 1rem;
  border: solid 1px black;
}

.logo-nav-item {
  height: 2.5rem;
}

.striped-container div:nth-child(odd) {
  background-color: var(--dci-grid-bg-striped-color);
}
.drag-handle {
    cursor: grab;
}

    .drag-handle:active {
        cursor: grabbing;
    }

.drag-icon {
    color: #BCBCBC;
}