/* DevExpress Component Customizations */

/* 
 * This file contains custom styling for DevExpress Blazor components.
 * Use CSS variables from variables.css for colors.
 * Target DevExpress classes with .dxbl-* prefix.
 * Use !important sparingly (only when necessary to override DevExpress defaults).
 */

/* ============================================
   Headers - Navy Color
   ============================================ */

/* Headers - All heading levels */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  color: var(--samba-primary-blue-navy) !important;
}

/* ============================================
   DevExpress Global Theme Variables
   ============================================ */

/* ============================================
   DevExpress Buttons
   ============================================ */

/* Grid Action Buttons */
.btnGrid {
  height: var(--samba-grid-btn-height) !important;
}

.btnGridNew,
.btnGridEdit,
.btnGridEmail {
  height: var(--samba-grid-btn-height) !important;
  color: var(--samba-black);
  border-color: var(--samba-gray-border);
}

.btnGridDelete {
  height: var(--samba-grid-btn-height) !important;
  color: var(--samba-error);
  border-color: var(--samba-gray-border);
}

.btnGridCancel {
  height: var(--samba-grid-btn-height) !important;
  color: var(--samba-warning);
  border-color: var(--samba-gray-border);
}

/* Action Buttons - Save, Cancel, Search */
/* Use these classes with CssClass property on DxButton components */
/* Example: <DxButton CssClass="btn-action-save" Text="Save" /> */

.btn-action-save,
.btn-action-search,
.dxbl-btn.btn-action-save,
.dxbl-btn.btn-action-search,
.dxbl-btn-primary.btn-action-save,
.dxbl-btn-primary.btn-action-search {
  background-color: #FF6600 !important; /* Main orange color - darker/more vibrant */
  border-color: #FF6600 !important;
  color: var(--samba-white) !important;
  height: 32px !important; /* h-8 = 2rem = 32px */
  padding: 0.375rem 0.75rem !important; /* py-1.5 px-3 = 6px 12px */
  font-size: 0.875rem !important; /* text-sm = 14px */
  font-weight: 500 !important; /* font-medium = 500, not bold */
  border-radius: 0.25rem !important; /* rounded = 4px */
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px -1px rgba(0, 0, 0, 0.1) !important; /* shadow-sm */
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.375rem !important; /* gap-1.5 = 6px */
  white-space: nowrap !important;
  transition: color 0.15s, background-color 0.15s, border-color 0.15s !important;
  --dxbl-btn-bg: #FF6600 !important; /* Override DevExpress CSS variable */
  --dxbl-btn-border-color: #FF6600 !important;
}

/* Hide default DevExpress icon for Save buttons */
.btn-action-save .dxbl-btn-icon,
.dxbl-btn.btn-action-save .dxbl-btn-icon,
.dxbl-btn-primary.btn-action-save .dxbl-btn-icon {
  display: none !important;
}

/* Add save icon to Save action buttons using Open Iconic */
.btn-action-save .dxbl-btn-caption::before,
.dxbl-btn.btn-action-save .dxbl-btn-caption::before,
.dxbl-btn-primary.btn-action-save .dxbl-btn-caption::before {
  content: "\e033" !important; /* Open Iconic file icon (oi-file) - commonly used for save */
  font-family: "Icons" !important;
  font-style: normal !important;
  font-weight: 400 !important;
  font-variant: normal !important;
  text-transform: none !important;
  line-height: 1 !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
  margin-right: 0.375rem !important;
  display: inline-block !important;
  position: relative !important;
  top: 1px !important;
}

/* Add X icon to Cancel button using Open Iconic  */
.btn-action-cancel .dxbl-btn-caption::before,
.dxbl-btn.btn-action-cancel .dxbl-btn-caption::before,
.dxbl-btn-secondary.btn-action-cancel .dxbl-btn-caption::before {
  content: "\e0db" !important; /* Open Iconic x icon (oi-x) */
  font-family: "Icons" !important;
  font-style: normal !important;
  font-weight: 400 !important;
  font-variant: normal !important;
  text-transform: none !important;
  line-height: 1 !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
  margin-right: 0.375rem !important;
  display: inline-block !important;
  position: relative !important;
  top: 1px !important;
}

/* Add icon to Clear button using Open Iconic - same as Clear button */

.btn-action-clear .dxbl-btn-caption::before,
.dxbl-btn.btn-action-clear .dxbl-btn-caption::before,
.dxbl-btn-secondary.btn-action-clear .dxbl-btn-caption::before {
  content: "\e0b3" !important; /* Open Iconic x icon (oi-x) */
  font-family: "Icons" !important;
  font-style: normal !important;
  font-weight: 400 !important;
  font-variant: normal !important;
  text-transform: none !important;
  line-height: 1 !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
  margin-right: 0.375rem !important;
  display: inline-block !important;
  position: relative !important;
  top: 1px !important;
}

