/* UI Refresh layer (keeps existing Bootstrap theme intact) */
:root{
  --ui-bg: #f5f7fb;
  --ui-card: #ffffff;
  --ui-text: #1f2937;
  --ui-muted: #6b7280;
  --ui-border: rgba(17,24,39,.08);
  --ui-shadow: 0 10px 30px rgba(17,24,39,.08);
  --ui-shadow-sm: 0 4px 14px rgba(17,24,39,.06);
  --ui-radius: 14px;
  --ui-radius-sm: 10px;
  --ui-primary: #615dad; /* matches existing theme */
  --ui-primary-600: #514db2;
  --ui-primary-50: rgba(97,93,173,.10);
}

body{
  background: var(--ui-bg) !important;
  color: var(--ui-text);
}

.page-content-wrapper .container-fluid{
  padding-left: 20px;
  padding-right: 20px;
}

/* Cards */
.card{
  border: 1px solid var(--ui-border) !important;
  border-radius: var(--ui-radius) !important;
  box-shadow: var(--ui-shadow-sm);
}
.card + .card{
  margin-top: 14px;
}
.card-header{
  background: transparent !important;
  border-bottom: 1px solid var(--ui-border) !important;
  padding: .9rem 1rem;
}
.card-body{
  padding: 1rem;
}

/* Tables */
.table{
  color: var(--ui-text);
}
.table thead th{
  border-bottom: 1px solid var(--ui-border);
  color: var(--ui-muted);
  font-weight: 600;
  text-transform: none;
}
.table td, .table th{
  border-top: 1px solid var(--ui-border);
}
.table thead th{
  position: sticky;
  top: 0;
  background: #ffffff;
  z-index: 2;
}
.table-hover tbody tr:hover{
  background: rgba(17,24,39,.03);
}
.table-responsive{
  border-radius: var(--ui-radius);
  border: 1px solid var(--ui-border);
  overflow: hidden;
}
.table-responsive .table{
  margin-bottom: 0;
}

/* Buttons */
.btn{
  border-radius: 10px;
}
.btn-sm{
  border-radius: 10px;
  padding: .35rem .6rem;
}
.btn-primary{
  background-color: var(--ui-primary) !important;
  border-color: var(--ui-primary) !important;
}
.btn-primary:hover,
.btn-primary:focus{
  background-color: var(--ui-primary-600) !important;
  border-color: var(--ui-primary-600) !important;
}
.btn-outline-primary{
  color: var(--ui-primary) !important;
  border-color: rgba(97,93,173,.35) !important;
}
.btn-outline-primary:hover,
.btn-outline-primary:focus{
  background: var(--ui-primary) !important;
  border-color: var(--ui-primary) !important;
  color: #fff !important;
}
.btn-light{
  background: rgba(17,24,39,.03) !important;
  border-color: var(--ui-border) !important;
}
.btn-link{
  text-decoration: none !important;
}

/* Page rhythm */
.page-content-wrapper{
  padding-top: 8px;
}
.page-title-box{
  margin-bottom: 10px;
}
.ui-section{
  margin-bottom: 18px;
}
.ui-section-title{
  font-weight: 700;
  color: var(--ui-text);
  margin-bottom: 10px;
}
.ui-muted{
  color: var(--ui-muted) !important;
}

/* Sidebar collapse + mobile behavior */
.side-menu,
.content-page{
  transition: all .18s ease;
}

.sidebar-overlay{
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(2,6,23,.55);
  backdrop-filter: blur(2px);
  z-index: 999;
}

/* On mobile/tablet when sidebar is opened (template uses #wrapper.enlarged) */
@media (max-width: 1024px){
  #wrapper.enlarged .sidebar-overlay{
    display: block;
  }
}

