@import url("https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300..800;1,300..800&display=swap");

/* Centralized palette for style.css.
   Brand / surface / text / semantic tokens are defined in alliance/alliance.css.
   The names below are file-local convenience for legacy values that don't have
   an alliance equivalent — referenced via var() throughout this file so colors
   stay in one place. */
:root {
  --style-white: var(--gray-0);
  --style-soft-white: var(--gray-1);
  --style-text-dark: var(--gray-7);
  --style-graphite-deep: var(--gray-10);
  --style-graphite-mid: var(--gray-8);
  --style-input-border-light: var(--gray-5);
  --style-link-blue: var(--info);
  --style-success: var(--success);
  --style-danger: var(--danger);
  --style-warning: var(--warning);
  --style-alert-rose: var(--danger);
  --style-alert-coral: var(--danger);
  --style-text-muted: var(--gray-6);
  --style-text-mid: var(--gray-5);
  --style-vuexy-light-border: var(--gray-3);
  --style-vuexy-soft-purple-text: var(--gray-4);
  --style-deep-red: var(--danger);
  --style-slate-blue-deep: var(--primary);
  --style-text-light: var(--gray-10);
  --style-disabled-bg: var(--gray-6);
}

* {
  margin: 0px;
  padding: 0px;
  box-sizing: border-box;
  font-family: "Open Sans", sans-serif;
}

/* Fix duplicate icon issue - hide ::before pseudo-element when <i> tag exists */
.menu-sub .menu-link:has(> i)::before {
  display: none !important;
}

.menu-inner > .menu-item .menu-sub .menu-link:has(> i)::before {
  display: none !important;
}

::selection {
  background-color: var(--primary);
  color: var(--style-white);
}
.bg-menu-theme.menu-vertical .menu-sub > .menu-item > .menu-link:before {
  left: 3rem;
}

.menu-vertical .menu-sub .menu-sub .menu-link {
  padding-left: 4.4rem;
}

html {
  /* font-size: 12px;
    height: 100%;
    letter-spacing: 0.01rem; */
}

.dark-style body {
  color: var(--style-white);
  background-color: var(--style-graphite-deep);
  font-size: 1rem;
  /* overflow-x: hidden; */
  /* font-size: 1.16rem; */
}

.light-style body {
  color: var(--style-text-dark);
  background-color: var(--surface-base);
  font-size: 1rem;
  /* overflow-x: hidden; */
  /* font-size: 1.16rem; */
}

/* .text-white {
  color: var(--text-white) !important;
} */
.light-style .text-white {
  color: var(--style-text-dark) !important;
}

.light-style hr.text-white {
  color: var(--gray-6) !important;
}

.bg-menu-theme.menu-vertical .menu-item.active>.menu-link:not(.menu-toggle) {
  /* color: var(--primary) !important; */
  color: var(--text-white) !important;
}

.bg-menu-theme .menu-item.open:not(.menu-item-closing)>.menu-toggle,
.bg-menu-theme .menu-inner .menu-item.active>.menu-link.menu-toggle {
  /* background-color: var(--style-white); */
}

.bg-menu-theme .menu-inner .menu-item.active>.menu-link.menu-toggle {
  background: var(--primary);
  color: var(--text-white) !important;
}

/* Keep active parent background when menu is collapsed and opened on hover */
.layout-menu-hover.layout-menu-collapsed
  .bg-menu-theme
  .menu-inner
  .menu-item.active
  > .menu-link.menu-toggle {
  background: var(--primary);
  color: var(--text-white) !important;
}

.bg-menu-theme .menu-item.active>.menu-link {
  /* color: #000000 !important; */
  color: var(--text-white) !important;
}


div.dataTables_processing>div:last-child>div {
  /* background-color: var(--light-primary); */
  background-color: var(--primary);
}

.light-style .input-group:focus-within .form-control,
.light-style .input-group:focus-within .input-group-text {
  /* border-color: var(--light-primary) !important; */
  border: 1px solid var(--style-success) !important;
  box-shadow: inset 0 0 0 1px var(--style-success);
}

.dark-style .input-group:focus-within .form-control,
.dark-style .input-group:focus-within .input-group-text {
  /* border-color: var(--light-primary) !important; */
  border-color: var(--style-white) !important;
}

.light-style .select2-container--default.select2-container--focus .select2-selection,
.light-style .select2-container--default.select2-container--open .select2-selection {
  /* border-color: var(--light-primary) !important; */
  border: 1px solid var(--style-success) !important;
  box-shadow: inset 0 0 0 1px var(--style-success);
}

.select2-container--default .select2-results__option--highlighted:not([aria-selected=true]) {
  background-color: var(--primary-soft) !important;
  color: var(--primary) !important;
}

.light-style .form-control:focus,
.light-style .form-select:focus {
  border: 1px solid var(--style-success) !important;
  box-shadow: inset 0 0 0 1px var(--style-success) !important;
  /* border-color: var(--light-primary) !important; */
  box-shadow: none;
}

.dark-style .form-control:focus,
.dark-style .form-select:focus {
  border-color: var(--style-white) !important;
  /* border-color: var(--light-primary) !important; */
  box-shadow: none;
}

.btn-check:focus+.btn-primary,
.btn-primary:focus,
.btn-primary.focus {
  color: var(--text-white) !important;
}

.text-muted-query {
  color: var(--light-primary) !important;
}

.dark-style .menu-vertical .app-brand {
  background-color: var(--style-text-light) !important;
  padding: 0 0.875rem 0 1rem;
  margin: 0px;
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
}

.light-style .menu-vertical .app-brand {
  box-shadow: none !important;
  background-color: var(--style-white) !important;
  padding: 0 0.875rem 0 1rem;
  margin: 0px;
}

.dark-style .menu-vertical .menu-inner {
  background-color: var(--style-text-light) !important;
}

.dark-style .bg-menu-theme .menu-inner .menu-item:not(.active)>.menu-link:hover {
  background: var(--primary-soft) !important;
}

.dark-style .bg-menu-theme .menu-inner .menu-item.open>.menu-link.menu-toggle {
  background: var(--primary) !important;
  color: var(--style-white) !important;
}

.menu-vertical .menu-inner>.menu-item {
  margin: 0.3rem 0rem;
  /* margin: 0.25rem 0rem; */
}

.dark-style .menu-vertical .menu-inner>.menu-item .menu-link {
  background: transparent;
  /* background: var(--style-soft-white); */
  color: var(--style-white);
  font-weight: 500;
  font-size: 1rem;
}

.menu-vertical .menu-inner {
  /* background-color: #003554; */
  background-color: var(--style-white);
}

.menu-vertical .menu-inner>.menu-item .menu-link {
  /* background: #FFFFFF33; */
  /* color: var(--style-white); */
  /* color: var(--style-text-muted); */
  /* color: #FFFFFF1A;
  background: var(--style-white); */
  font-weight: 500;
  font-size: 1rem;
}

.main-menu.menu-light .navigation li a:hover {
  background-color: var(--gray-1);
  border-radius: 4px;
}

.layout-navbar-fixed .layout-wrapper:not(.layout-horizontal) .layout-page:before {
  height: 4.3rem;
  background: none;
  backdrop-filter: none;
}

.select2-results__option[role=option][aria-selected=true] {
  background-color: var(--primary);
  color: var(--style-white);
}

.content-footer {
  display: none;
}

/* Grants admin vertical tabs */
.grants-stepper-card {
  border: none;
  border-radius: 12px;
  background-color: #fff;
  width: -webkit-fill-available;
  display: inline-block;
}
.light-style .grants-stepper-card {
  background-color: #ffffff;
}
.dark-style .grants-stepper-card {
  background-color: #3a3a3a;
}
.grants-stepper-card .card-body {
  padding: 0;
}
.grants-stepper-card .nav {
  width: auto;
  gap: 0.25rem;
}
.grants-stepper-link {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  width: 100%;
  border-radius: 10px;
  padding: 0.60rem 1rem;
  color: #6f6b7d;
  text-decoration: none;
}
.grants-stepper-link:not(.active):hover {
  color: #6f6b7d;
}
.grants-stepper-link.active {
  background-color: transparent;
  color: #6f6b7d;
}
.grants-stepper-link .step-number {
  width: 25px;
  height: 25px;
  border-radius: 6px;
  background-color: #f3f3f7;
  color: #6f6b7d;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: 0.95rem;
}
.grants-stepper-link .step-number.active {
  background-color: #6a89a0;
  color: #fff;
}
.grants-stepper-link .step-label {
  font-weight: 500;
}

.pl-0 {
  padding-left: 0 !important;
}

.menu-vertical .menu-item.active>.menu-link:not(.menu-toggle) {
  background: var(--primary) !important;
  /* background: var(--text-white) !important; */
  color: var(--text-white) !important;
  box-shadow: none !important;
}

.menu-vertical .menu-item .menu-link .ti {
  margin-right: 0.5rem !important;
}

.menu-vertical .menu-item .menu-link .fa-solid {
  margin-right: 0.5rem !important;
}

.dark-style .layout-navbar.navbar-detached {
  margin: 0rem auto 0;
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
  border-radius: 0px !important;
  background-color: var(--style-text-light) !important;
}

.light-style .layout-navbar.navbar-detached {
  margin: 0rem auto 0;
  box-shadow: 0 0.1rem 0.15rem rgba(15, 20, 34, 0.09);
  border-radius: 0px !important;
  background-color: var(--style-white) !important;
}

.layout-navbar.navbar-detached.container-xxl {
  /* max-width: calc(1440px - 1.5rem * 2 + 3rem); */
  max-width: 100%;
}

.layout-navbar-fixed .layout-navbar.navbar-detached {
  width: calc(100% - 1.5rem * 2 - 16.25rem + 3rem);
}


.tooltip {
  font-size: 1.16rem;
}

.fullscreen {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 9999;
}

.fullscreen canvas {
  width: 100% !important;
  height: 100% !important;
}

.graph-zoom-out-icon {
  position: absolute;
  top: 0px;
  right: 00px;
  cursor: pointer;
  width: 2.5rem;
  height: 2.5rem;
  background: none rgb(255, 255, 255);
  box-shadow: rgba(0, 0, 0, 0.3) 0px 1px 4px -1px;
  border-radius: 2px;
  margin: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.graph-zoom-out-icon img {
  width: 18px;
  height: 18px;
}

.expand-button {
  display: flex;
}

.exit-fullscreen-button {
  display: none;
}

.bg-red {
  background-color: var(--danger) !important;
}

.bg-secondary-red {
  background-color: var(--danger) !important;
}

.bg-primary-teal {
  background-color: var(--style-slate-blue-deep) !important;
}

.bg-secondary-blue {
  background-color: var(--style-link-blue) !important;
}

.bg-disabled {
  background-color: var(--gray-3) !important;
}

.text-primary {
  color: var(--primary) !important;
}

.text-primary2 {
  color: var(--light-primary) !important;
}

.spinner-border {
  /* border: var(--bs-spinner-border-width) solid var(--primary); */
  border: var(--bs-spinner-border-width) solid var(--primary);
  border-right-color: transparent;
}

.text-dark-grey {
  color: var(--gray-5) !important;
}

.text-secondary-grey {
  color: var(--gray-5) !important;
}

.text-light-red {
  color: var(--danger) !important;
}

.text-arstrik {
  margin-left: 5px;
  color: var(--danger) !important;
  font-size: 1.1rem;
}

.text-light-positive {
  /* color: #ff5a5a !important; */
  color: var(--danger) !important;
  font-weight: bold;
}

.text-light-dashboard {
  /* color: #ff5a5a !important; */
  color: var(--warning) !important;
  font-weight: bold;
}

.text-light-nagative {
  color: var(--danger) !important;
  font-weight: bold;
}

.text-secondary-blue {
  color: var(--light-primary) !important;
}

.text-secondary-blue2 {
  /* color: var(--style-link-blue) !important; */
  color: var(--light-primary) !important;
}

.dark-style input:-webkit-autofill {
  -webkit-text-fill-color: var(--style-white);
  font-size: 1rem !important;
}

.light-style input:-webkit-autofill {
  -webkit-text-fill-color: var(--style-text-dark);
  font-size: 0.875rem !important;
}

.bg-secondary-grey {
  background-color: var(--gray-5) !important;
}

.header-emergency-btn {
  max-height: 38px;
  align-items: center;
  display: flex;
  gap: 4px !important;
  border-radius: 30px !important;
  padding-top: 5px !important;
  padding-bottom: 5px !important;
  /* font-size: 14px !important; */
  font-size: 1.16rem !important;
}

.header-emergency-btn .feather-plus {
  height: 18px !important;
  width: 18px !important;
}

button:hover {
  box-shadow: none !important;
}

.dark-style body {
  color: var(--style-white);
  background-color: var(--style-graphite-deep);
}

/* Nav CSS */
.header-navbar.floating-nav {
  margin: 0px;
  width: calc(100vw - (100vw - 100%) - 260px);
  box-shadow: 0px 6px 4px -2px rgba(0, 0, 0, 0.25);
  /* background-color: var(--style-text-light) !important; */
  min-height: 70px;
  z-index: 9999;
}

.main-menu .navbar-header {
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
  min-height: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* .header-icon:nth-child(1) {
  width: 35px;
  height: 35px;
} */
.main-menu ul.navigation-main {
  padding: 24px 1px;
  gap: 9px;
}

.main-menu ul.navigation-main>li:first-child {
  margin-top: 0rem;
}

.dark-style .main-menu {
  background-color: var(--style-text-light) !important;
}

.main-menu.menu-dark .navigation li a {
  background: rgba(255, 255, 255, 0.2);
  color: var(--style-white) !important;
  font-weight: 500;
}

.main-menu.menu-dark .navigation>li>a {
  background: rgba(255, 255, 255, 0.2);
  box-shadow: none;
  border-radius: 4px;
  gap: 6px;
  padding: 8px;
}

.main-menu.menu-dark .navigation>li.active>a {
  box-shadow: none;
  background: var(--style-slate-blue-deep);
  font-weight: 500;
}

.main-menu .navbar-header .navbar-brand .brand-logo img {
  max-width: 175px;
}

.dark-style .select2-container .select2-selection,
.dark-style .select2-container .select2-selection__placeholder {
  background: transparent !important;
  /* border-color: var(--style-text-light) !important; */
  border-color: var(--style-white) !important;
  color: var(--style-white);
  /* min-height: 41.16px; */
  min-height: 2.5rem;
  border-radius: 8px;
}
.dark-style .select2-container.select2-container--focus .select2-selection,
.dark-style .select2-container.select2-container--open .select2-selection {
  border: 1px solid var(--style-success) !important;
  box-shadow: inset 0 0 0 1px var(--style-success);
}
/* Override for disabled Select2 - must come after the transparent rule */
.dark-style .select2-container.select2-container--disabled .select2-selection,
.dark-style select.form-select:disabled + .select2-container .select2-selection,
.dark-style select.form-select[disabled] + .select2-container .select2-selection,
.dark-style select.form-select:disabled ~ .select2-container .select2-selection,
.dark-style select.form-select[disabled] ~ .select2-container .select2-selection {
  background: var(--style-disabled-bg) !important;
  background-color: var(--style-disabled-bg) !important;
}

.select2-container--default .select2-selection {
  border-radius: var(--driven-component-radius) !important;
}

.dark-style .select2-container .select2-search__field {
  background: transparent !important;
  /* border-color: var(--style-text-light) !important; */
  border-color: var(--style-white) !important;
  color: var(--style-white);
}

.light-style .select2-container .select2-search__field {
  background: transparent !important;
  /* border-color: var(--style-text-light) !important;
  color: var(--style-white); */
}

.dark-style .select2-container .select2-search__field::placeholder {
  color: var(--text-tertiary) !important;
}

.dark-style .select2-container .select2-dropdown {
  /* background: var(--style-graphite-deep) !important; */
  background: var(--style-graphite-mid) !important;
  /* border-color: var(--style-text-light) !important; */
  border-color: var(--style-white) !important;
  color: var(--style-white);
}

.dark-style .select2-container--classic .select2-results__option[aria-selected="true"],
.dark-style .select2-container--default .select2-results__option[aria-selected="true"] {
  background-color: var(--style-text-light) !important;
  color: var(--style-white) !important;
}

.dark-style .select2-container--default .select2-results__option--highlighted:not([aria-selected=true]) {
  background-color: var(--style-text-light) !important;
  color: var(--style-white) !important;
}

.dark-style .select2-container--classic .select2-results__option--highlighted,
.dark-style .select2-container--default .select2-results__option--highlighted {
  background-color: var(--style-text-light) !important;
  color: var(--style-white) !important;
}

.select2-container--classic.select2-container .select2-selection--single,
.select2-container--default.select2-container .select2-selection--single {
  /* border-color: var(--style-text-light) !important; */
  outline: 0;
}

.dark-style .select2-container--default .select2-selection__rendered {
  color: var(--style-white) !important;
}

.dark-style .input-group .input-group-text {
  background-color: var(--style-graphite-mid);
  /* border-color: var(--style-text-light); */
  border-color: var(--style-white);
  color: var(--style-white);
}

.dark-style input.form-control:not(:focus),
.dark-style select.form-select:not(:focus),
.dark-style textarea.form-control:not(:focus) {
  /* border-color: var(--style-text-light); */
  border-color: var(--style-white);
}

.light-style input.form-control:not(:focus),
.light-style select.form-select:not(:focus),
.light-style textarea.form-control:not(:focus) {
  /* border-color: rgb(219, 218, 222.4) !important; */
  border-color: var(--style-input-border-light);
  /* border-color: #ccc; */
}

.light-style .flatpickr-time {
  border: 1px solid var(--style-input-border-light);
  /* border: 1px solid #ccc; */
  text-align: left;
}

.flatpickr-time .numInputWrapper {
  height: 2.5rem;
}

.flatpickr-calendar.hasTime {
  padding-bottom: 0px;
}

.flatpickr-time .numInputWrapper input {
  display: flex;
}

.form-control:hover:not([disabled]):not([focus]) {
  /* border-color: #ccc; */
  border-color: var(--style-input-border-light);
}

.dark-style input.form-control,
.dark-style select.form-select,
.dark-style textarea.form-control {
  background-color: var(--style-graphite-mid);
  color: var(--style-white) !important;
}

.light-style input.form-control,
.light-style select.form-select,
.light-style textarea.form-control {
  background-color: transparent !important;
  color: var(--style-text-dark) !important;
}

.light-style .input-group .input-group-text {
  background-color: transparent !important;
  /* border-color: rgb(219, 218, 222.4); */
  /* border-color: #ccc; */
  border-color: var(--style-input-border-light);
  /* color: var(--style-white) !important; */
}

.light-style .select2-selection--multiple .select2-selection__clear {
  margin-top: 0.375rem;
}
.light-style .select2-selection--multiple .select2-selection__rendered {
  padding: 0 0.375rem 0.375rem 0.375rem;
}
.light-style .select2-selection--multiple .select2-selection__choice {
  margin-right: 0.375rem;
  margin-top: 0.375rem;
}
.light-style .select2-selection--multiple .select2-selection__placeholder {
  margin-top: 0.375rem;
}
.light-style .select2-selection--multiple.select2-no-inline-search .select2-search--inline {
  display: none;
}
.dark-style .select2-selection--multiple.select2-no-inline-search .select2-search--inline {
  display: none;
}
.light-style .select2-search__field {
  color: var(--style-text-muted);
}
.light-style .select2-dropdown {
  background: var(--style-white);
  box-shadow: 0 0.25rem 1rem rgba(165, 163, 174, 0.45);
  background-clip: padding-box;
  /* border-color: var(--style-vuexy-light-border); */
  border-color: var(--style-input-border-light);
  z-index: 1000;
}
.light-style .select2-dropdown.select2-dropdown--above {
  box-shadow: 0 -0.2rem 1.25rem rgba(165, 163, 174, 0.4) !important;
}
.light-style .select2-container--default .select2-selection {
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  background-color: var(--style-white);
  border: 1px solid var(--input-border) !important;
  border-radius: 0.375rem;
}
.light-style .select2-container--default .select2-selection:hover {
  /* border-color: var(--style-input-border-light) !important; */
  border: 1px solid var(--style-success) !important;
  box-shadow: inset 0 0 0 1px var(--style-success);
}
.light-style .select2-container--default .select2-selection__placeholder {
  color: var(--gray-4);
}
.light-style .select2-container--default .select2-selection--single {
  height: calc(1.5em + 0.844rem + calc(var(--bs-border-width) * 2));
}
.light-style .select2-container--default .select2-selection--single .select2-selection__clear {
  color: var(--gray-5);
}
.light-style .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: calc(1.5em + 0.844rem + calc(var(--bs-border-width) * 2));
  position: absolute;
}
.light-style .select2-container--default .select2-selection--single .select2-selection__arrow b {
  background-image: url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%236f6b7d' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='white' stroke-opacity='0.2' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}
.light-style .select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 2.25rem;
  color: var(--style-text-muted);
  padding-left: 0.875rem;
}
.light-style .select2-container--default[dir=rtl] .select2-selection--single .select2-selection__rendered {
  padding-right: 0.875rem;
}
.light-style .select2-container--default.select2-container--disabled .select2-selection--single {
  background-color: var(--primary-soft);
  border-color: var(--style-vuexy-light-border) !important;
}
.light-style .select2-container--default .select2-selection--multiple {
  min-height: calc(1.5em + 0.844rem + calc(var(--bs-border-width) * 2));
}
.light-style .select2-container--default .select2-selection--multiple .select2-selection__choice {
  color: var(--style-text-muted);
  background-color: var(--primary-soft-strong);
}
.light-style .select2-container--default.select2-container--disabled .select2-selection--multiple {
  border-color: var(--style-vuexy-light-border) !important;
  background-color: var(--primary-soft);
}
.light-style .select2-container--default .select2-search--dropdown .select2-search__field {
  border: 1px solid var(--style-vuexy-light-border);
}
.light-style .select2-container--default .select2-search__field::-webkit-input-placeholder {
  color: var(--gray-4);
}
.light-style .select2-container--default .select2-search__field::-moz-placeholder {
  color: var(--gray-4);
}
.light-style .select2-container--default .select2-search__field:-ms-input-placeholder {
  color: var(--gray-4);
}
.light-style .select2-container--default .select2-results__option .select2-results__option[role=option] {
  width: calc(100% - 0.875rem);
  padding-left: 0.875rem;
}
.light-style .select2-container--default .select2-results__option .select2-results__option[role=option] .select2-results__option[role=option] {
  padding-left: 1.75rem;
}
.light-style .select2-container--default .select2-results__option .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] {
  padding-left: 2.625rem;
}
.light-style .select2-container--default .select2-results__option .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] {
  padding-left: 3.5rem;
}
.light-style .select2-container--default .select2-results__option .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] {
  padding-left: 4.375rem;
}
.light-style .select2-container--default .select2-results__option .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] {
  padding-left: 0.875rem;
}
.light-style .select2-container--default .select2-results__group {
  padding: 0.5rem 0.4375rem;
}
.light-style .select2-container--default[dir=rtl] .select2-selection--multiple .select2-selection__choice {
  margin-left: 0.375rem;
  margin-right: 0;
}
.light-style[dir=rtl] .select2-container--default .select2-results__option .select2-results__option {
  padding-right: 0.875rem;
  padding-left: 0 !important;
  margin-left: 0 !important;
}
.light-style[dir=rtl] .select2-container--default .select2-results__option .select2-results__option .select2-results__option[role=option] {
  padding-right: 1.75rem;
}
.light-style[dir=rtl] .select2-container--default .select2-results__option .select2-results__option .select2-results__option[role=option] .select2-results__option[role=option] {
  padding-right: 2.625rem;
}
.light-style[dir=rtl] .select2-container--default .select2-results__option .select2-results__option .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] {
  padding-right: 3.5rem;
}
.light-style[dir=rtl] .select2-container--default .select2-results__option .select2-results__option .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] {
  padding-right: 4.375rem;
}
.light-style[dir=rtl] .select2-container--default .select2-results__option .select2-results__option .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] {
  padding-right: 0.875rem;
}
.light-style .is-valid .select2-container--default .select2-selection,
.light-style .is-valid.select2-container--default .select2-selection {
  /* border-color: var(--style-success) !important; */
  border-color: var(--style-input-border-light) !important;
}
.light-style .is-invalid .select2-container--default .select2-selection,
.light-style .is-invalid.select2-container--default .select2-selection {
  border-color: var(--style-danger) !important;
}
.light-style .select2-secondary .select2-container--default .select2-selection--multiple .select2-selection__choice {
  background: rgba(168, 170, 174, 0.16) !important;
  color: var(--gray-5) !important;
}
.light-style .select2-success .select2-container--default .select2-selection--multiple .select2-selection__choice {
  background: var(--success-soft) !important;
  color: var(--style-success) !important;
}
.light-style .select2-info .select2-container--default .select2-selection--multiple .select2-selection__choice {
  background: var(--info-soft) !important;
  color: var(--info) !important;
}
.light-style .select2-warning .select2-container--default .select2-selection--multiple .select2-selection__choice {
  background: var(--warning-soft) !important;
  color: var(--style-warning) !important;
}
.light-style .select2-danger .select2-container--default .select2-selection--multiple .select2-selection__choice {
  background: var(--danger-soft) !important;
  color: var(--style-danger) !important;
}
.light-style .select2-light .select2-container--default .select2-selection--multiple .select2-selection__choice {
  background: rgba(223, 223, 227, 0.16) !important;
  color: var(--gray-3) !important;
}
.light-style .select2-dark .select2-container--default .select2-selection--multiple .select2-selection__choice {
  background: rgba(75, 75, 75, 0.16) !important;
  color: var(--gray-7) !important;
}
.light-style .select2-gray .select2-container--default .select2-selection--multiple .select2-selection__choice {
  background: var(--primary-soft-14) !important;
  color: var(--text-tertiary) !important;
}