/* Add icon to Search button using Open Iconic - same as Clear button */

.btn-action-search .dxbl-btn-caption::before,
.dxbl-btn.btn-action-search .dxbl-btn-caption::before,
.dxbl-btn-secondary.btn-action-search .dxbl-btn-caption::before {
  content: "\e08f" !important; /* Open Iconic x icon (oi-x) */
  font-family: "Icons" !important;
  font-style: normal !important;
  font-weight: 400 !important;
  font-variant: normal !important;
  text-transform: none !important;
  line-height: 1 !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
  margin-right: 0.375rem !important;
  display: inline-block !important;
  position: relative !important;
  top: 1px !important;
}


.btn-action-save:hover,
.btn-action-search:hover,
.dxbl-btn.btn-action-save:hover,
.dxbl-btn.btn-action-search:hover,
.dxbl-btn-primary.btn-action-save:hover,
.dxbl-btn-primary.btn-action-search:hover {
  background-color: #FF6600 !important;
  border-color: #FF6600 !important;
  opacity: 0.9 !important; /* Slight opacity change on hover */
  --dxbl-btn-bg: #FF6600 !important; /* Override DevExpress CSS variable on hover */
  --dxbl-btn-border-color: #FF6600 !important;
}

.btn-action-general,
.btn-action-cancel,
.btn-action-clear {
  height: 32px !important; /* h-8 = 2rem = 32px */
  padding: 0.375rem 0.75rem !important; /* py-1.5 px-3 = 6px 12px */
  font-size: 0.875rem !important; /* text-sm = 14px */
  font-weight: 500 !important; /* font-medium = 500, not bold */
  border-radius: 0.25rem !important; /* rounded = 4px */
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.375rem !important; /* gap-1.5 = 6px */
  white-space: nowrap !important;
  color: var(--samba-primary-blue-navy) !important; /* Navy text color */
}

/* Custom Button Styles */
.btn, .dxbl-btn {
  border-radius: var(--samba-border-radius-sm);
  border: none;
}

.btn-primary, .dxbl-btn-primary {
  background-color: #FF6600 !important; /* Main orange color for action buttons */
  border-color: #FF6600 !important;
  color: var(--samba-white) !important;
  border: none !important;
  box-shadow: var(--samba-shadow-card) !important; /* Match subtle shadow from grids/cards */
  --dxbl-btn-box-shadow: var(--samba-shadow-card) !important;
}

  .dxbl-btn-primary:hover {
    background-color: #FF6600 !important; /* Main orange on hover */
    border-color: #FF6600 !important;
    color: var(--samba-white) !important;
    box-shadow: var(--samba-shadow-card) !important; /* Maintain subtle shadow */
    opacity: 0.9 !important; /* Slight opacity change on hover */
  }

.btn-secondary, .dxbl-btn-secondary {
  background-color: var(--samba-gray-light);
  border-color: var(--samba-gray-border);
  color: var(--samba-black);
  border: none;
  box-shadow: var(--samba-shadow-card) !important; /* Match subtle shadow */
  --dxbl-btn-box-shadow: var(--samba-shadow-card) !important;
}


/* ============================================
   Navigation Menu - Clean & Simplified
   ============================================ */

/* Menu Container - Apply Samba V1 font */
.samba-menu,
.samba-menu .dxbl-menu {
  font-family: var(--samba-font-family) !important;
}

/* Menu Text Container */
.samba-menu .dxbl-menu-item-text-container {
  margin-left: 0 !important;
}

/* Hide dropdown chevron indicator only when sidebar is collapsed */
.sidebar-collapsed .samba-menu .dxbl-menu-dropdown-toggle {
  display: none !important;
}

/* ============================================
   Combo Box - Matching Border Radius
   ============================================ */

/* Combo box container - ensure proper border radius */
.dxbl-combo-box.dxbl-text-edit {
  border-radius: var(--samba-border-radius-sm) !important;
  overflow: hidden !important; /* Ensure child elements respect border radius */
}

/* Input field - rounded corners on left side only */
.dxbl-combo-box .dxbl-text-edit-input {
  border-top-left-radius: var(--samba-border-radius-sm) !important;
  border-bottom-left-radius: var(--samba-border-radius-sm) !important;
  border-top-right-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
}