/* Desktop collapsed (template uses #wrapper.enlarged) */
@media (min-width: 1025px){
  #wrapper.enlarged .side-menu{
    width: 70px !important;
  }
  #wrapper.enlarged .sidebar-header .sidebar-brand-text,
  #wrapper.enlarged .sidebar-user-meta,
  #wrapper.enlarged .sidebar-user-actions,
  #wrapper.enlarged .sidebar-footer,
  #wrapper.enlarged .sidebar-search-wrap{
    display: none !important;
  }
  #wrapper.enlarged .sidebar-user-compact{
    padding: 8px 0 10px !important;
    text-align: center !important;
  }
  #wrapper.enlarged .sidebar-user-row{
    justify-content: center;
  }
  #wrapper.enlarged .sidebar-user-avatar,
  #wrapper.enlarged .sidebar-user-initials{
    width: 42px;
    height: 42px;
  }
  #wrapper.enlarged .sidebar-brand{
    padding: 10px 0 6px;
  }
  #wrapper.enlarged .sidebar-brand-logo{
    max-height: 28px;
  }
  #wrapper.enlarged #sidebar-menu > ul > li > a > span{
    display: none;
  }
  #wrapper.enlarged #sidebar-menu > ul > li > a{
    text-align: center;
    padding: 12px 0 !important;
  }
  #wrapper.enlarged #sidebar-menu > ul > li > a i{
    margin-right: 0 !important;
  }
}

/* Mobile: make sidebar overlay feel cleaner */
@media (max-width: 991.98px){
  .side-menu{
    box-shadow: 0 30px 60px rgba(0,0,0,.35);
  }
}

@media (max-width: 1024px){
  /* When sidebar is open on mobile, keep full width (do not mini-collapse) */
  #wrapper.enlarged .side-menu{
    width: 250px !important;
  }
}