.dark-style .select2-selection--multiple .select2-selection__choice {
  margin-top: 0.375rem;
  margin-right: 0.375rem;
}
.dark-style .select2-selection--multiple .select2-selection__clear {
  margin-top: 0.375rem;
}
.dark-style .select2-selection--multiple .select2-selection__placeholder {
  margin-top: 0.375rem;
}
.dark-style .select2-selection--multiple .select2-selection__rendered {
  padding: 0 0.375rem 0.375rem 0.375rem;
}
.dark-style .select2-container--default[dir=rtl] .select2-selection--multiple .select2-selection__choice {
  margin-left: 0.375rem;
  margin-right: 0;
}
.dark-style .select2-container--default .select2-selection {
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  background-color: var(--surface-1);
  border: 1px solid var(--style-white);
  border-radius: 0.375rem;
}
.dark-style .select2-container--default .select2-selection:hover {
  border-color: var(--style-white);
}
.dark-style .select2-container--default .select2-selection__placeholder {
  color: var(--style-white);
}
.dark-style .select2-container--default .select2-selection--single {
  height: calc(1.5em + 0.844rem + calc(var(--bs-border-width) * 2));
}
.dark-style .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: calc(1.5em + 0.844rem + calc(var(--bs-border-width) * 2));
  position: absolute;
}
.dark-style .select2-container--default .select2-selection--single .select2-selection__arrow b {
  background-image: url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%23b6bee3' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='white' stroke-opacity='0.2' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}
.dark-style .select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 2.25rem;
  color: var(--style-vuexy-soft-purple-text);
  padding-left: 0.875rem;
}
.dark-style .select2-container--default .select2-selection--single .select2-selection__clear {
  color: var(--style-vuexy-soft-purple-text);
}
.dark-style .select2-container--default .select2-selection--multiple {
  min-height: calc(1.5em + 0.844rem + calc(var(--bs-border-width) * 2));
}
.dark-style .select2-container--default .select2-selection--multiple .select2-selection__choice {
  color: var(--style-vuexy-soft-purple-text);
  background-color: var(--surface-1);
}
.dark-style .select2-container--default.select2-container--disabled .select2-selection--multiple {
  border-color: var(--style-white) !important;
  background-color: var(--primary-soft);
}
.dark-style .select2-container--default[dir=rtl] .select2-selection--single .select2-selection__rendered {
  padding-right: 0.875rem;
}
.dark-style .select2-container--default.select2-container--disabled .select2-selection--single {
  background-color: var(--primary-soft);
  border-color: var(--style-white) !important;
}
.dark-style .select2-container--default .select2-search__field::-webkit-input-placeholder {
  color: var(--style-white);
}
.dark-style .select2-container--default .select2-search__field::-moz-placeholder {
  color: var(--style-white);
}
.dark-style .select2-container--default .select2-search__field:-ms-input-placeholder {
  color: var(--style-white);
}
.dark-style .select2-container--default .select2-search--dropdown .select2-search__field {
  border: 1px solid var(--style-white);
  background: var(--surface-1);
}
.dark-style .select2-container--default .select2-results__option .select2-results__option[role=option] {
  width: calc(100% - 0.875rem);
  padding-left: 0.875rem;
  padding-right: 0.875rem;
}
.dark-style .select2-container--default .select2-results__option .select2-results__option[role=option] .select2-results__option[role=option] {
  padding-left: 0.875rem;
}
.dark-style .select2-container--default .select2-results__option .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] {
  padding-left: 1.75rem;
}
.dark-style .select2-container--default .select2-results__option .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] {
  padding-left: 2.625rem;
}
.dark-style .select2-container--default .select2-results__option .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] {
  padding-left: 3.5rem;
}
.dark-style .select2-container--default .select2-results__option .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] {
  padding-left: 4.375rem;
}
.dark-style .select2-container--default .select2-results__option .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] {
  padding-left: 0.875rem;
}
.dark-style .select2-container--default .select2-results__group {
  padding: 0.5rem 0.4375rem;
}
.dark-style .select2-dropdown {
  z-index: 1000;
  background: var(--surface-1);
  border-color: var(--style-white);
  background-clip: padding-box;
  box-shadow: 0 0.25rem 1rem rgba(15, 20, 34, 0.55);
}
.dark-style .select2-dropdown.select2-dropdown--above {
  box-shadow: 0 -0.2rem 1.25rem rgba(15, 20, 34, 0.55) !important;
}
.dark-style .select2-search__field {
  color: var(--style-vuexy-soft-purple-text);
}
.dark-style[dir=rtl] .select2-container--default .select2-results__option .select2-results__option {
  padding-left: 0 !important;
  padding-right: 0.875rem;
  margin-left: 0 !important;
}
.dark-style[dir=rtl] .select2-container--default .select2-results__option .select2-results__option .select2-results__option[role=option] {
  padding-right: 1.75rem;
}
.dark-style[dir=rtl] .select2-container--default .select2-results__option .select2-results__option .select2-results__option[role=option] .select2-results__option[role=option] {
  padding-right: 2.625rem;
}
.dark-style[dir=rtl] .select2-container--default .select2-results__option .select2-results__option .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] {
  padding-right: 3.5rem;
}
.dark-style[dir=rtl] .select2-container--default .select2-results__option .select2-results__option .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] {
  padding-right: 4.375rem;
}
.dark-style[dir=rtl] .select2-container--default .select2-results__option .select2-results__option .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] .select2-results__option[role=option] {
  padding-right: 0.875rem;
}
.dark-style .is-valid .select2-container--default .select2-selection,
.dark-style .is-valid.select2-container--default .select2-selection {
  /* border-color: var(--style-success) !important; */
  border-color: var(--style-input-border-light) !important;
}
.dark-style .is-invalid .select2-container--default .select2-selection,
.dark-style .is-invalid.select2-container--default .select2-selection {
  border-color: var(--style-danger) !important;
}
.dark-style .select2-secondary .select2-container--default .select2-selection--multiple .select2-selection__choice {
  background: rgba(168, 170, 174, 0.16) !important;
  color: var(--gray-5) !important;
}
.dark-style .select2-success .select2-container--default .select2-selection--multiple .select2-selection__choice {
  background: var(--success-soft) !important;
  border: 1px solid var(--style-success) !important;
  box-shadow: inset 0 0 0 1px var(--style-success);
}
.dark-style .select2-info .select2-container--default .select2-selection--multiple .select2-selection__choice {
  background: var(--info-soft) !important;
  color: var(--info) !important;
}
.dark-style .select2-warning .select2-container--default .select2-selection--multiple .select2-selection__choice {
  background: var(--warning-soft) !important;
  color: var(--style-warning) !important;
}
.dark-style .select2-danger .select2-container--default .select2-selection--multiple .select2-selection__choice {
  background: var(--danger-soft) !important;
  color: var(--style-danger) !important;
}
.dark-style .select2-light .select2-container--default .select2-selection--multiple .select2-selection__choice {
  background: var(--primary-soft-14) !important;
  color: var(--gray-7) !important;
}
.dark-style .select2-dark .select2-container--default .select2-selection--multiple .select2-selection__choice {
  background: rgba(215, 216, 222, 0.16) !important;
  color: var(--gray-3) !important;
}
.dark-style .select2-gray .select2-container--default .select2-selection--multiple .select2-selection__choice {
  background: rgba(255, 255, 255, 0.16) !important;
  color: var(--text-secondary) !important;
}

.dark-style input.form-control:disabled,
.dark-style input.form-control[disabled],
.dark-style select.form-select:disabled,
.dark-style select.form-select[disabled],
.dark-style textarea.form-control:disabled,
.dark-style textarea.form-control[disabled],
.dark-style .form-control:disabled,
.dark-style .form-control[disabled],
.dark-style .form-select:disabled,
.dark-style .form-select[disabled] {
  background-color: var(--style-disabled-bg) !important;
  opacity: 1 !important;
  color: var(--style-white) !important;
}

/* Select2 disabled state - target the visible selection element */
.dark-style select.form-select:disabled ~ .select2-container .select2-selection,
.dark-style select.form-select[disabled] ~ .select2-container .select2-selection,
.dark-style .select2-container--default.select2-container--disabled .select2-selection,
.dark-style .select2-container--classic.select2-container--disabled .select2-selection,
.dark-style .select2-container.select2-container--disabled .select2-selection {
  background-color: var(--style-disabled-bg) !important;
  background: var(--style-disabled-bg) !important;
  opacity: 1 !important;
  border-color: var(--style-text-light) !important;
}

.dark-style select.form-select:disabled ~ .select2-container .select2-selection__rendered,
.dark-style select.form-select[disabled] ~ .select2-container .select2-selection__rendered,
.dark-style .select2-container--default.select2-container--disabled .select2-selection__rendered,
.dark-style .select2-container--classic.select2-container--disabled .select2-selection__rendered,
.dark-style .select2-container.select2-container--disabled .select2-selection__rendered {
  color: var(--style-white) !important;
}

/* Light mode disabled state — mirrors the dark block above. The earlier non-!important rule lost
   to the active selection background (so a disabled Select2 looked active); these use !important
   like the dark equivalents and give a faint primary-soft tint so disabled fields read as disabled. */
.light-style input.form-control:disabled,
.light-style input.form-control[disabled],
.light-style select.form-select:disabled,
.light-style select.form-select[disabled],
.light-style textarea.form-control:disabled,
.light-style textarea.form-control[disabled],
.light-style .form-control:disabled,
.light-style .form-control[disabled],
.light-style .form-select:disabled,
.light-style .form-select[disabled] {
  background-color: var(--primary-soft) !important;
  opacity: 1 !important;
}

/* Select2 disabled state - target the visible selection element */
.light-style select.form-select:disabled ~ .select2-container .select2-selection,
.light-style select.form-select[disabled] ~ .select2-container .select2-selection,
.light-style .select2-container--default.select2-container--disabled .select2-selection,
.light-style .select2-container--classic.select2-container--disabled .select2-selection,
.light-style .select2-container.select2-container--disabled .select2-selection {
  background-color: var(--primary-soft) !important;
  background: var(--primary-soft) !important;
  opacity: 1 !important;
  border-color: var(--input-border) !important;
}

.light-style select.form-select:disabled ~ .select2-container .select2-selection__rendered,
.light-style select.form-select[disabled] ~ .select2-container .select2-selection__rendered,
.light-style .select2-container--default.select2-container--disabled .select2-selection__rendered,
.light-style .select2-container--classic.select2-container--disabled .select2-selection__rendered,
.light-style .select2-container.select2-container--disabled .select2-selection__rendered {
  color: var(--text-secondary) !important;
  border-color: var(--input-border) !important;
}

.input-group:focus-within {
  box-shadow: none;
}

.dark-style input:-webkit-autofill {
  background-color: var(--style-graphite-mid) !important;
  box-shadow: 0 0 0 1000px var(--style-graphite-mid) inset !important;
  /* -webkit-text-fill-color: black !important; */
}

.sidemenu-icon {
  margin-right: 0.5rem;
  height: 1.5rem;
}

.dark-style .form-control:hover:not([disabled]):not([focus]) {
  /* border-color: var(--style-text-light); */
  border-color: var(--style-white);
}

.dark-style .input-group:focus-within .form-control,
.dark-style .input-group:focus-within .input-group-text {
  /* border-color: var(--style-text-light); */
  border-color: var(--style-white);
  box-shadow: none;
}

.dark-style .nav-tabs {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  flex-wrap: nowrap;
  /* row-gap: 20px; */
  /* column-gap: 32px; */
  /* column-gap: 25px; */
  /* border-bottom: 0 solid #dae1e7; */
  border-bottom: 0px solid var(--style-white);
  background-color: transparent;
  position: relative;
  /* width: 100%; */
  width: 120%;
}

.light-style .nav-tabs.admin-tabs {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  flex-wrap: nowrap;
  /* row-gap: 20px; */
  /* column-gap: 32px; */
  /* column-gap: 25px; */
  /* border-bottom: 0 solid #dae1e7; */
  border-bottom: 0px solid var(--style-white);
  background-color: transparent;
  position: relative;
  /* width: 100%; */
  width: 120%;
}

.dark-style .tab-hr {
  width: 100%;
  height: 2px;
  background-color: var(--style-white);
  /* background-color: rgb(219, 218, 222.4); */
  display: block;
  position: relative;
  bottom: 5px;
}

.tab-hr {
  width: 100%;
  height: 2px;
  /* background-color: var(--style-white); */
  background-color: rgb(219, 218, 222.4);
  display: block;
  position: relative;
  bottom: 4px;
}

.tab-wrapper {
  display: flex;
  flex-wrap: nowrap;
  overflow-x: auto;
  white-space: nowrap;
  /* scrollbar-width: thin;  */
  overflow-y: hidden;
  scrollbar-width: none;
}

.tab-wrapper::-webkit-scrollbar {
  /* height: 6px;  */
  display: none;
}

.tab-wrapper::-webkit-scrollbar-thumb {
  background-color: var(--gray-4);
  border-radius: 4px;
}

.tab-wrapper::-webkit-scrollbar-track {
  background-color: var(--style-white);
}

.tab-content {
  padding: 0px;
  border-radius: 0px;
  /* background-color: var(--style-white); */

}

.light-style .tab-content {
  padding: 0px;
}

.light-style .nav-tabs {
  background-color: transparent;
  border-bottom: 0px;
}

.light-style .nav-tabs .nav-link.active {
  background-color: transparent;
  /* color: #3e58b3; */
  color: var(--dark-primary);
  font-weight: 600;
}

.light-style .nav-item .nav-link {
  background-color: transparent;
  color: var(--style-text-dark);
}

.dark-style .nav-item .nav-link {
  background-color: transparent;
  color: var(--style-white);
}

.nav-tabs .nav-link:not(.active):hover,
.nav-tabs .nav-link:not(.active):focus,
.nav-pills .nav-link:not(.active):hover,
.nav-pills .nav-link:not(.active):focus {
  /* color: #3e58b3; */
  color: var(--dark-primary);
}

.dark-style .nav-tabs .nav-item .nav-link {
  /* color: #aaa;
  padding: 4px 4px 14px 4px; */
  /* margin-right: 32px; */
}

.dark-style .nav-tabs .nav-item:last-child .nav-link {
  /* margin-right: 0px; */
}

.dark-style .nav-tabs .nav-item .nav-link.active,
.dark-style .nav-pills .nav-item .nav-link.active,
.dark-style .nav-tabs.nav-justified .nav-item .nav-link.active {
  background-color: transparent;
  color: var(--style-white);
  /* font-weight: 700; */
  box-shadow: none;
}

.nav-tabs .nav-link:after {
  display: none;
}

.nav-tabs:after {
  /* content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  z-index: 2;
  width: 100%;
  height: 2px;
  background-color: var(--style-white); */
}

.nav-tabs .nav-link.active {
  border-bottom: 0px solid var(--primary);
  /* color: var(--primary); */
  position: relative;
  z-index: 5;
  box-shadow: none;
}

.nav-tabs .nav-link.active:after {
  /* content: "";
  position: absolute;
  bottom: 0px;
  left: 0;
  z-index: 2;
  width: 100%;
  height: 2px;
  background-color: var(--primary);
  display: block; */
}

.nav-tabs .nav-link.first-layer.active:after{
  content: "";
  position: absolute;
  bottom: 1px;
  left: 0;
  z-index: 2;
  width: 100%;
  height: 2px;
  background-color: var(--primary);
  display: block;
}

.nav-tabs .nav-link {
  /* font-size: 0.875rem; */
  font-size: 1rem;
  font-weight: 600;
  position: relative;
}

.schedule-tab .nav-pills {
  border: 1px solid var(--primary) !important;
  border-radius: var(--driven-component-radius);
  overflow: hidden;
}

.schedule-tab .nav-pills .nav-item {
  flex: 1;
}

.schedule-tab .nav-pills .nav-link {
  min-width: 160px;
  border-radius: 0px;
}

/* Divider only between tabs – no border on outer left/right */
.schedule-tab .nav-pills .nav-item:not(:last-child) .nav-link {
  border-right: 1px solid var(--primary);
}

.schedule-tab .nav-pills .nav-link:hover {
  /* color: var(--style-white); */
  color: var(--gray-6);
}

.dark-style .schedule-tab .nav-pills .nav-link:hover {
  color: var(--style-white);
}

.schedule-tab .nav-pills .nav-link.active {
  /* background-color: var(--light-primary) !important; */
  background-color: var(--primary) !important;
  /* color: var(--style-graphite-deep) !important; */
  color: var(--text-white) !important;
  box-shadow: none;
}

.schedule-take-action {
  background-color: var(--dark-primary);
  border-radius: 0.8rem;
  padding: 1rem;
}

.light-style .schedule-take-action .text-white {
  color: var(--style-white) !important;
}

.form-control {
  font-size: 1rem;
  border-radius: 0.5rem;
  /* padding: 0.66rem 1.16rem; */
}

.form-control:focus {
  border-color: var(--style-text-light);
}

.dark-style .form-control::placeholder {
  color: var(--gray-4);
}

.dark-style .form-label {
  margin-bottom: 0.5rem;
  /* font-weight: 400; */
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.37rem;
  color: var(--style-white);
}

.light-style .form-label {
  margin-bottom: 0.5rem;
  /* font-weight: 400; */
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.37rem;
  color: var(--style-text-dark);
}

.flatpickr-time {
  height: 2.57rem;
  max-height: 2.57rem;
}

.min-ht-form-control {
  min-height: 2.57rem;
}

.gap-16 {
  gap: 1rem !important;
}

.mb-16 {
  margin-bottom: 1rem !important;
}

.dark-style .select2-container .select2-selection__rendered {
  color: var(--style-white);
}

.select2 {
  font-size: 1rem;
}

.dataTable .select2,
.dataTable .form-control,
.dataTable .select2-results__option {
  font-size: 0.875rem;
}

.custom-selct2-class .select2-results__option {
  font-size: 0.875rem;
}

.select2-results__option {
  font-size: 1rem;
}

.py-75 {
  padding-top: 0.75rem !important;
  padding-bottom: 0.75rem !important;
}

.px-75 {
  padding-right: 0.75rem !important;
  padding-left: 0.75rem !important;
}

.mb-25 {
  margin-bottom: 0.25rem !important;
}

.flex-1 {
  flex: 1 !important;
}

.gap-50 {
  gap: 0.5rem;
}

.mb-75 {
  margin-bottom: 0.75rem !important;
}

.fs-18 {
  font-size: 1.125rem;
}

.fs-12 {
  font-size: 0.75rem;
}

.fs-14 {
  font-size: 0.875rem;
}

.fw-400 {
  font-weight: 400;
}

.fw-600 {
  font-weight: 600;
}

.fw-700 {
  font-weight: 700;
}

.section-wrapper h2 {
  font-size: 1.5rem;
}

.inner-card-title {
  font-size: 1.5rem;
}

html .content {
  min-height: 100%;
}

html .content.app-content {
  padding: calc(2.5rem + 4.45rem + 1rem) 2.5rem 2.5rem;
}

.min-w-auto {
  min-width: auto !important;
}

.form-group {
  margin-bottom: 16px;
}

@media (max-width: 1199.98px) {
  .header-navbar.floating-nav {
    width: 100% !important;
  }

  .dark-style .nav-tabs .nav-link.active:after {
    bottom: 1px;
  }

  .main-menu .navbar-header .navbar-brand .brand-logo img {
    max-width: 150px;
  }

  .modern-nav-toggle {
    display: flex !important;
  }

  .layout-navbar-fixed .layout-navbar.navbar-detached {
    width: 100% !important;
  }
}

/* Nav CSS */

.content-box {
  padding: 0px 0.5rem 0.5rem;
}

.section-gap {
  display: flex;
  flex-direction: column;
  /* gap: 2rem; */
  gap: 1.5rem;
}

.section-gap-dashboard {
  gap: 1.5rem;
}

.dark-style .flatpickr-days {
  background-color: transparent;
}

.dark-style span.flatpickr-weekday {
  background-color: transparent;
}

.dark-style .flatpickr-input:not(.is-invalid):not(.is-valid)~.form-control:disabled,
.dark-style .flatpickr-input:not(.is-invalid):not(.is-valid)[readonly],
.dark-style .flatpickr-input:not(.is-invalid):not(.is-valid)~.form-control[readonly] {
  background-color: transparent;
}

.section-wrapper {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* Keep Toxicology filter panel usable on shorter viewports */
.tox-filters-scroll-fields {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-gutter: stable;
  scrollbar-width: thick;
  scrollbar-color: rgba(93, 89, 108, 0.6) rgba(255, 255, 255, 0.08);
  max-height: calc(100vh - 140px);
  padding-right: 10px;
  margin-right: -11px;
  padding-bottom: 4px;
  overscroll-behavior: contain;
}

.tox-filters-scroll-fields::-webkit-scrollbar {
  width: 12px;
}

.tox-filters-scroll-fields::-webkit-scrollbar-thumb {
  background-color: rgba(93, 89, 108, 0.6);
  border-radius: 4px;
  border: 1px solid transparent;
  background-clip: content-box;
}

.tox-filters-scroll-fields::-webkit-scrollbar-track {
  /* Keep track "structure" consistent across light/dark */
  background: rgba(255, 255, 255, 0.08);
  border-radius: 4px;
}

.tox-filters-scroll-fields::-webkit-scrollbar-thumb:hover {
  background-color: rgba(93, 89, 108, 0.9);
}

.dark-style .tox-filters-scroll-fields {
  scrollbar-color: rgba(200, 200, 200, 0.5) rgba(255, 255, 255, 0.08);
}

.dark-style .tox-filters-scroll-fields::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.08);
}

.dark-style .tox-filters-scroll-fields::-webkit-scrollbar-thumb {
  background-color: rgba(200, 200, 200, 0.5);
}

/* Test Results filter group — flat inside its accordion toggle (no nested card
   box / border; sits in the same padding as the other filter sections). The
   layout + behaviour rules below are re-scoped off the old .tox-test-results-card
   wrapper so they keep working without it. */
.tox-kit-test-result-tabs {
  display: flex;
  flex-wrap: nowrap;
}

.tox-kit-test-result-tabs .nav-item {
  flex: 1 1 0;
}

.tox-kit-test-result-tabs .nav-link {
  min-width: 0;
  width: 100%;
  padding: 0.4rem 0.3rem;
}

.tox-test-result-header {
  margin-bottom: 0.35rem;
}

.tox-test-result-header-1 {
  margin-top: 0.35rem;
}

.tox-subsection-hr {
  opacity: 1;
}

.tox-test-result-header .form-switch .form-check-input {
  width: 2.5rem;
  height: 1.4rem;
  margin-top: 0;
}

.tox-filter-group-disabled {
  opacity: 0.55;
}

.tox-filter-group-disabled .nav-link,
.tox-filter-group-disabled input {
  pointer-events: none;
}

/* Keep the Kit/Lab toggle switches clickable even when the group is "disabled" */
.tox-filter-group-disabled #toggle_kit_test_result,
.tox-filter-group-disabled #toggle_lab_test_result {
  pointer-events: auto;
}

/* Keep age slider clear of scrollbar gutter */
.tox-filters-scroll-fields #age-range-slider {
  margin-left: 9px;
}

.page-title {
  color: var(--style-white) !important;
  font-family: Open Sans;
  /* font-size: 2.28rem; */
  font-size: 1.8rem;
  font-weight: 500;
  /* line-height: 43.58px; */
  line-height: 2.5rem;
  text-align: left;
  margin-top: -0.4rem;
}

.section-wrapper .page-title {
  font-size: 2rem;
}

.box-22 {
  height: 22px;
  width: 22px;
}

.btn {
  /* font-size: 1.125rem; */
  font-size: 1rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  /* line-height: 1.25rem; */
  line-height: 1.37rem;
  /* padding: 8px 16px; */
  padding: 0.5rem 1rem;
  border-radius: 0.5rem;
  box-shadow: none !important;
}

.btn:hover {
  box-shadow: none !important;
}

.btn .feather-plus {
  height: 22px;
  width: 22px;
}

.btn-primary {
  color: var(--text-white);
  background-color: var(--primary) !important;
  border-color: var(--primary) !important;
}

.btn-primary:hover {
  color: var(--text-white) !important;
  background-color: var(--dark-primary) !important;
  border-color: var(--dark-primary) !important;
}

.btn-primary.disabled,
.btn-primary:disabled {
  background-color: var(--primary) !important;
  border-color: var(--primary) !important;
}

.btn-outline-primary:hover {
  border-color: var(--primary) !important;
}

.table-btn {
  background-color: var(--primary);
  border-radius: 0.25rem;
  height: 1.8rem;
  width: 3rem;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}

.table-btn-long {
  width: 5rem !important;
}

.table-btn.table-mail-btn {
  background-color: var(--primary);
}

.table-btn.table-mail-btn .ti {
  color: var(--text-white) !important;
  font-size: 1.125rem;
}

.table-btn.table-trash-btn {
  background-color: var(--style-alert-rose) !important;
}

.table-btn.table-trash-one {
  background-color: var(--style-alert-rose) !important;
}

.table-btn.table-trash-two {
  background-color: var(--style-alert-rose) !important;
}

.table-btn.table-trash-three {
  background-color: var(--style-alert-rose) !important;
}

.table-btn.table-trash-four {
  background-color: var(--style-alert-rose) !important;
}

.table-btn.table-trash-five {
  background-color: var(--style-alert-rose) !important;
}

.table-btn.table-trash-six {
  background-color: var(--style-alert-rose) !important;
}

.table-btn.table-trash-seven {
  background-color: var(--style-alert-rose) !important;
}

.btn-check:checked+.btn-primary,
.btn-check:active+.btn-primary,
.btn-primary:active,
.btn-primary.active,
.btn-primary.show.dropdown-toggle,
.show>.btn-primary.dropdown-toggle {
  color: var(--text-white) !important;
  background-color: var(--dark-primary) !important;
  border-color: var(--dark-primary) !important;
}

.btn-outline-primary2 {
  border: 1px solid var(--light-primary);
  color: var(--light-primary);
}

.btn-outline-primary2:hover,
.btn-outline-primary2:focus {
  border: 1px solid var(--light-primary);
  color: var(--light-primary);
  /* border: 1px solid var(--dark-primary);
  color: var(--dark-primary); */
}

.btn-outline-danger2 {
  border: 1px solid var(--style-alert-coral);
  color: var(--style-alert-coral);
}

.btn-danger2:hover,
.btn-danger2:focus {
  background-color: var(--style-alert-coral);
  /* border: 1px solid var(--light-primary); */
  color: var(--gray-12);
}

.btn-danger2 {
  background-color: var(--style-alert-coral);
  /* border: 1px solid var(--style-alert-coral); */
  color: var(--gray-12);
}

.btn-outline-danger2:hover,
.btn-outline-danger2:focus {
  border: 1px solid var(--style-alert-coral);
  color: var(--style-alert-coral);
}

.btn-white-outline {
  border: 1px solid var(--style-white);
  color: var(--style-white);
}

.btn-white-outline:hover,
.btn-white-outline:focus {
  border: 1px solid var(--style-white);
  color: var(--style-white);
}

.min-w-160 {
  min-width: 160px;
}

.max-w-160 {
  max-width: 160px;
  width: 100%;
}

.max-w-140 {
  max-width: 140px;
  width: 100%;
}

.max-w-180 {
  max-width: 180px;
  width: 100%;
}

.max-w-200 {
  max-width: 200px;
  width: 100%;
}

.max-w-240 {
  max-width: 240px;
  width: 100%;
}

.watchlist-card-wrapper {
  display: flex;
  gap: 20px;
  overflow: auto;
}

.watchlist-card-wrapper::-webkit-scrollbar {
  display: none;
}

.watchlist-card-wrapper {
  -ms-overflow-style: none;
  /* IE and Edge */
  scrollbar-width: none;
  /* Firefox */
}

.watchlist-card {
  background-color: var(--style-text-light);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  width: 100%;
  /* min-width: 300px; */
  min-width: 25%;
}

.watchlist-card-inner {
  background-color: var(--style-graphite-mid);
  box-shadow: 0px 4px 8px 0px rgba(0, 0, 0, 0.85);
  border-radius: 0.5rem;
  padding: 1rem;
}

.light-style .watchlist-card-inner {
  background-color: var(--style-white);
  box-shadow: 0px 1px 5px 0px rgba(221, 221, 221, 0.85);
  border-radius: 0.5rem;
  padding: 1rem;
}

.watchlist-card .badge {
  padding: 4px 12px;
  font-weight: 600;
}

.badge {
  font-family: Open Sans;
  /* font-size: 14px; */
  font-size: 1.16rem;
  font-weight: 700;
  /* line-height: 19.07px; */
  line-height: 1.58rem;
  padding: 0.5rem 1rem;
  border-radius: 2.5rem;
}

.bg-emergency {
  background: var(--danger);
}

.bg-warning {
  background: var(--warning);
}

.bg-warning-dark {
  background: var(--warning);
}

.bg-notice {
  background: var(--gray-7);
}

.watchlist-avatar {
  width: 1.5rem;
  height: 1.5rem;
  object-fit: cover;
  object-position: 50% 100%;
}

.custom-card {
  background: var(--card-bg);
  /* padding: 1rem; */
  padding: 1.3rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  border-radius: 0.5rem;
}

/* .custom-map-card {
  justify-content: end;
} */

.light-style .custom-card {
  background: var(--card-bg);
  /* box-shadow: 0 0.25rem 0.75rem rgba(15, 20, 34, 0.05); */
  /* box-shadow: 0px 2px 6px 0px #0000001A;
  box-shadow: 0px 0px 4px 0px #0000000D; */
  box-shadow: 0 0.25rem 1.125rem rgba(75, 70, 92, 0.2);
}

.light-style .bs-stepper {
  background-color: transparent !important;
}

.active-dot {
  background: var(--success);
}

.bg-dark-active {
  background: var(--success);
}

