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

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

html {
  /* font-size: 16px; */
  scroll-behavior: smooth;
}

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

:root,
[data-bs-theme="light"] {
  --bs-primary: #8b0202;
  --bs-primary-rgb: 0, 0, 0, 0;
  --bs-info-rgb: 22, 119, 255;
  --bs-primary-text-emphasis: #5e0303;
  --bs-primary-bg-subtle: #fdd5d5;
  --bs-primary-border-subtle: #ff9c9c;
  --bs-body-font-size: 0.875rem;
  --bs-font-sans-serif: var(--font-inter), system-ui, sans-serif;
  --bs-box-shadow: 0 0 0 0.25rem rgba(159, 1, 1, 0.15);
  --bs-link-color: #fff;
  --bs-link-hover-color: #fff;
  --bs-nav-pills-link-active-color: #fff;
  --bs-dropdown-link-active-bg: #8b0202;

  --bs-btn-bg: #8b0202;
  --bs-btn-border-color: #8b0202;
  --bs-btn-hover-bg: #970000;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-border-color: #8a0000;
  --bs-btn-focus-shadow-rgb: 0, 0, 0, 0;
  --bs-btn-active-bg: #c90000;
  --bs-btn-active-color: #fff;
  --bs-btn-active-border-color: #c20b0b;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-bg: #8b0202;
  --bs-btn-disabled-border-color: #8b0202;

  --dt-row-selected: 139, 2, 2;
}

main {
  height: 100vh;
}

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

.btn-primary {
  --bs-btn-bg: #8b0202;
  --bs-btn-border-color: #8b0202;
  --bs-btn-hover-bg: #970000;
  --bs-btn-hover-border-color: #8a0000;
  --bs-btn-focus-shadow-rgb: 0, 0, 0, 0;
  --bs-btn-active-bg: #c90000;
  --bs-btn-active-border-color: #c20b0b;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-bg: #8b0202;
  --bs-btn-disabled-border-color: #8b0202;
}

.btn-outline-primary {
  --bs-btn-color: #8b0202;
  --bs-btn-border-color: #8b0202;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #8b0202;
  --bs-btn-hover-border-color: #8b0202;
  --bs-btn-focus-shadow-rgb: 13, 110, 253;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #8b0202;
  --bs-btn-active-border-color: #8b0202;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #8b0202;
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: #8b0202;
  --bs-gradient: none;
}

.dropdown-item.active,
.dropdown-item:active {
  background-color: #8b0202;
}

.toast {
  --bs-toast-box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
}

.nav-pills {
  --bs-nav-pills-link-active-bg: #5e0303;
}

.pagination {
  --bs-pagination-active-bg: #8b0202;
  --bs-pagination-active-border-color: #8b0202;
  --bs-pagination-active-color: #fff;
  --bs-pagination-hover-bg: #970000;
  --bs-pagination-hover-border-color: #8b0202;
  --bs-pagination-hover-color: #fff;
  --bs-pagination-bg: #fff;
  --bs-pagination-border-color: #8b0202;
  --bs-pagination-color: #8b0202;
}

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

.form-check-input:checked {
  background-color: #8b0202;
  border-color: #8b0202;
}

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

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

/* 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: #8b0202 !important;
  color: white !important;
}