/* FullCalendar polish */
.fc{
  background: #fff;
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius);
  box-shadow: var(--ui-shadow-sm);
  overflow: hidden;
}
.fc-toolbar{
  padding: 12px 14px;
  margin-bottom: 0 !important;
  border-bottom: 1px solid var(--ui-border);
}
.fc-toolbar h2{
  font-size: 16px;
  font-weight: 800;
  color: var(--ui-text);
}
.fc .fc-button{
  border-radius: 10px !important;
  border: 1px solid var(--ui-border) !important;
  background: rgba(17,24,39,.03) !important;
  text-shadow: none !important;
  box-shadow: none !important;
}
.fc .fc-button.fc-state-active{
  background: var(--ui-primary-50) !important;
  border-color: rgba(97,93,173,.25) !important;
}
.fc-unthemed td,
.fc-unthemed th{
  border-color: rgba(17,24,39,.08) !important;
}
.fc-unthemed .fc-today{
  background: rgba(97,93,173,.08) !important;
}
.fc-event{
  border-radius: 10px !important;
  border: none !important;
  background: var(--ui-primary) !important;
}
.fc-event.bg-gradient1{ background-image: linear-gradient(120deg, #f56348 0%, #f81f8b 100%) !important; }
.fc-event.bg-gradient2{ background-image: linear-gradient(120deg, #00e795 0%, #0095e2 100%) !important; }
.fc-event.bg-gradient3{ background-image: linear-gradient(120deg, #f6d365 0%, #fda085 100%) !important; }
.fc-event.bg-gradient4{ background-image: linear-gradient(120deg, #606c88 0%, #330867 100%) !important; }

.fc-event.bg-gradient1,
.fc-event.bg-gradient2,
.fc-event.bg-gradient3,
.fc-event.bg-gradient4{
  color: #fff !important;
}

/* Charts / widgets */
canvas{
  max-width: 100% !important;
}
.icon-contain i{
  filter: saturate(1.05);
}
.icon-contain .col-2{
  display: flex;
  align-items: center;
  justify-content: center;
}
.icon-contain .col-2 i{
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: rgba(17,24,39,.03);
}

/* Topbar */
.topbar .navbar-custom{
  background: rgba(255,255,255,.8);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--ui-border);
  padding: 10px 14px;
  position: relative;
  z-index: 1030;
}

.topbar{
  position: relative;
  z-index: 1030;
}

/* Mobile hamburger button (uses template JS binding) */
.topbar .button-menu-mobile{
  display: none;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  line-height: 42px;
  border-radius: 12px;
  background: var(--ui-primary);
  color: #fff;
  border: none;
}
.topbar .button-menu-mobile i{
  font-size: 22px;
  line-height: 1;
}
@media (max-width: 1024px){
  .topbar .button-menu-mobile{
    display: inline-flex;
  }
}

/* Fix mobile/tablet topbar side margins from old theme */
@media (max-width: 768px){
  .topbar{
    left: 0 !important;
    right: 0 !important;
    border-radius: 0 !important;
  }
}

.topbar-title{
  font-weight: 700;
  color: var(--ui-text);
  letter-spacing: .2px;
  line-height: 1.1;
}
.topbar-subtitle{
  font-size: 12px;
  color: var(--ui-muted);
}

.topbar-search{
  position: relative;
  max-width: 420px;
  width: 100%;
}
.topbar-search input{
  border-radius: 999px;
  border: 1px solid var(--ui-border);
  padding-left: 40px;
  height: 38px;
  background: rgba(255,255,255,.9);
}
.topbar-search .icon{
  position: absolute;
  top: 50%;
  left: 14px;
  transform: translateY(-50%);
  color: var(--ui-muted);
}

/* Dropdown polish */
.dropdown-menu{
  border: 1px solid var(--ui-border);
  border-radius: 14px;
  box-shadow: var(--ui-shadow);
  padding: 10px;
  z-index: 2000;
}
.dropdown-item{
  border-radius: 10px;
}
.dropdown-item:hover{
  background: rgba(17,24,39,.04);
}
.notify-item{
  border-radius: 12px;
}

/* Forms */
.form-group{
  margin-bottom: 14px;
}
label.col-from-label,
label.col-form-label,
label{
  font-weight: 600;
  color: var(--ui-text);
  margin-bottom: 6px;
}
.form-control{
  border-radius: 12px;
  border: 1px solid var(--ui-border);
  min-height: 40px;
}
.form-control:focus{
  border-color: rgba(96,93,175,.45);
  box-shadow: 0 0 0 .2rem rgba(96,93,175,.12);
}
select.form-control{
  padding-top: .45rem;
  padding-bottom: .45rem;
}
.input-group-text{
  border-radius: 12px;
  border: 1px solid var(--ui-border);
  background: rgba(17,24,39,.03);
}

/* Select2 */
.select2-container .select2-selection--single{
  height: 40px !important;
  border-radius: 12px !important;
  border: 1px solid var(--ui-border) !important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered{
  line-height: 38px !important;
  padding-left: 12px !important;
  color: var(--ui-text) !important;
}
.select2-container--default .select2-selection--single .select2-selection__arrow{
  height: 38px !important;
}
.select2-container .select2-selection--multiple{
  min-height: 40px !important;
  border-radius: 12px !important;
  border: 1px solid var(--ui-border) !important;
}
.select2-dropdown{
  border-radius: 14px !important;
  border: 1px solid var(--ui-border) !important;
  box-shadow: var(--ui-shadow);
}
.select2-results__option{
  border-radius: 10px;
}

/* Modals (Bootstrap) */
.modal-backdrop.show{
  opacity: .55;
}
.modal-content{
  border-radius: var(--ui-radius) !important;
  border: 1px solid var(--ui-border) !important;
  box-shadow: var(--ui-shadow);
}
.modal-header{
  border-bottom: 1px solid var(--ui-border) !important;
  padding: 14px 16px;
}
.modal-footer{
  border-top: 1px solid var(--ui-border) !important;
  padding: 12px 16px;
}
.modal-title{
  font-weight: 700;
}
.modal .close{
  opacity: .7;
}
.modal .close:hover{
  opacity: 1;
}

/* Toastr */
#toast-container > div{
  border-radius: 14px !important;
  box-shadow: var(--ui-shadow) !important;
  opacity: 1 !important;
  padding: 14px 16px !important;
}
#toast-container > .toast{
  background-image: none !important;
}
.toast-message{
  font-size: 13px;
  line-height: 1.35;
}
.toast-title{
  font-weight: 700;
}

/* Sidebar */
.side-menu{
  background: #0f172a; /* slate-900 */
}
.sidebar-inner{
  background: transparent !important;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.sidebar-scroll{
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
}
.sidebar-header{
  flex-shrink: 0;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.sidebar-brand{
  padding: 12px 14px 8px;
}
.sidebar-brand-link{
  display: block;
  text-align: center;
  text-decoration: none !important;
}
.sidebar-brand-logo{
  max-height: 34px;
  max-width: 100%;
  width: auto;
  object-fit: contain;
}
.sidebar-brand-text{
  display: block;
  color: #f8fafc;
  font-weight: 700;
  font-size: 14px;
  line-height: 1.35;
  letter-spacing: .02em;
}
.sidebar-user-compact{
  padding: 0 12px 12px !important;
  text-align: left !important;
  border-bottom: 0 !important;
}
.sidebar-user-row{
  display: flex;
  align-items: center;
  gap: 10px;
}
.sidebar-user-avatar-wrap{
  position: relative;
  flex-shrink: 0;
}
.sidebar-user-avatar,
.sidebar-user-initials{
  width: 40px;
  height: 40px;
  border-radius: 999px;
}
.sidebar-user-avatar{
  object-fit: cover;
  border: 2px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
}
.sidebar-user-initials{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #38bdf8 0%, #6366f1 100%);
  color: #fff;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: .03em;
}
.sidebar-user-meta{
  flex: 1;
  min-width: 0;
}
.sidebar-user-meta h6{
  margin: 0;
  font-size: 13px;
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sidebar-user-status{
  margin: 2px 0 0 !important;
  font-size: 11px !important;
  color: rgba(229,231,235,.65) !important;
  display: flex;
  align-items: center;
  gap: 5px;
}
.sidebar-status-dot{
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #22c55e;
  box-shadow: 0 0 0 2px rgba(34,197,94,.25);
}
.sidebar-user-actions{
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex-shrink: 0;
}
.sidebar-user-actions a{
  border: 1px solid rgba(255,255,255,.14) !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 28px !important;
  height: 28px !important;
  line-height: 1 !important;
  border-radius: 8px !important;
  background: rgba(255,255,255,.06) !important;
}
.sidebar-user-actions a:hover{
  background: rgba(255,255,255,.14) !important;
}
.sidebar-user-actions i{
  font-size: 14px;
  color: rgba(229,231,235,.92) !important;
}
.sidebar-footer{
  flex-shrink: 0;
  padding: 10px 14px 12px;
  border-top: 1px solid rgba(255,255,255,.08);
  background: rgba(15,23,42,.96);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  font-size: 11px;
  color: rgba(229,231,235,.5);
}
.sidebar-footer-app{
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sidebar-footer-year{
  flex-shrink: 0;
}

/* Sidebar scroll: logo + user are fixed height; only the menu area scrolls */
body.fixed-left .left.side-menu {
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
body.fixed-left .left.side-menu .sidebar-inner {
  flex: 1 1 auto;
  min-height: 0;
  height: auto !important;
  overflow: hidden;
}
body.fixed-left .left.side-menu .sidebar-scroll {
  scrollbar-width: thin;
  scrollbar-color: rgba(186, 187, 222, 0.85) rgba(15, 23, 42, 0.5);
}
body.fixed-left .left.side-menu .sidebar-scroll::-webkit-scrollbar {
  width: 6px;
}
body.fixed-left .left.side-menu .sidebar-scroll::-webkit-scrollbar-thumb {
  background: rgba(186, 187, 222, 0.85);
  border-radius: 6px;
}
body.fixed-left .left.side-menu .sidebar-scroll::-webkit-scrollbar-track {
  background: rgba(15, 23, 42, 0.35);
}
#sidebar-menu{
  background: transparent !important;
  padding-bottom: 8px;
}
.bg-logo{
  background: transparent !important;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.topbar-left .logo{
  font-weight: 700;
  letter-spacing: .2px;
}
.sidebar-user{
  border-bottom: 1px solid rgba(255,255,255,.08);
  padding-bottom: 14px;
}
.sidebar-user h6{
  color: #e5e7eb;
  font-weight: 700;
}
.sidebar-user p{
  color: rgba(229,231,235,.85) !important;
}

#sidebar-menu > ul > li > a{
  color: rgba(229,231,235,.9) !important;
  border-radius: 12px;
  margin: 4px 10px;
  padding: 10px 12px;
  background: transparent !important;
  transition: all .15s ease;
}
#sidebar-menu > ul > li > a.active,
#sidebar-menu > ul > li.nav-active > a{
  color: #ffffff !important;
}
#sidebar-menu > ul > li:not(.has_sub) > a.active{
  background: rgba(255,255,255,.12) !important;
  box-shadow: inset 3px 0 0 rgba(56,189,248,.9);
}
#sidebar-menu > ul > li.has_sub.nav-active > a,
#sidebar-menu > ul > li.has_sub > a.active{
  background: transparent !important;
  box-shadow: none !important;
  font-weight: 600;
}
#sidebar-menu > ul > li > a.active i,
#sidebar-menu > ul > li.nav-active > a i{
  color: #ffffff !important;
}

.menu-title{
  color: rgba(229,231,235,.6) !important;
  padding: 14px 18px 6px 18px !important;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: 11px;
  font-weight: 700;
  border-top: 1px solid rgba(255,255,255,.06);
  margin-top: 6px;
}
#sidebar-menu > ul > li.menu-title:first-child{
  border-top: 0;
  margin-top: 0;
}
.sidebar-search-wrap{
  position: sticky;
  top: 0;
  z-index: 2;
  padding: 10px 12px 8px;
  background: linear-gradient(180deg, rgba(15,23,42,.98) 0%, rgba(15,23,42,.92) 100%);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.sidebar-search{
  position: relative;
}
.sidebar-search i{
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: rgba(229,231,235,.55);
  font-size: 18px;
  pointer-events: none;
}
.sidebar-search input{
  width: 100%;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: #f8fafc;
  border-radius: 10px;
  padding: 8px 12px 8px 36px;
  font-size: 13px;
  outline: none;
  transition: border-color .15s ease, background .15s ease;
}
.sidebar-search input::placeholder{
  color: rgba(229,231,235,.45);
}
.sidebar-search input:focus{
  border-color: rgba(56,189,248,.55);
  background: rgba(255,255,255,.1);
  box-shadow: 0 0 0 3px rgba(56,189,248,.12);
}
.sidebar-search-clear{
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  border: 0;
  background: rgba(255,255,255,.12);
  color: #e5e7eb;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  line-height: 1;
  font-size: 16px;
  padding: 0;
  cursor: pointer;
}
#sidebar-menu li.sidebar-menu-empty{
  display: none;
  padding: 16px;
  text-align: center;
  color: rgba(229,231,235,.55);
  font-size: 13px;
}
#sidebar-menu > ul > li > a:hover{
  background: rgba(255,255,255,.08);
  transform: translateX(2px);
}
#sidebar-menu, #sidebar-menu ul, #sidebar-menu li, #sidebar-menu a{
  line-height: 1.25;
}

#sidebar-menu > ul > li.has_sub > a{
  display: flex;
  align-items: center;
}
#sidebar-menu > ul > li.has_sub > a > span.float-right{
  margin-left: auto;
  float: none !important;
}
#sidebar-menu > ul > li.has_sub > a > span:not(.float-right){
  flex: 1;
  min-width: 0;
}
#sidebar-menu > ul > li > a i{
  color: rgba(229,231,235,.9) !important;
}