.light-style .offline-dot {
  /* background: var(--style-white); */
  background: var(--style-text-dark);
}

.dark-style .offline-dot {
  background: var(--style-white);
  /* background: var(--style-text-dark); */
}

.emergency-dot {
  background: var(--danger);
}

.warning-dot {
  background: var(--warning);
}

.notice-dot {
  background: var(--style-text-light);
  border: 1px solid var(--gray-4);
}

.table-status-dot {
  width: 1.125rem;
  height: 1.125rem;
  border-radius: 100%;
}

.table thead th,
.table tfoot th {
  /* font-size: 14px; */
  /* font-size: 0.875rem; */
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-white) !important;
  /* background-color: var(--style-slate-blue-deep) !important; */
  background-color: var(--dark-primary) !important;
  text-transform: none;
}

.w-h-8 {
  width: 0.5rem;
  height: 0.5rem;
  flex-shrink: 0;
}

.w-h-14 {
  width: 0.875rem;
  height: 0.875rem;
  flex-shrink: 0;
}

.w-h-16 {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
}

.w-h-18 {
  width: 1.125rem;
  height: 1.125rem;
  flex-shrink: 0;
}

.w-h-20 {
  width: 1.25rem;
  height: 1.25rem;
  flex-shrink: 0;
}

.w-h-24 {
  width: 1.5rem;
  height: 1.5rem;
  flex-shrink: 0;
}

.w-h-32 {
  width: 2rem;
  height: 2rem;
  flex-shrink: 0;
}

.dark-style .table.table-striped tbody tr:nth-of-type(odd) {
  background-color: var(--style-graphite-mid);
}

.dark-style .table.table-striped tbody tr:nth-of-type(even) {
  background-color: var(--style-text-light);
}

.dark-style .table.table-striped.striped-light tbody tr:nth-of-type(even) {
  background-color: rgba(32, 32, 32, 0.5);
}

.light-style .table> :not(caption)>*>* {
  color: var(--style-text-dark);
}

.form-switch .form-check-input {
  height: 2.5rem;
  width: 4.375rem;
  background-color: var(--gray-3) !important;
  cursor: pointer;
}

/* .form-switch .form-check-input:disabled {
  opacity: 1;
} */
.form-switch .form-check-input:not(:checked):not(:focus),
.form-switch .form-check-input:not(:checked),
.form-switch .form-check-input:focus {
  background-image: url(../../assets/img/switch-off.png) !important;
  background-color: var(--gray-3) !important;
}

.form-switch .form-check-input:checked {
  background-image: url(../../assets/img/switch-on.png) !important;
  background-color: var(--primary) !important;
  border-color: var(--primary) !important;
  box-shadow: none !important;
}

.form-switch .form-check-input:focus {
  border: none;
}

/* Datatable CSS */
.dataTables_paginate .page-item.active .page-link {
  border-radius: 0px;
}

.dataTables_info {
  display: inline-block;
}

.dataTables_paginate {
  display: inline-block;
  float: right;
}

div.dataTables_wrapper div.dataTables_paginate ul.pagination {
  margin-bottom: 10px;
}

.dark-style input[type="file"].form-control::file-selector-button {
  background-color: var(--primary);
  color: var(--text-white);
}

.dark-style input[type="file"].form-control:hover::file-selector-button {
  background-color: var(--primary);
  color: var(--text-white);
}

div.dataTables_paginate ul.pagination .page-item,
ul.pagination.custom-pagination .page-item {
  position: relative;
}

div.dataTables_paginate ul.pagination .page-item .page-link img,
ul.pagination.custom-pagination .page-item .page-link img {
  display: none;
}

div.dataTables_paginate ul.pagination .page-item.previous .page-link:after,
ul.pagination.custom-pagination .page-item.prev .page-link:after {
  content: '';
  position: absolute;
  top: 50%;
  left: 57%;
  transform: translate(-50%, -50%) rotate(135deg);
  display: inline-block;
  border: solid var(--text-white);
  border-width: 0 2px 2px 0;
  padding: 3px;
  width: 0;
  height: 0;
}

div.dataTables_paginate ul.pagination .page-item.next .page-link:after,
ul.pagination.custom-pagination .page-item.next .page-link:after {
  content: '';
  position: absolute;
  top: 50%;
  left: 43%;
  transform: translate(-50%, -50%) rotate(-45deg);
  display: inline-block;
  border: solid var(--text-white);
  border-width: 0 2px 2px 0;
  padding: 3px;
  width: 0;
  height: 0;
}

table.dataTable {
  margin-top: 0px !important;
}

table.dataTable td {
  vertical-align: top;
  border: 0px;
  /* font-size: 0.875rem; */
  font-size: 1rem;
}

.dark-style table.dataTable td,
.dark-style table.dataTable th {
  padding: 12px 8px;
  /* color: #b4b7bd; */
  color: var(--gray-3);
  border-color: var(--primary) !important;
  /* border-color: transparent !important; */
  box-shadow: none !important;
}

.dashboard-event-name {
  color: var(--style-text-dark);
}

.dashboard-event-name:hover {
  color: var(--style-text-dark);
}

.dark-style .dashboard-event-name {
  color: var(--gray-3);
}

div.dataTables_wrapper div.dataTables_paginate ul.pagination .page-item.previous .page-link {
  background-color: var(--dark-primary);
}

div.dataTables_wrapper div.dataTables_paginate ul.pagination .page-item.next .page-link {
  background-color: var(--dark-primary);
}

.dataTables_paginate .pagination:not([class*="pagination-"]) .page-item.active .page-link {
  /* background-color: var(--light-primary) !important; */
  box-shadow: none !important;
  position: relative;
  color: var(--gray-6);
}

.dataTables_paginate .pagination:not([class*="pagination-"]) .page-item.active .page-link:after {
  content: "";
  /* background-color: var(--light-primary) !important; */
  /* background-color: var(--fc-today-bg-color, rgb(237 229 189)) !important; */
  /* background-color: #00496A33; */
  background-color: var(--primary-gradient-dark);
  opacity: 0.5;
  position: absolute;
  top: 0px;
  z-index: -1;
  left: 0px;
  width: 100%;
  height: 100%;
}

.dark-style .dataTables_paginate .pagination:not([class*="pagination-"]) .page-item.active .page-link:after {
  content: "";
  /* background-color: var(--light-primary) !important; */
  /* background-color: var(--fc-today-bg-color, rgb(237 229 189)) !important; */
  /* background-color: #00496A33; */
  background: var(--primary-gradient-dark) !important;
  opacity: 0.5;
  position: absolute;
  top: 0px;
  z-index: -1;
  left: 0px;
  width: 100%;
  height: 100%;
}

table.dataTable thead .sorting::before,
table.dataTable thead .sorting_asc::before,
table.dataTable thead .sorting_desc::before {
  background: url(../img/arrow_drop_up.png) !important;
  background-size: contain;
  height: 5px !important;
  width: 10px !important;
  top: 45% !important;
  content: "" !important;
}

table.dataTable thead .sorting::after,
table.dataTable thead .sorting_asc::after,
table.dataTable thead .sorting_desc::after {
  content: "";
  display: none !important;
}

table.dataTable .select-checkbox {
  width: 10px !important;
  min-width: 10px !important;
  padding-right: 0px !important;
}

table.dataTable thead th.select-checkbox:before {
  display: none;
}

table.dataTable thead .sorting:after,
table.dataTable thead .sorting_asc:after,
table.dataTable thead .sorting_desc:after {
  display: none;
}

.btn-outline-white {
  border: 1px solid var(--style-white) !important;
  color: var(--style-white) !important;
  background-color: transparent !important;
}

.btn-outline-white.active,
.btn-outline-white:active,
.btn-outline-white:focus,
.btn-outline-white:hover {
  border: 1px solid var(--style-white) !important;
  color: var(--style-white) !important;
  background-color: transparent !important;
}

table.dataTable .btn-outline-white {
  font-size: 0.875rem;
  padding: 0.3rem 1.2rem;
  font-weight: 500;
}

table.dataTable .action-btn-box .btn-outline-primary {
  font-size: 0.875rem;
  padding: 0.3rem 1.2rem;
  font-weight: 500;
}


.dataTables_paginate .pagination:not([class*="pagination-"]) .page-item .page-link {
  background-color: var(--style-white);
  /* font-size: 16px; */
  font-size: 1rem;
  height: 2.5rem;
  /* line-height: 20px; */
  line-height: 1.31rem;
  font-weight: 600;
  color: var(--style-text-dark);
  padding: 0.5rem 1rem;
  border: 1px solid var(--style-text-dark);
  border-right-width: 0px;
  border-radius: 0px;
}

.dark-style .dataTables_paginate .pagination:not([class*="pagination-"]) .page-item .page-link {
  background-color: transparent;
  /* font-size: 16px; */
  font-size: 1rem;
  height: 2.5rem;
  /* line-height: 20px; */
  line-height: 1.31rem;
  font-weight: 600;
  color: var(--style-soft-white);
  padding: 0.5rem 1rem;
  border: 1px solid var(--style-text-light);
  border-right-width: 0px;
  /* border-radius: 0px; */
}

.light-style table.dataTable.table-striped>tbody>tr.odd>* {
  box-shadow: none !important;
  background-color: var(--style-white);
}

.light-style table.dataTable.table-striped>tbody>tr.even>* {
  box-shadow: none !important;
  background-color: var(--gray-2);
}

/* Ensure highlighted report rows override DataTables striping */
.light-style table.dataTable.table-striped>tbody>tr.report-tr>* {
  background-color: #b5635e !important;
  color: #f2f2f2 !important;
}

.dataTables_paginate .pagination:not([class*="pagination-"]) .page-item:not(.active) .page-link:hover {
  background-color: var(--style-white);
  color: var(--style-text-dark);
}

.dataTables_paginate .pagination:not([class*="pagination-"]) .page-item.previous .page-link:hover,
.dataTables_paginate .pagination:not([class*="pagination-"]) .page-item.next .page-link:hover {
  background-color: var(--dark-primary);
  /* color: var(--style-text-dark); */
}

.dataTables_paginate .page-item:first-child:not(.prev-item) .page-link {
  border-top-left-radius: 6px;
  border-bottom-left-radius: 6px;
}

.dataTables_paginate .page-item:last-child:not(.next-item) .page-link {
  border-top-right-radius: 6px;
  border-bottom-right-radius: 6px;
  border-right-width: 1px;
}

.light-style div.dataTables_wrapper .dataTables_info {
  color: var(--style-text-dark) !important;
}

div.dataTables_wrapper .dataTables_info {
  padding-top: 0.7rem !important;
  /* font-size: 16px; */
  font-size: 1rem !important;
  font-weight: 400 !important;
  color: var(--style-white) !important;
}

div.dataTables_wrapper .page-item {
  border-radius: 5px;
}

div.dataTables_wrapper .page-item.active .page-link {
  transform: scale(1);
}

div.dataTables_wrapper .page-item:not(:first-child) .page-link {
  margin-left: 0px;
}

.dark-style .pagination .page-item.prev-item .page-link:before,
.dark-style .pagination .page-item.previous .page-link:before,
.dark-style .pagination .page-item.prev .page-link:before {
  display: none;
}

.dark-style .pagination .page-item.next-item .page-link::after,
.dark-style .pagination .page-item.next .page-link::after,
.page-item.next .page-link:hover:after {
  display: none;
}

table.dataTable thead>tr>th.sorting_asc:before {
  opacity: 1;
}

table.dataTable thead>tr>th.sorting_desc:before {
  /* opacity: 0.5; */
  opacity: 1;
  transform: rotate(180deg);
}

.grid-2 {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr);
}

.object-cover {
  object-fit: cover;
}

.map-wrapper {
  position: relative;
  height: 100%;
}

.map-layout {
  background-color: var(--gray-7);
  height: 100%;
  position: relative;
}

.map-layout::after {
  /* content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0%;
  left: 0%;
  z-index: 9;
  background: #0000009e; */
}

.map-info {
  /* position: absolute;
  z-index: 9;
  top: 0px;
  left: 0px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  width: 100%;
  padding: 30px; */
}

#customMap {
  height: calc(100vh - 70px);
}

.modal #customMap {
  height: 75vh !important;
}

.map-search-wrapper {
  position: absolute;
  width: 100%;
  top: 0px;
}

.map-button-wrapper {
  width: 180px;
  position: absolute;
  bottom: 30px;
  left: 30px;
}

.map-search {
  padding: 18px 30px;
  background: rgba(255, 255, 255, 0.1);
  display: flex;
  gap: 18px;
}

.map-filter-applied {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 50px;
  padding: 8px 24px;
  margin: 15px 30px 0px;
}

.filter-tag-wrapper {
  display: flex;
  align-items: start;
  column-gap: 15px;
  row-gap: 10px;
  flex-wrap: wrap;
}

.filter-tag {
  /* font-size: 14px; */
  font-size: 1.16rem;
  font-weight: 600;
  /* line-height: 19px; */
  line-height: 1.58rem;
  background: var(--style-link-blue);
  border: 1px solid var(--style-link-blue);
  padding: 4px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  border-radius: 38px;
}

#mapInfoPopup {
  background: var(--style-white);
  padding: 0px;
  border-radius: 16px;
  min-width: 350px;
}

/* #mapInfoPopup #bodyContent {
  display: flex;
  flex-direction: column;
  gap: 10px;
} */
.gm-style .gm-style-iw-c {
  background: var(--style-text-light);
  padding: 0px !important;
  border-radius: 16px;
  box-shadow: none;
  overflow: visible;
}

.gm-style-iw-d {
  overflow: auto !important;
}

.gm-style .gm-style-iw-tc::after {
  background: var(--style-text-light) !important;
  top: -2px;
}

.gm-ui-hover-effect {
  width: 24px !important;
  height: 24px !important;
  opacity: 0.8 !important;
}

.gm-style .gm-style-iw {
  /* font-size: 14px; */
  font-size: 1.16rem;
}

.gm-style-iw-chr {
  position: absolute;
  top: -30px;
  right: -5px;
}

.gm-ui-hover-effect>span {
  background-color: var(--style-white);
  margin: 0px !important;
}

.gm-style-moc {
  background-color: rgb(0 0 0 / 90%);
}

.gm-style-cc {
  display: none;
}

.gmnoprint div {
  border: 1px solid var(--gray-2) !important;
  background-color: var(--style-text-light) !important;
  box-shadow: none !important;
  border-radius: 8px !important;
  outline: none;
}

.map-user-infobox {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 16px;
}

.map-infobox-title {
  border-top-left-radius: 16px;
  border-top-right-radius: 16px;
  padding: 9px 16px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
}

.map-infobox-border {
  display: flex;
  flex-direction: column;
  gap: 10px;
  border-bottom-right-radius: 16px;
  border-bottom-left-radius: 16px;
  padding: 16px;
}

.map-infobox-emergency-border {
  border: 2px solid var(--danger);
}

.map-infobox-warning-border {
  border: 2px solid var(--warning);
}

.map-infobox-notice-border {
  border: 2px solid var(--gray-7);
}

.border-radius-top-16 {
  border-top-right-radius: 16px;
  border-top-left-radius: 16px;
}


.modal {
  /* z-index: 99999; */
}

.modal-content {
  background-color: var(--gray-0);
}

.dark-style .modal .modal-content,
.dark-style .modal .modal-body,
.dark-style .modal .modal-footer {
  /* background-color: #f5f5f5; */
}

.dark-style .modal .modal-header {
  padding: 1rem;
  padding-bottom: 0.1rem;
  justify-content: space-between;
}

.dark-style .modal .modal-body {
  padding: 1rem;
  padding-bottom: 1.1rem;
}

.modal .modal-header .btn-close {
  background-image: url(../../assets/img/modal-close.png);
  position: relative;
  background-color: transparent;
  background-repeat: no-repeat;
  padding: 0px;
  margin: 0px;
  right: 0px !important;
  top: 0px !important;
  height: 1.5rem;
  width: 1.5rem;
  box-shadow: none;
  background-size: contain;
  transition: none;
  transform: none !important;
}

.dark-style .modal .modal-header .btn-close {
  background-image: url(../../assets/img/modal-close1.png);
}

.dark-style .modal .modal-content {
  border: 1px solid var(--gray-5);
  /* overflow: hidden; */
  background-color: var(--style-graphite-mid);
}

.mapfilter-sidebar {
  width: 0;
  position: fixed;
  z-index: 9999;
  top: 70px;
  right: 0;
  overflow-x: hidden;
  transition: 0.2s;
  height: 100vh;
  margin-right: 1px;
  background-color: var(--style-graphite-deep);
}

.mapfilter-sidebar.open {
  display: flex;
  gap: 16px;
  flex-direction: column;
  padding: 16px;
  width: 366px;
  height: calc(100vh - 70px);
}

.mapfilter-sidebar .select2-search__field {
  width: auto !important;
}

.fs-32 {
  /* font-size: 32px; */
  font-size: 2.66rem;
}

.modern-nav-toggle {
  display: none;
}

.bg-primary-black {
  background-color: var(--style-text-light) !important;
}

.fs-16 {
  /* font-size: 16px; */
  font-size: 1rem;
}

.view-notification-wrapper {
  display: flex;
  gap: 30px;
  flex-direction: row;
  width: 100%;
}

.notification-left {
  display: flex;
  flex-direction: column;
  gap: 22px;
  width: 253px;
  flex-shrink: 0;
}

.notification-right {
  width: calc(100% - 275px);
}

.notification-left-info {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

#selectMap .modal-dialog {
  max-width: 80%;
}

.select-map-image {
  max-height: 80vh;
  min-height: 500px;
}

.profile-image {
  width: 164px;
  height: 164px;
  object-fit: cover;
  object-position: 50% 100%;
}

.graph-filter-btn-group.btn-group label[class*="btn-outline-"] {
  color: var(--style-link-blue) !important;
  /* font-size: 14px; */
  font-size: 1.16rem;
  padding: 3px 17px;
  font-weight: 600;
}

.graph-filter-btn-group .btn-check:checked+.btn-outline-primary,
.graph-filter-btn-group .btn-check:active+.btn-outline-primary {
  color: var(--style-white) !important;
  background-color: var(--style-link-blue) !important;
}

.graph-filter-btn-group .btn {
  border-radius: 30px;
}

.graph-filter-btn-group label {
  cursor: pointer;
}

.timeline-btn-group.btn-group label[class*="btn-outline-"] {
  color: var(--style-white) !important;
  /* font-size: 17px; */
  font-size: 1.41rem;
  padding: 5px 18px;
  font-weight: 500;
  cursor: pointer;
}

.sleeping-graph {
  display: none;
}

.timeline-btn-group .btn-check:checked+.btn-outline-primary,
.timeline-btn-group .btn-check:active+.btn-outline-primary {
  color: var(--style-white) !important;
  background-color: var(--style-link-blue) !important;
}

.timeline-btn-group .btn-outline-primary {
  border: 2px solid var(--style-link-blue) !important;
  border-radius: 8px;
}

.checkbox-wrapper .form-check {
  padding-left: 2.3rem;
}

.checkbox-wrapper .form-check .form-check-input {
  /* width: 24px;
  height: 24px; */
  width: 1.375rem;
  height: 1.375rem;
  margin-left: -2.3rem;
  box-shadow: none !important;
  border-color: var(--style-soft-white);
  cursor: pointer;
}

.checkbox-wrapper.dataTable .form-check-input {
  width: 1.125rem;
  height: 1.125rem;
  border-radius: 0px;
  border-color: var(--style-white) !important;
  cursor: pointer;
}

.checkbox-wrapper .form-check-label {
  font-size: 1rem;
  /* font-size: 1.33rem; */
  /* font-weight: 600; */
  /* list-style: 24px; */
  line-height: 1.375rem;
}

.checkbox-wrapper .form-check:not(.form-switch) .form-check-input[type="checkbox"]:checked {
  /* background-size: 85%; */
  background-size: 93%;
}

.checkbox-wrapper .form-check-input:checked {
  /* background-color: var(--style-white);
  border-color: var(--style-white); */
  background-color: var(--primary) !important;
  border-color: var(--primary) !important;
}

.radio-wrapper .form-check-input:checked {
  border-color: var(--style-white);
  position: relative;
}

.radio-wrapper .form-check-input:checked:after {
  content: "";
  position: absolute;
  top: 1px;
  left: 1px;
  /* width: 1.125rem;
  height: 1.125rem; */
  width: 1.375rem;
  height: 1.375rem;
  background-color: transparent;
  border-radius: 100%;
  /* border: 0.125rem solid var(--style-graphite-mid); */
}

.radio-wrapper .form-check-input:checked[type=radio] {
  background-image: none;
}

.checkbox-wrapper .form-check-input[type=checkbox] {
  appearance: none;
  /* Remove default checkbox styling */
  -webkit-appearance: none;
  /* For Safari */
  width: 1.375rem;
  height: 1.375rem;
  background-color: transparent;
  /* border: 0.125rem solid var(--style-graphite-mid); */
  border-radius: 4px;
  /* Optional: for rounded corners */
  position: relative;
}

.checkbox-wrapper .form-check-input:checked[type=checkbox] {
  /* background-image: none !important; */
  /* background-image: url(../../assets/img/white-check.svg); */
  background-color: var(--primary) !important;
  /* Background color for checked state */
}

.dark-style .checkbox-wrapper .form-check-input:not(:checked):not(:indeterminate):not(:focus) {
  /* border-color: var(--style-text-dark); */
  border-color: var(--style-white);
}

.light-style .checkbox-wrapper .form-check-input:not(:checked):not(:indeterminate):not(:focus) {
  /* border-color: var(--style-text-dark); */
  border-color: var(--style-text-dark);
}

.checkbox-wrapper .select-dataset:not(:checked):not(:indeterminate):not(:focus) {
  border-color: var(--style-soft-white);
}

.checkbox-wrapper .form-check-input:not(:checked):not(:indeterminate) {
  background-color: transparent;
}

.dark-style .checkbox-wrapper .form-check-input:not(:checked) {
  /* border-color: var(--style-text-dark); */
  border-color: var(--style-white);
  background-color: transparent;
}

/* Match .form-control:hover/:focus — .form-check-input is not .form-control. Use .form-check-input (not only .form-check .form-check-input) so .form-check.checkbox-wrapper on one row matches; include .radio-wrapper for radios */
.dark-style .checkbox-wrapper .form-check-input:hover:not(:disabled):not([disabled]),
.dark-style .checkbox-wrapper .form-check-input:focus,
.dark-style .checkbox-wrapper .form-check-input:focus-visible,
.dark-style .radio-wrapper .form-check-input:hover:not(:disabled):not([disabled]),
.dark-style .radio-wrapper .form-check-input:focus,
.dark-style .radio-wrapper .form-check-input:focus-visible {
  border: 1px solid var(--style-success) !important;
  box-shadow: inset 0 0 0 1px var(--style-success) !important;
  outline: none;
}

.light-style .checkbox-wrapper .form-check-input:hover:not(:disabled):not([disabled]),
.light-style .checkbox-wrapper .form-check-input:focus,
.light-style .checkbox-wrapper .form-check-input:focus-visible,
.light-style .radio-wrapper .form-check-input:hover:not(:disabled):not([disabled]),
.light-style .radio-wrapper .form-check-input:focus,
.light-style .radio-wrapper .form-check-input:focus-visible {
  border: 1px solid var(--style-success) !important;
  box-shadow: inset 0 0 0 1px var(--style-success) !important;
  outline: none;
}

/* DBS wizard footer — match form field focus ring (Back / Next / Submit) */
.dark-style .footer-btn-fix .btn:focus,
.dark-style .footer-btn-fix .btn:focus-visible {
  border: 2px solid var(--style-success) !important;
  box-shadow: inset 0 0 0 1px var(--style-success);
  outline: none;
}

.light-style .footer-btn-fix .btn:focus,
.light-style .footer-btn-fix .btn:focus-visible {
  border: 2px solid var(--style-success) !important;
  box-shadow: inset 0 0 0 1px var(--style-success);
  outline: none;
}

.light-style .checkbox-wrapper .form-check-input:not(:checked):not(:indeterminate) {
  /* border-color: var(--style-text-dark); */
  border-color: var(--style-text-dark);
}

.checkbox-wrapper .select-dataset:not(:checked) {
  border-color: var(--style-soft-white);
}


.dark-style .select2-container .select2-selection__arrow b {
  background-image: url(../../assets/img/expand_more.svg);
  background-size: 1.5rem;
  height: 1.5rem;
  width: 1.5rem;
  top: 23%;
}

.dark-style .flatpickr-calendar {
  background: var(--style-text-light);
  border-color: var(--gray-10);
  box-shadow: none;
}

.dark-style .flatpickr-time {
  border: 1px solid var(--style-text-light);
  background-color: var(--style-text-light);
}

.dark-style .flatpickr-time input {
  color: var(--light-primary);
}

.flatpickr-calendar .flatpickr-day.today {
  /* border-color: var(--style-link-blue); */
  border-color: var(--primary) !important;
}

.flatpickr-calendar .flatpickr-day.selected,
.flatpickr-calendar .flatpickr-day.selected:hover {
  background: var(--primary) !important;
  color: var(--style-white);
  border-color: var(--primary) !important;
}

.dark-style .flatpickr-day {
  color: var(--light-primary);
}

.dark-style .flatpickr-day.nextMonthDay,
.dark-style .flatpickr-day.prevMonthDay,
.dark-style .flatpickr-day.flatpickr-disabled {
  color: var(--dark-primary);
}

.dark-style .flatpickr-prev-month,
.dark-style .flatpickr-next-month {
  background-color: var(--dark-primary);
}

.flatpickr-current-month {
  top: 0.8rem;
}

.dark-style .select2-container--default .select2-selection--single .select2-selection__arrow b {
  background-image: url(../../assets/img/expand_more.png);
}

.select2-container.select2-container--open .select2-selection .select2-selection__arrow b {
  transform: rotate(180deg) !important;
}

.dark-style .select2-selection.select2-selection--multiple::after {
  background-image: url(../../assets/img/expand_more.png);
}

.select2-selection.select2-selection--multiple::after {
  content: "";
  position: absolute;
  right: 9px;
  background-image: url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%236f6b7d' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='white' stroke-opacity='0.2' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-size: 1.5rem;
  height: 1.5rem;
  width: 1.5rem;
  top: 25%;
  cursor: pointer;
}

.select2-container.select2-container--open .select2-selection::after {
  transform: rotate(180deg) !important;
}

.tooltip-inner {
  font-size: 0.875rem;
}

.flatpickr-basic {
  position: relative;
}

.flatpickr-basic:after {
  content: "";
  position: absolute;
  right: 9px;
  background-image: url(../../assets/img/expand_more.png);
  background-size: 1.5rem;
  height: 1.5rem;
  width: 1.5rem;
  top: 25%;
  cursor: pointer;
}

.dark-style .select2-container .select2-selection--multiple .select2-selection__choice {
  color: var(--style-white) !important;
  border: none;
  /* font-size: 15px; */
  font-size: 0.93rem;
  font-weight: 400;
  background: rgba(255, 255, 255, 0.2) !important;
  /* border-radius: 2.5rem;
  padding: 0.325rem 0.62rem; */
  /* margin-right: 0.5rem;
  margin-top: 0.45rem !important;
  padding-right: 1.7rem !important; */
  /* margin-right: 0.27em;
  margin-top: 0.27em; */
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
  color: var(--style-white) !important;
  opacity: 1 !important;
  top: 0.28rem;
  right: 0.2rem !important;
}

.light-style .select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
  color: var(--style-text-dark) !important;
  opacity: 1 !important;
  top: 0.28rem;
  /* top: 3px; */
  right: 0.2rem !important;
}

.light-style .select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--style-text-dark);
}

.light-style .select2-container--default .select2-selection--multiple .select2-selection__choice {
  color: var(--style-text-dark);
}

