@import "fontawesome/css/all.min.css";
@import "fonts.css";

:root, [data-bs-theme=light] {
    --bs-card-cap-bg: #FFF;
    --bs-primary: #824aff;
    /*--bs-primary-rgb: rgba(130, 74, 255, 1);*/
    --bs-nav-pills-link-active-bg: #824aff;
    --bs-link-color: #824aff;

    /* CRA */
    --cra-outline: grey;
    --cra-outline-used: var(--bs-primary);
    --cra-outline-disable: white;

    --cra-text-size: 0.75rem;
    --cra-text: black;
    --cra-text-disabled: darkgrey;
    --cra-text-sub: grey;

    --cra-line: darkgrey;
    --cra-background: white;
    --cra-arrow: var(--bs-primary);
    --cra-corrupted-background: orange;
    --cra-row-hover: rgba(0, 0, 0, .075);

    --sidebar-width: 280px;
    --sidebar-header-height: 79px;

}

.btn-primary {
    --bs-btn-bg: #824aff;
    --bs-btn-border-color: #824aff;
    --bs-btn-hover-bg: #6b3ed1;
    --bs-btn-hover-border-color: #6b3ed1;
    --bs-btn-active-bg: #6b3ed1;
    --bs-btn-active-border-color: #6b3ed1;
    --bs-btn-disabled-bg: #824aff;
    --bs-btn-disabled-border-color: #824aff;
}

.nav-pills {
    --bs-nav-pills-link-active-bg: #824aff;
}

.offcanvas {
    --bs-offcanvas-width: 700px;
}

#sidebar {
  --sidebar-width: 280px;
  position: fixed;
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  margin-top: var(--sidebar-header-height);
  padding: 0 1rem 1rem;
  color: #fff;
  background-color: RGBA(var(--bs-dark-rgb), var(--bs-bg-opacity, 1));
  height: calc(100vh - var(--sidebar-header-height));
  width: var(--sidebar-width);
  overflow-y: auto;
}

#sidebar {
  transition: all .12s ease;
}


#sidebar .home {
  position: fixed;
  display: flex;
  top: 0;
  left: 0;
  height: var(--sidebar-header-height);
  padding: 16px 1rem ;
  flex-grow: 0;
  flex-shrink: 0;
  background-color: RGBA(var(--bs-dark-rgb), var(--bs-bg-opacity, 1));
  width: var(--sidebar-width);
}
#sidebar .home button {
  display: none;
  border: none;
  background: unset;
  color: var(--bs-primary);
  font-size: 2em;
  align-items: center;
  justify-content: end;
}

#sidebar hr {
  margin-top: 0;
}

#sidebar ul {

}

#sidebar .nav-link:focus, #sidebar .nav-link:hover {
    background-color: #171717;
}

body {
    background-color: #f6f6f6;
    font-family: 'Inter-Regular', Arial, sans-serif;
}

h1, h2, h3, h4, h5, h6 {
    font-family: 'MonoLisa-Bold', serif;
}

.navbar-logo {
    width: 50px;
}

#page-container {
    padding: 20px 30px 20px calc(30px + var(--sidebar-width));
}

@media screen and (max-width: 1500px) {
  #sidebar {
    z-index: 100;
  }

  #sidebar.closed {
    margin-top: 0;
    height: 0;
  }

  #sidebar.closed .home {
    width: 100%;
  }

  #sidebar.closed hr {
    opacity: 0;
  }

  #sidebar .home button {
    display: flex;
  }
  #sidebar.closed .home button {
    transform: rotate(180deg);
  }

  #page-container {
    padding: calc(20px + var(--sidebar-header-height)) 30px 20px 30px;
  }
}

@media screen and (max-width: 900px) {
  #page-container {
    padding: calc(20px + var(--sidebar-header-height)) 5px 20px 5px;
  }
}

