/* 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 {
  height: var(--samba-grid-btn-height) !important;
  color: var(--samba-orange);
  border-color: var(--samba-gray-border);
}

.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 */
  width: 100% !important;
  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 */
}

/* Fixed icon column for consistent icon/text alignment across menu levels */
.samba-menu-item-content > span:first-child {
  width: 1.25rem !important;
  min-width: 1.25rem !important;
  height: 1.25rem !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}

.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;
  flex: 1 1 auto !important;
  text-align: left !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-600 {
  --dxbl-popup-max-width: 600px;
}


.pw-800 {
  --dxbl-popup-max-width: 800px;
}

.pw-900 {
  --dxbl-popup-max-width: 900px;
}

.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;
}

/* Affordability totals footer should match header styling */
.affordability-grid tfoot td,
.affordability-grid tfoot th {
  background-color: var(--samba-primary-blue-navy-10) !important;
  color: var(--samba-primary-blue-navy) !important;
  font-weight: var(--samba-font-weight-bold) !important;
  border-top: 1px solid var(--samba-primary-blue-navy-20) !important;
}

.affordability-grid .affordability-footer-row {
  padding: 0.125rem 0 !important;
  line-height: 1.35 !important;
  white-space: nowrap !important;
}

.affordability-grid .affordability-footer-row-secondary {
  margin-top: 0.2rem !important;
  padding-top: 0.35rem !important;
  margin-left: -0.75rem !important;
  margin-right: -0.75rem !important;
  padding-left: 0.75rem !important;
  padding-right: 0.75rem !important;
  border-top: 1px solid var(--samba-primary-blue-navy-20) !important;
}

.affordability-grid .affordability-footer-label {
  font-weight: var(--samba-font-weight-bold) !important;
  white-space: nowrap !important;
}

.affordability-grid .affordability-footer-label-derived {
  font-weight: var(--samba-font-weight-bold) !important;
}

.affordability-grid .affordability-footer-amount {
  display: block !important;
  width: 100% !important;
  text-align: right !important;
  white-space: nowrap !important;
  font-weight: var(--samba-font-weight-bold) !important;
  font-variant-numeric: tabular-nums lining-nums !important;
  font-feature-settings: "tnum" 1, "lnum" 1 !important;
}

.affordability-grid .affordability-footer-amount-derived {
  font-weight: var(--samba-font-weight-bold) !important;
}

.affordability-grid .affordability-footer-value-negative {
  color: inherit !important;
}

.affordability-grid .affordability-footer-value-positive {
  color: var(--samba-primary-blue-navy) !important;
}

/* Affordability grids: keep body row heights consistent, including icon rows */
.affordability-grid tbody .dxbl-grid-cell,
.affordability-grid tbody .dxbl-grid-command-cell {
  padding-top: 0.35rem !important;
  padding-bottom: 0.35rem !important;
  min-height: 36px !important;
}

.affordability-grid tbody .dxbl-grid-cell .dxbl-btn,
.affordability-grid tbody .dxbl-grid-command-cell .dxbl-btn {
  height: 24px !important;
  min-height: 24px !important;
}

/* TreeList-specific row normalization (e.g. "Other (specify)" rows with icons) */
.affordability-grid tbody tr {
  height: 36px !important;
}

.affordability-grid tbody td,
.affordability-grid tbody .dxbl-tl-cell,
.affordability-grid tbody .dxbl-tl-command-cell,
.affordability-grid tbody .dxbl-tl-data-cell {
  height: 36px !important;
  min-height: 36px !important;
  vertical-align: middle !important;
  line-height: 1.25 !important;
}

.affordability-grid tbody .dxbl-tl-cell .dxbl-btn,
.affordability-grid tbody .dxbl-tl-command-cell .dxbl-btn {
  height: 24px !important;
  min-height: 24px !important;
  line-height: 1 !important;
}

/* Affordability TreeList: place expand chevron after row text */
.affordability-grid tbody .dxbl-tl-cell .dxbl-tl-cell-content,
.affordability-grid tbody .dxbl-tl-data-cell .dxbl-tl-cell-content,
.affordability-grid tbody .dxbl-tl-cell .dxbl-tl-text-container,
.affordability-grid tbody .dxbl-tl-data-cell .dxbl-tl-text-container {
  display: inline-flex !important;
  align-items: center !important;
}

.affordability-grid tbody .dxbl-tl-cell .dxbl-tl-indent,
.affordability-grid tbody .dxbl-tl-data-cell .dxbl-tl-indent {
  order: 1 !important;
}

.affordability-grid tbody .dxbl-tl-cell .dxbl-tl-text,
.affordability-grid tbody .dxbl-tl-data-cell .dxbl-tl-text,
.affordability-grid tbody .dxbl-tl-cell .dxbl-tl-cell-text,
.affordability-grid tbody .dxbl-tl-data-cell .dxbl-tl-cell-text {
  order: 2 !important;
}