.dark-style .select2-container .select2-selection--multiple .select2-selection__choice__remove:before {
  background-image: url(../../assets/img/close_small.png);
  background-size: 90%;
  background-repeat: no-repeat;
  top: 47%;
  left: 0px;
  width: 11px;
  height: 11px;
}

.select2-container--default .select2-selection--multiple {
  min-height: 2.5rem !important;
}

.select2-container--classic.select2-container--focus .select2-selection--multiple,
.select2-container--default.select2-container--focus .select2-selection--multiple {
  /* border-color: var(--style-text-light) !important; */
}

.select2-container--default .select2-selection--multiple .select2-selection__rendered {
  padding: 0px 12px;
}

.profile-wrapper {
  border-radius: 100% !important;
  overflow: hidden;
  width: 4.5rem;
  height: 4.5rem;
  outline: 1px solid var(--gray-1);
  background: var(--gray-3);
  border-radius: 100%;
  flex-shrink: 0;
}

.agency-logo-wrapper {
  border-radius: 0% !important;
  width: 15.5rem;
  height: 5rem;
}

.file-upload {
  display: none;
}

.profile-pic {
  /* width: 128px;
  height: 128px; */
  width: 4.5rem;
  height: 4.5rem;
  object-fit: contain;
  /* object-fit: cover;
  object-position: 50% 100%; */
  display: inline-block;
}

.program-logo {
  width: 8rem;
  height: 8rem;
  border-radius: 0.5rem !important;
}

.program-logo .profile-pic {
  width: 8rem;
  height: 8rem;
}

.program-pic {
  width: 8rem;
  height: 8rem;
  object-fit: cover;
  object-position: 50% 100%;
  display: inline-block;
}

.agency-logo {
  width: 100%;
  height: 80px;
}

.agency-color {
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 100%;
  background-color: var(--primary);
}

.g-13,
.gx-13 {
  --bs-gutter-x: 1.3rem;
}

.g-13,
.gy-13 {
  --bs-gutter-y: 1.3rem;
}

.account-badge {
  color: var(--style-white) !important;
  /* font-size: 15px; */
  font-size: 1.25rem;
  font-weight: 500;
  background: rgba(255, 255, 255, 0.2) !important;
  border-radius: 2.5rem;
  padding: 2px 12px;
}

.light-style .form-control::placeholder {
  /* font-weight: 600; */
  color: var(--text-tertiary) !important;
}

.light-style .form-control::-ms-input-placeholder {
  /* font-weight: 600; */
  color: var(--text-tertiary) !important;
}

.light-style .form-control:disabled {
  background-color: var(--primary-soft) !important;
}

.light-style .select2-selection__placeholder {
  color: var(--text-tertiary) !important;
}

.navigation-main .nav-item .badge {
  padding: 5px 9px;
  font-size: 1.16rem;
  font-weight: 500;
  line-height: 1rem;
}

.fs-40 {
  font-size: 3.33rem;
  line-height: 4.5rem;
}

.dark-style .dropdown-menu .dropdown-item {
  color: var(--style-soft-white);
}

.header-navbar .navbar-container ul.navbar-nav li.dropdown-user .dropdown-menu {
  width: 14rem;
  background: var(--gray-7);
}

.dark-style .dropdown-menu .dropdown-item:hover,
.dark-style .dropdown-menu .dropdown-item:focus {
  background: var(--style-slate-blue-deep);
  color: var(--style-white);
}

.header-navbar .navbar-container ul.navbar-nav li.dropdown-user .dropdown-menu i,
.header-navbar .navbar-container ul.navbar-nav li.dropdown-user .dropdown-menu svg {
  width: 18px;
  height: 18px;
}

.dropdown-menu {
  font-size: 1.16rem;
}

.dropdown-item {
  padding: 0.75rem 1.38rem;
}

.feather,
[data-feather] {
  width: 1.16rem;
  height: 1.16rem;
}



.score-trend-wrapper {
  display: flex;
  gap: 1.5rem;
  height: 100%;
}

.score-graph {
  height: 5rem;
  /* background-color: var(--style-soft-white); */
  /* background: rgb(58, 58, 58); */
  background-color: var(--style-white);
}

.dark-style .score-graph {
  background-color: var(--style-graphite-mid);
}

.score-trend-2 {
  width: 1px;
  background: var(--style-text-mid);
}

.score-trend-info {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.score-trend-info-inner {
  display: flex;
  gap: 0.7rem;
}

.score-trend-info-inner .text-light-red {
  flex-shrink: 0;
}

.score-trend-info-inner .text-light-positive {
  flex-shrink: 0;
}

.score-trend-info-inner .text-light-nagative {
  flex-shrink: 0;
}

.score-arrow-up {
  height: 1.5rem;
}

.criteria-info-wrapper {}

/* Graph */
.graph-legend {
  display: flex;
  gap: 1.5rem;
}

.legend-box {
  height: 1rem;
  width: 1rem;
}

.male-box {
  background: var(--legend-male);
}

.female-box {
  background: var(--legend-female);
}

.budget-used-box {
  background: var(--budget-used);
}

.budget-remaining-box {
  background: var(--budget-remaining);
}

.graph-box {
  width: 100%;
  height: 10rem;
  background-color: var(--style-soft-white);
}

/* Graph */

.gap-75 {
  gap: 0.75rem !important;
}

.gap-50 {
  gap: 0.5rem !important;
}

.mb-50 {
  margin-bottom: 0.5rem !important;
}

.header-menu .header-icon {
  width: 1.87rem;
  height: 1.87rem;
}

.header-menu li .header-icon-profile {
  width: 2.435rem;
  height: 2.435rem;
  position: relative;
  top: 2px;
}

.header-menu .header-logout-icon {
  /* width: 2.435rem;
    height: 2.435rem; */
  position: relative;
  top: 1px;
  font-size: 2.16rem;
  margin-left: -5px;
}

.dark-style .bg-menu-theme .menu-inner-shadow {
  background: linear-gradient(var(--style-text-light) 41%, rgba(22, 25, 49, 0.11) 95%, rgba(22, 25, 49, 0));
}

.light-style .bg-menu-theme .menu-inner-shadow {
  background: none;
  /* box-shadow: 0 0.25rem 0.75rem rgba(15, 20, 34, 0.05); */
}

.light-style .bg-menu-theme {
  background-color: var(--style-white) !important;
  /* box-shadow: none; */
}

.custom-pagination {
  display: flex;
  justify-content: space-between;
  align-items: center;
  text-align: center;
  gap: 0.2rem;
}

.custom-pagination .page-link {
  font-size: 1rem;
  height: 2.5rem;
  font-weight: 500;
  color: var(--style-white);
  padding: 0.5rem 1rem;
  /* border: 1px solid var(--style-text-light); */
  border: 1px solid var(--style-text-dark);
  border-right-width: 0px;
  border-radius: 0px;
}

.custom-pagination .prev .page-link,
.custom-pagination .next .page-link {
  background-color: var(--dark-primary);
  border-radius: 6px;
  display: block;
}

.custom-pagination .next .page-link {
  margin-left: 0px;
}

.action-btn-box {
  display: flex;
  gap: 1rem;
  align-items: center;
  justify-content: end;
}

.dark-style .report-tr {
  background-color: var(--report-stale-bg) !important;
  border-bottom: 1px solid var(--style-graphite-mid);
}

.light-style .report-tr {
  /* border-bottom: 1px solid #8c0c04; */
  /* border-bottom: 1px solid #a7453f; */
  border-bottom: 1px solid var(--report-stale-border);
  /* background-color: #8c0c04 !important; */
  /* background-color: #a7453f !important; */
  background-color: var(--report-stale-bg-light) !important;
}

.light-style .report-tr td,
.light-style .report-tr .text-white {
  color: var(--style-soft-white) !important;
}

/* .dark-style input.form-control:not(:focus), .dark-style select.form-select:not(:focus), .dark-style textarea.form-control:not(:focus) {
    border-color: var(--style-text-light);
} */

.criteria-badge {
  background-color: var(--dark-primary);
  padding: 0.5rem 1rem;
  text-align: center;
  color: var(--text-white);
}

table.dataTable .form-switch .form-check-input {
  height: 28px !important;
  width: 49px !important
}

.plan-tabs {
  overflow: hidden;
  margin-bottom: 0px;
  text-align: center;
  display: flex;
  justify-content: space-between;
  /* flex-wrap: wrap; */
  padding: 0px;
  padding-bottom: 1.5rem;
  display: grid;
  grid-template-columns: repeat(6, 1fr);

}

.engag-tabs {
  grid-template-columns: repeat(5, 1fr);
}

.three-tabs{
  grid-template-columns: repeat(3, 1fr);
}

.plan-tabs li.active.content.remove-after:after{
  display: none;
}

.plan-tabs li.remove-after:after{
  display: none;
}

.engagement-tabs {
  grid-template-columns: repeat(7, 1fr);
}

.schedule-tabs {
  grid-template-columns: repeat(3, 1fr);
}

.plan-tabs li {
  list-style-type: none;
  /* color: #D9D9D9; */
  /* color: var(--text-black); */
  color: var(--style-text-dark);
  font-size: 1rem;
  font-weight: 600;
  /* width: 33.33%;
  float: left; */
  position: relative;
  flex-grow: 1;
  padding: 0px 0.2rem;
  padding-left: 1.8rem;
}

.dark-style .plan-tabs li {
  color: var(--gray-4);
}

.plan-tabs li:after {
  content: "";
  /* counter-increment: step; */
  width: 1.5rem;
  height: 1.5rem;
  display: block;
  font-size: 10px;
  color: var(--style-white);
  /* background: var(--style-graphite-mid); */
  background: var(--light-primary);
  border-radius: 100%;
  margin: 0.5rem auto 0 auto;
  position: absolute;
  left: 50%;
  bottom: -1.5rem;
}

.plan-tabs li:before {
  content: "";
  width: 100%;
  height: 2px;
  /* background: var(--style-graphite-mid); */
  background: var(--light-primary);
  position: absolute;
  left: -50%;
  bottom: -0.9rem;
  z-index: -1;
}

.plan-tabs li:first-child:before {
  content: none;
}

.plan-tabs li.active {
  color: var(--primary) !important;
  font-weight: 600;
}

.plan-tabs li.active a {
  color: var(--primary) !important;
  font-weight: 600;
}

.plan-tabs li.plan-tab-visited:after {
  background: var(--primary) !important;
  border: 0px solid var(--primary);
  color: var(--text-white);
}

.plan-tabs li.active:after {
  /* background: var(--style-graphite-deep); */
  background: var(--primary);
  border: 2px solid var(--primary);
  color: var(--text-white);
}

.plan-tabs li.current-tan:after {
  background: var(--primary-hover) !important;
  border: 2px solid var(--primary-hover);
  color: var(--text-white);
}

.light-style .plan-tabs li.current-tan {
  color: var(--primary-hover) !important;
}

.light-style .plan-tabs li.current-tan a {
  color: var(--primary-hover) !important;
}

.dataTable .report-tr a.event-link {
  font-weight: 600;
}

.dataTable a.event-link {
  color: var(--light-primary) !important;
  font-weight: 600;
}


.plan-tabs li.active:before {
  background: var(--primary);
}

/* UPCOMING — muted label, dark hollow dot, subtle connector */
.dark-style .plan-tabs li:not(.active),
[data-theme="dark"] .plan-tabs li:not(.active) {
  color: var(--text-tertiary) !important;
}
.dark-style .plan-tabs li:not(.active):after,
[data-theme="dark"] .plan-tabs li:not(.active):after {
  background: var(--surface-3) !important;
  border: 1px solid var(--border-strong) !important;
}
.dark-style .plan-tabs li:before,
[data-theme="dark"] .plan-tabs li:before {
  background: var(--border-strong) !important;
}

/* VISITED — legible slate label + filled accent dot + accent connector */
.dark-style .plan-tabs li.active:not(.current-tan),
.dark-style .plan-tabs li.active:not(.current-tan) a,
[data-theme="dark"] .plan-tabs li.active:not(.current-tan),
[data-theme="dark"] .plan-tabs li.active:not(.current-tan) a {
  color: var(--primary-accent) !important;
  font-weight: 600 !important;
}
.dark-style .plan-tabs li.plan-tab-visited:not(.current-tan):after,
.dark-style .plan-tabs li.active:not(.current-tan):after,
[data-theme="dark"] .plan-tabs li.plan-tab-visited:not(.current-tan):after,
[data-theme="dark"] .plan-tabs li.active:not(.current-tan):after {
  background: var(--primary-accent) !important;
  border: 2px solid var(--primary-accent) !important;
  color: var(--text-primary) !important;
}
.dark-style .plan-tabs li.active:before,
[data-theme="dark"] .plan-tabs li.active:before {
  background: var(--primary-accent) !important;
}

/* CURRENT — brightest: white bold label, ringed dot so "you are here" pops */
.dark-style .plan-tabs li.current-tan,
.dark-style .plan-tabs li.current-tan a,
[data-theme="dark"] .plan-tabs li.current-tan,
[data-theme="dark"] .plan-tabs li.current-tan a {
  color: var(--text-primary) !important;
  font-weight: 700 !important;
}

#total-equity-slider .noUi-value {
  width: 1rem;
  height: 1rem;
  background: var(--gray-4);
  font-size: 0px;
  border-radius: 100%;
  top: -1.25rem;
}

#total-equity-slider .noUi-handle {
  height: 2.5rem;
  width: 2.5rem;
  background-image: url(../../assets/img/score-slider-handler.png) !important;
  background-size: contain !important;
  background-repeat: no-repeat;
  display: block;
  border: 0px;
  box-shadow: none;
  top: -1.125rem !important;
  right: -1.125rem !important;
  transform: scale(1);
  background-color: var(--primary) !important;
  /* position: relative; */
}

/* #total-equity-slider .noUi-handle:before {
  content: "";
  position: absolute;
  height: 24px;
  width: 24px;
  background-image: url(../../assets/img/hamburger-handler.png) !important;
  background-size: contain;
  background-repeat: no-repeat;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
} */

#total-equity-slider .noUi-pips-horizontal {
  padding: 0px;
}

#total-equity-slider .noUi-marker {
  display: none;
}

#total-equity-slider .noUi-connects {
  height: 2rem;
  top: -0.9rem;
}

.custom-accordion .accordion-button {
  background-color: var(--dark-primary);
  border-radius: 0px !important;
  color: var(--style-white);
  font-weight: 400;
  font-size: 1rem;
  padding: 0.75rem;
}

.custom-accordion .accordion-button::after {
  background-size: 1.5rem;
  transform: rotate(180deg);
  width: 1.5rem;
  height: 1.5rem;
  background-image: url(../../assets/img/expand_more.svg) !important;
}

.custom-accordion .accordion-button:not(.collapsed)::after {
  width: 1.5rem;
  height: 1.5rem;
  background-size: 1.5rem;
  background-image: url(../../assets/img/expand_more.svg) !important;
  transform: rotate(0deg);
}

.custom-accordion .accordion-title-wrapper {
  padding-right: 1rem;
}

.custom-accordion .accordion:not(.accordion-bordered)>.card.accordion-item {
  box-shadow: none;
  border: 0px;
}

.custom-accordion .accordion-header+.accordion-collapse .accordion-body {
  padding: 0.75rem 0px 0px;
}

.custom-accordion .accordion-item:last-child .accordion-header+.accordion-collapse .accordion-body {
  padding-bottom: 0.5rem;
}

.custom-accordion .accordion-item {
  background-color: transparent !important;
  border: 0px !important;
  box-shadow: none !important;
  margin-bottom: 1.5rem !important;
}

.custom-accordion .accordion-item:last-child {
  margin-bottom: 0rem !important;
}

.view-program-wrapper {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.view-program-item {
  /* display: flex;
  flex-direction: column;
  gap: 1.5rem; */
}

.view-program-item-header {
  background-color: var(--dark-primary);
  border-radius: 0px !important;
  color: var(--style-white);
  font-weight: 400;
  padding: 0.75rem;
}

.view-program-item-body {
  padding: 0.75rem 0px 0px;
}

.event-program-item .view-program-item-body {
  padding: 0px 0px 0px;
}

.plain-form-control {
  background-color: transparent;
  border: 0px;
  padding-left: 0px;
  padding-right: 0px;
}

.table-res {
  width: 100%;
  /* overflow: auto;
  padding-bottom: 0.2rem; */
}

.table-responsive {
  position: relative;
}

.allocate-program-table thead th {
  background-color: transparent !important;
  padding: 0rem 0.5rem;
  border: 0px;
}

.allocate-program-table tbody td {
  background-color: transparent !important;
  border: 0px;
  padding: 0.4rem 0.5rem;
}

.view-program-table thead th {
  background-color: transparent !important;
  padding: 0.5rem;
  border-bottom: 1px solid var(--style-text-mid);
}

.view-program-table tbody td {
  background-color: transparent !important;
  border-bottom: 1px solid var(--style-text-mid);
  padding: 0.9rem 0.5rem;
}

.view-program-table tbody tr:last-child td {
  border-bottom: 0px solid var(--style-text-mid);
}

.total-cost-wrapper {
  border: 1px solid var(--dark-primary);
}

.total-cost-header {
  background-color: var(--dark-primary);
  border-radius: 0px !important;
  padding: 0.75rem;
}

.total-cost-body {
  background-color: transparent;
  padding: 1rem;
}

.total-cost-item-wrapper {
  display: flex;
  gap: 0.75rem;
  /* overflow-x: auto; */
  width: 100%;
  /* cursor: grab; */
  padding-bottom: 0.6rem;
}

.total-cost-item-wrapper::-webkit-scrollbar {
  cursor: grab;
  height: 0.5rem;
}

.total-cost-item-wrapper::-webkit-scrollbar-thumb {
  background-color: rgba(0, 0, 0, 0.3);
  border-radius: 0.5rem;
}

.total-cost-item-wrapper::-webkit-scrollbar-track {
  background: rgba(0, 0, 0, 0.1);
}

.hor-scrollbar {
  overflow-x: auto;
  overflow-y: hidden;
  white-space: nowrap;
  flex-wrap: nowrap;
  /* padding-bottom: 0.5rem; */
}

.hor-scrollbar::-webkit-scrollbar {
  cursor: pointer;
  height: 0.4rem;
}

.hor-scrollbar::-webkit-scrollbar-thumb {
  background-color: rgba(0, 0, 0, 0.3);
  border-radius: 0.5rem;
}

.hor-scrollbar::-webkit-scrollbar-track {
  background: rgba(0, 0, 0, 0.1);
}

.table-responsive::-webkit-scrollbar-thumb {
  background-color: rgba(255, 255, 255, 0.8) !important;
}

.table-responsive::-webkit-scrollbar-track {
  background: rgba(0, 0, 0, 0.1) !important;
}

.total-cost-item {
  /* background-color: var(--style-text-light); */
  background-color: var(--gray-1);
  padding: 0.8rem 1rem .9rem;
  gap: 0.5rem;
  display: flex;
  flex-direction: column;
  min-width: 13.12rem;
  width: 30%;
}

.dark-style .total-cost-item {
  background-color: var(--style-text-light);
}

.gap-15 {
  gap: 1.5rem;
}

.gap-25 {
  gap: 2.5rem;
}

.crash-data-box {
  border: 1px solid var(--style-text-mid);
  /* padding: 1rem; */
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  align-items: start;
}

.crash-count-wrapper {
  display: flex;
  flex-direction: column;
  /* min-width: 14rem; */
  width: 100%;
  white-space: nowrap;
}

.crash-count-wrapper .crash-placeholder-text {
  /* min-width: 10rem; */
}

.crash-count {
  font-size: 2.5rem;
  /* line-height: 3.4rem; */
  white-space: nowrap;
}

.crash-progress {
  border-radius: 0px !important;
}

.crash-progress .progress-bar {
  border-radius: 0px !important;
}

.bg-demographic1 {
  background: var(--demographic-1);
}

.bg-demographic2 {
  background: var(--demographic-2);
}

.bg-demographic3 {
  background: var(--demographic-3);
}

.bg-demographic4 {
  background: var(--demographic-4);
}

.bg-demographic5 {
  background: var(--demographic-5);
}

.bg-demographic6 {
  background: var(--demographic-6);
}

.bg-demographic7 {
  background: var(--demographic-7);
}

.bg-demographic8 {
  background: var(--demographic-8);
}

.crash-progress-dot-wrapper {
  display: flex;
  gap: 1.5rem;
  /* row-gap: 0.5rem;
  column-gap: 1.5rem; */
  /* flex-wrap: wrap; */
}

.crash-progress-dot-item {
  /* display: flex; */
  /* gap: 0.5rem; */
  align-items: center;

}

.crash-progress-dot {
  width: 0.75rem;
  height: 0.75rem;
  border-radius: 100%;
  flex-shrink: 0;
  /* background-color: transparent; */
}

.crash-progress-text {
  font-size: 0.75rem;
  font-weight: 400;
  white-space: nowrap;
}

.event-narrative-box {
  border: 1px solid var(--style-text-light);
  border-radius: 0.5rem;
  padding: 0.422rem 0.875rem;
  min-height: 20rem;
}

.table-file-img {
  height: 2.5rem;
  max-height: 2.5rem;
  min-width: 2.5rem;
  max-width: 7rem;
  object-fit: contain;
  padding: 4px;
  border: 1px solid var(--gray-4);
  border-radius: 8px;
  box-shadow: var(--shadow-card);
  background-color: var(--gray-0);
  background-image:
    linear-gradient(45deg, var(--gray-3) 25%, transparent 25%),
    linear-gradient(-45deg, var(--gray-3) 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, var(--gray-3) 75%),
    linear-gradient(-45deg, transparent 75%, var(--gray-3) 75%);
  background-size: 12px 12px;
  background-position: 0 0, 0 6px, 6px -6px, -6px 0;
}

.lightbox .lb-container {
  /* display: flex;
  justify-content: center;
  align-items: center; */
}

.lightbox .lb-image {
  /* height: 100% !important; */
  /* width: 100% !important; */
  /* max-height: 70vh; */
  /* width: 25rem !important; */
  /* object-fit: contain !important; */
}

.county-dot {
  width: 0.875rem;
  height: 0.875rem;
  border-radius: 100%;
  flex-shrink: 0;
}

.event-list-wrapper {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  align-items: start;
}

.event-list-item {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: start;
  padding: 1rem;
  background-color: var(--style-graphite-mid);
  box-shadow: 0px 4px 8px 0px rgba(0, 0, 0, 0.85);
  border-radius: 0.8rem;
}

.schedule-event-box .watchlist-card-inner {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.schedule-event-box .event-title {
  /* font-size: 1.125rem; */
  font-size: 1.5rem;
}

.schedule-event-box .offline-dot {
  width: 1rem;
  height: 1rem;
  position: relative;
  top: 1px;
  flex-shrink: 0;
}

.schedule-event-box .watchlist-card {
  gap: 1.5rem;
}


/* pdf css */
.pdf-section {
  /* background-color: #F9F9F9; */
  background-color: var(--style-white);
  padding: 1rem;
  border-radius: 0.5rem;
  width: 100%;
}

.pdf-event-section {
  background-image: url(../../assets/img/pdf-logo-bg.png);
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
  height: 100%;
}

.pdf-event-section table td {
  padding: 0px;
  border: 0px;
}

.pdf-td-p-0 {
  padding: 0px !important;
  border: 0px !important;
}

.profile-col1 {
  background-color: var(--style-deep-red);
  /* width: 50%; */
  padding-top: 4rem;
  padding-bottom: 4rem;
}

.profile-col2 {
  /* width: 50%; */
}

.org-logo-wrapper {
  /* padding: 3rem 0px; */
  display: block;
  margin-bottom: 3rem;
  margin-top: 1rem;
}

.org-logo {
  width: 19.75rem;
  height: 19.75rem;
  background-color: var(--style-white);
  border: 8px solid var(--warning);
  border-radius: 100%;
  margin: 0 auto;
  position: relative;
  overflow: hidden;
  padding: 1rem;
}

.pdf-org-logo {
  /* object-fit: cover; */
  object-fit: contain;
  border-radius: 100%;
  width: 100%;
  height: 100%;
}

.org-logo-text {
  color: var(--gray-4) !important;
  font-size: 1.5rem;
  line-height: 2rem;
  font-weight: 700;
  font-style: italic;
  text-align: center;
  vertical-align: middle;
  margin-bottom: 0px;
  margin-top: 0px;
  position: absolute;
  /* top: calc(50% + 0.5rem); */
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.org-name {
  font-size: 2.5rem;
  line-height: 3.5rem;
  color: var(--style-white);
  text-align: center;
  font-weight: 700;
  /* margin: 3rem 2rem; */
  margin: 3rem;
  margin-top: 0px;
  display: block;
}

.pdf-text-center {
  text-align: center;
}

.event-wrapper {
  background: rgba(0, 0, 0, 0.2);
  padding: 1rem;
  text-align: center;
}

.event-name {
  color: var(--style-white);
  font-size: 24px;
  font-weight: 700;
  line-height: 2rem;
  margin: 0px;
}

.event-date {
  margin-top: 2rem;
  margin-bottom: 0px;
}

.program-type {
  color: var(--style-white);
  font-size: 24px;
  font-weight: 400;
  line-height: 2rem;
  margin-bottom: 0px;
  margin-top: 0.125rem;
}

.pdf-alliance-logo-wrapper {
  position: relative;
  text-align: center;
}

.pdf-alliance-logo {
  height: 7.5rem;
  text-align: center;
  margin: auto;
}

.pdf-gap {
  margin-bottom: 1.5rem;
}

.pdf-header {
  border-bottom: 2px solid var(--style-deep-red);
  padding-bottom: 1.5rem;
  margin-bottom: 1.5rem;
}

.pdf-header-logo {
  height: 60px;
}

.pdf-footer {
  border-top: 2px solid var(--warning);
  padding-top: 1.5rem;
  margin-top: 1.5rem;
}

.footer-text {
  font-size: 0.75rem;
  font-weight: 400;
  color: var(--style-graphite-mid);
  margin: 0px;
}

.pdf-text-right {
  text-align: right;
}

.ctr-text-center {
  text-align: center;
}

.text-red {
  color: var(--style-deep-red) !important;
}

.pdf-header-col1 {
  text-align: left;
}

.pdf-header-col2 {
  text-align: right;
}

.pdf-text-section {
  padding: 2.2rem;
}

.section-title {
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.5rem;
  margin-bottom: 0px;
  margin-top: 0px;
}

.pdf-section-row {
  width: 100%;
}

.pdf-section-col {
  margin-right: 1rem;
  margin-bottom: 1rem;
  display: inline-block;
}

.pdf-section-col:last-child {
  margin-right: 0rem;
}

.event-pic-wrapper {
  border: 2px solid var(--style-deep-red);
  width: 200px;
  height: 200px;
}

.event-pic {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.social-media-wrapper {
  width: 200px;
  height: auto;
}

.social-media-row {
  display: inline-flex;
  margin-right: 2rem;
  margin-bottom: 1rem;
}

.social-media-row:last-child {
  margin-right: 0px;
}

.social-media-pic {
  object-fit: contain;
  width: 196px;
}

.pdf-text-italic {
  font-style: italic;
}

.social-media-label {
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1rem;
  color: var(--style-graphite-mid);
  margin: 0px;
  margin-bottom: 4px;
}

.social-media-count {
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.18rem;
  color: var(--style-graphite-mid);
  margin: 0px;
}

.pdf-program-pic {
  width: 160px;
  height: 160px;
  border: 1px solid var(--gray-3);
  object-fit: cover;
}

.location-name {
  font-size: 2rem;
  font-weight: 700;
  line-height: 2.7rem;
  color: var(--style-graphite-mid);
  margin: 0px;
}

.td-inactive {
  background: rgba(218, 220, 224, 0.6);
}

.td-active {
  /* background: #A50F15; */
  background: var(--danger);
}

.table-cell-gap {
  border-spacing: 0.5rem;
  border-collapse: separate;
}

.table-cell-gap tr td {
  padding: 0.225rem 0.5rem;
}

.td-active .social-media-label,
.td-active .social-media-count {
  color: var(--style-white);
}

.crash-data-table th {
  background: rgba(218, 220, 224, 0.6);
  padding: 0.225rem 0.5rem;
}

.crash-data-table tbody tr:nth-of-type(odd) {
  background: rgba(255, 255, 255, 0.6);
}

.crash-data-table tbody tr:nth-of-type(even) {
  background: rgba(218, 220, 224, 0.3);
}

.crash-data-table td {
  padding: 0.225rem 0.5rem;
}

.crash-data-table td p {
  font-weight: 400 !important;
}

.crash-data-red {
  /* background: #A50F15; */
  background: var(--danger);
  padding: 0.225rem 0.5rem;
}

.crash-data-green {
  background: var(--success);
  padding: 0.225rem 0.5rem;
}

.green-dot {
  width: .7rem;
  height: .7rem;
  background-color: var(--success);
  border-radius: 100%;
  margin-left: .2rem;
  /* display: inline-block; */
  display: none;
}

.crash-data-red .social-media-label,
.crash-data-green .social-media-label {
  color: var(--style-white);
}

.pdf-map-pic {
  width: 176px;
  height: 176px;
  object-fit: cover;
}

.social-vulnerability-table-wrapper table {
  width: calc(100% + 1rem);
  margin-left: -0.5rem !important;
}

.pdf-ul li {
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.18rem;
  color: var(--style-graphite-mid);
}

.program-event-name {
  color: var(--style-graphite-mid);
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 2rem;
}

.program-event-pic {
  width: 2.5rem;
  height: 2.5rem;
  object-fit: cover;
}

.pdf-mb-3 {
  margin-bottom: 1rem !important;
}

.pdf-mb-4 {
  margin-bottom: 1.5rem !important;
}

.pdf-m-0 {
  margin: 0px;
}

.pdf-mt-0 {
  margin-top: 0px !important;
}

/* pdf css */
.dataTable input[type="text"] {
  background-color: transparent;
}

.dataTable input[type="score"] {
  background-color: transparent;
}

div.dataTables_processing {
  z-index: 9999;
}

/* Map CSS Start */
#mappopup {
  display: none;
  position: absolute;
  background: var(--style-graphite-deep);
  border-radius: 1rem;
  padding: 1rem;
  z-index: 100;
  min-width: 15rem;
}

#mappopup .mapPopupBtn {
  padding: 0.28rem 0.75rem;
  font-size: 0.875rem;
  font-weight: 600;
}

#mappopup::before {
  content: '';
  position: absolute;
  top: -19px;
  /* Adjust as needed */
  left: 50%;
  transform: translateX(-50%);
  border-width: 10px;
  border-style: solid;
  border-color: transparent transparent var(--style-graphite-deep) transparent;
  /* Creates the notch */
}

/* Map CSS End */

/* Calendar css */
.schedule-calendar-wrapper {
  background-color: var(--style-graphite-mid);
  /* padding: 1rem; */
  border-radius: 0.5rem;
  position: relative;
}

.light-style .schedule-calendar-wrapper {
  background-color: var(--style-soft-white);
  /* padding: 1rem; */
  border-radius: 0.5rem;
  position: relative;
}

.fc-h-event {
  background-color: transparent;
  border: 0px;
}

.fc-daygrid-day-top {
  justify-content: start;
  padding: 0.5rem;
}

.fc .fc-daygrid-day-number {
  padding: 0.5rem;
  font-size: 0.625rem;
  font-weight: 500;
  color: var(--gray-12);
}

.dark-style .fc .fc-daygrid-day-number {
  color: var(--style-white);
}

.fc-daygrid-day-frame {
  display: flex;
  flex-direction: column;
}

.fc-daygrid-day-events {
  /* margin-top: auto !important; */
  padding: 0.25rem;
}

.fc .fc-col-header-cell-cushion {
  font-size: 0.75rem;
  font-weight: 500;
}

.fc-event-time {
  font-size: 0.625rem;
  font-weight: 500;
  color: var(--style-text-mid);
  margin-right: 0px !important;
}

.fc-event-title {
  position: relative;
  /* font-size: 0.625rem; */
  /* font-size: 0.8rem; */
  font-size: 0.9rem;
  font-weight: 500 !important;
  padding-left: 0.7rem !important;
  color: var(--style-white);
}

.fc-event-title::before {
  /* content: "";
  width: 0.5rem;
  height: 0.5rem;
  background-color: var(--style-white);
  border-radius: 100%;
  position: absolute;
  left: 0px;
  top: 50%;
  transform: translate(0%, -50%); */
}

.fc .fc-toolbar.fc-header-toolbar {
  border: 1px solid var(--gray-3);
  border-top-right-radius: 0.5rem;
  border-top-left-radius: 0.5rem;
  border-bottom: 0px;
  border-collapse: collapse;
  margin-bottom: 0px;
  padding: 1rem;
  justify-content: space-between;
  flex-direction: row;
  gap: 2rem;
}

.fc .fc-toolbar-title {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--style-text-dark);
  padding-right: 1.5rem;
  /* min-width: 15rem; */
}