/* Dropdown button - rounded corners on right side only */
.dxbl-combo-box .dxbl-edit-btn-dropdown {
  border-top-left-radius: 0 !important;
  border-bottom-left-radius: 0 !important;
  border-top-right-radius: var(--samba-border-radius-sm) !important;
  border-bottom-right-radius: var(--samba-border-radius-sm) !important;
}

/* Dropdown options - muted navy hover */
.dxbl-list-group-item:hover,
.dxbl-dropdown-dialog li[role="option"]:hover,
.dxbl-edit-dropdown li[role="option"]:hover {
  background-color: var(--samba-primary-blue-navy-10) !important;
}

/* Menu Item Container - Base Styles */
.samba-menu .dxbl-menu-item {
  padding: 0 !important;
  margin-bottom: var(--samba-menu-item-gap) !important;
  margin-top: 0 !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  position: relative !important;
  overflow: visible !important; /* Allow rounded corners to show */
}

.samba-menu .dxbl-menu-item:last-child {
  margin-bottom: 0 !important;
}

/* When collapsed - Menu item container should shrink to fit content */
.sidebar-collapsed .samba-menu .dxbl-menu-item {
  width: fit-content !important; /* Shrink to fit the clickable element */
  margin-left: 0 !important;
  margin-right: 0 !important;
  justify-content: flex-start !important; /* Override NavMenu.razor.css centering */
}

/* Clickable Element (a, button, .dxbl-btn) - Fills container */
.samba-menu .dxbl-menu-item > a,
.samba-menu .dxbl-menu-item > .dxbl-btn {
  width: 100% !important;
  min-height: var(--samba-menu-item-height) !important;
  padding: var(--samba-menu-item-padding) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important; /* Default: align content to start */
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  background-color: transparent !important;
  text-decoration: none !important;
  color: var(--samba-primary-blue-navy) !important;
  border-radius: var(--samba-border-radius-sm) !important; /* Round all corners */
  transition: background-color 0.2s ease, color 0.2s ease !important;
}

/* When collapsed - Keep icon in same position, shrink menu item from right to create equal padding */
.sidebar-collapsed .samba-menu .dxbl-menu-item > a,
.sidebar-collapsed .samba-menu .dxbl-menu-item > .dxbl-btn {
  padding-left: var(--samba-spacing-1) !important; /* 16px - same as expanded */
  padding-right: var(--samba-spacing-1) !important; /* 16px - match left */
  padding-top: var(--samba-spacing-075) !important;
  padding-bottom: var(--samba-spacing-075) !important;
  width: auto !important; /* Allow to shrink */
  min-width: fit-content !important; /* Shrink to fit icon */
  margin: 0 !important; /* No margins */
  justify-content: flex-start !important; /* Icon stays on left */
}

/* Menu Item Content - Text & Icons */
.samba-menu-item-content {
  display: flex !important;
  align-items: center !important;
  gap: var(--samba-spacing-md) !important; /* Space between icon and text */
  color: var(--samba-primary-blue-navy) !important;
  font-family: var(--samba-font-family) !important; /* Match Samba V1 font */
}

.samba-menu-item-content > p,
.samba-menu-item-content > span {
  color: var(--samba-primary-blue-navy) !important;
  font-family: var(--samba-font-family) !important; /* Match Samba V1 font */
}

.samba-menu-item-content > p {
  font-size: var(--samba-menu-item-font-size) !important;
  font-weight: var(--samba-menu-item-font-weight) !important;
  font-family: var(--samba-font-family) !important; /* Match Samba V1 font */
  line-height: 1.5 !important;
  margin: 0 !important;
}

/* Hover State - Grey background only (text stays navy by default) */
.samba-menu .dxbl-menu-item > a:hover,
.samba-menu .dxbl-menu-item > .dxbl-btn:hover {
  background-color: var(--samba-gray-muted) !important;
}

/* Active State - Target li element directly */
.dxbl-menu-list-item.samba-nav-item-active > .dxbl-menu-item > a,
.dxbl-menu-list-item.samba-nav-item-active > .dxbl-menu-item > .dxbl-btn {
  background-color: var(--samba-primary-blue-navy) !important;
  color: var(--samba-white) !important;
}

.dxbl-menu-list-item.samba-nav-item-active .samba-menu-item-content,
.dxbl-menu-list-item.samba-nav-item-active .samba-menu-item-content > p,
.dxbl-menu-list-item.samba-nav-item-active .samba-menu-item-content > span {
  color: var(--samba-white) !important;
}

/* Orange Indicator Line - Positioned on active li element, aligned to sidebar edge */
.dxbl-menu-list-item.samba-nav-item-active {
  position: relative !important;
}