.affordability-grid tbody .dxbl-tl-cell .dxbl-tl-expander,
.affordability-grid tbody .dxbl-tl-data-cell .dxbl-tl-expander {
  order: 3 !important;
  margin-left: 0.375rem !important;
  margin-right: 0 !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 */
}

/* Explicit Custom DXSpinEdit Text Align rule for numerics (incase don't want it globally) */
.dxSpin-align-numeric input {
  text-align: left;
}

/* Make all DXSpinEdit Text Align right */

/*.dxbl-spin-edit .dxbl-text-edit-input {
  text-align: right !important;
}*/


/* ============================================
   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
   ============================================ */

/* ComboBox dropdown arrow button - Orange accent color */
.dxbl-combo-box .dxbl-edit-btn-dropdown,
.dxbl-combo-box .dxbl-edit-btn-dropdown .dxbl-btn-icon,
.dxbl-combo-box .dxbl-edit-btn-dropdown::before,
.dxbl-combo-box .dxbl-edit-btn-dropdown svg,
.dxbl-combo-box .dxbl-edit-btn-dropdown path {
  color: var(--samba-accent-orange) !important;
  fill: var(--samba-accent-orange) !important;
}

/* ComboBox dropdown arrow button hover */
.dxbl-combo-box .dxbl-edit-btn-dropdown:hover,
.dxbl-combo-box .dxbl-edit-btn-dropdown:hover .dxbl-btn-icon,
.dxbl-combo-box .dxbl-edit-btn-dropdown:hover svg,
.dxbl-combo-box .dxbl-edit-btn-dropdown:hover path {
  color: var(--samba-accent-orange) !important;
  fill: var(--samba-accent-orange) !important;
  opacity: 0.8 !important;
}

/* All dropdown buttons - Orange accent color */
.dxbl-edit-btn-dropdown,
.dxbl-edit-btn-dropdown .dxbl-btn-icon,
.dxbl-edit-btn-dropdown::before,
.dxbl-edit-btn-dropdown svg,
.dxbl-edit-btn-dropdown path {
  color: var(--samba-accent-orange) !important;
  fill: var(--samba-accent-orange) !important;
}

/* All dropdown buttons hover */
.dxbl-edit-btn-dropdown:hover,
.dxbl-edit-btn-dropdown:hover .dxbl-btn-icon,
.dxbl-edit-btn-dropdown:hover svg,
.dxbl-edit-btn-dropdown:hover path {
  color: var(--samba-accent-orange) !important;
  fill: var(--samba-accent-orange) !important;
  opacity: 0.8 !important;
}

/* ComboBox clear button - Red accent color */
.dxbl-combo-box .dxbl-edit-btn-clear,
.dxbl-combo-box .dxbl-edit-btn-clear .dxbl-btn-icon,
.dxbl-combo-box .dxbl-edit-btn-clear::before,
.dxbl-combo-box .dxbl-edit-btn-clear svg,
.dxbl-combo-box .dxbl-edit-btn-clear path {
  color: var(--samba-accent-red) !important;
  fill: var(--samba-accent-red) !important;
  background-color: transparent !important; /* Remove background by default */
  box-shadow: none !important; /* Remove shadow by default */
}

/* ComboBox clear button hover - Add subtle background */
.dxbl-combo-box .dxbl-edit-btn-clear:hover,
.dxbl-combo-box .dxbl-edit-btn-clear:hover .dxbl-btn-icon,
.dxbl-combo-box .dxbl-edit-btn-clear:hover svg,
.dxbl-combo-box .dxbl-edit-btn-clear:hover path {
  color: var(--samba-accent-red) !important;
  fill: var(--samba-accent-red) !important;
  opacity: 0.9 !important;
}

/* Add background to the button element on hover */
.dxbl-combo-box .dxbl-edit-btn-clear:hover {
  background-color: rgba(255, 153, 153, 0.15) !important; /* Light red background on hover */
  border-radius: 50% !important; /* Circular background */
}

/* All clear buttons - Red accent color */
.dxbl-edit-btn-clear,
.dxbl-edit-btn-clear .dxbl-btn-icon,
.dxbl-edit-btn-clear::before,
.dxbl-edit-btn-clear svg,
.dxbl-edit-btn-clear path {
  color: var(--samba-accent-red) !important;
  fill: var(--samba-accent-red) !important;
  background-color: transparent !important; /* Remove background by default */
  box-shadow: none !important; /* Remove shadow by default */
}

/* All clear buttons hover - Add subtle background */
.dxbl-edit-btn-clear:hover,
.dxbl-edit-btn-clear:hover .dxbl-btn-icon,
.dxbl-edit-btn-clear:hover svg,
.dxbl-edit-btn-clear:hover path {
  color: var(--samba-accent-red) !important;
  fill: var(--samba-accent-red) !important;
  opacity: 0.9 !important;
}