.dark-style .fc .fc-toolbar-title {
  color: var(--style-white);
}

.fc-dayGridMonth-button,
.fc-today-button,
.fc-timeGridWeek-button {
  padding: 0.4rem 1rem !important;
}

.fc-timeGridWeek-button {
  line-height: 25px;
}

.fc-today-button {
  color: var(--text-white) !important;
}

.fc-button {
  outline: none !important;
}

.fc-button:focus {
  box-shadow: none !important;
}

.fc-theme-standard th {
  /* border-top: 0px;
  border-right: 0px; */
  border-right-color: transparent !important;
}

.fc-theme-standard .fc-scrollgrid {
  /* border: 1px solid #DADCE0;
  border-collapse: collapse; */
}

.fc-scrollgrid-sync-table tbody tr:last-child td:last-child {
  border-bottom-left-radius: 0.5rem;
}

.fc-prev-button,
.fc-next-button {
  /* display: none !important; */
  /* z-index: 9999; */
  background-color: var(--primary) !important;
  color: var(--style-white) !important;
}



.fc .fc-button-group {
  /* z-index: 9999; */
  /* border: 1px solid var(--light-primary) !important; */
  border: 1px solid var(--primary) !important;
  border-radius: 8px;
  overflow: hidden;
}

.fc-toolbar-chunk {
  z-index: 999;
}

.fc-toolbar-center {
  border: 1px solid var(--light-primary) !important;
  border-radius: 0.5rem;
  overflow: hidden;
}

.fc-toolbar-left .fc-button-group {
  border-radius: 0.5rem;
  /* border: 1px solid var(--light-primary) !important; */
}

.fc .fc-button-primary {
  border: 0px !important;
  border-color: var(--dark-primary) !important;
}

.fc-prev-button {
  /* border-right: 1px solid var(--dark-primary) !important; */
  /* border: 0px 1px 0px 0px !important; */
}

.fc-next-button {
  /* border-left: 1px solid var(--dark-primary) !important; */
  /* border: 0px 0px 0px 1px !important; */
}

.fc-button-group .fc-today-button {
  /* z-index: 9999; */
  background-color: var(--style-graphite-deep) !important;
  /* color: #cfd3ec !important; */
  color: var(--gray-12) !important;
  /* border: 1px solid var(--light-primary) !important; */
}

.dark-style .fc-button-group .fc-today-button {
  color: var(--style-white) !important;
}


.fc .fc-button:disabled {
  opacity: 1;
}

.fc .fc-button-primary:not(.fc-prev-button):not(.fc-next-button).fc-button-active {
  background-color: var(--primary) !important;
  color: var(--style-white) !important;
}


/* .fc-toolbar-center .fc-button-active {
  background-color: var(--light-primary) !important;
    color: var(--style-graphite-deep) !important;
} */

.fc-daygrid-block-event {
  display: inline-block !important;
}

.fc-media-screen {
  position: relative;
  border-radius: 0.5rem;
  overflow: hidden;
}

.fc-media-screen::after {
  content: "";
  border: 1px solid var(--gray-3);
  border-radius: 0.5rem;
  border-collapse: collapse;
  position: absolute;
  /* z-index: -1; */
  width: 100%;
  height: 100%;
}

.fc-daygrid-event-dot {
  display: none;
}

.fc-daygrid-event {
  display: flex;
  /* flex-direction: row-reverse; */
  column-gap: 10px;
  flex-wrap: wrap;
}

.fc-daygrid-dot-event:hover {
  background: transparent;
}

.fc-event {
  cursor: pointer;
}

.schedule-calendar {
  width: 100%;
  position: relative;
  height: calc(100vh - 11rem) !important;
}

.light-style .select2-container--default .select2-selection {
  background-color: transparent;
}

.authentication-wrapper.authentication-basic .authentication-inner {
  max-width: 32rem;
  position: relative;
}

/* .schedule-calendar-filter {
  position: absolute;
  right: 2rem;
  top: 2.15rem;
  z-index: 1;
} */

.schedule-calendar-filter .calender-icon {
  width: 2rem;
  height: 2rem;
  background-color: var(--primary);
  border-radius: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
}

.calender-icon-img {
  height: 1rem;
}

.fc-day-other {
  /* background-color: var(--style-graphite-deep); */
  background-color: var(--gray-4);
  color: var(--style-white);
}

.dark-style .fc-day-other {
  background-color: var(--style-graphite-deep);
  color: var(--style-white);
}

.fc .fc-daygrid-day.fc-day-today {
  background-color: var(--light-primary);
}

.fc .fc-scrollgrid-section table tr:last-child td:first-child {
  border-bottom-left-radius: 0.5rem;
}

.fc .fc-scrollgrid-section table tr:last-child td:last-child {
  border-bottom-right-radius: 0.5rem;
}

.calendar-search-wrapper {
  position: relative;
  top: -3px;
}

.calendar-modal-scrollbar {
  max-height: 40vh;
}

/* Calendar css */

@media (min-width: 1600px) {
  .watchlist-card {
    min-width: 22%;
  }
}

@media (min-width: 1440px) {
  .container-xxl {
    max-width: 100%;
  }
}

@media (max-width: 820px) {
  .crash-count-wrapper {
    width: auto;
    /* min-width: 12rem; */
  }
}

.header-navbar .navbar-container ul.navbar-nav li a.menu-toggle i,
.header-navbar .navbar-container ul.navbar-nav li a.menu-toggle svg {
  height: 2.6rem;
  width: 2.6rem;
  font-size: 2.6rem;
}

@media (max-width: 767px) {
  .schedule-tab .nav-pills .nav-link {
    min-width: auto;
  }

  .dash-btn-box {
    overflow-x: auto;
  }

  .dash-btn-box .btn-primary {
    width: auto !important;
    flex-shrink: 0;
  }

  .modal-dialog {
    margin: 1rem;
  }

  .schedule-event-box .offline-dot {
    position: relative;
    top: 0.5rem;
  }

  .survey-data-text {
    max-width: 220px;
  }

  .score-trend-wrapper {
    flex-direction: column;
  }

  .score-trend-2 {
    width: 100%;
    height: 1px;
  }

  .header-navbar .navbar-container .show~.dropdown-menu {
    width: 14rem !important;
    right: 6rem !important;
    left: auto !important;

  }

  .vertical-layout .header-navbar .navbar-container ul.navbar-nav li.dropdown .dropdown-menu {
    top: 55px !important;
  }

  /* .dark-style .nav-tabs {
    column-gap: 25px;
  } */

  /* .dark-style .nav-tabs.admin-tab {
    justify-content: space-between;
    column-gap: 5px;
  }

  .dark-style .nav-tabs.setting-tab {
    justify-content: start;
    column-gap: 25px;
  } */

  #selectMap .modal-dialog {
    max-width: 100%;
  }

  .select-map-image {
    min-height: 500px;
  }

  .m-w-100 {
    width: 100%;
    max-width: 100%;
  }

  .page-title {
    font-size: 1.8rem;
    /* line-height: 2.91rem; */
  }

  .watchlist-card {
    min-width: 90%;
  }

  html body .app-content {
    padding: calc(2rem - 0.8rem + 4.45rem + 1.3rem) calc(2rem - 0.8rem) calc(2rem - 0.8rem) calc(2rem - 0.8rem) !important;
  }

  .dataTables_info {
    display: block;
  }

  .dataTables_paginate {
    display: block;
    float: none;
  }

  .map-info {
    padding: 15px;
  }

  .map-search {
    padding: 18px 20px;
    flex-direction: column;
  }

  .map-filter-applied {
    margin: 15px 20px 0px;
    padding: 8px 16px;
    border-radius: 15px;
  }

  .view-notification-wrapper {
    gap: 23px;
    flex-direction: column;
  }

  .notification-left,
  .notification-right {
    width: 100%;
  }

  .map-search-wrapper {
    width: 90%;
  }
}

/* for seelect2 validation  */
form select.is-valid~.select2 .select2-selection {
  /* border-color: var(--bs-form-valid-color) !important; */
  border-color: var(--style-input-border-light) !important;
}

.was-validated .form-control:valid, .form-control.is-valid{
  border-color: var(--style-input-border-light) !important;
}

.was-validated .form-control:valid, .form-control.is-valid select.is-valid{
  border-color: var(--style-input-border-light) !important;
}

.dark-style .was-validated .form-control:valid, .dark-style .form-control.is-valid{
  border: 1px solid var(--input-border) !important;
}

.dark-style .was-validated .form-control:valid, .dark-style .form-control.is-valid select.is-valid{
  border-color: var(--input-border) !important;
}
.dark-style .was-validated .form-control:valid, .dark-style .form-control.is-valid{
  border-color: var(--input-border) !important;
}

/* ===== INPUT FIELDS ===== */
.dark-style .form-control:hover,
.dark-style .form-control:focus {
  border: 1px solid var(--style-success) !important;
  box-shadow: inset 0 0 0 1px var(--style-success);
}


/* ===== SELECT2 FIELDS ===== */
.dark-style .select2-container:hover .select2-selection,
.dark-style .select2-container.select2-container--focus .select2-selection,
.dark-style .select2-container.select2-container--open .select2-selection {
  border: 1px solid var(--style-success) !important;
  box-shadow: inset 0 0 0 1px var(--style-success);
}

/* ===== INPUT FIELDS ===== */
.light-style .form-control:hover,
.light-style .form-control:focus {
  border: 1px solid var(--style-success) !important;
  box-shadow: inset 0 0 0 1px var(--style-success);
}


/* ===== SELECT2 FIELDS ===== */
.light-style .select2-container:hover .select2-selection,
.light-style .select2-container.select2-container--focus .select2-selection,
.light-style .select2-container.select2-container--open .select2-selection {
  border: 1px solid var(--style-success) !important;
  box-shadow: inset 0 0 0 1px var(--style-success);
}

.dark-style .was-validated .form-control:valid, .dark-style .form-control:focus{
  border: 1px solid var(--style-success) !important;
  box-shadow: inset 0 0 0 1px var(--style-success);
}

.dark-style .was-validated .form-control:valid, .dark-style .form-control select:focus{
  border: 1px solid var(--style-success) !important;
  box-shadow: inset 0 0 0 1px var(--style-success);
}

.text-error {
  width: 100%;
  margin-top: 0.25rem;
  font-size: 0.8125rem;
  color: var(--bs-form-invalid-color);
}

/* css for  delete bootbox of */
.bootbox.modal .modal-header {
  justify-content: space-between;
  /* background-color: var(--bs-primary); */
  /* padding: .5rem 1rem; */
}

.bootbox-close-button.close {
  border: none;
  /* background: transparent; */
  /* color: #223A2B; */
  font-size: 2rem !important;
  width: 25px;
  height: 25px;
  line-height: 25px;
  position: relative;
  right: -7px;
  top: -3px
}

.bootbox.modal .modal-content {}

.bootbox.modal .modal-footer {
  /* background-color:var(--bs-primary) ; */
  /* padding: 0; */
  padding-top: 0;
  padding-bottom: 1rem;
}

.bootbox.modal .modal-footer .btn {
  line-height: 1rem;
}

.bootbox.modal .modal-title {
  color: var(--text-black);
}

.btn-outline-primary {
  color: var(--primary);
  border-color: var(--primary);
  background: transparent;
}

.btn-outline-primary:hover,
.btn-outline-primary:active,
.btn-outline-primary:focus {
  color: var(--primary) !important;
  background-color: transparent !important;
}

.btn-check:focus+.btn-outline-primary,
.btn-outline-primary:focus {
  border-color: var(--primary) !important;
}

.btn-check:checked+.btn-outline-primary,
.btn-check:active+.btn-outline-primary,
.btn-outline-primary:active,
.btn-outline-primary.active,
.btn-outline-primary.dropdown-toggle.show {
  border-color: var(--primary) !important;
}


.spinner-loader {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100vh;
  width: 100%;
  position: fixed;
  z-index: 99999;
  background-color: rgba(0, 0, 0, 0.69);
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

.spinner-loader div {
  width: 50px;
  height: 50px;
  font-size: 24px;
}

/* .spinner-loader {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100vh;
  width: 100%;
  position: fixed;
  z-index: 99999;
  background-color: initial;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

.spinner-loader .loader-logo {
  width: 80px;
  height: 80px;
  animation: rotate 1.5s linear infinite;
}

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

  100% {
    transform: rotate(360deg);
  }
} */

.required-title {
  font-size: 0.875rem !important;
  margin-bottom: 0px !important;
}

.estimate-input {
  border: 0;
  text-align: right;
}

.estimate-input:focus {
  box-shadow: none !important;
}

ul.menu-inner li.adminBottonMenu {
  position: relative;
  bottom: 0%;
  margin-top: auto !important;
}

html:not(.layout-menu-collapsed) .bg-menu-theme .menu-inner .menu-item:not(.active)>.menu-link:hover,
.layout-menu-hover.layout-menu-collapsed .bg-menu-theme .menu-inner .menu-item:not(.active)>.menu-link:hover {
  /* background: var(--style-white);
  color: #00496A; */
}

.recommended {
  background-color: var(--primary);
  padding: 2px 10px;
  display: inline-block;
  font-size: 0.812rem;
  color: var(--style-white);
}

.fc-toolbar-center {
  display: none;
}

.fc .fc-customStateFilter-button,
.fc .fc-customEventFilter-button {
  border: 1px solid var(--primary) !important;
  border-radius: 0.5rem;
  padding: .4em 1.2em;
}

.focus-btn-report {
  color: var(--style-white);
  font-weight: bold;
}

/* div.dataTables_wrapper div.dataTables_paginate ul.pagination .page-item.disabled .page-link {
  background-color: #ccc;
} */

@media (max-width: 992px) {
  .fc .fc-toolbar.fc-header-toolbar {
    flex-direction: column;
    gap: 1rem;
    align-items: start;
  }
}

@media (max-width: 560px) {
  .fc .fc-toolbar.fc-header-toolbar {
    justify-content: space-between;
    flex-direction: column;
    gap: 5px;
    align-items: flex-start;
  }

  .fc-toolbar-right {
    display: flex;
    flex-direction: column;
    gap: 10px;
    justify-content: start;
    width: 100%;
  }

  .fc-button-group {
    margin-left: 0 !important;
  }

  .fc-customStateFilter-button,
  .fc-customEventFilter-button {
    margin-left: 0 !important;
  }

  .fc-header-toolbar .fc-toolbar-chunk:last-child {
    gap: 15px;
    display: flex;
    flex-direction: column;
  }
}

@media only screen and (min-width: 1024px) and (max-height: 1366px) {
  .fc .fc-toolbar.fc-header-toolbar {
    padding: 0.5rem;
    gap: 1rem;
  }
}

/* Portrait */
@media only screen and (min-width: 1024px) and (max-height: 1366px) and (orientation: portrait) {
  .fc .fc-toolbar.fc-header-toolbar {
    padding: 0.5rem;
    gap: 1rem;
  }
}

/* Landscape */
@media only screen and (min-width: 1024px) and (max-height: 1366px) and (orientation: landscape) {
  .fc .fc-toolbar.fc-header-toolbar {
    padding: 0.5rem;
    gap: 1rem;
  }
}

.content-box {
  padding: 0px 0rem 0rem !important;
}

.container-p-y:not([class^=pt-]):not([class*=" pt-"]) {
  /* padding-top: 0rem !important; */
  /* margin-top: -0.5rem; */
}

.apexcharts-theme-dark .apexcharts-menu-icon svg {
  fill: var(--style-text-dark) !important;
}

:root {
  font-size: 14px;
}

@media (max-width: 1950px) {
  :root {
    font-size: 13px;
  }
}

@media (max-width: 1336px) {
  :root {
    font-size: 12px;
  }
}

.cursor-default {
  cursor: default !important;
}

#county_label {
  position: absolute;
  top: -7px;
  left: -2px;
  z-index: 10;
}

.warning-message {
  color: var(--danger);
  font-size: 15px;
  background-color: var(--danger-soft);
  padding: 5px 10px;
  border-radius: 5px;
}

.admin-tabs .dropdown-item {
  margin: 0.25rem 0.5rem !important;
  border-radius: 0.375rem !important;
  padding: 0.5rem 1rem !important;
  font-size: 1rem !important;
}

.admin-tabs .dropdown-item.active {
  background-color: var(--primary) !important;
  color: var(--style-white) !important;
}

.admin-tabs .dropdown-item:not(.disabled).active,
.dropdown-item:not(.disabled):active {
  background-color: var(--primary) !important;
  color: var(--style-white) !important;
}

.admin-tabs .dropdown-item:hover,
.dropdown-item:focus {
  background-color: var(--primary) !important;
  color: var(--style-white) !important;
}

.admin-tabs .adminDropDownActive::after {
  content: "";
  position: absolute;
  bottom: 1px;
  left: -6px;
  z-index: 2;
  width: 100%;
  height: 2px;
  background-color: var(--primary);
  display: block;
  transform: rotate(0deg);
  border: 0px;
}

.admin-tabs .dropdown-menu.show {
  /* right: 1px !important; */
  background-color: transparent;
  box-shadow: none;
  padding-bottom: 0px;
}

.adminDropDownActive:hover,
.adminDropDownActive:focus {
  isolation: auto !important;
}

/* .admin-tabs .adminDropDownActive:hover {
  box-shadow: 0 -2px 0 #7367f0 inset;
  position: relative;
} */

/* Arrow styling */
.admin-tabs .dropdown-arrow {
  display: inline-block;
  margin-left: 0.455em;
  margin-bottom: 0.255em;
  vertical-align: 0.455em;
  width: 0;
  height: 0;
  border-top: 0.4em solid;
  border-right: 0.4em solid transparent;
  border-bottom: 0;
  border-left: 0.4em solid transparent;
  transform: rotate(0deg);
}

.check-icon-accordian {
  display: flex;
  flex-direction: row-reverse;
  align-items: center;
}

.allocate-check-icon {
  height: 20px;
  width: 20px;
}

.admin-role-view {
  max-width: 55rem;
}

.light-style .allocation-label {
  color: var(--style-text-dark);
}

/* .engagement-admin-tab .nav-item {
  border-bottom: 2px solid rgb(219, 218, 222.4);
} */
.sub-tab {
  /* width: 425px; */
  width: 32.8rem;
}

.selected-criteria-tag {
  padding: 0 1px;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-white) !important;
  background-color: var(--dark-primary) !important;
  text-transform: none;
}

.crietria-names-search {
  border-color: var(--dark-primary) !important;
}

.layout-navbar-fixed.layout-menu-collapsed .layout-navbar.navbar-detached {
  width: calc(100% - 5.25rem);
}

.dashboard-laoyuts {
  background-color: var(--dash-dark) !important;
  border-color: var(--dash-dark) !important;
}

.dashboard-laoyuts:hover {
  background-color: var(--dash-dark) !important;
  border-color: var(--dash-dark) !important;
}

@media (max-width:560px) {
  .sub-tab {
    width: 100%;
  }

  .sub-tab .nav-link {
    padding-left: 0.75rem;
    padding-right: 0.75rem;
  }

  .header-menu .header-logout-icon {
    top: 2px;
    margin-left: -4px;
  }
}

@media (max-width:430px) {
  .sub-tab {
    width: 28.8rem;
    overflow: auto;
  }
}

@media (max-width:414px) {
  .sub-tab {
    width: 28.8rem;
    overflow: auto;
  }
}

@media (max-width: 390px) {
  .sub-tab {
    width: 28.8rem;
    overflow: auto;
  }
}

@media (max-width: 360px) {
  .sub-tab {
    width: 28.8rem;
    overflow: auto;
  }
}

.themesOptions .theme-icon {
  color: var(--style-text-dark);
  font-size: 2.16rem !important;
  position: relative;
  top: 2px;
}

.dark-style .themesOptions .theme-icon {
  color: var(--style-white);
}

.themesOptions .custom-option-icon i {
  /* color: #637687; */
}

.dark-style .bootbox-body {
  color: var(--style-white) !important;
}

.fl-wrapper{
  z-index: 1080 !important;
}
.bs-stepper .bs-stepper-header .step.active .bs-stepper-circle {
  background-color: var(--dash-dark) !important;
  border-color: var(--dash-dark) !important;
}
.bs-stepper .bs-stepper-header .step.active .bs-stepper-title {
 font-weight: 800 !important;
}

.bs-stepper .bs-stepper-header .step:not(.active) .bs-stepper-circle{
  color: var(--text-white);
  background-color: var(--primary) !important;
  border-color: var(--primary) !important;
}

.dark-style .bs-stepper .bs-stepper-header .step:not(.active) .bs-stepper-circle{
  color: var(--text-white);
  background-color: var(--primary) !important;
  border-color: var(--primary) !important;
}

.light-style .bs-stepper .bs-stepper-header .step:not(.active) .bs-stepper-circle{
  color: var(--text-white);
  background-color: var(--primary) !important;
  border-color: var(--primary) !important;
}

.bs-stepper .bs-stepper-header .step .step-trigger .bs-stepper-label {
  font-size: 1rem !important;
}

/* Grant Type Quick Action Icons */
.gt-quick-action-icon {
  color: #ffffff !important;
}

/* Grant Type Obligations Card min-height */
@media (min-width: 768px) {
  .gt-obligations-card {
    min-height: 400px;
  }
}

/* Grant Type Funding Accordion Styles */
.gt-fund-accordion-item {
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 0.5rem;
  overflow: hidden;
  margin-bottom: 0.75rem;
  background-color: rgba(255, 255, 255, 0.02);
}

.light-style .gt-fund-accordion-item {
  border: 1px solid rgba(0, 0, 0, 0.1);
  background-color: rgba(0, 0, 0, 0.02);
}

.gt-fund-accordion-header {
  width: 100%;
  padding: 0.75rem 1rem;
  background-color: rgba(255, 255, 255, 0.05);
  border: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  transition: background-color 0.2s ease;
  text-align: left;
  position: relative;
}

.light-style .gt-fund-accordion-header {
  background-color: rgba(0, 0, 0, 0.03);
}

.gt-fund-accordion-header:hover {
  background-color: rgba(255, 255, 255, 0.08);
}

.light-style .gt-fund-accordion-header:hover {
  background-color: rgba(0, 0, 0, 0.05);
}

.gt-fund-accordion-header:not(.collapsed) {
  background-color: rgba(255, 255, 255, 0.08);
}

.light-style .gt-fund-accordion-header:not(.collapsed) {
  background-color: rgba(0, 0, 0, 0.06);
}

.gt-fund-accordion-info {
  display: flex;
  gap: 1.25rem;
  flex: 1;
  align-items: center;
}

.gt-fund-accordion-field {
  min-width: 5rem;
}

.gt-fund-accordion-right {
  text-align: right;
  margin-right: 2rem;
}

.gt-fund-accordion-label {
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 0.25rem;
  font-weight: 400;
}

.light-style .gt-fund-accordion-label {
  color: rgba(74, 76, 75, 0.6);
}