/* Position orange line flush with the left edge of the sidebar (accounting for nav padding) */
.samba-sidebar-nav .dxbl-menu-list-item.samba-nav-item-active::before {
  content: '' !important;
  position: absolute !important;
  left: calc(-1 * 1.5rem) !important; /* Negative of nav container left padding to align with sidebar edge */
  top: 0 !important;
  bottom: 0 !important;
  width: var(--samba-menu-indicator-width) !important;
  background-color: var(--samba-accent-amber) !important; /* Orange indicator line */
  border-radius: 0 2px 2px 0 !important;
  z-index: 1 !important;
  pointer-events: none !important;
  margin-left: 0 !important; /* Ensure no additional margin */
}

/* Active + Hover - Keep navy background */
.dxbl-menu-list-item.samba-nav-item-active > .dxbl-menu-item > a:hover,
.dxbl-menu-list-item.samba-nav-item-active > .dxbl-menu-item > .dxbl-btn:hover {
  background-color: var(--samba-primary-blue-navy) !important;
}

/* ============================================
   Submenu/Popup Styles
   ============================================ */

/* Submenu Container - Padding */
.dxbl-menu-popup .dxbl-popup-content {
  padding: var(--samba-menu-submenu-padding) !important;
}

/* Submenu Items - Container */
.dxbl-menu-popup .dxbl-menu-item {
  padding: 0 !important;
  margin-bottom: var(--samba-menu-item-gap) !important;
  margin-left: 0 !important; /* Remove any DevExpress left margin/indent */
  border: none !important;
  background-color: transparent !important;
  --dxbl-menu-item-indent-count: 0 !important; /* Remove DevExpress indentation */
}

.dxbl-menu-popup .dxbl-menu-item:last-child {
  margin-bottom: 0 !important;
}

/* Submenu Items - Clickable Element */
.dxbl-menu-popup .dxbl-menu-item > a,
.dxbl-menu-popup .dxbl-menu-item > .dxbl-btn {
  width: 100% !important;
  padding: var(--samba-menu-submenu-item-padding) !important;
  padding-left: var(--samba-spacing-075) !important; /* Ensure consistent left padding (12px) */
  display: flex !important;
  align-items: center !important;
  background-color: var(--samba-white) !important;
  color: var(--samba-primary-blue-navy) !important;
  border: 1px solid transparent !important;
  border-radius: var(--samba-border-radius-sm) !important;
  text-decoration: none !important;
  transition: background-color 0.2s ease, color 0.2s ease !important;
}

/* Submenu Items - Hover */
.dxbl-menu-popup .dxbl-menu-item > a:hover,
.dxbl-menu-popup .dxbl-menu-item > .dxbl-btn:hover {
  background-color: var(--samba-gray-muted) !important;
  color: var(--samba-primary-blue-navy) !important;
}

/* Submenu Items - Active State */
.dxbl-menu-popup .dxbl-menu-list-item.samba-nav-item-active > .dxbl-menu-item > a,
.dxbl-menu-popup .dxbl-menu-list-item.samba-nav-item-active > .dxbl-menu-item > .dxbl-btn {
  background-color: var(--samba-primary-blue-navy) !important;
  color: var(--samba-white) !important;
  border-color: var(--samba-primary-blue-navy) !important;
}

.dxbl-menu-popup .dxbl-menu-list-item.samba-nav-item-active .samba-menu-item-content,
.dxbl-menu-popup .dxbl-menu-list-item.samba-nav-item-active .samba-menu-item-content > p,
.dxbl-menu-popup .dxbl-menu-list-item.samba-nav-item-active .samba-menu-item-content > span {
  color: var(--samba-white) !important;
}

/* No orange indicator on submenu items */
.dxbl-menu-popup .dxbl-menu-list-item::before {
  display: none !important;
}

/* Menu Submenu/Popup - Ensure it appears above sidebar */
/* DevExpress renders popups in a portal to the body */
/* Sidebar no longer has a z-index, so a reasonable z-index for popups should work */
body > .dxbl-popup-wrapper,
body > .dxbl-overlay-wrapper {
  z-index: 1000 !important; /* Standard popup z-index */
}

/* Target all DevExpress popup elements */
.dxbl-menu-popup,
.dxbl-menu .dxbl-popup,
.dxbl-popup-wrapper,
.dxbl-popup-content,
.dxbl-overlay-wrapper {
  z-index: 1000 !important;
}

/* Specifically target menu submenu popup wrapper */
.dxbl-menu .dxbl-popup-wrapper,
.dxbl-menu-popup .dxbl-popup-wrapper,
.samba-menu .dxbl-popup-wrapper,
.samba-sub-menu .dxbl-popup-wrapper {
  z-index: 1000 !important;
}

