:root {
  --font-inter: "Inter";
}

@supports (font-variation-settings: normal) {
  :root {
    --font-inter: "InterVariable";
  }
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-inter), sans-serif;
  font-optical-sizing: auto;
}

:root,
[data-bs-theme="light"] {
  --bs-blue: #0d6efd;
  --bs-indigo: #6610f2;
  --bs-purple: #6f42c1;
  --bs-pink: #d63384;
  --bs-red: #dc3545;
  --bs-orange: #fd7e14;
  --bs-yellow: #ffc107;
  --bs-green: #198754;
  --bs-teal: #20c997;
  --bs-cyan: #0dcaf0;
  --bs-black: #000;
  --bs-white: #fff;
  --bs-gray: #6c757d;
  --bs-gray-dark: #343a40;
  --bs-gray-100: #f8f9fa;
  --bs-gray-200: #e9ecef;
  --bs-gray-300: #dee2e6;
  --bs-gray-400: #ced4da;
  --bs-gray-500: #adb5bd;
  --bs-gray-600: #6c757d;
  --bs-gray-700: #495057;
  --bs-gray-800: #343a40;
  --bs-gray-900: #212529;
  --bs-primary: #0d6efd;
  --bs-secondary: #6c757d;
  --bs-success: #198754;
  --bs-info: #0dcaf0;
  --bs-warning: #ffc107;
  --bs-danger: #dc3545;
  --bs-light: #f8f9fa;
  --bs-dark: #212529;
  --bs-primary-rgb: 13, 110, 253;
  --bs-secondary-rgb: 108, 117, 125;
  --bs-success-rgb: 25, 135, 84;
  --bs-info-rgb: 13, 202, 240;
  --bs-warning-rgb: 255, 193, 7;
  --bs-danger-rgb: 220, 53, 69;
  --bs-light-rgb: 248, 249, 250;
  --bs-dark-rgb: 33, 37, 41;
  --bs-primary-text-emphasis: #052c65;
  --bs-secondary-text-emphasis: #2b2f32;
  --bs-success-text-emphasis: #0a3622;
  --bs-info-text-emphasis: #055160;
  --bs-warning-text-emphasis: #664d03;
  --bs-danger-text-emphasis: #58151c;
  --bs-light-text-emphasis: #495057;
  --bs-dark-text-emphasis: #495057;
  --bs-primary-bg-subtle: #cfe2ff;
  --bs-secondary-bg-subtle: #e2e3e5;
  --bs-success-bg-subtle: #d1e7dd;
  --bs-info-bg-subtle: #cff4fc;
  --bs-warning-bg-subtle: #fff3cd;
  --bs-danger-bg-subtle: #f8d7da;
  --bs-light-bg-subtle: #fcfcfd;
  --bs-dark-bg-subtle: #ced4da;
  --bs-primary-border-subtle: #9ec5fe;
  --bs-secondary-border-subtle: #c4c8cb;
  --bs-success-border-subtle: #a3cfbb;
  --bs-info-border-subtle: #9eeaf9;
  --bs-warning-border-subtle: #ffe69c;
  --bs-danger-border-subtle: #f1aeb5;
  --bs-light-border-subtle: #e9ecef;
  --bs-dark-border-subtle: #adb5bd;
  --bs-white-rgb: 255, 255, 255;
  --bs-black-rgb: 0, 0, 0;
  --bs-body-font-size: 0.875rem;
  --bs-font-sans-serif:
    var(--font-inter), system-ui, "Source Sans Pro", Helvetica, Arial,
    sans-serif;
  --bs-font-monospace:
    SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New",
    monospace;
  --bs-gradient: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.15),
    rgba(255, 255, 255, 0)
  );
  --bs-body-font-family: var(--bs-font-sans-serif);
  --bs-body-font-size: 0.875rem;
  --bs-body-font-weight: 400;
  --bs-body-line-height: 1.5;
  --bs-body-color: #212529;
  --bs-body-color-rgb: 33, 37, 41;
  --bs-body-bg: #fff;
  --bs-body-bg-rgb: 255, 255, 255;
  --bs-emphasis-color: #000;
  --bs-emphasis-color-rgb: 0, 0, 0;
  --bs-secondary-color: rgba(33, 37, 41, 0.75);
  --bs-secondary-color-rgb: 33, 37, 41;
  --bs-secondary-bg: #e9ecef;
  --bs-secondary-bg-rgb: 233, 236, 239;
  --bs-tertiary-color: rgba(33, 37, 41, 0.5);
  --bs-tertiary-color-rgb: 33, 37, 41;
  --bs-tertiary-bg: #f8f9fa;
  --bs-tertiary-bg-rgb: 248, 249, 250;
  --bs-heading-color: inherit;
  --bs-link-color: #0d6efd;
  --bs-link-color-rgb: 13, 110, 253;
  --bs-link-decoration: underline;
  --bs-link-hover-color: #0a58ca;
  --bs-link-hover-color-rgb: 10, 88, 202;
  --bs-code-color: #d63384;
  --bs-highlight-color: #212529;
  --bs-highlight-bg: #fff3cd;
  --bs-border-width: 1px;
  --bs-border-style: solid;
  --bs-border-color: #dee2e6;
  --bs-border-color-translucent: rgba(0, 0, 0, 0.175);
  --bs-border-radius: 0.375rem;
  --bs-border-radius-sm: 0.25rem;
  --bs-border-radius-lg: 0.5rem;
  --bs-border-radius-xl: 1rem;
  --bs-border-radius-xxl: 2rem;
  --bs-border-radius-2xl: var(--bs-border-radius-xxl);
  --bs-border-radius-pill: 50rem;
  --bs-box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
  --bs-box-shadow-sm: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
  --bs-box-shadow-lg: 0 1rem 3rem rgba(0, 0, 0, 0.175);
  --bs-box-shadow-inset: inset 0 1px 2px rgba(0, 0, 0, 0.075);
  --bs-focus-ring-width: 0.25rem;
  --bs-focus-ring-opacity: 0.25;
  --bs-focus-ring-color: rgba(13, 110, 253, 0.25);
  --bs-form-valid-color: #198754;
  --bs-form-valid-border-color: #198754;
  --bs-form-invalid-color: #dc3545;
  --bs-form-invalid-border-color: #dc3545;
}