.gt-fund-accordion-value {
  font-weight: 600;
  color: #ffffff;
  font-size: 0.875rem;
}

.light-style .gt-fund-accordion-value {
  color: #4A4C4B;
}

.gt-fund-accordion-source {
  font-weight: 700;
}

.gt-fund-accordion-icon {
  position: absolute;
  right: 1rem;
  font-size: 1.125rem;
  color: rgba(255, 255, 255, 0.7);
  transition: transform 0.3s ease;
  flex-shrink: 0;
}

.light-style .gt-fund-accordion-icon {
  color: rgba(74, 76, 75, 0.7);
}

.gt-fund-accordion-header:not(.collapsed) .gt-fund-accordion-icon {
  transform: rotate(180deg);
}

.gt-fund-accordion-body {
  padding: 0.75rem 1rem;
  background-color: rgba(255, 255, 255, 0.02);
}

.light-style .gt-fund-accordion-body {
  background-color: rgba(0, 0, 0, 0.01);
}

.gt-fund-accordion-details {
  padding: 0.5rem 0;
}

.gt-fund-accordion-detail-item {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.gt-fund-accordion-accent {
  color: #4ade80 !important;
}

.light-style .gt-fund-accordion-accent {
  color: #22c55e !important;
}

@media (max-width: 767.98px) {
  .gt-fund-accordion-info {
    flex-direction: column;
    gap: 0.5rem;
    align-items: flex-start;
  }

  .gt-fund-accordion-right {
    margin-right: 2.5rem;
    margin-top: 0.5rem;
  }

  .gt-fund-accordion-field {
    min-width: auto;
  }
}

/* Grant Category Quick Action Icons */
.gc-quick-action-icon {
  color: #ffffff !important;
}

/* Grant Category Obligations Card min-height */
@media (min-width: 768px) {
  .gc-obligations-card {
    min-height: 400px;
  }
}

/* Grant Category Funding Accordion Styles */
.gc-fund-accordion-item {
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 0.5rem;
  overflow: hidden;
  margin-bottom: 0.75rem;
  background-color: rgba(255, 255, 255, 0.02);
}

.light-style .gc-fund-accordion-item {
  border: 1px solid rgba(0, 0, 0, 0.1);
  background-color: rgba(0, 0, 0, 0.02);
}

.gc-fund-accordion-header {
  width: 100%;
  padding: 0.75rem 1rem;
  background-color: rgba(255, 255, 255, 0.05);
  border: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  transition: background-color 0.2s ease;
  text-align: left;
  position: relative;
}

.light-style .gc-fund-accordion-header {
  background-color: rgba(0, 0, 0, 0.03);
}

.gc-fund-accordion-header:hover {
  background-color: rgba(255, 255, 255, 0.08);
}

.light-style .gc-fund-accordion-header:hover {
  background-color: rgba(0, 0, 0, 0.05);
}

.gc-fund-accordion-header:not(.collapsed) {
  background-color: rgba(255, 255, 255, 0.08);
}

.light-style .gc-fund-accordion-header:not(.collapsed) {
  background-color: rgba(0, 0, 0, 0.06);
}

.gc-fund-accordion-info {
  display: flex;
  gap: 1.25rem;
  flex: 1;
  align-items: center;
}

.gc-fund-accordion-field {
  min-width: 5rem;
}

.gc-fund-accordion-right {
  text-align: right;
  margin-right: 2rem;
}

.gc-fund-accordion-label {
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 0.25rem;
  font-weight: 400;
}

.light-style .gc-fund-accordion-label {
  color: rgba(74, 76, 75, 0.6);
}

.gc-fund-accordion-value {
  font-weight: 600;
  color: #ffffff;
  font-size: 0.875rem;
}

.light-style .gc-fund-accordion-value {
  color: #4A4C4B;
}

.gc-fund-accordion-source {
  font-weight: 700;
}

.gc-fund-accordion-icon {
  position: absolute;
  right: 1rem;
  font-size: 1.125rem;
  color: rgba(255, 255, 255, 0.7);
  transition: transform 0.3s ease;
  flex-shrink: 0;
}

.light-style .gc-fund-accordion-icon {
  color: rgba(74, 76, 75, 0.7);
}

.gc-fund-accordion-header:not(.collapsed) .gc-fund-accordion-icon {
  transform: rotate(180deg);
}

.gc-fund-accordion-body {
  padding: 0.75rem 1rem;
  background-color: rgba(255, 255, 255, 0.02);
}

.light-style .gc-fund-accordion-body {
  background-color: rgba(0, 0, 0, 0.01);
}

.gc-fund-accordion-details {
  padding: 0.5rem 0;
}

.gc-fund-accordion-detail-item {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.gc-fund-accordion-accent {
  color: #4ade80 !important;
}

.light-style .gc-fund-accordion-accent {
  color: #22c55e !important;
}

@media (max-width: 767.98px) {
  .gc-fund-accordion-info {
    flex-direction: column;
    gap: 0.5rem;
    align-items: flex-start;
  }

  .gc-fund-accordion-right {
    margin-right: 2.5rem;
    margin-top: 0.5rem;
  }

  .gc-fund-accordion-field {
    min-width: auto;
  }
}

#chat-button {
  display: flex;
  justify-content: center;
  align-items: center;
  transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
  background-color: transparent !important;
  position: relative;
  border-radius: 50%;
  overflow: visible;
  cursor: pointer;
  flex: 0 0 auto;
  width: 40px;
  height: 40px;
  padding: 0;
  line-height: 0;
}

/* Larger chat popup on bigger screens for better look & feel */
@media (min-width: 1400px) {
  #chat-frame-wrapper {
    width: 600px;
    height: 620px;
  }
}

@media (min-width: 1800px) {
  #chat-frame-wrapper {
    width: 680px;
    height: 700px;
  }
}

/* Ensure chat icon/button is visible even if JS theme sync hasn't run yet */
.light-style #chat-button:not(.active) {
  background-color: var(--gray-2) !important;
  border: 1px solid rgba(18, 18, 18, 0.12);
}

.dark-style #chat-button:not(.active) {
  background-color: var(--style-graphite-deep) !important;
  border: 1px solid rgba(255, 255, 255, 0.12);
}

.light-style #chat-button svg [stroke] {
  stroke: var(--style-graphite-deep) !important;
}

.dark-style #chat-button svg [stroke] {
  stroke: var(--style-white) !important;
}

#chat-button::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(106, 137, 160, 0.3) 0%, transparent 70%);
  opacity: 0;
  transition: opacity 0.4s ease-in-out, transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
  pointer-events: none;
}

#chat-button::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0);
  width: 120%;
  height: 120%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(106, 137, 160, 0.15) 0%, transparent 70%);
  opacity: 0;
  transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
  pointer-events: none;
  z-index: -1;
}

#chat-button:hover {
  transform: scale(1.15);
  background: linear-gradient(135deg, var(--primary) 0%, var(--warning) 100%) !important;
  box-shadow: 0 4px 20px rgba(106, 137, 160, 0.4), 0 0 15px rgba(255, 215, 0, 0.3);
}

#chat-button:hover::before {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1.3);
  background: radial-gradient(circle, rgba(255, 215, 0, 0.4) 0%, rgba(106, 137, 160, 0.3) 50%, transparent 80%);
}

#chat-button:hover::after {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
  animation: pulse-ring 1.5s ease-out infinite;
  background: radial-gradient(circle, rgba(255, 215, 0, 0.2) 0%, rgba(106, 137, 160, 0.15) 50%, transparent 70%);
}

#chat-button.active {
  background-color: var(--primary) !important;
  box-shadow: 0 2px 10px rgba(106, 137, 160, 0.5);
}

#chat-button svg {
  transition: transform 0.6s cubic-bezier(0.34, 1.56, 0.64, 1);
  filter: drop-shadow(0 0 0 rgba(255, 255, 255, 0));
  transform-origin: center;
  z-index: 1;
  position: relative;
}

#chat-button:hover svg {
  transform: rotate(360deg) scale(1.1);
  filter: drop-shadow(0 4px 12px rgba(255, 215, 0, 0.8)) drop-shadow(0 0 8px rgba(255, 255, 255, 0.5));
}

@keyframes pulse-ring {
  0% {
    transform: translate(-50%, -50%) scale(1);
    opacity: 1;
  }
  50% {
    transform: translate(-50%, -50%) scale(1.2);
    opacity: 0.7;
  }
  100% {
    transform: translate(-50%, -50%) scale(1.4);
    opacity: 0;
  }
}

#chat-frame-wrapper {
  position: fixed;
  bottom: 55px;
  right: 20px;
  width: 500px;
  height: 500px;
  display: none;
  z-index: 9999;
}

#chat-frame {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: none;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
  border-radius: 10px;
  transition: all 0.3s ease-in-out;
}

#chat-frame-wrapper.expanded {
  bottom: 20px;
  right: 20px;
  left: 20px;
  top: 20px;
  width: auto;
  height: auto;
}

#chat-close-button {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 32px;
  height: 32px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: rgba(255, 255, 255, 0.9);
  border: none;
  border-radius: 6px;
  cursor: pointer;
  z-index: 10001;
  padding: 6px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  transition: all 0.2s ease-in-out;
}

#chat-close-button:hover {
  background-color: rgba(255, 255, 255, 1);
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.2);
  transform: scale(1.05);
}

.dark-style #chat-close-button {
  background-color: rgba(18, 18, 18, 0.9);
}

.dark-style #chat-close-button:hover {
  background-color: rgba(18, 18, 18, 1);
}

#chat-close-button svg {
  width: 100%;
  height: 100%;
  transition: opacity 0.2s ease-in-out;
}

#chat-expand-button {
  position: absolute;
  top: 10px;
  right: 50px;
  width: 32px;
  height: 32px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: rgba(255, 255, 255, 0.9);
  border: none;
  border-radius: 6px;
  cursor: pointer;
  z-index: 10000;
  padding: 6px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  transition: all 0.2s ease-in-out;
}

#chat-expand-button:hover {
  background-color: rgba(255, 255, 255, 1);
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.2);
  transform: scale(1.05);
}

.dark-style #chat-expand-button:hover {
  background-color: rgba(18, 18, 18, 1);
}

#chat-expand-button svg {
  width: 100%;
  height: 100%;
  transition: opacity 0.2s ease-in-out;
}

/* Responsive styles for chat frame on mobile devices */
@media (max-width: 768px) {
  #chat-button {
    width: 38px;
    height: 38px;
    padding: 0;
    background-color: transparent !important;
  }

  #chat-frame-wrapper {
    width: 90vw;
    height: 70vh;
    max-width: 90vw;
    max-height: 70vh;
    bottom: 45px;
    right: 5vw;
    left: auto;
  }

  #chat-frame-wrapper.expanded {
    bottom: 10px;
    right: 10px;
    left: 10px;
    top: 10px;
    width: auto;
    height: auto;
  }

  #chat-expand-button {
    width: 36px;
    height: 36px;
    top: 8px;
    right: 8px;
  }
}

@media (max-width: 480px) {
  #chat-button {
    width: 40px;
    height: 40px;
    padding: 0;
    background-color: transparent !important;
  }

  #chat-frame-wrapper {
    width: 95vw;
    height: 75vh;
    max-width: 95vw;
    max-height: 75vh;
    bottom: 40px;
    right: 2.5vw;
    left: auto;
  }

  #chat-frame-wrapper.expanded {
    bottom: 0;
    right: 0;
    left: 0;
    top: 0;
    width: 100vw;
    height: 100vh;
    border-radius: 0;
  }

  #chat-frame {
    border-radius: 10px;
  }

  #chat-frame-wrapper.expanded #chat-frame {
    border-radius: 0;
  }

  #chat-expand-button {
    width: 40px;
    height: 40px;
    top: 5px;
    right: 5px;
    padding: 8px;
  }
}

/* Larger chat popup on bigger screens for better look & feel */
@media (min-width: 1400px) {
  #chat-frame-wrapper {
    width: 600px;
    height: 620px;
  }
}

@media (min-width: 1800px) {
  #chat-frame-wrapper {
    width: 680px;
    height: 700px;
  }
}

[dir=rtl].dark-style .bs-stepper.vertical .bs-stepper-header {
  border-left: 1px solid var(--style-graphite-deep);
}

html:not([dir=rtl]).dark-style .bs-stepper.vertical .bs-stepper-header {
  border-right: 1px solid var(--style-graphite-deep);
  border-right: none !important;
}

html:not([dir=rtl]).light-style .bs-stepper.vertical .bs-stepper-header{
  border-right: none !important;
}

.light-style .bs-stepper:not(.wizard-modern){
  box-shadow: none !important;
  border: none !important;
}

@media (max-width: 991.98px) {
  .dark-style .bs-stepper.vertical .bs-stepper-header {
    border-right: none !important;
    border-left: none !important;
    border-bottom: 1px solid var(--style-graphite-deep);
  }
}

.bs-stepper {
  background-color: transparent !important;
}

.bs-stepper .bs-stepper-header{
  padding: 0px !important;
}

.bs-stepper .bs-stepper-header .step .step-trigger .bs-stepper-label .bs-stepper-title{
  line-height: 1.5 !important;
}

#wizard-vertical-form {
  position: relative;
  min-height: 100%;
  padding-bottom: 70px;
}

/* ===== Form-validation helpers — consolidated from duplicated inline <style>
   blocks across the SVR Admin / Impound / Wrecker forms. Generic, Bootstrap-
   variable based (no hardcoded colours); lives in the global stylesheet so the
   per-page inline copies can be removed. ===== */
.repeater-item-wrapper .btn-danger {
  margin-top: .5rem;
}
.input-group-border-invalid,
.input-group:focus-within .input-group-text.input-group-border-invalid {
  border-color: var(--bs-form-invalid-color) !important;
}
.input-group-border-valid,
.input-group:focus-within .input-group-text.input-group-border-valid {
  border-color: var(--bs-form-valid-color) !important;
}

.sticky-btn {
  position: absolute;
  bottom: 0;
  right: 0;
  padding: 0.75rem 1.5rem;
  z-index: 10;
  width: 100%;
}

/* SVR DBS Wizard Layout - Unique classes to prevent horizontal scroll */
.svr-dbs-wizard-row,
.engagement-wizard-row {
  gap: 1rem;
  flex-wrap: nowrap;
}

.svr-dbs-wizard-menu,
.engagement-wizard-menu {
  max-width: 225px;
  flex: 0 0 auto;
}

.svr-dbs-wizard-content,
.engagement-wizard-content {
  flex: 1 1 auto;
  min-width: 0;
}

.question-border {
  border: 1px solid #dee2e6;
  border-radius: 0.4rem;
  padding: 1rem;
  margin-bottom: 1rem;
  margin-left: 0px;
}

.content-box .input-w-180 {
    width: 200px !important;
    max-width: 200px;
}

.max-w-130 {
  max-width: 130px !important;
  width: 100%;
}
/* State inbox tabs: self-contained styles (no dependency on schedule-tab) */
.state-inbox-tab-list .inbox-tab {
  width: fit-content;
}
.state-inbox-tab-list .inbox-tab .nav-pills {
  width: fit-content;
  border: 1px solid var(--primary) !important;
  border-radius: 0.5rem;
  overflow: hidden;
}
.state-inbox-tab-list .inbox-tab .nav-pills .nav-item {
  flex: none;
}
.state-inbox-tab-list .inbox-tab .nav-pills .nav-link {
  min-width: auto;
  padding-left: 1rem;
  padding-right: 1rem;
  border-radius: 0;
}
.state-inbox-tab-list .inbox-tab .nav-pills .nav-link:hover {
  color: #555555;
}
.dark-style .state-inbox-tab-list .inbox-tab .nav-pills .nav-link:hover {
  color: #ffffff;
}
.state-inbox-tab-list .inbox-tab .nav-pills .nav-link.active {
  background-color: var(--primary) !important;
  color: var(--text-white) !important;
  box-shadow: none;
}
/* State inbox: vertical line to the right of each nav item (except last) */
.state-inbox-tab-list .inbox-tab .nav-pills .nav-item:not(:last-child) .nav-link {
  border-right: 1px solid var(--primary);
}

.auto-expand-textarea {
  resize: none;
  overflow: hidden;
  min-height: 2.5rem;
}
.engagement-modal-width{
 max-width: 43rem !important;
 }
/* Reusable count badge (pill) */
.tab-count-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.4rem;
  height: 1.4rem;
  padding: 0 0.35rem;
  margin-left: 0.4rem;
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1;
  border-radius: 999px;
  background-color: rgba(0, 0, 0, 0.15);
  color: inherit;
  vertical-align: middle;
}
.active > .tab-count-badge,
.active .tab-count-badge {
  background-color: rgba(255, 255, 255, 0.25);
  color: var(--text-white);
}
.dark-style .tab-count-badge {
  background-color: rgba(255, 255, 255, 0.12);
}
.dark-style .active > .tab-count-badge,
.dark-style .active .tab-count-badge {
  background-color: rgba(255, 255, 255, 0.25);
  color: var(--text-white);
}

/* Single-line textarea (Goals & Milestones) */
.textarea-single-line {
  min-height: calc(1.5em + 0.75rem + 2px);
  resize: vertical;
}
.button-size-adjust {
  width:120px;
}


.max-w-105{
   width: 113px !important; 
 }

.max-w-125{
  width: 125px !important; 
}
 max-w-125

 .max-w-170{
   width: 170px !important; 
 }

 .select2-selection__clear {
      display: none !important;
  }

/* default: 600px for viewports below 1500px */
.col-width-600 {
  width: 400px !important;
}

/* at 1500px and above: reduce to 400px */
@media (min-width: 1500px) {
  .col-width-600 {
    width: 600px !important;
  }
}

.col-width-300{
    width: 300px !important;
  }
  
.col-width-200{
    width: 200px !important;
  }

.col-width-100{
    width: 100px !important;
  }

.col-width-50{
    width: 50px !important;
  }


/* Search input */
.light-style .input-group.search-css:focus-within .form-control,
.light-style .input-group.search-css:hover .form-control,
.dark-style .input-group.search-css:focus-within .form-control,
.dark-style .input-group.search-css:hover .form-control {
  border: 2px solid var(--style-success) !important;
  border-left: 0 !important;
  box-shadow: none !important;
}

.light-style .input-group.search-css:focus-within .input-group-text,
.light-style .input-group.search-css:hover .input-group-text,
.dark-style .input-group.search-css:focus-within .input-group-text,
.dark-style .input-group.search-css:hover .input-group-text {
  border: 2px solid var(--style-success) !important;
  border-right: 0 !important;
  box-shadow: none !important;
}

.light-style .input-group.password-css:focus-within .form-control,
.light-style .input-group.password-css:hover .form-control,
.dark-style .input-group.password-css:focus-within .form-control,
.dark-style .input-group.password-css:hover .form-control {
  border: 2px solid var(--style-success) !important;
  border-right: 0 !important;
  box-shadow: none !important;
}

.light-style .input-group.password-css:focus-within .input-group-text,
.light-style .input-group.password-css:hover .input-group-text,
.dark-style .input-group.password-css:focus-within .input-group-text,
.dark-style .input-group.password-css:hover .input-group-text {
  border: 2px solid var(--style-success) !important;
  border-left: 0 !important;
  box-shadow: none !important;
}

/* bs-stepper theme overrides (moved from vendor: bs-stepper.css) */
.light-style .bs-stepper {
  background-color: var(--style-white);
}
.light-style .bs-stepper:not(.wizard-modern) {
  box-shadow: 0 0.25rem 1.125rem rgba(75, 70, 92, 0.1);
}
.light-style .bs-stepper .bs-stepper-header {
  border-bottom: 1px solid var(--style-vuexy-light-border);
}
.light-style .bs-stepper .bs-stepper-header .line i {
  color: var(--gray-5);
}
.light-style .bs-stepper .bs-stepper-header .bs-stepper-title,
.light-style .bs-stepper .bs-stepper-header .bs-stepper-label {
  color: var(--gray-6);
}
.light-style .bs-stepper .bs-stepper-header .bs-stepper-label .bs-stepper-subtitle {
  color: var(--gray-5) !important;
}
.light-style .bs-stepper .bs-stepper-header .step:not(.active) .bs-stepper-circle {
  background-color: var(--gray-2);
  color: var(--style-white);
}
.light-style .bs-stepper .bs-stepper-header .step.active .bs-stepper-circle {
  box-shadow: 0 0.125rem 0.25rem rgba(165, 163, 174, 0.3);
}
.light-style .bs-stepper .bs-stepper-header .step.crossed .bs-stepper-label,
.light-style .bs-stepper .bs-stepper-header .step.crossed .bs-stepper-title {
  color: var(--gray-5);
}
.light-style .bs-stepper .step-trigger:focus {
  color: var(--gray-6);
}
.light-style .bs-stepper.vertical .bs-stepper-header {
  border-bottom: none;
}
@media (max-width: 991.98px) {
  .light-style .bs-stepper.vertical .bs-stepper-header {
    border-right: none !important;
    border-left: none !important;
    border-bottom: 1px solid var(--style-vuexy-light-border);
  }
}
.light-style .bs-stepper.wizard-modern {
  background-color: transparent;
}
.light-style .bs-stepper.wizard-modern .bs-stepper-content {
  background-color: var(--style-white);
  box-shadow: 0 0.25rem 1.125rem rgba(75, 70, 92, 0.1);
}
.light-style .bs-stepper.wizard-icons .bs-stepper-header .bs-stepper-icon svg {
  fill: var(--style-text-muted);
}
.light-style .bs-stepper.wizard-icons .bs-stepper-header .bs-stepper-icon i {
  fill: var(--style-text-muted);
}
.light-style .bs-stepper.wizard-icons .bs-stepper-header .bs-stepper-label {
  color: var(--style-text-muted);
}
[dir=rtl].light-style .bs-stepper.vertical .bs-stepper-header {
  border-left: 1px solid var(--style-vuexy-light-border);
}
html:not([dir=rtl]).light-style .bs-stepper.vertical .bs-stepper-header {
  border-right: 1px solid var(--style-vuexy-light-border);
}

.dark-style .bs-stepper {
  background-color: var(--style-graphite-deep) !important;
}
.dark-style .bs-stepper .bs-stepper-header {
  border-bottom: 1px solid var(--style-graphite-deep);
}
.dark-style .bs-stepper .bs-stepper-header .line i {
  color: var(--primary-accent);
}
.dark-style .bs-stepper .bs-stepper-header .bs-stepper-label,
.dark-style .bs-stepper .bs-stepper-header .bs-stepper-title {
  color: var(--style-white);
}
.dark-style .bs-stepper .bs-stepper-header .bs-stepper-label .bs-stepper-subtitle {
  color: var(--primary-accent) !important;
}
.dark-style .bs-stepper .bs-stepper-header .step:not(.active) .bs-stepper-circle {
  background-color: var(--surface-3);
  color: var(--style-white);
}
.dark-style .bs-stepper .bs-stepper-header .step.active .bs-stepper-circle {
  box-shadow: 0 0.125rem 0.25rem rgba(15, 20, 34, 0.4);
}
.dark-style .bs-stepper .bs-stepper-header .step.crossed .bs-stepper-label,
.dark-style .bs-stepper .bs-stepper-header .step.crossed .bs-stepper-title {
  color: var(--style-white);
}
.dark-style .bs-stepper .step-trigger:focus {
  color: var(--style-white);
}
.dark-style .bs-stepper.vertical .bs-stepper-header {
  border-bottom: none;
}
@media (max-width: 991.98px) {
  .dark-style .bs-stepper.vertical .bs-stepper-header {
    border-right: none !important;
    border-left: none !important;
    border-bottom: 1px solid var(--style-graphite-deep);
  }
}
.dark-style .bs-stepper.wizard-modern {
  background-color: transparent;
}
.dark-style .bs-stepper.wizard-modern .bs-stepper-content {
  background-color: var(--surface-1);
  box-shadow: 0 0.25rem 1.25rem rgba(15, 20, 34, 0.4);
}
.dark-style .bs-stepper.wizard-icons .bs-stepper-header .bs-stepper-icon i {
  color: var(--style-white);
}
.dark-style .bs-stepper.wizard-icons .bs-stepper-header .bs-stepper-icon svg {
  fill: var(--style-vuexy-soft-purple-text);
}
.dark-style .bs-stepper.wizard-icons .bs-stepper-header .bs-stepper-label {
  color: var(--style-white);
}
[dir=rtl].dark-style .bs-stepper.vertical .bs-stepper-header {
  border-left: 1px solid var(--style-graphite-deep);
}
html:not([dir=rtl]).dark-style .bs-stepper.vertical .bs-stepper-header {
  border-right: 1px solid var(--style-graphite-deep);
}

/* ==========================================================================
   UI Refined Layout — opt-in via .ui-refined-layout on .layout-wrapper
   Set @php $uiRefinedLayout = true; @endphp at the top of any blade view.
   Styles below are ported literally from feat/ui-refinement reference branch.
   ========================================================================== */

/* === UI Refined Layout: Data Tables ===
   All colors derive from --primary (set in layouts/sections/styles.blade.php
   from $stateColor). Change --primary and the entire DataTable look adapts. */
.ui-refined-layout .table {
  border-collapse: separate;
  border-spacing: 0;
}

