/* 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(--CFP-primary-blue-navy) !important;
}

/* ============================================
   DevExpress Global Theme Variables
   ============================================ */

/* ============================================
   DevExpress Buttons
   ============================================ */

/* Grid Action Buttons */
.btnGrid {
  height: var(--CFP-grid-btn-height) !important;
}

.btnGridNew,
.btnGridEdit,
.btnGridEmail {
  height: var(--CFP-grid-btn-height) !important;
  color: var(--CFP-black);
  border-color: var(--CFP-gray-border);
}

.btnGridDelete {
  height: var(--CFP-grid-btn-height) !important;
  color: var(--CFP-error);
  border-color: var(--CFP-gray-border);
}

.btnGridCancel {
  height: var(--CFP-grid-btn-height) !important;
  color: var(--CFP-warning);
  border-color: var(--CFP-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: var(--CFP-cta-orange) !important; /* Main orange color - darker/more vibrant */
  border-color: var(--CFP-cta-orange) !important;
  color: var(--CFP-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: var(--CFP-cta-orange) !important; /* Override DevExpress CSS variable */
  --dxbl-btn-border-color: var(--CFP-cta-orange) !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: var(--CFP-cta-orange) !important;
  border-color: var(--CFP-cta-orange) !important;
  opacity: 0.9 !important; /* Slight opacity change on hover */
  --dxbl-btn-bg: var(--CFP-cta-orange) !important; /* Override DevExpress CSS variable on hover */
  --dxbl-btn-border-color: var(--CFP-cta-orange) !important;
}

.btn-action-general,
.btn-action-cancel,
.btn-action-clear,
.btn-action-new,
.btn-action-transition {
  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(--CFP-primary-blue-navy) !important; /* Navy text color */
}

/* Add file icon to New button using Open Iconic (same as grid New) */
.btn-action-new .dxbl-btn-caption::before,
.dxbl-btn.btn-action-new .dxbl-btn-caption::before,
.dxbl-btn-secondary.btn-action-new .dxbl-btn-caption::before {
  content: "\e033" !important; /* Open Iconic file icon (oi-file) */
  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;
}



/* Custom Button Styles */
.btn, .dxbl-btn {
  border-radius: var(--CFP-border-radius-sm);
  border: none;
}

.btn-primary, .dxbl-btn-primary {
  background-color: var(--CFP-cta-orange) !important; /* Main orange color for action buttons */
  border-color: var(--CFP-cta-orange) !important;
  color: var(--CFP-white) !important;
  border: none !important;
  box-shadow: var(--CFP-shadow-card) !important; /* Match subtle shadow from grids/cards */
  --dxbl-btn-box-shadow: var(--CFP-shadow-card) !important;
}

  .dxbl-btn-primary:hover {
    background-color: var(--CFP-cta-orange) !important; /* Main orange on hover */
    border-color: var(--CFP-cta-orange) !important;
    color: var(--CFP-white) !important;
    box-shadow: var(--CFP-shadow-card) !important; /* Maintain subtle shadow */
    opacity: 0.9 !important; /* Slight opacity change on hover */
  }

.btn-secondary, .dxbl-btn-secondary {
  background-color: var(--CFP-gray-light);
  border-color: var(--CFP-gray-border);
  color: var(--CFP-black);
  border: none;
  box-shadow: var(--CFP-shadow-card) !important; /* Match subtle shadow */
  --dxbl-btn-box-shadow: var(--CFP-shadow-card) !important;
}


/* ============================================
   Navigation Menu - Clean & Simplified
   ============================================ */

/* Menu Container - Apply CFP V1 font */
.CFP-menu,
.CFP-menu .dxbl-menu {
  font-family: var(--CFP-font-family) !important;
}

  /* Menu Text Container */
  .CFP-menu .dxbl-menu-item-text-container {
    margin-left: 0 !important;
  }

/* Hide dropdown chevron indicator only when sidebar is collapsed */
.sidebar-collapsed .CFP-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(--CFP-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(--CFP-border-radius-sm) !important;
  border-bottom-left-radius: var(--CFP-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(--CFP-border-radius-sm) !important;
  border-bottom-right-radius: var(--CFP-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(--CFP-primary-blue-navy-10) !important;
}

/* Menu Item Container - Base Styles */
.CFP-menu .dxbl-menu-item {
  padding: 0 !important;
  margin-bottom: var(--CFP-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 */
}

  .CFP-menu .dxbl-menu-item:last-child {
    margin-bottom: 0 !important;
  }

/* When collapsed - Menu item container should shrink to fit content */
.sidebar-collapsed .CFP-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 */
.CFP-menu .dxbl-menu-item > a,
.CFP-menu .dxbl-menu-item > .dxbl-btn {
  width: 100% !important;
  min-height: var(--CFP-menu-item-height) !important;
  padding: var(--CFP-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(--CFP-primary-blue-navy) !important;
  border-radius: var(--CFP-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 .CFP-menu .dxbl-menu-item > a,
.sidebar-collapsed .CFP-menu .dxbl-menu-item > .dxbl-btn {
  padding-left: var(--CFP-spacing-1) !important; /* 16px - same as expanded */
  padding-right: var(--CFP-spacing-1) !important; /* 16px - match left */
  padding-top: var(--CFP-spacing-075) !important;
  padding-bottom: var(--CFP-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 */
.CFP-menu-item-content {
  display: flex !important;
  align-items: center !important;
  gap: var(--CFP-spacing-md) !important; /* Space between icon and text */
  color: var(--CFP-primary-blue-navy) !important;
  font-family: var(--CFP-font-family) !important; /* Match CFP V1 font */
}

  .CFP-menu-item-content > p,
  .CFP-menu-item-content > span {
    color: var(--CFP-primary-blue-navy) !important;
    font-family: var(--CFP-font-family) !important; /* Match CFP V1 font */
  }

  .CFP-menu-item-content > p {
    font-size: var(--CFP-menu-item-font-size) !important;
    font-weight: var(--CFP-menu-item-font-weight) !important;
    font-family: var(--CFP-font-family) !important; /* Match CFP V1 font */
    line-height: 1.5 !important;
    margin: 0 !important;
  }

/* Hover State - Grey background only (text stays navy by default) */
.CFP-menu .dxbl-menu-item > a:hover,
.CFP-menu .dxbl-menu-item > .dxbl-btn:hover {
  background-color: var(--CFP-gray-muted) !important;
}

/* Active State - Target li element directly */
.dxbl-menu-list-item.CFP-nav-item-active > .dxbl-menu-item > a,
.dxbl-menu-list-item.CFP-nav-item-active > .dxbl-menu-item > .dxbl-btn {
  background-color: var(--CFP-primary-blue-navy) !important;
  color: var(--CFP-white) !important;
}

.dxbl-menu-list-item.CFP-nav-item-active .CFP-menu-item-content,
.dxbl-menu-list-item.CFP-nav-item-active .CFP-menu-item-content > p,
.dxbl-menu-list-item.CFP-nav-item-active .CFP-menu-item-content > span {
  color: var(--CFP-white) !important;
}

/* Orange Indicator Line - Positioned on active li element, aligned to sidebar edge */
.dxbl-menu-list-item.CFP-nav-item-active {
  position: relative !important;
}

/* Position orange line flush with the left edge of the sidebar (accounting for nav padding) */
.CFP-sidebar-nav .dxbl-menu-list-item.CFP-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(--CFP-menu-indicator-width) !important;
  background-color: var(--CFP-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.CFP-nav-item-active > .dxbl-menu-item > a:hover,
.dxbl-menu-list-item.CFP-nav-item-active > .dxbl-menu-item > .dxbl-btn:hover {
  background-color: var(--CFP-primary-blue-navy) !important;
}

/* ============================================
   Submenu/Popup Styles
   ============================================ */

/* Submenu Container - Padding */
.dxbl-menu-popup .dxbl-popup-content {
  padding: var(--CFP-menu-submenu-padding) !important;
}

/* Submenu Items - Container */
.dxbl-menu-popup .dxbl-menu-item {
  padding: 0 !important;
  margin-bottom: var(--CFP-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(--CFP-menu-submenu-item-padding) !important;
    padding-left: var(--CFP-spacing-075) !important; /* Ensure consistent left padding (12px) */
    display: flex !important;
    align-items: center !important;
    background-color: var(--CFP-white) !important;
    color: var(--CFP-primary-blue-navy) !important;
    border: 1px solid transparent !important;
    border-radius: var(--CFP-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(--CFP-gray-muted) !important;
      color: var(--CFP-primary-blue-navy) !important;
    }

/* Submenu Items - Active State */
.dxbl-menu-popup .dxbl-menu-list-item.CFP-nav-item-active > .dxbl-menu-item > a,
.dxbl-menu-popup .dxbl-menu-list-item.CFP-nav-item-active > .dxbl-menu-item > .dxbl-btn {
  background-color: var(--CFP-primary-blue-navy) !important;
  color: var(--CFP-white) !important;
  border-color: var(--CFP-primary-blue-navy) !important;
}

.dxbl-menu-popup .dxbl-menu-list-item.CFP-nav-item-active .CFP-menu-item-content,
.dxbl-menu-popup .dxbl-menu-list-item.CFP-nav-item-active .CFP-menu-item-content > p,
.dxbl-menu-popup .dxbl-menu-list-item.CFP-nav-item-active .CFP-menu-item-content > span {
  color: var(--CFP-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,
  .CFP-menu .dxbl-popup-wrapper,
  .CFP-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-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(--CFP-white) !important;
  border-radius: var(--CFP-border-radius-sm) !important; /* Less rounded - 6px instead of 10px */
  box-shadow: var(--CFP-shadow-card) !important; /* shadow-sm from CFP V1 - subtle shadow */
  border: 1px solid var(--CFP-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(--CFP-primary-blue-navy-10) !important; /* Light muted navy */
  border-bottom: 1px solid var(--CFP-primary-blue-navy-20) !important;
  font-weight: var(--CFP-font-weight-medium) !important;
  color: var(--CFP-primary-blue-navy) !important;
}

/* Grid Header Cells */
.dxbl-grid-header-cell {
  background-color: var(--CFP-primary-blue-navy-10) !important; /* Light muted navy */
  color: var(--CFP-primary-blue-navy) !important;
  font-weight: var(--CFP-font-weight-medium) !important;
  font-size: var(--CFP-font-size-sm) !important;
  padding: var(--CFP-spacing-075) var(--CFP-spacing-1) !important;
  border-bottom: 1px solid var(--CFP-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(--CFP-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(--CFP-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(--CFP-spacing-075) var(--CFP-spacing-1) !important; /* 12px 16px - consistent with header */
  color: var(--CFP-primary-blue-navy) !important;
  font-size: var(--CFP-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(--CFP-spacing-05) !important;
  text-align: center !important;
}

/* Grid Title/Header Text */
.dxbl-grid-title {
  color: var(--CFP-primary-blue-navy) !important;
  font-weight: var(--CFP-font-weight-bold) !important;
  font-size: var(--CFP-font-size-lg) !important;
  margin-bottom: var(--CFP-spacing-1) !important;
}

/* Grid Footer */
.dxbl-grid-footer {
  background-color: var(--CFP-white) !important;
  border-top: 1px solid var(--CFP-primary-blue-navy-20) !important;
  padding: var(--CFP-spacing-075) var(--CFP-spacing-1) !important;
}

/* Grid Pager */
.dxbl-grid-pager {
  background-color: var(--CFP-white) !important;
  border-top: 1px solid var(--CFP-primary-blue-navy-20) !important;
  padding: var(--CFP-spacing-075) var(--CFP-spacing-1) !important;
}

/* Grid Filter Row */
.dxbl-grid-filter-row {
  background-color: var(--CFP-white) !important;
  border-bottom: 1px solid var(--CFP-primary-blue-navy-10) !important;
}

.dxbl-grid-filter-row-cell {
  padding: var(--CFP-spacing-05) var(--CFP-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(--CFP-spacing-05) !important;
}

/* Grid Action Buttons in Cells */
.dxbl-grid-cell .dxbl-btn {
  padding: var(--CFP-spacing-025) var(--CFP-spacing-05) !important;
  min-height: auto !important;
  font-size: var(--CFP-font-size-sm) !important;
}

/* Grid Edit Form */
.dxbl-grid-edit-form {
  background-color: var(--CFP-white) !important;
  border-radius: var(--CFP-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: var(--CFP-cta-orange) !important; /* Main orange color - darker/more vibrant */
  border-color: var(--CFP-cta-orange) !important;
  color: var(--CFP-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: var(--CFP-cta-orange) !important; /* Override DevExpress CSS variable */
  --dxbl-btn-border-color: var(--CFP-cta-orange) !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: var(--CFP-cta-orange) !important;
  border-color: var(--CFP-cta-orange) !important;
  opacity: 0.9 !important; /* Slight opacity change on hover */
  --dxbl-btn-bg: var(--CFP-cta-orange) !important; /* Override DevExpress CSS variable on hover */
  --dxbl-btn-border-color: var(--CFP-cta-orange) !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(--CFP-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(--CFP-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(--CFP-font-family) !important;
  font-size: var(--CFP-font-size-base) !important;
  font-weight: var(--CFP-font-weight-normal) !important; /* Normal weight to match CFP V1 */
  line-height: 1.5 !important;
  color: var(--CFP-primary-blue-navy) !important;
  margin-bottom: var(--CFP-spacing-05) !important;
}

/* Standalone labels (like in search forms) */
label.form-label,
.dxbl-form-layout-item label {
  font-family: var(--CFP-font-family) !important;
  font-size: var(--CFP-font-size-sm) !important; /* 14px - slightly smaller */
  font-weight: var(--CFP-font-weight-normal) !important; /* Normal weight to match CFP V1 */
  line-height: 1.5 !important;
  color: var(--CFP-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(--CFP-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(--CFP-primary-blue-navy) !important; /* Navy accent - all borders including bottom */
    border-bottom-color: var(--CFP-primary-blue-navy) !important; /* Navy accent - ensure bottom border matches */
    outline-color: var(--CFP-primary-blue-navy) !important; /* Navy accent */
    /* Override theme CSS variables on focused element */
    --dxbl-text-edit-focus-border-color: var(--CFP-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(--CFP-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(--CFP-font-size-sm) !important; /* 14px - smaller text */
  line-height: 1.5 !important;
  border-radius: var(--CFP-border-radius-sm) !important; /* Ensure input respects border-radius */
  color: var(--CFP-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(--CFP-border-radius-sm) !important;
  border-bottom-right-radius: var(--CFP-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(--CFP-border-radius-sm) !important;
    border-bottom-right-radius: var(--CFP-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(--CFP-primary-blue-navy) !important; /* Navy */
    color: var(--CFP-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(--CFP-primary-blue-navy) !important;
    accent-color: var(--CFP-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(--CFP-primary-blue-navy) !important;
  accent-color: var(--CFP-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(--CFP-font-size-sm) !important; /* 14px - smaller text */
  color: var(--CFP-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(--CFP-font-size-sm) !important; /* 14px - smaller text */
  color: var(--CFP-primary-blue-navy) !important; /* Navy text color */
}


/* ============================================
   DevExpress Checkbox Label
   ============================================ */

/* Checkbox label text - Navy */
.dxbl-checkbox label,
.dxbl-checkbox .dxbl-text {
  color: var(--CFP-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(--CFP-accent-orange) !important;
  fill: var(--CFP-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(--CFP-accent-orange) !important;
    fill: var(--CFP-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(--CFP-accent-orange) !important;
  fill: var(--CFP-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(--CFP-accent-orange) !important;
    fill: var(--CFP-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(--CFP-accent-red) !important;
  fill: var(--CFP-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(--CFP-accent-red) !important;
    fill: var(--CFP-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(--CFP-accent-red) !important;
  fill: var(--CFP-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(--CFP-accent-red) !important;
    fill: var(--CFP-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(--CFP-primary-blue-navy) !important;
  color: var(--CFP-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(--CFP-primary-blue-navy) !important;
  color: var(--CFP-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(--CFP-primary-blue-navy) !important;
    color: var(--CFP-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(--CFP-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(--CFP-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(--CFP-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(--CFP-accent-orange) !important;
  fill: var(--CFP-accent-orange) !important;
  opacity: 0.8 !important;
  font-size: 1rem !important;
}

/* Override Button - Styled to match lookup button */
.btn-editor-icon-override::before {
  content: '\F53F' !important;
  font-family: "bootstrap-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(--CFP-accent-orange) !important;
  fill: var(--CFP-accent-orange) !important;
  opacity: 0.8 !important;
  font-size: 1rem !important;
}

/* Clear Button - Styled to match DxComboBox 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(--CFP-error) !important;
  fill: var(--CFP-error) !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(--CFP-error) !important;
  opacity: 0.8 !important;
  display: inline-block !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(200, 92, 92, 0.15) !important;
  border-radius: 50% !important;
  color: var(--CFP-error) !important;
  fill: var(--CFP-error) !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;
}