/* Popup Width Utilities */
.pw-400 {
  --dxbl-popup-max-width: 400px;
}

.pw-800 {
  --dxbl-popup-max-width: 800px;
}

.pw-1400 {
  --dxbl-popup-max-width: 1400px;
}

/* ============================================
   DevExpress Grid
   ============================================ */

/* Grid Container - Card-like appearance */
.dxbl-grid {
  background-color: var(--samba-white) !important;
  border-radius: var(--samba-border-radius-sm) !important; /* Less rounded - 6px instead of 10px */
  box-shadow: var(--samba-shadow-card) !important; /* shadow-sm from Samba V1 - subtle shadow */
  border: 1px solid var(--samba-primary-blue-navy-20) !important;
  overflow: hidden !important;
}

/* Remove all vertical borders from grid cells */
.dxbl-grid td,
.dxbl-grid th,
.dxbl-grid .dxbl-grid-header-cell,
.dxbl-grid .dxbl-grid-cell,
.dxbl-grid .dxbl-grid-filter-row-cell,
.dxbl-grid .dxbl-grid-command-cell,
.dxbl-grid .dxbl-grid-selection-cell {
  border-left: none !important;
  border-right: none !important;
}

/* Grid Header Row */
.dxbl-grid-header {
  background-color: var(--samba-primary-blue-navy-10) !important; /* Light muted navy */
  border-bottom: 1px solid var(--samba-primary-blue-navy-20) !important;
  font-weight: var(--samba-font-weight-medium) !important;
  color: var(--samba-primary-blue-navy) !important;
}

/* Grid Header Cells */
.dxbl-grid-header-cell {
  background-color: var(--samba-primary-blue-navy-10) !important; /* Light muted navy */
  color: var(--samba-primary-blue-navy) !important;
  font-weight: var(--samba-font-weight-medium) !important;
  font-size: var(--samba-font-size-sm) !important;
  padding: var(--samba-spacing-075) var(--samba-spacing-1) !important;
  border-bottom: 1px solid var(--samba-primary-blue-navy-20) !important;
  border-right: none !important; /* No vertical borders */
  border-left: none !important; /* No vertical borders */
}

/* Grid Data Rows */
.dxbl-grid-data-row {
  border-bottom: 1px solid var(--samba-primary-blue-navy-10) !important;
  transition: background-color 0.2s ease !important;
  min-height: auto !important; /* Ensure consistent row height */
}

.dxbl-grid-data-row:hover {
  background-color: var(--samba-gray-light) !important;
}

.dxbl-grid-data-row:last-child {
  border-bottom: none !important;
}

/* Grid Data Cells - Consistent padding for all grids */
.dxbl-grid-cell {
  padding: var(--samba-spacing-075) var(--samba-spacing-1) !important; /* 12px 16px - consistent with header */
  color: var(--samba-primary-blue-navy) !important;
  font-size: var(--samba-font-size-sm) !important;
  border-right: none !important; /* No vertical borders */
  border-left: none !important; /* No vertical borders */
  vertical-align: middle !important;
  line-height: 1.5 !important; /* Consistent line height */
}

/* Grid Command Column Cells */
.dxbl-grid-command-cell {
  padding: var(--samba-spacing-05) !important;
  text-align: center !important;
}

/* Grid Title/Header Text */
.dxbl-grid-title {
  color: var(--samba-primary-blue-navy) !important;
  font-weight: var(--samba-font-weight-bold) !important;
  font-size: var(--samba-font-size-lg) !important;
  margin-bottom: var(--samba-spacing-1) !important;
}

/* Grid Footer */
.dxbl-grid-footer {
  background-color: var(--samba-white) !important;
  border-top: 1px solid var(--samba-primary-blue-navy-20) !important;
  padding: var(--samba-spacing-075) var(--samba-spacing-1) !important;
}

/* Grid Pager */
.dxbl-grid-pager {
  background-color: var(--samba-white) !important;
  border-top: 1px solid var(--samba-primary-blue-navy-20) !important;
  padding: var(--samba-spacing-075) var(--samba-spacing-1) !important;
}

/* Grid Filter Row */
.dxbl-grid-filter-row {
  background-color: var(--samba-white) !important;
  border-bottom: 1px solid var(--samba-primary-blue-navy-10) !important;
}

.dxbl-grid-filter-row-cell {
  padding: var(--samba-spacing-05) var(--samba-spacing-1) !important;
  border-right: none !important; /* No vertical borders */
  border-left: none !important; /* No vertical borders */
}

/* Grid Selection Checkbox */
.dxbl-grid-selection-cell {
  text-align: center !important;
  padding: var(--samba-spacing-05) !important;
}