/* Header — light */
.light-style .ui-refined-layout .table thead th {
  background: var(--primary-gradient-light) !important;
  color: var(--style-white) !important;
  border-bottom: 0 !important;
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

/* Header — dark */
.dark-style .ui-refined-layout .table thead th {
  background: var(--primary-gradient-dark) !important;
  color: var(--style-white) !important;
  border-bottom: 0 !important;
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

.ui-refined-layout .table thead th:first-child {
  /* border-top-left-radius: 12px; */
}

.ui-refined-layout .table thead th:last-child {
  /* border-top-right-radius: 12px; */
}

/* Body cells */
.light-style .ui-refined-layout .table tbody td {
  border-color: var(--border-light) !important;
  vertical-align: middle;
  color: var(--text-on-light) !important;
}

.dark-style .ui-refined-layout .table tbody td {
  border-color: var(--border-dark) !important;
  vertical-align: middle;
  color: var(--text-on-dark) !important;
}

/* Alternating rows — light (high contrast: pure white vs primary-tinted) */
.light-style .ui-refined-layout .table tbody tr:nth-child(odd) td {
  background: var(--surface-light) !important;
}

.light-style .ui-refined-layout .table tbody tr:nth-child(even) td {
  background: var(--surface-light-alt) !important;
}

/* Alternating rows — dark */
.dark-style .ui-refined-layout .table tbody tr:nth-child(odd) td {
  background: var(--surface-dark) !important;
}

.dark-style .ui-refined-layout .table tbody tr:nth-child(even) td {
  background: var(--surface-dark-alt) !important;
}

/* Hover */
.light-style .ui-refined-layout .table tbody tr:hover td {
  background: var(--surface-light-hover) !important;
}

.dark-style .ui-refined-layout .table tbody tr:hover td {
  background: var(--surface-dark-hover) !important;
}

/* Table responsive shell */
.light-style .ui-refined-layout .table-responsive,
.light-style .ui-refined-layout .ui-table-shell {
  border: 1px solid var(--border-light);
  border-radius: 10px;
  overflow: hidden;
  background: var(--surface-light);
}

.dark-style .ui-refined-layout .table-responsive,
.dark-style .ui-refined-layout .ui-table-shell {
  border: 1px solid var(--border-dark) !important;
  border-radius: 10px;
  overflow: hidden;
  background: var(--surface-dark);
}

/* DataTables wrapper text */
.light-style .ui-refined-layout .dataTables_wrapper .dataTables_info,
.light-style .ui-refined-layout .dataTables_wrapper .dataTables_length,
.light-style .ui-refined-layout .dataTables_wrapper .dataTables_filter {
  color: var(--text-on-light) !important;
}

.dark-style .ui-refined-layout .dataTables_wrapper .dataTables_info,
.dark-style .ui-refined-layout .dataTables_wrapper .dataTables_length,
.dark-style .ui-refined-layout .dataTables_wrapper .dataTables_filter,
.dark-style .ui-refined-layout .dataTables_wrapper .dataTables_paginate {
  color: var(--text-on-dark) !important;
}

/* Spacing for info / paginate row ("Showing X to Y of Z results") */
.ui-refined-layout .dataTables_wrapper .dataTables_info {
  padding: 0.85rem 0.25rem 0.25rem;
  font-size: 0.875rem;
}

.ui-refined-layout .dataTables_wrapper .dataTables_paginate {
  padding: 0.5rem 0.25rem 0.25rem;
}

@media (min-width: 768px) {
  .ui-refined-layout .dataTables_wrapper .dataTables_info {
    padding: 0rem 1rem 0.25rem;
  }
  .ui-refined-layout .dataTables_wrapper .dataTables_paginate {
    padding: 0rem 0.5rem 0.25rem;
  }
}

/* Pagination — style the actual <a class="page-link"> element (DataTables BS5 wraps it inside <li class="paginate_button page-item">). */
.ui-refined-layout .dataTables_wrapper .pagination .page-link,
.ui-refined-layout .pagination .page-link {
  border: 1px solid var(--border-light) !important;
  background: var(--surface-light) !important;
  color: var(--text-on-light) !important;
  border-radius: var(--driven-component-radius) !important;
  margin: 0 2px !important;
  padding: 0 0.55rem !important;
  min-width: 2rem;
  height: 2rem;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1;
  transition: background 180ms ease, color 180ms ease, border-color 180ms ease;
}

.dark-style .ui-refined-layout .dataTables_wrapper .pagination .page-link,
.dark-style .ui-refined-layout .pagination .page-link {
  border: 1px solid var(--border-dark) !important;
  background: var(--surface-dark) !important;
  color: var(--text-on-dark) !important;
}

/* Inner span (DataTables wraps "‹" "›" arrows in <span aria-hidden>) inherits parent color */
.ui-refined-layout .dataTables_wrapper .pagination .page-link > *,
.ui-refined-layout .pagination .page-link > * {
  color: inherit !important;
}

/* Active page — gradient bg, white text (matches reference) */
.ui-refined-layout .dataTables_wrapper .pagination .page-item.active .page-link,
.ui-refined-layout .dataTables_wrapper .pagination .paginate_button.active .page-link,
.ui-refined-layout .pagination .page-item.active .page-link {
  background: var(--primary-gradient-dark) !important;
  color: var(--style-white) !important;
  border-color: var(--primary) !important;
}

/* Hover on any page-link */
.ui-refined-layout .dataTables_wrapper .pagination .page-link:hover,
.ui-refined-layout .pagination .page-link:hover {
  background: var(--primary-gradient-dark) !important;
  color: var(--style-white) !important;
  border-color: var(--primary) !important;
}

/* Prev / Next — ALWAYS gradient + white arrow (visible in both modes) */
.ui-refined-layout .dataTables_wrapper .pagination .paginate_button.previous .page-link,
.ui-refined-layout .dataTables_wrapper .pagination .paginate_button.next .page-link,
.ui-refined-layout .dataTables_wrapper .pagination .page-item.previous .page-link,
.ui-refined-layout .dataTables_wrapper .pagination .page-item.next .page-link {
  background: var(--primary-gradient-dark) !important;
  color: var(--style-white) !important;
  border-color: var(--primary) !important;
}

/* Disabled */
.ui-refined-layout .dataTables_wrapper .pagination .page-item.disabled .page-link,
.ui-refined-layout .pagination .page-item.disabled .page-link {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

/* === UI Refined Layout: Navbar Icon Sizing (project-wide) === */
.header-menu .header-logout-icon,
.themesOptions .theme-icon {
  font-size: 1.55rem !important;
  margin-left: 0 !important;
  top: 0 !important;
}

.ui-refined-layout .header-menu .header-logout-icon,
.ui-refined-layout .themesOptions .theme-icon,
.ui-refined-layout .layout-menu-toggle .ti {
  font-size: 2.0rem !important;
  margin-left: 0 !important;
  top: 0 !important;
}

/* === UI Refined Layout: Top Navbar === */
.light-style .ui-refined-layout .layout-navbar.navbar-detached {
  margin: 0;
  min-height: 4.5rem;
  padding: 0 1rem;
  border: 1px solid var(--navbar-border-light);
  border-radius: 0 !important;
  background: var(--navbar-bg-light) !important;
  box-shadow: var(--navbar-shadow-light);
  backdrop-filter: blur(14px);
}

.dark-style .ui-refined-layout .layout-navbar.navbar-detached {
  margin: 0;
  min-height: 4.5rem;
  padding: 0 1rem;
  border: 0 !important;
  border-bottom: 1px solid var(--navbar-border-dark) !important;
  border-radius: 0 !important;
  background: var(--navbar-bg-dark) !important;
  box-shadow: none !important;
  backdrop-filter: blur(14px);
}

.ui-refined-layout .layout-navbar.navbar-detached .navbar-nav-right {
  width: 100%;
}

.light-style .ui-refined-layout .header-menu > li > .nav-link,
.light-style .ui-refined-layout .header-menu > li > div {
  color: var(--navbar-text-light);
}

.dark-style .ui-refined-layout .header-menu > li > .nav-link,
.dark-style .ui-refined-layout .header-menu > li > div {
  color: var(--navbar-text-dark);
}

.light-style .ui-refined-layout .header-menu .header-logout-icon,
.light-style .ui-refined-layout .themesOptions .theme-icon,
.light-style .ui-refined-layout .layout-menu-toggle .ti {
  color: var(--navbar-text-light) !important;
}

.dark-style .ui-refined-layout .header-menu .header-logout-icon,
.dark-style .ui-refined-layout .themesOptions .theme-icon,
.dark-style .ui-refined-layout .layout-menu-toggle .ti {
  color: var(--navbar-text-dark) !important;
}

.ui-refined-layout .layout-page {
  padding-top: 0;
  padding-right: 1rem;
  padding-bottom: 1rem;
}

.ui-refined-layout.layout-navbar-fixed .layout-wrapper:not(.layout-horizontal) .layout-page:before,
.ui-refined-layout .layout-page:before {
  height: 0;
}

/* === UI Refined Layout: Sidebar (Left Navigation) === */
.light-style .ui-refined-layout .menu-vertical {
  background: var(--sidebar-bg-light) !important;
  box-shadow: 18px 0 40px rgba(22, 33, 47, 0.18);
}

.dark-style .ui-refined-layout .menu-vertical {
  background: var(--sidebar-bg-dark) !important;
  box-shadow: 18px 0 40px rgba(6, 10, 15, 0.28);
}

.dark-style .ui-refined-layout #layout-menu.alliance-sidebar.bg-menu-theme,
.dark-style .ui-refined-layout #layout-menu.alliance-sidebar {
  background: var(--sidebar-bg-dark) !important;
  background-color: var(--surface-base) !important;
  box-shadow: inset -1px 0 0 var(--sidebar-divider);
}

.light-style .ui-refined-layout .menu-vertical .app-brand {
  min-height: 72px;
  padding: 1rem 1.2rem 0.9rem;
  background: var(--sidebar-brand-bg-light) !important;
}

.dark-style .ui-refined-layout .menu-vertical .app-brand {
  min-height: 72px;
  padding: 1rem 1.2rem 0.9rem;
  background: rgba(255, 255, 255, 0.02) !important;
}

.dark-style .ui-refined-layout #layout-menu.alliance-sidebar .alliance-sidebar-brand,
.dark-style .ui-refined-layout #layout-menu.alliance-sidebar .app-brand {
  background: var(--sidebar-brand-bg-dark) !important;
  background-color: var(--surface-base) !important;
  border-bottom: 1px solid var(--sidebar-divider) !important;
  box-shadow: none !important;
}

.dark-style .ui-refined-layout #layout-menu.alliance-sidebar .menu-inner,
.dark-style .ui-refined-layout #layout-menu.alliance-sidebar .menu-inner-shadow {
  background: transparent !important;
  background-color: transparent !important;
}

.ui-refined-layout .menu-vertical .menu-inner {
  background: transparent;
}

/* Even horizontal inset on every menu-link (leaf and toggle alike) so the
   active gradient highlight sits centered, not flush against the right edge.
   Vendor CSS uses margin: 0 0.875rem; we keep that, but normalize internal
   padding so toggles and leaves don't have different widths. */
.ui-refined-layout .menu-vertical .menu-inner > .menu-item .menu-link {
  margin-left: 0.5rem !important;
  margin-right: 0.5rem !important;
}

.ui-refined-layout .bg-menu-theme,
.ui-refined-layout .bg-menu-theme .menu-inner-shadow {
  background: transparent !important;
}

.ui-refined-layout .menu-vertical .menu-inner > .menu-item {
  margin: 0.22rem 0;
}

.ui-refined-layout .menu-vertical .menu-inner > .menu-item > .menu-link,
.ui-refined-layout .menu-vertical .menu-sub .menu-link {
  min-height: 3rem;
  border-radius: 0.95rem;
  color: var(--sidebar-text);
  font-weight: 600;
  letter-spacing: 0.01em;
  transition: background-color 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.ui-refined-layout .menu-vertical .menu-link div,
.ui-refined-layout .menu-vertical .menu-link span,
.ui-refined-layout .menu-vertical .menu-link i {
  color: inherit !important;
}

/* Hover — !important so we beat the base rule at line 168 (which is !important) */
.light-style .ui-refined-layout .menu-vertical .menu-inner > .menu-item > .menu-link:hover,
.light-style .ui-refined-layout .menu-vertical .menu-sub .menu-link:hover {
  background: var(--sidebar-hover-light) !important;
  color: var(--sidebar-text-strong) !important;
  transform: translateX(2px);
}

.dark-style .ui-refined-layout .menu-vertical .menu-inner > .menu-item > .menu-link:hover,
.dark-style .ui-refined-layout .menu-vertical .menu-sub .menu-link:hover {
  background: var(--sidebar-hover-dark) !important;
  color: var(--sidebar-text-strong) !important;
  transform: translateX(2px);
}

/* Active state — leaf items + active parent toggles + collapsed-hover variant */
.light-style .ui-refined-layout .menu-vertical .menu-item.active > .menu-link:not(.menu-toggle),
.light-style .ui-refined-layout .bg-menu-theme .menu-inner .menu-item.active > .menu-link.menu-toggle,
.light-style .ui-refined-layout.layout-menu-hover.layout-menu-collapsed .bg-menu-theme .menu-inner .menu-item.active > .menu-link.menu-toggle {
  background: var(--sidebar-active-light) !important;
  border: 1px solid var(--sidebar-active-light-border);
  color: var(--sidebar-text-strong) !important;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
}

.dark-style .ui-refined-layout .menu-vertical .menu-item.active > .menu-link:not(.menu-toggle),
.dark-style .ui-refined-layout .bg-menu-theme .menu-inner .menu-item.active > .menu-link.menu-toggle,
.dark-style .ui-refined-layout.layout-menu-hover.layout-menu-collapsed .bg-menu-theme .menu-inner .menu-item.active > .menu-link.menu-toggle {
  background: var(--sidebar-active-dark) !important;
  border: 1px solid var(--sidebar-active-dark-border);
  color: var(--sidebar-text-strong) !important;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
}

/* Open state — parent toggle that's expanded showing children.
   Overrides base rule at line 172 which uses solid var(--primary). */
.light-style .ui-refined-layout .bg-menu-theme .menu-inner .menu-item.open > .menu-link.menu-toggle,
.light-style .ui-refined-layout .menu-vertical .menu-item.open:not(.menu-item-closing) > .menu-toggle {
  background: var(--sidebar-active-light) !important;
  border: 1px solid var(--sidebar-active-light-border);
  color: var(--sidebar-text-strong) !important;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
}

.dark-style .ui-refined-layout .bg-menu-theme .menu-inner .menu-item.open > .menu-link.menu-toggle,
.dark-style .ui-refined-layout .menu-vertical .menu-item.open:not(.menu-item-closing) > .menu-toggle {
  background: var(--sidebar-active-dark) !important;
  border: 1px solid var(--sidebar-active-dark-border);
  color: var(--sidebar-text-strong) !important;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
}

/* Open submenu links — keep readable text */
.ui-refined-layout .menu-vertical .menu-item.open > .menu-link.menu-toggle div,
.ui-refined-layout .menu-vertical .menu-item.open > .menu-link.menu-toggle span,
.ui-refined-layout .menu-vertical .menu-item.open > .menu-link.menu-toggle i {
  color: inherit !important;
}

/* Force readable text colors inside refined sidebar (sidebar bg is always
   dark navy regardless of mode). Overrides:
     line 56:  `.light-style .text-white { color: var(--style-text-dark) !important }`
     line 65:  `.bg-menu-theme.menu-vertical .menu-item.active > .menu-link:not(.menu-toggle) { color: white }`
     line 168: `.dark-style .bg-menu-theme .menu-inner .menu-item:not(.active) > .menu-link:hover { ... }`
   Strategy: set sidebar text color on the container, force inherit on inner spans/divs/icons/.text-white. */
.light-style .ui-refined-layout .menu-vertical,
.dark-style .ui-refined-layout .menu-vertical {
  color: var(--sidebar-text);
}

.light-style .ui-refined-layout .menu-vertical .menu-link,
.light-style .ui-refined-layout .menu-vertical .menu-link.text-white,
.dark-style .ui-refined-layout .menu-vertical .menu-link,
.dark-style .ui-refined-layout .menu-vertical .menu-link.text-white {
  color: var(--sidebar-text) !important;
}

.light-style .ui-refined-layout .menu-vertical .menu-link .text-white,
.light-style .ui-refined-layout .menu-vertical .menu-link i,
.light-style .ui-refined-layout .menu-vertical .menu-link span,
.light-style .ui-refined-layout .menu-vertical .menu-link div,
.dark-style .ui-refined-layout .menu-vertical .menu-link .text-white,
.dark-style .ui-refined-layout .menu-vertical .menu-link i,
.dark-style .ui-refined-layout .menu-vertical .menu-link span,
.dark-style .ui-refined-layout .menu-vertical .menu-link div {
  color: inherit !important;
}

/* Strong text on hover / active / open */
.light-style .ui-refined-layout .menu-vertical .menu-link:hover,
.light-style .ui-refined-layout .menu-vertical .menu-item.active > .menu-link,
.light-style .ui-refined-layout .menu-vertical .menu-item.open > .menu-link,
.dark-style .ui-refined-layout .menu-vertical .menu-link:hover,
.dark-style .ui-refined-layout .menu-vertical .menu-item.active > .menu-link,
.dark-style .ui-refined-layout .menu-vertical .menu-item.open > .menu-link {
  color: var(--sidebar-text-strong) !important;
}

/* Brand area at top of sidebar — keep brand text/logo readable on dark navy */
.ui-refined-layout .menu-vertical .app-brand,
.ui-refined-layout .menu-vertical .app-brand .text-white,
.ui-refined-layout .menu-vertical .app-brand .app-brand-text,
.ui-refined-layout .menu-vertical .app-brand .app-brand-link {
  color: var(--sidebar-text-strong) !important;
}

.ui-refined-layout .menu-vertical .menu-sub {
  padding-top: 0.25rem;
}

/* === Top-level menu group dividers ===
   Visible only when the user has 2+ module menus. The blade stamps
   `.menu-item-divider` on every visible top-level item after the first
   (Admin is bottom-fixed and never receives the class).

   Why border-top (not ::before/::after):
   - Vendor css already uses `.menu-item.active:before` for the right-side
     accent bar, so ::before is taken.
   - Some vendor themes also set ::after on related menu states, so it's
     not safe either.
   A real `border-top` on the menu-item participates in normal layout and
   is impossible to hide via pseudo-element conflicts or stacking. The
   line spans the full sidebar width like a clean horizontal rule. */
.menu-vertical .menu-inner > .menu-item.menu-item-divider {
  border-top: 1px solid rgba(255, 255, 255, 0.18);
  margin-top: 0.55rem;
  padding-top: 0.55rem;
}

/* Refined layout: brighter line so it stays visible alongside active /
   open menu items (which carry a strong gradient highlight). */
.ui-refined-layout .menu-vertical .menu-inner > .menu-item.menu-item-divider {
  border-top-color: var(--sidebar-divider);
}

@media (max-width: 991.98px) {
  .ui-refined-layout #layout-menu {
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.3);
  }
  .ui-refined-layout .menu-vertical .menu-inner > .menu-item > .menu-link:hover,
  .ui-refined-layout .menu-vertical .menu-sub .menu-link:hover {
    transform: none;
  }
}

/* === UI Refined Layout: Buttons ===
   Mode-agnostic by design — buttons look identical in light AND dark mode.
   No .light-style / .dark-style prefixes; everything derives from --primary.
   Standardized variants: Add (+Add), Next, Back, Cancel, Save, Save as Draft, Finalize.
   Bridge selectors target existing .btn.btn-primary / .btn-secondary etc.
   so existing app code inherits the refined look without per-view changes. */

.ui-refined-layout .btn {
  border-radius: var(--driven-component-radius) !important;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.5rem 1.25rem;
  white-space: nowrap;
  transition: background 180ms ease, border-color 180ms ease, color 180ms ease, box-shadow 180ms ease, transform 180ms ease;
}

.ui-refined-layout .btn-sm {
  min-height: 36px;
  padding: 0.35rem 0.9rem;
  border-radius: 10px !important;
  font-size: 0.8125rem;
}

.ui-refined-layout .btn-lg {
  min-height: 52px;
  padding: 0.65rem 1.5rem;
  border-radius: var(--driven-component-radius) !important;
  font-size: 1rem;
}

.ui-refined-layout .btn i {
  font-size: 1rem;
  line-height: 1;
}

/* Primary action — Add (+Add), Save, Next, plus any existing .btn-primary */
.ui-refined-layout .btn.btn-primary,
.ui-refined-layout .btn-refined-add,
.ui-refined-layout .btn-refined-save,
.ui-refined-layout .btn-refined-next {
  background: var(--primary-gradient-dark) !important;
  border: 1px solid var(--primary) !important;
  color: var(--style-white) !important;
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.24);
}

.ui-refined-layout .btn.btn-primary:hover,
.ui-refined-layout .btn.btn-primary:focus,
.ui-refined-layout .btn-refined-add:hover,
.ui-refined-layout .btn-refined-add:focus,
.ui-refined-layout .btn-refined-save:hover,
.ui-refined-layout .btn-refined-save:focus,
.ui-refined-layout .btn-refined-next:hover,
.ui-refined-layout .btn-refined-next:focus {
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--primary) 88%, var(--style-white)) 0%,
    var(--primary) 100%) !important;
  border-color: var(--primary) !important;
  color: var(--style-white) !important;
  transform: translateY(-1px);
  box-shadow: 0 16px 30px rgba(0, 0, 0, 0.32);
}

/* Outline-primary — Save as Draft + any existing .btn-outline-primary */
.ui-refined-layout .btn.btn-outline-primary,
.ui-refined-layout .btn-refined-draft {
  background: transparent !important;
  border: 1px solid var(--primary) !important;
  color: var(--primary) !important;
  box-shadow: none;
}

.ui-refined-layout .btn.btn-outline-primary:hover,
.ui-refined-layout .btn.btn-outline-primary:focus,
.ui-refined-layout .btn-refined-draft:hover,
.ui-refined-layout .btn-refined-draft:focus {
  background: var(--primary-soft-14) !important;
  border-color: var(--primary) !important;
  color: var(--primary) !important;
}

/* Secondary / outline-secondary — Back + existing .btn-secondary, .btn-outline-secondary */
.ui-refined-layout .btn.btn-secondary,
.ui-refined-layout .btn.btn-outline-secondary,
.ui-refined-layout .btn-refined-back {
  background: transparent !important;
  border: 1px solid var(--primary-soft-strong) !important;
  color: var(--primary) !important;
  box-shadow: none;
}

.ui-refined-layout .btn.btn-secondary:hover,
.ui-refined-layout .btn.btn-outline-secondary:hover,
.ui-refined-layout .btn-refined-back:hover,
.ui-refined-layout .btn-refined-back:focus {
  background: var(--primary-soft-14) !important;
  border-color: var(--primary) !important;
  color: var(--primary) !important;
}

/* Dark mode — RESTING state: --primary (#304a63 dark slate) is barely visible on a dark surface,
   so lift the outline/secondary/back buttons' border + text to the light accent slate (--primary-accent
   #7195b7). Keeps the transparent fill from the base rule; hover (below) adds the slate fill. */
.dark-style .ui-refined-layout .btn.btn-outline-primary,
.dark-style .ui-refined-layout .btn-refined-draft,
.dark-style .ui-refined-layout .btn.btn-secondary,
.dark-style .ui-refined-layout .btn.btn-outline-secondary,
.dark-style .ui-refined-layout .btn-refined-back {
  border-color: var(--primary-accent) !important;
  color: var(--primary-accent) !important;
}

/* Dark mode — hover/focus: brighten to the light accent slate (--primary-accent) for readable
   text + border, with a more visible slate fill. */
.dark-style .ui-refined-layout .btn.btn-outline-primary:hover,
.dark-style .ui-refined-layout .btn.btn-outline-primary:focus,
.dark-style .ui-refined-layout .btn-refined-draft:hover,
.dark-style .ui-refined-layout .btn-refined-draft:focus,
.dark-style .ui-refined-layout .btn.btn-secondary:hover,
.dark-style .ui-refined-layout .btn.btn-outline-secondary:hover,
.dark-style .ui-refined-layout .btn-refined-back:hover,
.dark-style .ui-refined-layout .btn-refined-back:focus {
  background: var(--primary-soft-strong) !important;
  border-color: var(--primary-accent) !important;
  color: var(--primary-accent) !important;
}

/* Cancel — neutral outline, danger tint on hover */
.ui-refined-layout .btn-refined-cancel {
  background: transparent !important;
  border: 1px solid var(--primary-soft-strong) !important;
  color: var(--primary) !important;
  box-shadow: none;
}

.ui-refined-layout .btn-refined-cancel:hover,
.ui-refined-layout .btn-refined-cancel:focus {
  background: var(--danger-soft) !important;
  border-color: var(--danger) !important;
  color: var(--style-danger) !important;
}

/* Success — Finalize + existing .btn-success */
.ui-refined-layout .btn.btn-success,
.ui-refined-layout .btn-refined-finalize {
  background: var(--success-gradient) !important;
  border: 1px solid var(--success) !important;
  color: var(--style-white) !important;
  box-shadow: 0 12px 24px rgba(31, 157, 86, 0.24);
}

.ui-refined-layout .btn.btn-success:hover,
.ui-refined-layout .btn.btn-success:focus,
.ui-refined-layout .btn-refined-finalize:hover,
.ui-refined-layout .btn-refined-finalize:focus {
  background: var(--success-gradient-hover) !important;
  border-color: var(--success) !important;
  color: var(--style-white) !important;
  transform: translateY(-1px);
  box-shadow: 0 16px 30px rgba(31, 157, 86, 0.32);
}

/* Danger — existing .btn-danger */
.ui-refined-layout .btn.btn-danger {
  background: var(--danger-gradient) !important;
  border: 1px solid var(--danger) !important;
  color: var(--style-white) !important;
  box-shadow: 0 12px 24px rgba(201, 63, 64, 0.24);
}

.ui-refined-layout .btn.btn-danger:hover,
.ui-refined-layout .btn.btn-danger:focus {
  background: var(--danger-gradient-hover) !important;
  border-color: var(--danger) !important;
  color: var(--style-white) !important;
  transform: translateY(-1px);
  box-shadow: 0 16px 30px rgba(201, 63, 64, 0.32);
}

/* Warning — existing .btn-warning */
.ui-refined-layout .btn.btn-warning {
  background: var(--warning-gradient) !important;
  border: 1px solid var(--warning) !important;
  color: var(--style-white) !important;
  box-shadow: 0 12px 24px rgba(224, 131, 39, 0.24);
}

.ui-refined-layout .btn.btn-warning:hover,
.ui-refined-layout .btn.btn-warning:focus {
  background: var(--warning-gradient-hover) !important;
  border-color: var(--warning) !important;
  color: var(--style-white) !important;
  transform: translateY(-1px);
  box-shadow: 0 16px 30px rgba(224, 131, 39, 0.32);
}

/* Disabled — overrides any variant */
.ui-refined-layout .btn:disabled,
.ui-refined-layout .btn.disabled,
.ui-refined-layout [class*="btn-refined-"]:disabled,
.ui-refined-layout [class*="btn-refined-"].disabled {
  opacity: 0.55 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
  transform: none !important;
  box-shadow: none !important;
}

/* Focus ring (keyboard accessibility) */
.ui-refined-layout .btn:focus-visible,
.ui-refined-layout [class*="btn-refined-"]:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--primary) 55%, transparent);
  outline-offset: 2px;
}

/* Loading state — add .is-loading; spinner overlays the label */
.ui-refined-layout .btn.is-loading,
.ui-refined-layout [class*="btn-refined-"].is-loading {
  position: relative;
  color: transparent !important;
  pointer-events: none;
}

.ui-refined-layout .btn.is-loading::after,
.ui-refined-layout [class*="btn-refined-"].is-loading::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1rem;
  height: 1rem;
  margin: -0.5rem 0 0 -0.5rem;
  border: 2px solid var(--style-white);
  border-top-color: transparent;
  border-radius: 50%;
  animation: refined-btn-spin 0.7s linear infinite;
}

@keyframes refined-btn-spin {
  to { transform: rotate(360deg); }
}

/* Mobile — optional full-width via .btn-refined-block */
@media (max-width: 575.98px) {
  .ui-refined-layout .btn-refined-block {
    width: 100%;
  }
}

/* === UI Refined Layout: Accordion === */
.ui-refined-layout .accordion-item,
.ui-refined-layout .card.accordion-item {
  border-radius: var(--driven-component-radius) !important;
  overflow: hidden;
  margin-bottom: 0.75rem;
}

.light-style .ui-refined-layout .accordion-item,
.light-style .ui-refined-layout .card.accordion-item {
  border: 1px solid var(--border-light) !important;
  background: var(--surface-light) !important;
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
}

.dark-style .ui-refined-layout .accordion-item,
.dark-style .ui-refined-layout .card.accordion-item {
  border: 1px solid var(--border-dark) !important;
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--primary) 8%, var(--surface-dark)) 0%,
    var(--surface-dark) 100%) !important;
  box-shadow: 0 20px 42px rgba(0, 0, 0, 0.34);
}

.ui-refined-layout .accordion-button {
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 1rem 1.1rem !important;
  font-weight: 700;
}

.light-style .ui-refined-layout .accordion-button.collapsed {
  background: var(--primary-gradient-dark) !important;
  color: var(--text-on-dark) !important;
}

.dark-style .ui-refined-layout .accordion-button.collapsed {
  background: var(--primary-gradient-dark) !important;
  color: var(--text-on-dark) !important;
}

.ui-refined-layout .accordion-button:not(.collapsed) {
  background: var(--primary-gradient-dark) !important;
  color: var(--style-white) !important;
}

.ui-refined-layout .accordion-button:not(.collapsed)::after {
  filter: brightness(0) invert(1);
  opacity: 0.95;
}

.dark-style .ui-refined-layout .accordion-button.collapsed::after {
  filter: brightness(0) invert(1);
  opacity: 0.7;
}

.ui-refined-layout .accordion-body {
  padding: 1.1rem;
}

.light-style .ui-refined-layout .accordion-body {
  background: var(--surface-light) !important;
  color: var(--text-on-light);
}

.dark-style .ui-refined-layout .accordion-body {
  background: transparent !important;
  color: var(--text-on-dark);
}

/* === UI Refined Layout: Card / .custom-card === */
.ui-refined-layout .custom-card {
  border-radius: var(--driven-component-radius) !important;
  overflow: hidden;
}