/* Submenu arrow */
#sidebar-menu > ul > li.has_sub > a .mdi-chevron-right{
  transition: transform .22s cubic-bezier(.4,0,.2,1);
  opacity: .65;
  font-size: 16px;
}
#sidebar-menu > ul > li.nav-active > a .mdi-chevron-right{
  transform: rotate(-90deg);
  opacity: 1;
}

/* Expanded parent — grouped card */
#sidebar-menu > ul > li.has_sub.nav-active{
  margin: 4px 8px 8px;
  padding-bottom: 2px;
  border-radius: 14px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.07);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}
#sidebar-menu > ul > li.has_sub.nav-active > a{
  margin: 2px 4px 0 !important;
  background: transparent !important;
  font-weight: 600;
  color: #f8fafc !important;
}
#sidebar-menu > ul > li.has_sub.nav-active > a:hover{
  background: rgba(255,255,255,.04) !important;
  transform: none;
}

/* Nested submenu panel + dot timeline */
#sidebar-menu .sidebar-submenu,
#sidebar-menu li.has_sub > ul{
  position: relative;
  margin: 4px 6px 6px;
  padding: 4px 6px 6px;
  list-style: none;
  border-radius: 10px;
  background: rgba(0,0,0,.14);
}
#sidebar-menu .sidebar-submenu::before,
#sidebar-menu li.has_sub > ul::before{
  content: "";
  position: absolute;
  left: 15px;
  top: 12px;
  bottom: 12px;
  width: 1px;
  background: rgba(255,255,255,.1);
  pointer-events: none;
}
#sidebar-menu .sidebar-submenu > li,
#sidebar-menu li.has_sub > ul > li{
  position: relative;
  padding: 0;
}
#sidebar-menu .sidebar-submenu > li::before,
#sidebar-menu li.has_sub > ul > li::before,
#sidebar-menu .sidebar-submenu > li::after,
#sidebar-menu li.has_sub > ul > li::after{
  display: none;
  content: none;
}
#sidebar-menu > ul > li.nav-active > ul,
#sidebar-menu > ul > li.nav-active > .sidebar-submenu{
  display: block !important;
}
#sidebar-menu .sidebar-submenu li > a,
#sidebar-menu li.has_sub > ul > li > a{
  position: relative;
  z-index: 1;
  display: block;
  color: rgba(226,232,240,.72) !important;
  padding: 7px 10px 7px 28px;
  margin: 1px 0;
  border-radius: 8px;
  background: transparent !important;
  font-size: 12.5px;
  font-weight: 500;
  line-height: 1.35;
  box-shadow: none !important;
  transition: background .15s ease, color .15s ease, box-shadow .15s ease;
}
#sidebar-menu .sidebar-submenu li > a::before,
#sidebar-menu li.has_sub > ul > li > a::before{
  content: "";
  position: absolute;
  left: 11px;
  top: 50%;
  width: 5px;
  height: 5px;
  margin-top: -2.5px;
  border-radius: 999px;
  background: rgba(255,255,255,.22);
  box-shadow: 0 0 0 0 transparent;
  transition: background .15s ease, box-shadow .15s ease, transform .15s ease;
  pointer-events: none;
}
#sidebar-menu .sidebar-submenu li > a:hover,
#sidebar-menu li.has_sub > ul > li > a:hover{
  background: rgba(255,255,255,.07) !important;
  color: rgba(255,255,255,.95) !important;
}
#sidebar-menu .sidebar-submenu li > a:hover::before,
#sidebar-menu li.has_sub > ul > li > a:hover::before{
  background: rgba(255,255,255,.45);
  transform: scale(1.15);
}
#sidebar-menu .sidebar-submenu li.active > a,
#sidebar-menu li.has_sub > ul > li.active > a{
  background: rgba(255,255,255,.96) !important;
  color: #0f172a !important;
  font-weight: 600;
  box-shadow: 0 1px 2px rgba(15,23,42,.16), 0 4px 12px rgba(15,23,42,.12) !important;
}
#sidebar-menu .sidebar-submenu li.active > a::before,
#sidebar-menu li.has_sub > ul > li.active > a::before{
  background: #0ea5e9;
  box-shadow: 0 0 0 3px rgba(14,165,233,.28);
  transform: scale(1.2);
}