/* Grid Action Buttons in Cells */
.dxbl-grid-cell .dxbl-btn {
  padding: var(--samba-spacing-025) var(--samba-spacing-05) !important;
  min-height: auto !important;
  font-size: var(--samba-font-size-sm) !important;
}

/* Grid Edit Form */
.dxbl-grid-edit-form {
  background-color: var(--samba-white) !important;
  border-radius: var(--samba-border-radius-md) !important;
  box-shadow: none !important; /* No shadow */
}

/* Grid Edit Form Buttons - Match action button styling */
.dxbl-grid-edit-form-buttons .dxbl-btn-primary,
.dxbl-grid-edit-form-buttons .dxbl-btn.dxbl-btn-primary {
  background-color: #FF6600 !important; /* Main orange color - darker/more vibrant */
  border-color: #FF6600 !important;
  color: var(--samba-white) !important;
  height: 32px !important; /* h-8 = 2rem = 32px */
  padding: 0.375rem 0.75rem !important; /* py-1.5 px-3 = 6px 12px */
  font-size: 0.875rem !important; /* text-sm = 14px */
  font-weight: 500 !important; /* font-medium = 500, not bold */
  border-radius: 0.25rem !important; /* rounded = 4px */
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px -1px rgba(0, 0, 0, 0.1) !important; /* shadow-sm */
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.375rem !important; /* gap-1.5 = 6px */
  white-space: nowrap !important;
  transition: color 0.15s, background-color 0.15s, border-color 0.15s !important;
  --dxbl-btn-bg: #FF6600 !important; /* Override DevExpress CSS variable */
  --dxbl-btn-border-color: #FF6600 !important;
}

/* Add save icon to Save button using Open Iconic - same as action buttons */
.dxbl-grid-edit-form-buttons .dxbl-btn-primary .dxbl-btn-caption::before,
.dxbl-grid-edit-form-buttons .dxbl-btn.dxbl-btn-primary .dxbl-btn-caption::before {
  content: "\e033" !important; /* Open Iconic file icon (oi-file) - commonly used for save */
  font-family: "Icons" !important;
  font-style: normal !important;
  font-weight: 400 !important;
  font-variant: normal !important;
  text-transform: none !important;
  line-height: 1 !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
  margin-right: 0.375rem !important;
  display: inline-block !important;
  position: relative !important;
  top: 1px !important;
}

/* Add X icon to Cancel button using Open Iconic - same as Clear button */
.dxbl-grid-edit-form-buttons .dxbl-btn-secondary .dxbl-btn-caption::before,
.dxbl-grid-edit-form-buttons .dxbl-btn.dxbl-btn-secondary .dxbl-btn-caption::before {
  content: "\e0db" !important; /* Open Iconic x icon (oi-x) */
  font-family: "Icons" !important;
  font-style: normal !important;
  font-weight: 400 !important;
  font-variant: normal !important;
  text-transform: none !important;
  line-height: 1 !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
  margin-right: 0.375rem !important;
  display: inline-block !important;
  position: relative !important;
  top: 1px !important;
}

.dxbl-grid-edit-form-buttons .dxbl-btn-primary:hover,
.dxbl-grid-edit-form-buttons .dxbl-btn.dxbl-btn-primary:hover {
  background-color: #FF6600 !important;
  border-color: #FF6600 !important;
  opacity: 0.9 !important; /* Slight opacity change on hover */
  --dxbl-btn-bg: #FF6600 !important; /* Override DevExpress CSS variable on hover */
  --dxbl-btn-border-color: #FF6600 !important;
}

.dxbl-grid-edit-form-buttons .dxbl-btn-secondary,
.dxbl-grid-edit-form-buttons .dxbl-btn.dxbl-btn-secondary {
  height: 32px !important; /* h-8 = 2rem = 32px */
  padding: 0.375rem 0.75rem !important; /* py-1.5 px-3 = 6px 12px */
  font-size: 0.875rem !important; /* text-sm = 14px */
  font-weight: 500 !important; /* font-medium = 500, not bold */
  border-radius: 0.25rem !important; /* rounded = 4px */
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.375rem !important; /* gap-1.5 = 6px */
  white-space: nowrap !important;
  color: var(--samba-primary-blue-navy) !important; /* Navy text color */
}