main {
  height: 100vh;
}

.bg-primary-gradient {
  background: linear-gradient(
    135deg,
    rgb(0, 0, 0) 0%,
    #0b4bac 69%,
    #0d6efd 89%
  );
}

.form-control,
.form-select,
.input-group-sm > .form-control {
  border-radius: 0.5rem;
}

.form-control:focus,
.form-select:focus {
  border: 1px solid var(--bs-primary);
  box-shadow: var(--bs-box-shadow);
}

label.required::after {
  content: " *";
  color: red;
  margin-left: 4px;
}

.form-control::placeholder {
  font-size: small;
  font-style: italic;
  color: #b0b0b0;
}

.form-select::placeholder {
  font-size: small;
  font-style: italic;
  color: #b0b0b0;
}

.select2-container--bootstrap-5 .select2-selection__placeholder {
  font-size: small;
  font-style: italic;
  color: #b0b0b0;
}

.btn {
  border-radius: 0.5rem;
}

.nav {
  --bs-nav-link-padding-x: 1rem;
  --bs-nav-link-padding-y: 0.35rem;
}
.nav-pills {
  --bs-nav-pills-border-radius: var(--bs-border-radius-lg);
  gap: 5px;
}

.select2-container--bootstrap-5 .select2-selection {
  border-radius: 0.5rem;
}

.select2-container--bootstrap-5
  .select2-dropdown
  .select2-search
  .select2-search__field:focus {
  border: 1px solid var(--bs-primary);
  box-shadow: var(--bs-box-shadow);
}

.select2-container--bootstrap-5.select2-container--focus .select2-selection,
.select2-container--bootstrap-5.select2-container--open .select2-selection {
  border: 1px solid var(--bs-primary);
  box-shadow: var(--bs-box-shadow);
}

.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);
}

.select2-container--bootstrap-5 .bill-dropdown .select2-results__option {
  font-size: 10px !important;
}

.form-select-sm ~ .select2-container--bootstrap-5 .select2-selection {
  border-radius: 0.5rem;
}

.select2-container--bootstrap-5 .select2-dropdown {
  border-color: var(--bs-primary);
  border-radius: 0.5rem;
}

.select2-search__field {
  border-radius: 0.5rem;
  height: 30px;
}

table.dataTable input.dt-select-checkbox {
  width: 15px;
  height: 15px;
  font-size: 24px;
}

table.dataTable input.dt-select-checkbox:indeterminate:after {
  top: 4px;
  left: 4px;
  width: 5px;
  height: 5px;
}

table.dataTable thead > tr > th {
  color: rgb(108, 117, 125);
  font-size: 13.2px;
  text-transform: uppercase;
}

table.table.dataTable > tbody > tr.selected > * {
  box-shadow: inset 0 0 0 9999px #857575f2 !important;
}

.dt-disabled .dt-select {
  cursor: not-allowed;
}

.dt-disabled input.dt-select-checkbox {
  background-color: #d0d3d6 !important;
  cursor: not-allowed;
  opacity: 0.5;
}