.light-style .ui-refined-layout .custom-card {
  background: var(--card-bg) !important;
  border: 1px solid var(--border-light) !important;
  box-shadow: 0 16px 36px rgba(15, 23, 42, 0.08);
}

.dark-style .ui-refined-layout .custom-card {
  background: var(--card-bg) !important;
  border: 1px solid var(--border-dark) !important;
  box-shadow: 0 20px 42px rgba(0, 0, 0, 0.34);
}

/* === UI Refined Layout: Modal === */
.ui-refined-layout .modal .modal-content,
body:has(.ui-refined-layout) .modal .modal-content {
  border-radius: var(--driven-component-radius) !important;
  overflow: hidden;
  border: 0 !important;
}

.light-style .ui-refined-layout .modal .modal-content,
.light-style body:has(.ui-refined-layout) .modal .modal-content {
  background: var(--surface-light) !important;
  box-shadow: 0 24px 56px rgba(15, 23, 42, 0.18);
}

.dark-style .ui-refined-layout .modal .modal-content,
.dark-style body:has(.ui-refined-layout) .modal .modal-content {
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--primary) 8%, var(--surface-dark)) 0%,
    var(--surface-dark) 100%) !important;
  box-shadow: 0 28px 64px rgba(0, 0, 0, 0.55);
}

.ui-refined-layout .modal .modal-header,
body:has(.ui-refined-layout) .modal .modal-header {
  background: var(--primary-gradient-dark) !important;
  color: var(--style-white) !important;
  border-bottom: 0 !important;
  padding: 1rem 1.25rem;
}

.ui-refined-layout .modal .modal-header .btn-close,
body:has(.ui-refined-layout) .modal .modal-header .btn-close {
  filter: brightness(0) invert(1);
  opacity: 0.85;
}

/* === UI Refined Layout: Tabs (.nav-tabs / .nav-pills) === */
.ui-refined-layout .nav-tabs .nav-link,
.ui-refined-layout .nav-pills .nav-link {
  border-radius: var(--driven-component-radius) !important;
  font-weight: 600;
  padding: 0.6rem 1.1rem;
  border: 0 !important;
  transition: background 180ms ease, color 180ms ease;
}

.light-style .ui-refined-layout .nav-tabs .nav-link,
.light-style .ui-refined-layout .nav-pills .nav-link {
  color: var(--text-on-light);
}

.dark-style .ui-refined-layout .nav-tabs .nav-link,
.dark-style .ui-refined-layout .nav-pills .nav-link {
  color: var(--text-on-dark);
}

.ui-refined-layout .nav-tabs .nav-link:hover,
.ui-refined-layout .nav-pills .nav-link:hover {
  background: var(--primary-soft-08) !important;
  color: var(--primary) !important;
}

.ui-refined-layout .nav-tabs .nav-link.active,
.ui-refined-layout .nav-pills .nav-link.active,
.ui-refined-layout .nav-tabs .nav-item.show .nav-link,
.ui-refined-layout .nav-pills .nav-item.show .nav-link {
  background: var(--primary-gradient-dark) !important;
  color: var(--style-white) !important;
  border: 0 !important;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.18);
}

/* === UI Refined Layout: Form controls (focus ring + radius) === */
.ui-refined-layout .form-control:focus,
.ui-refined-layout .form-select:focus,
.ui-refined-layout .input-group:focus-within .form-control,
.ui-refined-layout .input-group:focus-within .input-group-text {
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 3px var(--primary-soft-22) !important;
  outline: 0 !important;
}

.ui-refined-layout .text-arstrik {
  color: var(--danger);
  font-weight: 600;
  margin-left: 0.15rem;
}

/* === UI Refined Layout: Badge === */
.ui-refined-layout .badge.bg-primary,
.ui-refined-layout .badge.bg-label-primary {
  background: var(--primary-soft-22) !important;
  color: var(--primary) !important;
  border: 1px solid color-mix(in srgb, var(--primary) 30%, transparent);
  border-radius: 999px;
  font-weight: 600;
  padding: 0.35rem 0.75rem;
}

.dark-style .ui-refined-layout .badge.bg-primary,
.dark-style .ui-refined-layout .badge.bg-label-primary {
  background: var(--primary-soft-14) !important;
  color: color-mix(in srgb, var(--primary) 60%, var(--style-white)) !important;
}

/* === UI Refined Layout: Alert === */
.ui-refined-layout .alert {
  border-radius: var(--driven-component-radius) !important;
  padding: 0.85rem 1rem;
  border: 1px solid transparent;
}

.ui-refined-layout .alert.alert-primary {
  background: var(--primary-soft-14) !important;
  color: var(--primary) !important;
  border-color: color-mix(in srgb, var(--primary) 30%, transparent) !important;
}

.dark-style .ui-refined-layout .alert.alert-primary {
  color: color-mix(in srgb, var(--primary) 60%, var(--style-white)) !important;
}

/* === UI Refined Layout: Admin Tab Lists ===
   Segmented-control look (single rounded outer border + internal dividers).
   Works for top-level admin-tab-list AND nested SVR/DRE/Engagement variants.
   Both `.active` (leaf) and `.adminDropDownActive` (dropdown parent whose
   child is active, e.g. "Stored Vehicle" while on "Reporting Counties")
   get the primary gradient. */
.ui-refined-layout .admin-tabs {
  display: inline-flex !important;
  width: -moz-fit-content !important;
  width: fit-content !important;
  max-width: 100%;
  flex-wrap: wrap;
  gap: 0 !important;
  border-radius: 12px;
  overflow: hidden;
  border-bottom: 0 !important;
  margin-bottom: 1rem;
}

/* Wrappers as flex so auto-margin on the UL can center it */
.ui-refined-layout .tab-row,
.ui-refined-layout .tab-wrapper {
  display: flex;
  flex-wrap: wrap;
}

/* Center the second-level tab lists (DRE / Engagement / SVR sub-tabs).
   They already have `.justify-content-center` on the UL — when present,
   center the whole UL within its wrapper via auto margins. The top-level
   `admin-tab-list` does not have that class so it stays left-aligned. */
.ui-refined-layout .admin-tabs.justify-content-center {
  margin-left: auto !important;
  margin-right: auto !important;
}

.light-style .ui-refined-layout .admin-tabs {
  border: 1px solid color-mix(in srgb, var(--primary) 35%, var(--surface-light)) !important;
  background: var(--surface-light);
}

.dark-style .ui-refined-layout .admin-tabs {
  border: 1px solid var(--border-dark) !important;
  background: var(--surface-dark);
}

.ui-refined-layout .admin-tabs .nav-link {
  min-height: 2.8rem;
  border: 0 !important;
  border-right: 1px solid transparent !important;
  border-radius: 0 !important;
  font-size: 0.95rem;
  font-weight: 600;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  margin: 0 !important;
  transition: background 180ms ease, color 180ms ease;
}

.light-style .ui-refined-layout .admin-tabs .nav-link {
  border-right-color: color-mix(in srgb, var(--primary) 30%, var(--surface-light)) !important;
  background: var(--surface-light) !important;
  color: var(--text-on-light) !important;
}

.dark-style .ui-refined-layout .admin-tabs .nav-link {
  border-right-color: var(--border-dark) !important;
  background: transparent !important;
  color: var(--text-on-dark) !important;
}

.ui-refined-layout .admin-tabs .nav-item:last-child .nav-link {
  border-right: 0 !important;
}

/* Active + active-parent + hover — primary gradient */
.ui-refined-layout .admin-tabs .nav-link.active,
.ui-refined-layout .admin-tabs .nav-link.adminDropDownActive,
.ui-refined-layout .admin-tabs .nav-link:hover {
  background: var(--primary-gradient-dark) !important;
  color: var(--style-white) !important;
  border-right-color: var(--primary) !important;
}

/* Hide chevron on adminDropDownActive parent (user is already on child page) */
.ui-refined-layout .admin-tabs .nav-link.adminDropDownActive::after {
  display: none !important;
}

.ui-refined-layout .admin-tabs .nav-link.dropdown-toggle::after {
  margin-left: 0.4rem;
}

@media (max-width: 575.98px) {
  .ui-refined-layout .admin-tabs {
    width: 100%;
    border-radius: 12px;
  }
  .ui-refined-layout .admin-tabs .nav-link {
    padding: 0.55rem 0.85rem !important;
    font-size: 0.875rem;
  }
}

/* === UI Refined Layout: Report row state (.report-tr) ===
   Rows marked with .report-tr keep a fixed red background (#371B1B) regardless
   of light/dark mode, odd/even row position, or hover state. Multi-class
   selectors (`tr.report-tr.odd`, `tr.report-tr:hover`) bump specificity above
   the standard alternating-row + hover rules so this state wins everywhere. */
.ui-refined-layout .table tbody tr.report-tr td,
.ui-refined-layout .table tbody tr.report-tr.odd td,
.ui-refined-layout .table tbody tr.report-tr.even td,
.ui-refined-layout .table tbody tr.report-tr:hover td,
.ui-refined-layout .table tbody tr.report-tr.odd:hover td,
.ui-refined-layout .table tbody tr.report-tr.even:hover td,
.dark-style .ui-refined-layout .table tbody tr.report-tr td,
.dark-style .ui-refined-layout .table tbody tr.report-tr.odd td,
.dark-style .ui-refined-layout .table tbody tr.report-tr.even td,
.dark-style .ui-refined-layout .table tbody tr.report-tr:hover td,
.light-style .ui-refined-layout .table tbody tr.report-tr td,
.light-style .ui-refined-layout .table tbody tr.report-tr.odd td,
.light-style .ui-refined-layout .table tbody tr.report-tr.even td,
.light-style .ui-refined-layout .table tbody tr.report-tr:hover td {
  background: var(--report-stale-bg) !important;
}

/* ==========================================================================
   Wizard Vertical Stepper — visual rules shared by DRE Wizard and SVR DPS
   --------------------------------------------------------------------------
   Both wizards use the same wrapper classes (`bs-stepper wizard-vertical
   vertical`) so any rule targeting those applies to both. Only visual rules
   (step layout, circle, label, line, active state) are ported here. Layout
   rules (heights, scrollbars, body overflow) stay in style_dre.css to avoid
   breaking SVR DPS pages that have their own layout in style.css.
   ========================================================================== */

/* Vertical stepper — single column, full-width steps.
   Vendor bs-stepper.css sets `min-width: 18rem` (288px) on the header which
   overflows the 225px-wide wizard-menu wrapper — override to remove it. */
.bs-stepper.vertical .bs-stepper-header,
.bs-stepper.wizard-vertical .bs-stepper-header {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  width: 100% !important;
  min-width: 0 !important;
}

.bs-stepper.vertical .bs-stepper-header .step,
.bs-stepper.wizard-vertical .bs-stepper-header .step {
  width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
}

/* Compact step trigger */
.bs-stepper.vertical .bs-stepper-header .step .step-trigger,
.bs-stepper.wizard-vertical .bs-stepper-header .step .step-trigger {
  display: flex !important;
  width: 100% !important;
  flex-wrap: nowrap !important;
  justify-content: flex-start !important;
  align-items: center !important;
  padding: 0.4rem 0.5rem !important;
  min-height: auto !important;
}

/* Circle — fixed 2rem, won't shrink */
.bs-stepper.vertical .bs-stepper-header .step .step-trigger .bs-stepper-circle,
.bs-stepper.wizard-vertical .bs-stepper-header .step .step-trigger .bs-stepper-circle {
  flex-shrink: 0 !important;
  flex-grow: 0 !important;
  min-width: 2rem !important;
  min-height: 2rem !important;
  width: 2rem !important;
  height: 2rem !important;
  font-size: 1rem !important;
}

/* Empty/placeholder circles (e.g., "Admin Details" non-numbered step) */
.circle-placeholder {
  visibility: hidden;
}

/* Label grows + wraps */
.bs-stepper.vertical .bs-stepper-header .step .step-trigger .bs-stepper-label,
.bs-stepper.wizard-vertical .bs-stepper-header .step .step-trigger .bs-stepper-label {
  flex: 1 1 auto !important;
  max-width: none !important;
  min-width: 0 !important;
  text-align: start !important;
  white-space: normal !important;
  word-break: break-word !important;
}

/* Error indicator (red triangle) sits at right inside the label */
.bs-stepper.vertical .bs-stepper-header .step .step-trigger .bs-stepper-label.has-error-indicator,
.bs-stepper.wizard-vertical .bs-stepper-header .step .step-trigger .bs-stepper-label.has-error-indicator {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 0.5rem !important;
  padding-right: 0.75rem !important;
}

.bs-stepper-label .error-indicator {
  color: var(--style-alert-rose) !important;
  font-size: 14px !important;
  display: inline-flex !important;
  align-items: center !important;
  flex-shrink: 0 !important;
  white-space: nowrap !important;
}

/* Vertical connector line between steps (rendered by `<div class="line">`) */
.bs-stepper.vertical .bs-stepper-header .line,
.bs-stepper.wizard-vertical .bs-stepper-header .line {
  position: relative !important;
  min-height: 0.75rem !important;
  width: 100% !important;
}

.bs-stepper.vertical .bs-stepper-header .line::before,
.bs-stepper.wizard-vertical .bs-stepper-header .line::before {
  content: '' !important;
  position: absolute !important;
  left: 1rem !important;
  top: 0 !important;
  bottom: 0 !important;
  width: 2px !important;
  background-color: rgba(0, 0, 0, 0.12) !important;
  transform: translateX(-50%) !important;
}

/* Active step — primary background, white text, inverted circle (white bg, primary number) */
.bs-stepper.vertical .bs-stepper-header .step.active .step-trigger,
.bs-stepper.wizard-vertical .bs-stepper-header .step.active .step-trigger {
  background-color: var(--primary) !important;
  color: var(--text-white) !important;
  box-shadow: none;
  padding: 0.4rem 0.5rem !important;
  min-height: auto !important;
  border-radius: 0.5rem;
}

.bs-stepper.vertical .bs-stepper-header .step.active .step-trigger .bs-stepper-circle,
.bs-stepper.wizard-vertical .bs-stepper-header .step.active .step-trigger .bs-stepper-circle {
  background-color: var(--text-white) !important;
  border-color: var(--text-white) !important;
  color: var(--primary) !important;
  min-width: 2rem !important;
  min-height: 2rem !important;
  width: 2rem !important;
  height: 2rem !important;
  font-size: 1rem !important;
}

.bs-stepper.vertical .bs-stepper-header .step.active .step-trigger .bs-stepper-label,
.bs-stepper.wizard-vertical .bs-stepper-header .step.active .step-trigger .bs-stepper-label {
  color: var(--text-white) !important;
  font-weight: 700 !important;
}

/* SVR DPS-specific markup: label contains a nested `bs-stepper-title` span
   for the title text and an `error-indicator` span for the warning icon.
   Make sure both inherit/get the right colors in all states. */
.bs-stepper.vertical .bs-stepper-header .step .step-trigger .bs-stepper-title,
.bs-stepper.wizard-vertical .bs-stepper-header .step .step-trigger .bs-stepper-title {
  color: inherit !important;
  font-weight: 500;
  font-size: 1rem !important;
  line-height: 1.08 !important;
}

.bs-stepper.vertical .bs-stepper-header .step.active .step-trigger .bs-stepper-title,
.bs-stepper.wizard-vertical .bs-stepper-header .step.active .step-trigger .bs-stepper-title,
.bs-stepper.wizard-vertical .bs-stepper-header .step.active .step-trigger .bs-stepper-title {
  color: var(--text-white) !important;
  font-weight: 700 !important;
  font-size: 1rem !important;
  line-height: 1.08 !important;
}

/* Hide vertical line connector — DRE intentionally has it commented out in
   markup; SVR DPS and Engagement render `<div class="line">` between steps.
   Hide via CSS so all three look identical without any markup change. */
.bs-stepper.vertical .bs-stepper-header .line,
.bs-stepper.wizard-vertical .bs-stepper-header .line {
  display: none !important;
}

/* Each step renders as its own card — matches DRE wizard look from
   style_dre.css `.ui-page-dre-wizard` rules, but applied globally so
   SVR DPS and Engagement wizards get the same treatment. */
.bs-stepper.vertical .bs-stepper-header .step,
.bs-stepper.wizard-vertical .bs-stepper-header .step {
  margin: 0 !important;
  padding: 0 0 5px 0 !important;
}

.bs-stepper.vertical .bs-stepper-header,
.bs-stepper.wizard-vertical .bs-stepper-header {
  gap: 0.3rem;
}

.bs-stepper.vertical .bs-stepper-header .step .step-trigger,
.bs-stepper.wizard-vertical .bs-stepper-header .step .step-trigger {
  width: 100%;
  min-height: 2.28rem;
  border-radius: 10px;
  border: 1px solid transparent;
  background: transparent;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

/* Inactive step card — light gray bg + light border (light mode) */
.light-style .bs-stepper.vertical .bs-stepper-header .step:not(.active) .step-trigger,
.light-style .bs-stepper.wizard-vertical .bs-stepper-header .step:not(.active) .step-trigger {
  background: var(--gray-1) !important;
  border-color: var(--gray-3) !important;
}

/* Inactive step card — dark surface (dark mode) */
.dark-style .bs-stepper.vertical .bs-stepper-header .step:not(.active) .step-trigger,
.dark-style .bs-stepper.wizard-vertical .bs-stepper-header .step:not(.active) .step-trigger {
  background: rgba(15, 23, 32, 0.86) !important;
  border-color: var(--card-border) !important;
}

/* Hover on inactive — primary gradient (same as active, matches DRE behavior) */
.bs-stepper.vertical .bs-stepper-header .step:not(.active) .step-trigger:hover,
.bs-stepper.wizard-vertical .bs-stepper-header .step:not(.active) .step-trigger:hover {
  background: linear-gradient(180deg, var(--primary) 0%, var(--primary-hover) 100%) !important;
  border-color: var(--primary) !important;
  color: var(--style-white) !important;
  cursor: pointer;
}

.bs-stepper.vertical .bs-stepper-header .step:not(.active) .step-trigger:hover *,
.bs-stepper.wizard-vertical .bs-stepper-header .step:not(.active) .step-trigger:hover * {
  color: var(--style-white) !important;
}

/* Active step — primary gradient bg + white text (matches DRE) */
.bs-stepper.vertical .bs-stepper-header .step.active .step-trigger,
.bs-stepper.wizard-vertical .bs-stepper-header .step.active .step-trigger {
  background: linear-gradient(180deg, var(--primary) 0%, var(--primary-hover) 100%) !important;
  border-color: var(--primary) !important;
  color: var(--style-white) !important;
}

.bs-stepper.vertical .bs-stepper-header .step.active .step-trigger *,
.bs-stepper.wizard-vertical .bs-stepper-header .step.active .step-trigger * {
  color: var(--style-white) !important;
}

/* === Circle styling — white bg / dark text inactive, translucent / white active === */
.light-style .bs-stepper.vertical .bs-stepper-header .step:not(.active) .bs-stepper-circle,
.light-style .bs-stepper.wizard-vertical .bs-stepper-header .step:not(.active) .bs-stepper-circle {
  background: var(--style-white) !important;
  color: var(--primary) !important;
  border: 1px solid var(--gray-4) !important;
}

.dark-style .bs-stepper.vertical .bs-stepper-header .step:not(.active) .bs-stepper-circle,
.dark-style .bs-stepper.wizard-vertical .bs-stepper-header .step:not(.active) .bs-stepper-circle {
  background: var(--surface-base) !important;
  color: var(--gray-3) !important;
  border: 1px solid var(--primary-soft-strong) !important;
}

.bs-stepper.vertical .bs-stepper-header .step.active .bs-stepper-circle,
.bs-stepper.wizard-vertical .bs-stepper-header .step.active .bs-stepper-circle,
.bs-stepper.vertical .bs-stepper-header .step:not(.active) .step-trigger:hover .bs-stepper-circle,
.bs-stepper.wizard-vertical .bs-stepper-header .step:not(.active) .step-trigger:hover .bs-stepper-circle {
  background: rgba(255, 255, 255, 0.16) !important;
  color: var(--style-white) !important;
  border-color: var(--card-border) !important;
}

.circle-placeholder {
  opacity: 0.35 !important;
}

/* Error indicator visibility (SVR DPS Impound + Engagement) — keep the red
   triangle warning visible even inside a narrow 225px sidebar.
   The SVR markup wraps the title in `<span style="min-width: 136px">` which
   pushes the error icon out of view in a constrained menu. Override that
   inline min-width via a more specific CSS selector (no markup change). */
.bs-stepper.vertical .bs-stepper-header .step .step-trigger .bs-stepper-label > span[style*="min-width"],
.bs-stepper.wizard-vertical .bs-stepper-header .step .step-trigger .bs-stepper-label > span[style*="min-width"] {
  min-width: 0 !important;
  flex: 1 1 auto !important;
}

/* Error-indicator pinned at the right with fixed size, never shrinks */
.bs-stepper.vertical .bs-stepper-header .step .step-trigger .error-indicator,
.bs-stepper.wizard-vertical .bs-stepper-header .step .step-trigger .error-indicator {
  flex: 0 0 auto !important;
  margin-left: auto;
  padding-left: 0.4rem;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  min-width: 1.25rem;
}

.bs-stepper.vertical .bs-stepper-header .step .step-trigger .error-indicator .fa-triangle-exclamation,
.bs-stepper.wizard-vertical .bs-stepper-header .step .step-trigger .error-indicator .fa-triangle-exclamation,
.bs-stepper.vertical .bs-stepper-header .step .step-trigger .error-indicator i,
.bs-stepper.wizard-vertical .bs-stepper-header .step .step-trigger .error-indicator i {
  color: var(--style-danger) !important;
  font-size: 0.95rem !important;
  display: inline-block !important;
  visibility: visible !important;
}

/* On active step (white text on primary bg), keep the warning triangle a
   warm tone so it stays visible without clashing with the gradient */
.bs-stepper.vertical .bs-stepper-header .step.active .step-trigger .error-indicator i,
.bs-stepper.wizard-vertical .bs-stepper-header .step.active .step-trigger .error-indicator i {
  color: var(--warning) !important;
}

/* ==========================================================================
   UI Refined Layout: Authentication pages (login, forgot password, reset)
   --------------------------------------------------------------------------
   Auth pages render through blankLayout (no top nav, no sidebar). They use
   `.authentication-wrapper` + `.authentication-inner` + `.custom-card.card`
   for the form card. The .ui-refined-layout class on the layout wrapper
   activates the refined design here.
   ========================================================================== */

/* Full-height centered authentication container */
.ui-refined-layout .authentication-wrapper {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
}

.ui-refined-layout .authentication-inner {
  width: 100%;
  max-width: 420px;
}

/* Authentication card — bigger radius + softer shadow than dashboard cards */
.ui-refined-layout .authentication-wrapper .custom-card,
.ui-refined-layout .authentication-wrapper .card {
  border-radius: var(--driven-component-radius) !important;
  overflow: hidden;
}

.light-style .ui-refined-layout .authentication-wrapper .custom-card,
.light-style .ui-refined-layout .authentication-wrapper .card {
  background: var(--card-bg) !important;
  border: 1px solid var(--border-light) !important;
  box-shadow: 0 24px 56px rgba(15, 23, 42, 0.10);
}

.dark-style .ui-refined-layout .authentication-wrapper .custom-card,
.dark-style .ui-refined-layout .authentication-wrapper .card {
  background: var(--card-bg) !important;
  border: 1px solid var(--border-dark) !important;
  box-shadow: 0 28px 64px rgba(0, 0, 0, 0.55);
}

.ui-refined-layout .authentication-wrapper .card-body {
  padding: 2rem 1.75rem;
}

@media (min-width: 576px) {
  .ui-refined-layout .authentication-wrapper .card-body {
    padding: 2.25rem 2rem;
  }
}

/* Brand / logo area */
.ui-refined-layout .authentication-wrapper .app-brand {
  margin-bottom: 1.5rem;
}

.ui-refined-layout .authentication-wrapper .app-brand img {
  max-width: 200px;
  height: auto;
}

/* Heading on auth pages */
.ui-refined-layout .authentication-wrapper h4,
.ui-refined-layout .authentication-wrapper h5 {
  font-weight: 700;
  letter-spacing: -0.01em;
  margin-bottom: 1.25rem;
}

.light-style .ui-refined-layout .authentication-wrapper h4,
.light-style .ui-refined-layout .authentication-wrapper h5 {
  color: var(--text-strong, var(--gray-11)) !important;
}

.dark-style .ui-refined-layout .authentication-wrapper h4,
.dark-style .ui-refined-layout .authentication-wrapper h5 {
  color: var(--text-on-dark) !important;
}

/* Form labels in auth — override the white forced color from dashboard sections */
.light-style .ui-refined-layout .authentication-wrapper .form-label,
.light-style .ui-refined-layout .authentication-wrapper .form-label.text-white {
  color: var(--text-on-light) !important;
  font-weight: 500;
}

.dark-style .ui-refined-layout .authentication-wrapper .form-label,
.dark-style .ui-refined-layout .authentication-wrapper .form-label.text-white {
  color: var(--text-on-dark) !important;
  font-weight: 500;
}

/* Form controls — refined radius + focus ring (re-state for higher specificity) */
.ui-refined-layout .authentication-wrapper .form-control,
.ui-refined-layout .authentication-wrapper .form-select {
  border-radius: 10px !important;
  /* min-height: 44px; */
  padding: 0.55rem 0.9rem;
}

.ui-refined-layout .authentication-wrapper .form-control:focus,
.ui-refined-layout .authentication-wrapper .form-select:focus,
.ui-refined-layout .authentication-wrapper .input-group:focus-within .form-control,
.ui-refined-layout .authentication-wrapper .input-group:focus-within .input-group-text {
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 3px var(--primary-soft-22) !important;
  outline: 0 !important;
}

/* Input group merge (password toggle) — rounded outer corners only */
.ui-refined-layout .authentication-wrapper .input-group.input-group-merge {
  border-radius: 10px !important;
  overflow: hidden;
  /* min-height: 44px; */
}

.ui-refined-layout .authentication-wrapper .input-group.input-group-merge .form-control {
  border-right: 0 !important;
}

.ui-refined-layout .authentication-wrapper .input-group.input-group-merge .input-group-text {
  cursor: pointer;
  background: transparent !important;
  border-left: 0 !important;
}

.light-style .ui-refined-layout .authentication-wrapper .input-group.input-group-merge .input-group-text {
  color: var(--text-on-light) !important;
}

.dark-style .ui-refined-layout .authentication-wrapper .input-group.input-group-merge .input-group-text {
  color: var(--text-on-dark) !important;
}

/* Submit button — use refined .btn.btn-primary look from earlier section but
   stretch full width via existing .d-grid.w-100 utility on the markup */
.ui-refined-layout .authentication-wrapper .btn.btn-primary {
  /* min-height: 46px; */
  border-radius: var(--driven-component-radius) !important;
  font-weight: 700;
  letter-spacing: 0.01em;
}

/* "Forgot Password?" link — primary color */
.ui-refined-layout .authentication-wrapper a.text-primary {
  color: var(--primary) !important;
  text-decoration: none;
  font-weight: 600;
}

.ui-refined-layout .authentication-wrapper a.text-primary:hover {
  color: color-mix(in srgb, var(--primary) 80%, var(--gray-12)) !important;
  text-decoration: underline;
}

/* Footer / "Don't have account?" line */
.ui-refined-layout .authentication-wrapper .auth-footer-text,
.ui-refined-layout .authentication-wrapper p {
  text-align: center;
}

/* Validation feedback */
.ui-refined-layout .authentication-wrapper .invalid-feedback {
  display: block;
  font-size: 0.8125rem;
  color: var(--style-danger) !important;
  margin-top: 0.35rem;
}

.no-table-border{
  border: none !important;
}

.dark-style .ui-refined-layout .no-table-border{
  border: none !important;
}