.card {
    background-color: white !important;
    box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.1);
    border: 1px solid #dcdcdc;
}

.card-header {
    background-color: #fff;
}

.card-title {
    text-transform: uppercase;
    font-weight: bold;
}

#dashboard .table {
    font-size: 14px !important;
}

#dashboard .table td:not(:last-child) {
    font-size: 12px !important;
}

.no-focus-effect:focus {
    outline: none !important;
    box-shadow: none;
    border-color: rgb(222, 226, 230);
}

.nav-icon {
    width: 25px;
}

#monthlyReportTable th, #monthlyReportTable td {
    min-width: 120px;
}

#monthlyReportTable th, #monthlyReportTable td,
#invoiceTable th, #invoiceTable td,
#payrollTable th, #payrollTable td,
#purchasesTable th, #purchasesTable td {
    white-space: nowrap;
}

#monthlyReportTable td:last-child {
    min-width: 150px;
}

.sticky-first th:first-child,
.sticky-first td:first-child {
    position: sticky;
    left: 0;
    background: #F5F5F5;
    z-index: 2;
}

.sticky-last th:last-child,
.sticky-last td:last-child {
    position: sticky;
    right: 0;
    background: #F5F5F5;
    z-index: 2;
}

.table-responsive {
    scrollbar-color: #F0F0F0 #FEFEFE;
    scrollbar-arrow-color: #FEFEFE;
    scrollbar-width: thin;
}

/* --- CRA --- */

.cra-frame {
    display: flex !important;
    flex-direction: column;
    flex-wrap: nowrap;
    align-content: center;
    align-items: center;
}

.cra-header {
    display: flex !important;
    align-items: center;
    justify-content: center;
    flex-wrap: nowrap;
    flex-direction: row;
    gap: 1vw;
    margin-bottom: 2vh;
}
.cra-header .form-select {
  width: fit-content;
}

.cra-grid {
    background: var(--cra-background);
    border: 1px solid var(--cra-line);
    border-radius: var(--bs-border-radius);
    overflow-x: auto;
    color: var(--cra-text);
    display: flex;
    flex-direction: column;
    position: relative;
}

.cra-grid-container {
  min-width: fit-content;
}
.cra-row {
    position: relative;
    display: flex;
    border-top: 1px solid var(--cra-line);
}

.cra-row:not(.cra-row--head):not(.cra-row--footer):hover {
    background-color: var(--cra-row-hover);
}

.cra-row--head {
    background: transparent;
    border-top: 0;
}

.cra-row--footer {
    background: rgba(255, 255, 255, 0.02);
}

.cra-cell {
    /*padding: .1rem .5rem;*/
    border-right: 1px solid var(--cra-line);
    /*min-height: 56px;*/
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    flex-direction: column;
    flex-shrink: 0;
}

.cra-row > .cra-cell:first-child {
    border-left: 0;
}

.cra-row .cra-cell:last-child {
    border-right: 0;
}

.cra-cell--head {
    text-transform: uppercase;
    font-size: 1rem;
    font-weight: 600;
    color: var(--cra-text);
}

.cra-cell--project {
    position: sticky;
    left: 0;
    z-index: 1;
    background: white;
    font-weight: 600;
    text-overflow: ellipsis;
    overflow: hidden;
    width: 200px;
    flex-grow: 0;
    flex-shrink: 0;
    margin-left: calc(var(--bs-gutter-x) * .5);
    margin-right: calc(var(--bs-gutter-x) * -.5);
    transform: translateX(calc(var(--bs-gutter-x) * -.5));
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
}
.cra-cell--project button {
  border: none;
  background: none;
  transition: all 0.2ms ease;
}
.cra-cell--project button:hover {
  color: var(--bs-primary);
}
.cra-cell--day {
  padding: 0 3px;
  flex-basis: 15%;
  flex-grow: 1;
  flex-shrink: 0;
}