/* Add background to the button element on hover */
.dxbl-edit-btn-clear:hover {
  background-color: rgba(255, 153, 153, 0.15) !important; /* Light red background on hover */
  border-radius: 50% !important; /* Circular background */
}

/* ============================================
   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;
  }
}

.dxbl-group > .dxbl-group-header > .dxbl-text {
  color: var(--samba-primary-blue-navy) !important;
  font-weight: 500;
}

/* ============================================
   Editor Buttons (DxEditorButton) - Custom Icons
   ============================================ */

/* Lookup Button - Magnifying glass icon with accent color */
.btn-editor-icon-lookup::before {
  content: '\e08f' !important; /* Open Iconic magnifying-glass */
  font-family: "Icons" !important;
  font-style: normal !important;
  font-weight: 400 !important;
  line-height: 1 !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
  color: var(--samba-accent-orange) !important;
  fill: var(--samba-accent-orange) !important;
  opacity: 0.8 !important;
  font-size: 1rem !important;
}

/* Clear Button - Styled to match default DevExpress clear button */
.dxbl-btn.btn-editor-icon-clear,
.dxbl-edit-btn.btn-editor-icon-clear,
.btn-editor-icon-clear.dxbl-edit-btn-clear,
button.btn-editor-icon-clear,
button.dxbl-edit-btn-clear.btn-editor-icon-clear,
.btn-editor-icon-clear {
  display: inline-flex !important;
  visibility: visible !important;
  opacity: 1 !important;
  color: var(--samba-accent-red) !important;
  fill: var(--samba-accent-red) !important;
  background-color: transparent !important;
  box-shadow: none !important;
  border: none !important;
  padding: 0 !important;
  min-width: auto !important;
  width: auto !important;
}

.btn-editor-icon-clear.dxbl-edit-btn-clear::before,
.dxbl-btn.btn-editor-icon-clear::before,
.dxbl-edit-btn.btn-editor-icon-clear::before,
.btn-editor-icon-clear::before {    
  content: '\00d7' !important; 
  font-family: Arial, sans-serif !important;
  font-size: 1.25rem !important;
  font-weight: 300 !important;
  line-height: 1 !important;
  color: var(--samba-accent-red) !important;
  opacity: 0.8 !important;
  display: inline-block !important;
}

.btn-editor-icon-clear.dxbl-edit-btn-clear svg,
.btn-editor-icon-clear.dxbl-edit-btn-clear .dxbl-image,
.dxbl-btn.btn-editor-icon-clear svg,
.dxbl-edit-btn.btn-editor-icon-clear svg,
.btn-editor-icon-clear svg {
  color: var(--samba-accent-red) !important;
  fill: var(--samba-accent-red) !important;
}

.dxbl-text-edit .dxbl-btn.btn-editor-icon-clear,
.dxbl-text-edit button.btn-editor-icon-clear {
  display: inline-flex !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.dxbl-btn.btn-editor-icon-clear:hover,
.dxbl-edit-btn.btn-editor-icon-clear:hover,
.btn-editor-icon-clear.dxbl-edit-btn-clear:hover {
  background-color: rgba(255, 153, 153, 0.15) !important;
  border-radius: 50% !important;
  color: var(--samba-accent-red) !important;
  fill: var(--samba-accent-red) !important;
}

.btn-editor-icon-clear.dxbl-edit-btn-clear:hover::before,
.dxbl-btn.btn-editor-icon-clear:hover::before,
.dxbl-edit-btn.btn-editor-icon-clear:hover::before {
  color: var(--samba-accent-red) !important;
  opacity: 0.9 !important;
}

.btn-editor-icon-clear.dxbl-edit-btn-clear:hover svg,
.btn-editor-icon-clear.dxbl-edit-btn-clear:hover .dxbl-image,
.dxbl-btn.btn-editor-icon-clear:hover svg,
.dxbl-edit-btn.btn-editor-icon-clear:hover svg,
.btn-editor-icon-clear:hover svg {
  color: var(--samba-accent-red) !important;
  fill: var(--samba-accent-red) !important;
  opacity: 0.9 !important;
}

.btn-editor-icon-clear.dxbl-edit-btn-clear:hover,
.dxbl-btn.btn-editor-icon-clear:hover,
.dxbl-edit-btn.btn-editor-icon-clear:hover,
.btn-editor-icon-clear:hover {
  background-color: rgba(255, 153, 153, 0.15) !important;
  border-radius: 50% !important;
}

/* ============================================
   DxUpload Custom Drop Zone
   ============================================ */

.custom-drop-zone {
    min-height: 150px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}

.custom-drop-zone i {
    font-size: 2rem;
    color: var(--samba-gray-text);
}

.custom-drop-zone:hover {
    background-color: var(--samba-gray-light) !important;
}

.upload-validation-text {
  flex-direction: column;
  align-items: flex-end;
  font-size: 12px;
}