.page-link:focus {
  box-shadow: var(--bs-box-shadow);
}

.badge.bg-danger {
  background-color: rgb(244 62 92 / 0.2) !important;
  color: rgb(185 28 28 / 0.8) !important;
  border: 1px solid rgb(220 38 38 / 0.1) !important;
}

.badge.bg-success {
  background-color: rgb(34 197 94 / 0.2) !important;
  color: rgb(21 128 61 / 0.8) !important;
  border: 1px solid rgb(22 163 74 / 0.2) !important;
}

.badge.bg-info {
  background-color: rgb(59 130 246 / 0.2) !important;
  color: rgb(29 78 216 / 0.8) !important;
  border: 1px solid rgb(29 78 216 / 0.1) !important;
}

.badge.bg-warning {
  background-color: rgb(234 179 8 / 0.2) !important;
  color: rgb(133 77 14 / 0.8) !important;
  border: 1px solid rgb(202 138 4 / 0.2) !important;
}

.badge.bg-pink {
  background-color: rgb(236 72 153 / 0.2) !important;
  color: rgb(190 24 93 / 0.8) !important;
  border: 0.1px solid rgb(190 24 93 / 0.1) !important;
}

.badge.bg-indigo {
  background-color: rgb(168 85 247 / 0.2) !important;
  color: rgb(126 34 206 / 0.8) !important;
  border: 1px solid rgb(126 34 206 / 0.1) !important;
}

.badge.bg-orange {
  background-color: rgb(249 115 22 / 0.2) !important;
  color: rgb(194 65 12 / 0.8) !important;
  border: 1px solid rgb(194 65 12 / 0.1) !important;
}

.badge.bg-light {
  background-color: rgba(107, 128, 109, 0.2) !important;
  color: rgb(75, 99, 77 / 0.8) !important;
  border: 1px solid rgba(107, 128, 107, 0.1) !important;
}

.badge.bg-gray {
  background-color: rgb(156 163 175 / 0.2) !important;
  color: rgb(75 85 99 / 1) !important;
  border: 1px solid rgb(75 85 99 / 0.1) !important;
}

.bg-color-blue {
  background-color: #c2e2ff !important;
}

.bg-color-blue > div {
  color: #4099ff !important;
}

.bg-color-green {
  background-color: #c2f7e8 !important;
}

.bg-color-green > div {
  color: #28bea0 !important;
}

.bg-color-yellow {
  background-color: #fff3c0 !important;
}

.bg-color-yellow > div {
  color: #ffb041 !important;
}

.bg-color-pink {
  background-color: #ffd6e5 !important;
}

.bg-color-pink > div {
  color: #db2777 !important;
}

.bg-color-purple {
  background-color: #f0e6ff !important;
}

.bg-color-purple > div {
  color: #845ef7 !important;
}

.bg-color-orange {
  background-color: rgb(249 115 22 / 0.2) !important;
}

.bg-color-orange > div {
  color: rgb(194 65 12 / 1) !important;
}

.bg-color-red {
  background-color: #ffd6e5 !important;
}

.bg-color-red > div {
  color: #fc2549 !important;
}

.bg-red {
  background-color: rgb(244 62 92 / 0.2) !important;
  border: 1px solid rgb(220 38 38 / 0.1) !important;
}

.bg-open {
  background-color: rgb(255 165 0 / 0.1) !important;
  border: 1px solid rgb(255 165 0 / 0.2) !important;
}

.bg-inprogress {
  background-color: rgb(0 123 255 / 0.1) !important;
  border: 1px solid rgb(0 123 255 / 0.2) !important;
}

.bg-closed {
  background-color: rgb(40 167 69 / 0.1) !important;
  border: 1px solid rgb(40 167 69 / 0.2) !important;
}

.text-orange {
  color: rgb(194 65 12 / 1) !important;
}

/* Toast */

#message-container {
  position: fixed;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 9999;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}

.message {
  display: flex;
  align-items: start;
  padding: 12px 20px;
  border-radius: 6px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  min-width: 300px;
  max-width: 90%;
  opacity: 0;
  transform: translateY(-20px);
  animation: slideFadeIn 0.4s ease forwards;
  transition:
    opacity 0.5s ease,
    transform 0.3s ease,
    margin 0.3s ease,
    max-height 0.3s ease;
  position: relative;
  gap: 5px;
  max-height: 100px;
  overflow: hidden;
}