.cra-cell--total {
    right: 0;
    font-weight: 600;
    width: 100px;
    flex-grow: 0;
    flex-shrink: 0;
}

.cra-cell--footlabel {
    font-weight: 700;
    padding-left: .75rem;
}

.cra-dayname {
    font-weight: 700;
    color: var(--cra-text);
    display: flex;
    gap: 5px;
    margin-left: 5px;
}
.cra-disable-info {
  display: flex;
  align-items: center;
}
.cra-disable-info .bg-warning {
  font-size: 0.65em;
}
.cra-daydate {
    font-size: .75rem;
    color: var(--cra-text-sub);
    margin-left: 5px;
    margin-top: .125rem;
}

.cra-parts {
    display: flex;
    justify-content: space-between;
}
.cra-part {
    border: none;
    background: none;
    padding: 0 1px;
}
.cra-part span {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 20px !important;
    height: 20px;
    border: 1px solid transparent;
    background: transparent;
    color: var(--cra-text-sub);
    /*border-radius: 1rem;*/
    border-radius: 0.2rem;
    font-size: var(--cra-text-size);
    transition: transform .12s ease, background-color .12s ease, border-color .12s ease, color .12s ease;
    cursor: pointer;
    width: inherit;
}
.cra-part:not(:first-child) {
    margin-left: -1px;
}

.cra-part:hover span {
    border-color: var(--cra-outline-used);
    color: var(--cra-text);
}

.cra-part--corrupt span {
    background-color: var(--cra-corrupted-background) !important;
}

.cra-part--used span {
    background: linear-gradient(180deg, rgba(79, 70, 229, .22), rgba(79, 70, 229, .12));
    /*border-color: var(--bs-white);*/
    color: transparent;
}

.cra-part--used.cra-part--selected span {
  color: var(--cra-text);
}

.cra-part--disabled span,
.cra-part--force-disabled,
.cra-part--force-disabled span {
    cursor: not-allowed;
    color: var(--cra-text-disabled);
    /*border-color: var(--cra-outline-disable);*/
    background: rgba(148, 163, 184, .3);
    opacity: 0.3;
}

.cra-badge {
    text-align: center;
    font-weight: 700;
    border-radius: .5rem;
    /*background: rgba(79, 70, 229, .18);*/
    /*border: 1px solid var(--cra-outline-used);*/
    color: var(--bs-primary);
}

.cra-project {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 0.75em ;
    padding: 0 5px;
    max-width: 100%;
    flex-grow: 1;
}

.cra-disable-text {
    font-weight: 600;
}

.cra-arrow {
    color: var(--cra-arrow);
}


@media screen and (max-width: 900px) {
  .cra-part:not(.cra-part--selected) {
    display: none;
  }

  .cra-cell--day.cra-cell--head {
    padding-top: 5px;
    padding-bottom: 5px;
    writing-mode: vertical-lr;
  }

  .cra-cell--day.cra-cell--head > div {
    transform: rotate(180deg);
  }

  .cra-cell--day {
    flex-basis: 11%;
  }
  .cra-parts.cra-opened {
    position: absolute;
    background: white;
    border: 1px solid var(--bs-primary);
    border-radius: var(--bs-border-radius);
    padding: 5px;
    width: 340px !important;
    left: 0px;
    bottom: -100%;
    z-index: 50;
  }

  .cra-parts.cra-opened .cra-part span {
    height: 35px;
    width: 35px !important;
  }

  .cra-cell--day:has(.cra-parts.cra-opened) {
    background: var(--bs-primary);
  }

  .cra-parts.cra-opened .cra-part:not(.cra-part--selected) {
    display: flex;
  }

  .cra-row--footer {
    font-size: 0.75em;
  }

  .cra-parts {
    justify-content: center;
  }
  .cra-dayname {
    font-size: 0.65em;
    margin-left: 0px;
    margin-bottom: 0px;
  }
  .cra-daydate {
    margin: 0;
  }

  .cra-cell .badge.bg-warning {
    color: rgba(var(--bs-warning-rgb),var(--bs-bg-opacity))!important;
    background: none !important;
    padding: 0;
  }
  .cra-cell.cra-cell--project {
    flex-direction: column;
    align-items: flex-end;
    padding: 0 5px;
    width: 140px;
  }

  .cra-part--used span {
    color: var(--cra-text);
  }
}