/* Grid Popup Edit Form Header Title - Navy */
.dxbl-popup-header,
.dxbl-popup-title,
.dxbl-popup-header-text,
.dxbl-grid-edit-form .dxbl-popup-header,
.dxbl-grid-edit-form .dxbl-popup-title,
.dxbl-popup .dxbl-popup-header,
.dxbl-popup .dxbl-popup-title,
.dxbl-popup-header .dxbl-popup-title-text,
.dxbl-popup-header-text,
.dxbl-popup-header h1,
.dxbl-popup-header h2,
.dxbl-popup-header h3,
.dxbl-popup-header h4,
.dxbl-popup-header h5,
.dxbl-popup-header h6,
.dxbl-popup-header .dxbl-text {
  color: var(--samba-primary-blue-navy) !important;
}

/* ============================================
   DevExpress Form Layout
   ============================================ */

.dxbl-form-layout-item-caption,
.dxbl-form-layout-item-caption label,
label.dxbl-form-layout-item-caption {
  font-family: var(--samba-font-family) !important;
  font-size: var(--samba-font-size-base) !important;
  font-weight: var(--samba-font-weight-normal) !important; /* Normal weight to match Samba V1 */
  line-height: 1.5 !important;
  color: var(--samba-primary-blue-navy) !important;
  margin-bottom: var(--samba-spacing-05) !important;
}

/* Standalone labels (like in search forms) */
label.form-label,
.dxbl-form-layout-item label {
  font-family: var(--samba-font-family) !important;
  font-size: var(--samba-font-size-sm) !important; /* 14px - slightly smaller */
  font-weight: var(--samba-font-weight-normal) !important; /* Normal weight to match Samba V1 */
  line-height: 1.5 !important;
  color: var(--samba-primary-blue-navy) !important;
}

/* ============================================
   DevExpress TextBox & Inputs
   ============================================ */

/* Direct CSS targeting - override DevExpress defaults */
.dxbl-text-edit {
  min-height: 34px !important;
  height: auto !important;
  border-radius: var(--samba-border-radius-sm) !important; /* 6px */
  overflow: hidden !important; /* Ensure underline respects border-radius */
  position: relative !important;
  /* Make bottom border same color as other borders (not underline color) */
  border-bottom-color: var(--dxbl-text-edit-border-color) !important;
  /* Remove accent underline indicator */
  --dxbl-text-edit-underline-focused-color: transparent !important;
  --dxbl-text-edit-underline-focused-height: 0 !important;
  --dxbl-text-edit-underline-color: transparent !important;
}

/* Textbox focus state - Navy border on all sides (including bottom) */
.dxbl-text-edit.dxbl-text-edit-focused,
.dxbl-text-edit:focus {
  border-color: var(--samba-primary-blue-navy) !important; /* Navy accent - all borders including bottom */
  border-bottom-color: var(--samba-primary-blue-navy) !important; /* Navy accent - ensure bottom border matches */
  outline-color: var(--samba-primary-blue-navy) !important; /* Navy accent */
  /* Override theme CSS variables on focused element */
  --dxbl-text-edit-focus-border-color: var(--samba-primary-blue-navy); /* Navy accent */
  --dxbl-text-edit-focus-shadow-color: rgba(24, 48, 82, 0.25); /* Navy shadow */
  --dxbl-text-edit-underline-focused-color: transparent !important; /* Remove accent underline on focus */
  --dxbl-text-edit-underline-focused-height: 0 !important; /* Remove accent underline height */
  --dxbl-text-edit-underline-color: transparent !important; /* Remove underline color */
}

.dxbl-text-edit.dxbl-text-edit-focused .dxbl-text-edit-input {
  border-color: var(--samba-primary-blue-navy) !important; /* Navy - force override OfficeWhite orange */
}

/* Remove DevExpress underline/indicator on focus */
.dxbl-text-edit.dxbl-text-edit-focused::after,
.dxbl-text-edit.dxbl-text-edit-focused::before,
.dxbl-text-edit.dxbl-text-edit-focused .dxbl-text-edit-underline {
  display: none !important; /* Hide underline pseudo-elements */
  background-color: transparent !important;
  border-color: transparent !important;
  height: 0 !important;
  width: 0 !important;
}

.dxbl-text-edit-input {
  min-height: 32px !important;
  height: 32px !important;
  padding: 6px 12px !important;
  font-size: var(--samba-font-size-sm) !important; /* 14px - smaller text */
  line-height: 1.5 !important;
  border-radius: var(--samba-border-radius-sm) !important; /* Ensure input respects border-radius */
  color: var(--samba-primary-blue-navy) !important; /* Navy text color */
}

/* Make the underline rounded to match border - target the border-bottom */
.dxbl-text-edit,
.dxbl-text-edit.dxbl-text-edit-focused {
  border-bottom-left-radius: var(--samba-border-radius-sm) !important;
  border-bottom-right-radius: var(--samba-border-radius-sm) !important;
}