@keyframes slideFadeIn {
  0% {
    opacity: 0;
    transform: translateY(-20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

.message i {
  font-size: 18px;
}

.message-success,
.message-error,
.message-info,
.message-warning {
  background-color: white;
}

.selected {
  background-color: #e6ffe6 !important;
}

.nav-link.collapsed .fa-angle-down {
  transform: rotate(0deg);
  transition: transform 0.3s;
}

.nav-link:not(.collapsed) .fa-angle-down {
  transform: rotate(-180deg);
}

.textarea-table {
  padding: 0px;
  border: none;
  background: transparent;
  outline: none;
  width: 100%;
  height: 21px;
}

.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.selected.inRange,
.flatpickr-day.startRange.inRange,
.flatpickr-day.endRange.inRange,
.flatpickr-day.selected:focus,
.flatpickr-day.startRange:focus,
.flatpickr-day.endRange:focus,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange:hover,
.flatpickr-day.endRange:hover,
.flatpickr-day.selected.prevMonthDay,
.flatpickr-day.startRange.prevMonthDay,
.flatpickr-day.endRange.prevMonthDay,
.flatpickr-day.selected.nextMonthDay,
.flatpickr-day.startRange.nextMonthDay,
.flatpickr-day.endRange.nextMonthDay {
  background-color: var(--bs-primary) !important;
  color: white !important;
}

/* Login password eye toggle */
.password-toggle {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: #6c757d;
  cursor: pointer;
  padding: 0;
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.password-toggle:hover {
  color: #495057;
}

.password-input-wrapper {
  position: relative;
}

.password-input-wrapper .form-control {
  padding-right: 40px;
}

.announcement-container {
  position: fixed;
  bottom: 4px;
  right: 4px;
  max-width: 312px;
  background-color: #e3f7fd;
  border: 1px solid #9cdbff;
  padding: 8px 12px;
  border-radius: 0.5rem;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  z-index: 1000;
  overflow: hidden;
}

.announcement-text {
  white-space: nowrap;
  /* color: #15c01d; */
  font-weight: 500;
  display: inline-block;
  animation: scroll-left 12s linear infinite;
}

.announcement-container:hover .announcement-text {
  animation-play-state: paused;
}

@keyframes scroll-left {
  0% {
    transform: translateX(100%);
  }

  100% {
    transform: translateX(-100%);
  }
}

@media (min-width: 768px) {
  .w-md-50 {
    width: 50% !important;
  }
}

/* Task style */

.task-board-wrapper {
  height: calc(100vh - 15px);
  overflow: hidden;
}

.task-board {
  display: flex;
  min-width: 1000px;
  height: 100%;
}

.task-column {
  flex: 0 0 32.8%;
  max-width: 32.8%;
  display: flex;
  flex-direction: column;
  height: 100%;
  border-top-left-radius: 1rem;
  border-top-right-radius: 1rem;
}

.task-column > .d-flex {
  position: sticky;
  top: 0;
  z-index: 10;
  /* background: white; */
  padding: 0.5rem 0;
}

.cards-area {
  overflow-y: auto;
  flex-grow: 1;
  padding: 0.5rem;
}

#tableView .table-responsive {
  max-height: calc(100vh - 17px);
  overflow-y: auto;
  overflow-x: auto;
}

#tasksTable thead th {
  position: sticky;
  top: 0;
  background-color: #fff;
  z-index: 1;
}

#tasksTable_wrapper > div:nth-child(3) {
  position: sticky;
  bottom: 0;
  background-color: #fff;
  z-index: 1;
}

#filterForm {
  position: relative;
  z-index: 1;
}

@media (max-width: 991.98px) {
  .task-board-wrapper {
    overflow-x: auto;
    overflow-y: auto;
  }

  #tasksTable thead,
  #tasksTable tbody {
    width: 100%;
  }

  .task-board {
    flex-wrap: nowrap;
    min-width: unset;
    overflow-x: auto;
  }

  .task-column {
    flex: 0 0 100%;
    max-width: 100%;
    height: auto;
  }
}

.carousel-item img {
  display: block;
  object-fit: cover;
  border-radius: 1px 1px 0px 0px;
  object-position: center 50%;
}

/* ---------- */
.task-card {
  cursor: pointer;
}
.task-card:active {
  cursor: grabbing;
  opacity: 0.5;
}

.task-card > .card-body {
  padding: 0.75rem;
}

.task-subject {
  font-size: 14px;
  font-weight: 500;
}

.text-truncate-3 {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 12px;
  font-weight: 400;
  color: #6c757d;
  margin-bottom: 0;
}

/* make the next and previous icons of carousel more visible */
.carousel-control-prev-icon,
.carousel-control-next-icon {
  background-color: rgba(0, 0, 0, 0.5);
  border-radius: 50%;
  width: 30px;
  height: 30px;
  background-size: 70%;
}