#page-content {
    display: flex;
    flex-direction: column;
    height: 100%;
}

#list-container {
    flex-grow: 1;
    overflow: auto;
    padding-bottom: 90px;
}

#list-container::-webkit-scrollbar {
    width: 0;
}

.form-check-input:checked {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
}

.form-switch {
    margin-top: .125rem;
    padding-left: 3em;
}

.form-switch .form-check-input{
    transform: scale(1.5);
}

.nav-link:not(.active) {
    color: var(--bs-gray-600);
}

.select2-container--bootstrap-5 .select2-dropdown.select2-dropdown--below {
    left: -1px;
    position: relative;
    box-shadow: 0.25em 0.25em rgba(13, 110, 253, .25), -0.25em 0.25rem rgba(13, 110, 253, .25);
}


.select2-container--bootstrap-5 .select2-dropdown .select2-results__options .select2-results__option.select2-results__option--selected,
.select2-container--bootstrap-5 .select2-dropdown .select2-results__options .select2-results__option[aria-selected=true]:not(.select2-results__option--highlighted) {
    background-color: var(--bs-primary);
    color: white;
}

.uploadComponent {
    background-color: var(--bs-dark);
    outline: 2px dashed var(--bs-primary);
    color: var(--bs-white);
    border-radius: var(--bs-border-radius);
    padding: 20px;
    text-align: center;
    cursor: pointer;
    transition: all 0.3s;
}

.uploadComponent:hover {
    background-color: var(--bs-primary);
    border-color: var(--bs-white);
    outline: 2px dashed var(--bs-white);
    color: var(--bs-dark);
}

.uploadComponent input { display: none; }

.uploadComponent label {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    padding: 10px 20px;
}

.actionLink {
    margin-left: 1rem;
    cursor: pointer;
    text-decoration: underline;
    transition: all 0.3s;
}

.actionLink:hover {
    color: var(--bs-primary);
}

.employee-cra-head {
    border-top : 2px solid var(--bs-dark);
    border-bottom : 1px solid var(--bs-gray-500);
}
.cra-endofweek {
    border-right: 1px solid var(--bs-gray-300);
}

.accordion-item .inactiveClient,
.accordion-item .activeClient,
.accordion-item .inactiveProject,
.accordion-item .activeProject {
    display: none;
}


.accordion-item .inactiveClient button,
.accordion-item .inactiveProject button {
    color: var(--cra-text-sub) !important;
}

.show-open-client .activeClient,
.show-closed-client .inactiveClient,
.show-open-project .activeProject,
.show-closed-project .inactiveProject
{
    display: initial;
}

#accordionAgencies .filterButtons {
    display: flex;
    justify-content: space-between;
    margin-bottom: 10px;
}

#accordionAgencies .filterButtons button {
    color: var(--cra-text-sub);
    border: none;
    background: none;
}

#accordionAgencies.show-closed-client .filterButtons button.inactiveClient,
#accordionAgencies.show-open-client .filterButtons button.activeClient,
#accordionAgencies.show-closed-project .filterButtons button.inactiveProject,
#accordionAgencies.show-open-project .filterButtons button.activeProject {
    color: var(--bs-primary);
}

#accordionAgencies .filterButtons button:hover {
    color: var(--bs-btn-hover-bg) !important;
}

#projectContainer {
    position: sticky;
    top : var(--sidebar-header-height);
    overflow-y: auto;
    height: calc(100vh - var(--sidebar-header-height));
}