/* Target any pseudo-elements that create the underline */
.dxbl-text-edit::after,
.dxbl-text-edit::before {
  border-bottom-left-radius: var(--samba-border-radius-sm) !important;
  border-bottom-right-radius: var(--samba-border-radius-sm) !important;
}

/* Force navy color on all text edit focus states - Override OfficeWhite orange */
.dxbl-text-edit.dxbl-text-edit-focused *,
.dxbl-text-edit:focus * {
  border-color: var(--samba-primary-blue-navy) !important; /* Navy */
  color: var(--samba-primary-blue-navy) !important; /* Navy */
}

/* Force navy on all DevExpress accent colors - Override any orange values */
.dxbl-text-edit[style*="border-color"],
.dxbl-text-edit[style*="accent-color"],
.dxbl-text-edit[style*="orange"],
.dxbl-text-edit[style*="#fe7109"],
.dxbl-text-edit[style*="#F04D38"] {
  border-color: var(--samba-primary-blue-navy) !important;
  accent-color: var(--samba-primary-blue-navy) !important;
}

/* Global override for any orange accent colors in DevExpress components */
[style*="border-color: orange"],
[style*="border-color: #fe7109"],
[style*="border-color: #F04D38"],
[style*="accent-color: orange"],
[style*="accent-color: #fe7109"],
[style*="accent-color: #F04D38"] {
  border-color: var(--samba-primary-blue-navy) !important;
  accent-color: var(--samba-primary-blue-navy) !important;
}

/* ComboBox - same height */
.dxbl-combo-box .dxbl-text-edit {
  min-height: 34px !important;
}

.dxbl-combo-box .dxbl-text-edit-input {
  min-height: 32px !important;
  height: 32px !important;
  padding: 6px 12px !important;
  font-size: var(--samba-font-size-sm) !important; /* 14px - smaller text */
  color: var(--samba-primary-blue-navy) !important; /* Navy text color */
}

/* DateEdit - same height */
.dxbl-date-edit .dxbl-text-edit {
  min-height: 34px !important;
}

.dxbl-date-edit .dxbl-text-edit-input {
  min-height: 32px !important;
  height: 32px !important;
  padding: 6px 12px !important;
  font-size: var(--samba-font-size-sm) !important; /* 14px - smaller text */
  color: var(--samba-primary-blue-navy) !important; /* Navy text color */
}


/* ============================================
   DevExpress Checkbox Label
   ============================================ */

/* Checkbox label text - Navy */
.dxbl-checkbox label,
.dxbl-checkbox .dxbl-text {
  color: var(--samba-primary-blue-navy) !important;
}

/* ============================================
   DevExpress ComboBox/Dropdown Button Styling
   ============================================ */

/* ============================================
   DevExpress ComboBox/Dropdown Selected Items
   ============================================ */

/* Dropdown selected item - Navy background with white text */
.dxbl-list-group-item.dxbl-list-group-item-selected,
.dxbl-dropdown-dialog li[role="option"].dxbl-list-group-item-selected,
.dxbl-edit-dropdown li[role="option"].dxbl-list-group-item-selected,
.dxbl-list-group-item[aria-selected="true"],
.dxbl-dropdown-dialog li[role="option"][aria-selected="true"],
.dxbl-edit-dropdown li[role="option"][aria-selected="true"] {
  background-color: var(--samba-primary-blue-navy) !important;
  color: var(--samba-white) !important;
}

/* List Box selected item - Navy background with white text */
.dxbl-list-box-item-selected,
.dxbl-list-box-item[aria-selected="true"],
li.dxbl-list-box-item-selected {
  background-color: var(--samba-primary-blue-navy) !important;
  color: var(--samba-white) !important;
}

/* List Box selected item hover - Keep navy background */
.dxbl-list-box-item-selected:hover,
.dxbl-list-box-item[aria-selected="true"]:hover,
li.dxbl-list-box-item-selected:hover {
  background-color: var(--samba-primary-blue-navy) !important;
  color: var(--samba-white) !important;
}

/* ComboBox input border - Navy on focus */
.dxbl-combo-box.dxbl-text-edit.dxbl-text-edit-focused,
.dxbl-combo-box.dxbl-text-edit:focus {
  border-color: var(--samba-primary-blue-navy) !important;
}

/* DateEdit input border - Navy on focus */
.dxbl-date-edit.dxbl-text-edit.dxbl-text-edit-focused,
.dxbl-date-edit.dxbl-text-edit:focus {
  border-color: var(--samba-primary-blue-navy) !important;
}

/* ============================================
   Responsive Adjustments
   ============================================ */

@media (max-width: 768px) {
  .dxbl-grid {
    font-size: 0.875rem;
  }
}