/* Legacy theme overrides */
#sidebar-menu ul ul a{
  padding: 7px 10px 7px 28px !important;
}

/* Badges */
.badge{
  border-radius: 999px;
}

.sidebar-menu-badge{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 999px;
  background: #ef4444;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  line-height: 1;
  flex-shrink: 0;
  letter-spacing: -.01em;
}
.sidebar-menu-badge--parent{
  margin-right: 2px;
}
.sidebar-menu-badge--top{
  margin-left: auto;
}
.sidebar-sub-toggle{
  display: inline-flex;
  align-items: center;
  gap: 2px;
}
.sidebar-menu-label{
  flex: 1;
  min-width: 0;
}
#sidebar-menu > ul > li:not(.has_sub) > a{
  display: flex;
  align-items: center;
  gap: 6px;
}
#sidebar-menu > ul > li:not(.has_sub) > a > span:not(.sidebar-menu-badge){
  flex: 1;
  min-width: 0;
}
#sidebar-menu .sidebar-submenu li > a,
#sidebar-menu li.has_sub > ul > li > a{
  display: flex;
  align-items: center;
  gap: 6px;
}
#sidebar-menu .sidebar-submenu li.active > a .sidebar-menu-badge,
#sidebar-menu li.has_sub > ul > li.active > a .sidebar-menu-badge{
  background: #0ea5e9;
  color: #fff;
}

/* Dashboard stat cards */
.dash-stat-card{
  overflow: hidden;
}
.dash-stat-card .card-body{
  padding: .9rem 1rem;
}

/* Responsive tweaks */
@media (max-width: 575.98px){
  .page-content-wrapper .container-fluid{
    padding-left: 12px;
    padding-right: 12px;
  }
  #sidebar-menu > ul > li > a{
    margin: 4px 8px;
  }
}

