:root {
  /* Accent colors (overridden by theme-switcher.js) */
  --selectedBackColor: #fe7109;
  --selectedForeColor: #fff;
  --selectedHover: #e56608;
  --tabTextColor: #252129;
  --iconThemeColor: #d27614;
  --tabIconSelected: #d27614;
  --tabTextSelectedColor: var(--tabIconSelected);

  /* Theme-aware variables */
  --app-accent: #fe7109;
  --app-accent-dark: #d27614;
  --app-accent-hover: #e56608;
  --app-accent-light: rgba(254, 113, 9, 0.12);
  --app-accent-fg: #fff;

  /* Surfaces */
  --app-bg: #fff;
  --app-surface: #f5f5f5;
  --app-surface-hover: #e8e8e8;
  --app-header-bg: #fff;
  --app-header-fg: #333;
  --app-topbar-bg: #fff;
  --app-topbar-fg: #333;
  --app-sidebar-bg: #f5f5f5;
  --app-card-bg: #fff;
  --app-footer-bg: #fff;
  --app-border: #dee1e3;
  --app-border-light: rgba(0, 0, 0, 0.075);

  /* Text */
  --app-text: #333;
  --app-text-secondary: #666;
  --app-text-muted: #999;

  /* Scrollbar */
  --app-scrollbar-thumb: #c4c4c4;
  --app-scrollbar-thumb-hover: rgba(212, 46, 17, 0.8);
  --app-scrollbar-thumb-active: #d42e11;
  --app-scrollbar-track: #f0f0f0;

  /* Splash */
  --app-splash-color: #ff6600;

  /* Font */
  --app-font: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

body,
html {
  margin: 0;
  font-family: var(--app-font) !important;
  height: 100%;
  overflow: hidden;
}

/* RTL font override for Persian/Arabic */
[dir="rtl"] body,
[dir="rtl"] html,
[dir="rtl"] .dx-widget {
  font-family: 'IRANSans', 'Vazirmatn', 'Segoe UI', Tahoma, Arial, sans-serif !important;
}

.ltr {
  direction: ltr !important;
}

.left-align {
  text-align: left !important;
}

.dx-theme-material-typography,
.dx-theme-generic-typography,
.dx-widget,
.dx-toast-message,
.dx-toast-content,
.dx-widget input,
.dx-widget textarea {
  font-family: var(--app-font) !important;
}

#username-display {
  z-index: 9999; /* Bring it to the front */
  position: relative; /* Ensure it's on top */
  cursor: pointer;
}

.footer {
  position: fixed;
  text-align: start;
  padding: 0px 5px;
  background-color: var(--app-footer-bg);
  position: absolute;
  bottom: 0;
  inset-inline-end: 0;
  width: 100%;
  font-size: 12px;
  color: var(--app-text-secondary);
  height: 30px;
  border-top: 1px solid var(--app-border-light);
}

.footer p {
  margin: 0;
  padding: 7px;
}

.footer-content {
  display: flex;
  align-items: center; /* Vertically align logo and text */
}

.footer-logo {
  height: 25px;
  margin-right: 10px; /* Space between the logo and the text */
}

.dx-drawer-panel-content {
  padding-bottom: 30px; /* Adjust for footer height */
}

.softwareTitle {
  margin: -40px 40px;
  font-weight: bolder;
  font-size: 18px;
  line-height: 0;
}

.softwareTitle img {
  height: 30px;
  width: auto;
  vertical-align: middle;
  mix-blend-mode: multiply;
}

/* All non-amber themes have dark topbar - show white logo */
html[data-apx-theme]:not([data-apx-theme="amber"]) .softwareTitle img {
  filter: invert(1) grayscale(1) brightness(5);
  mix-blend-mode: screen;
}

.demo-container {
  overflow: visible;
  height: 100%;
}

.flex-container {
  display: flex;
  flex-direction: column;
}

.dx-drawer-content {
  display: flex;
}

#topbar {
  background: var(--app-topbar-bg) !important;
  color: var(--app-topbar-fg) !important;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15) !important;
  min-height: 60px;
  z-index: 1500;
}

#topbar .softwareTitle {
  color: var(--app-topbar-fg) !important;
}

#topbar .dx-icon-menu::before {
  color: var(--app-topbar-fg) !important;
}

#topbar #username-display {
  color: var(--app-topbar-fg) !important;
}

#topbar .dx-icon-bell::before {
  color: var(--app-topbar-fg) !important;
}

/* Settings gear button – match topbar text */
#topbar #theme-picker .dx-buttongroup,
#topbar #theme-picker .dx-dropdownbutton,
#topbar #theme-picker .dx-button {
  background: transparent !important;
  border: none !important;
}
#topbar #theme-picker .dx-button-content,
#topbar #theme-picker .dx-icon {
  color: var(--app-topbar-fg) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) #topbar #theme-picker .dx-icon {
  filter: brightness(0) invert(1);
  opacity: 0.85;
}

/* Settings panel (popover) */
.settings-panel {
  padding: 4px 0;
}
.settings-section {
  padding: 6px 12px;
}
.settings-section-title {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--app-text-muted, #888);
  margin-bottom: 8px;
}
.settings-theme-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
}
.settings-theme-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 6px;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.15s;
}
.settings-theme-item:hover {
  background: var(--app-surface-hover, rgba(0,0,0,0.05));
}
.settings-theme-item.active .settings-theme-label {
  font-weight: 600;
}
.settings-theme-label {
  font-size: 12px;
  color: var(--app-text, #333);
}
.settings-divider {
  border: none;
  border-top: 1px solid var(--app-border-light, rgba(0,0,0,0.1));
  margin: 6px 12px;
}
#settings-popover .dx-popover-content {
  padding: 0 !important;
}
#settings-popover .dx-overlay-content {
  border-radius: 10px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.18);
}

.dx-accordion-item-title {
  background: var(--app-header-bg) !important;
  color: var(--app-header-fg) !important;
}

.dx-accordion-item.dx-state-hover > .dx-accordion-item-title,
.dx-accordion-item.dx-state-active > .dx-accordion-item-title,
.dx-accordion-item.dx-state-focused > .dx-accordion-item-title {
  background: var(--app-header-bg) !important;
  color: var(--app-header-fg) !important;
  filter: brightness(1.1);
}

.dx-accordion-item {
  box-shadow: none !important;
}

/* Amber-specific navigation surfaces */
html[data-apx-theme="amber"] .dx-drawer-panel-content {
  background-color: #fff !important;
}

html[data-apx-theme="amber"] .dx-accordion-item-title {
  background: #f5f5f5 !important;
  color: var(--app-header-fg, #333) !important;
}

html[data-apx-theme="amber"] .dx-accordion-item.dx-state-hover > .dx-accordion-item-title,
html[data-apx-theme="amber"] .dx-accordion-item.dx-state-active > .dx-accordion-item-title,
html[data-apx-theme="amber"] .dx-accordion-item.dx-state-focused > .dx-accordion-item-title {
  background: #ededed !important;
  filter: none !important;
}

html[data-apx-theme="amber"] .dx-accordion-item-opened > .dx-accordion-item-title {
  background: #e5e5e5 !important;
  color: var(--app-header-fg, #333) !important;
}

.versionBox {
  position: absolute;
  bottom: 0;
  width: 276px;
  height: 97px;
  font-size: smaller;
  opacity: 0.7;
  box-shadow: -5px 0px 8px -5px rgba(0, 0, 0, 0.1);
}

.shadow-sm {
  -webkit-box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075) !important;
  box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075) !important;
}

[dir="ltr"] .dx-drawer-panel-content, [dir="rtl"] .sidebar {
  box-shadow: 5px -4px 8px -5px rgba(0, 0, 0, 0.1);
}

[dir="rtl"] .dx-drawer-panel-content, [dir="ltr"] .sidebar {
  box-shadow: -5px -4px 8px -5px rgba(0, 0, 0, 0.1);
}
.padding-16 {
  padding: 16px;
}

.padding-8 {
  padding: 12px;
}

.padding-4 {
  padding: 4px;
}

.dx-treeview-item {
  padding: 5px 1px !important;
}

.dx-datagrid > .dx-datagrid-headers {
  background: var(--app-header-bg) !important;
  color: var(--app-header-fg) !important;
}

.dx-header-row {
  background: var(--app-header-bg) !important;
  color: var(--app-header-fg) !important;
}

.dx-header-row .dx-datagrid-text-content {
  color: var(--app-header-fg) !important;
}

.dx-header-row .dx-column-indicators .dx-sort {
  color: var(--app-header-fg) !important;
}

.dx-datagrid-headers .dx-header-filter {
  color: var(--app-header-fg) !important;
}

/* Page toolbar (listview/detailview action bar) - NOT topbar, NOT popups */
.dx-toolbar {
  background: var(--app-header-bg) !important;
  color: var(--app-header-fg) !important;
}

.dx-toolbar .dx-button-mode-text .dx-icon {
  color: var(--app-header-fg) !important;
}

.dx-toolbar .dx-toolbar-label {
  color: var(--app-header-fg) !important;
}

/* Topbar toolbar stays transparent (inherits topbar gradient) */
#topbar .dx-toolbar {
  background-color: transparent !important;
  color: var(--app-topbar-fg) !important;
}

#topbar .dx-toolbar .dx-button-mode-text .dx-icon {
  color: var(--app-topbar-fg) !important;
}

/* Popup/overlay toolbars stay neutral */
.dx-popup-wrapper .dx-toolbar,
.dx-overlay-content .dx-toolbar {
  background-color: var(--app-card-bg) !important;
  color: var(--app-text) !important;
}

.dx-popup-wrapper .dx-toolbar .dx-button-mode-text .dx-icon,
.dx-overlay-content .dx-toolbar .dx-button-mode-text .dx-icon {
  color: var(--app-text-secondary) !important;
}

/* Sidebar drawer panel */
.dx-drawer-panel-content {
  background-color: var(--app-sidebar-bg, var(--app-surface)) !important;
}

.dx-accordion-item-title {
  font-size: 16px !important;
}

/* #hamburger {
  padding-top: 8px;

} */

.dx-treeview-node.dx-state-selected > .dx-treeview-item,
.dx-treeview
  .dx-treeview-node:not(.dx-treeview-item-with-checkbox).dx-state-selected
  > .dx-treeview-item {
  background-color: var(--selectedBackColor);
  color: white;
}

.dx-tabpanel-tabs-position-top.dx-state-focused
  .dx-tabpanel-tab.dx-state-disabled:not(.dx-state-focused) {
  -webkit-border-after: 1px none !important;
  border-block-end: 1px none !important;
}

.dx-tabpanel-tabs-position-bottom.dx-state-focused
  .dx-tabpanel-tab.dx-state-disabled:not(.dx-state-focused) {
  -webkit-border-after: 1px solid var(--selectedBackColor);
  border-block-end: 1px solid var(--selectedBackColor);
}

/*EasyUI Tab Color*/
.tabs li.tabs-selected .tabs-inner {
  color: var(--selectedBackColor) !important;
  border-bottom: 2px solid var(--selectedBackColor) !important;
}
.tabs {
  width: 100% !important;
}

[dir="rtl"] .tabs li .tabs-close {
  left: 0px !important;
  right: auto !important;
}

.tabs-closable {
  padding-right: 18px !important;
}

.tabs-inner:hover {
  background: var(--app-surface) !important;
  border-bottom: 2px solid lightgray !important;
  border-radius: 0 !important;
}

.tabs-tool {
  border-width: 0 0 1px 0 !important;
}

.tab-icon-refresh {
  background-image: url("../image/system/Action_Refresh.svg"); /* Adjust the path */
  background-repeat: no-repeat;
  display: inline-block;
  width: 16px; /* Adjust as needed */
  height: 16px; /* Adjust as needed */
  vertical-align: middle;
}

/* Remove the focus outline (blue border) */
#tab-tools .easyui-linkbutton:focus {
  outline: none;
  box-shadow: none;
}

.tabs-selected .tabs-icon {
  color: var(--tabIconSelected);
}

.tabs-selected .tabs-title {
  color: var(--tabTextSelectedColor);
}

/*.tabs-title.tabs-with-icon {
	 color: var(--tabTextColor); 
}
*/

.dx-datagrid-rowsview .dx-selection.dx-row:not(.dx-row-focused):hover > td,
.dx-datagrid-rowsview .dx-selection.dx-row:not(.dx-row-focused):hover > tr > td,
.dx-datagrid-rowsview .dx-selection.dx-row:not(.dx-row-focused) > td,
.dx-datagrid-rowsview .dx-selection.dx-row:not(.dx-row-focused) > tr > td {
  background-color: var(--selectedBackColor) !important;
  color: var(--selectedForeColor) !important;
}

.dx-texteditor.dx-state-active.dx-editor-filled,
.dx-texteditor.dx-state-active.dx-editor-outlined,
.dx-texteditor.dx-state-active.dx-editor-underlined,
.dx-texteditor.dx-state-focused.dx-editor-filled,
.dx-texteditor.dx-state-focused.dx-editor-outlined,
.dx-texteditor.dx-state-focused.dx-editor-underlined {
  border-color: var(--selectedBackColor) !important;
}

.dx-popup-wrapper .dx-state-focused.dx-overlay-content {
  border: 1px solid var(--selectedBackColor) !important;
}

.dx-icon-clear {
  color: lightgray !important;
}

.dx-dialog-message {
  font-family: var(--app-font) !important;
}

.my-custom-theme .dx-button .dx-button-content {
  background-color: var(
    --selectedBackColor
  ) !important; /* Use !important to ensure override */
}

.icon-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
  gap: 10px;
  padding: 10px;
}
.icon-item {
  text-align: center;
  cursor: pointer;
  padding: 5px;
  border: 1px solid transparent;
  transition: border-color 0.3s ease;
}
.icon-item:hover {
  border-color: #ccc;
}
.icon-item i {
  font-size: 24px;
  display: block;
}
.icon-item span {
  font-size: 12px;
  display: block;
  margin-top: 5px;
}

.panel-body.panel-body-noheader.panel-body-noborder {
  overflow-y: hidden !important;
}

.dx-icon-spindown:before {
  color: var(--app-text, #333) !important;
}

.burlywood-icon .dx-icon {
  color: var(--iconThemeColor) !important;
}

.black-icon .dx-icon {
  color: black !important;
}

.orange-icon .dx-icon {
  color: #fe7109 !important;
}

.cornflowerblue-icon .dx-icon {
  color: cornflowerblue !important;
}

.darkgray-icon .dx-icon {
  color: darkgray !important;
}

.monacoEditorContainer {
  direction: ltr !important;
}

.dx-button-mode-text .dx-icon {
  color: darkgray !important;
}

.dx-treeview-item .dx-treeview-item-content .dx-icon {
  font-size: 20px !important;
}

.dx-loadindicator-icon {
  inset-inline-start: 0 !important;
  width: 100% !important;
}

.custom-focused-cell {
  border: 2px dotted darkgray !important; /* Highlight with a border */
}

.dx-button-mode-contained.dx-button-default.dx-state-focused {
  background-color: var(--selectedBackColor) !important;
}

.dx-button-mode-contained.dx-button-default.dx-state-hover {
  background-color: var(--selectedHover) !important;
}

.dx-button-mode-contained.dx-button-default {
  background-color: var(--selectedBackColor) !important;
  border-color: transparent;
  color: #fff;
}

.custom-toast {
  font-size: 14px;
  font-weight: 100;
}

.dx-toast-error {
  background-color: #e81123 !important;
}

.dx-button-has-icon .dx-button-content,
.dx-button-has-text .dx-button-content {
  padding-block: 6px !important;
}

.dx-icon-column-chooser {
  color: var(--iconThemeColor) !important;
}

.dx-icon-export {
  color: var(--iconThemeColor) !important;
}

.dx-icon-xlsxfile {
  color: green !important;
}

.dx-icon-pdffile {
  color: #db0001 !important;
}

.dx-icon-exportselected {
  color: var(--iconThemeColor) !important;
}

#splash-screen {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--app-bg);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 10000;
}

.logo {
  position: relative;
  display: flex;
  flex-direction: column; /* Stack circle and text vertically */
  align-items: center; /* Align content in center */
}

.circle {
  position: relative;
  width: 100px;
  height: 100px;
  border-radius: 50%;
  background-color: var(--app-splash-color);
  display: flex;
  justify-content: center;
  align-items: center;
  color: white;
  font-size: 16px;
  font-weight: bold;
}

/* Outer animated circle */
.circle::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 120px;
  height: 120px;
  border: 5px solid var(--app-splash-color);
  border-radius: 50%;
  border-left-color: transparent;
  border-right-color: transparent;
  animation: spin 1.5s linear infinite;
  transform: translate(-50%, -50%);
}

/* Text below the circle */
.logo p {
  margin-top: 30px;
  font-size: 16px;
  font-weight: bold;
  text-align: center;
}

/* Spin animation for the outer circle */
@keyframes spin {
  0% {
    transform: translate(-50%, -50%) rotate(0deg); /* Ensure translate is there */
  }
  100% {
    transform: translate(-50%, -50%) rotate(360deg); /* Complete 360-degree spin */
  }
}

/* Scrollbar styles for WebKit browsers (Chrome, Safari, Edge) */
::-webkit-scrollbar {
  width: 10px; /* Width of the scrollbar */
  height: 10px; /* Height for horizontal scroll */
}

::-webkit-scrollbar-track {
  background: var(--app-scrollbar-track);
  border-radius: 5px;
}

::-webkit-scrollbar-thumb {
  background-color: var(--app-scrollbar-thumb);
  border-radius: 5px;
  border: 2px solid transparent;
  background-clip: content-box;
}

::-webkit-scrollbar-thumb:hover {
  background-color: var(--app-scrollbar-thumb-hover);
}

::-webkit-scrollbar-thumb:active {
  background-color: var(--app-scrollbar-thumb-active);
}

/* Scrollbar styling for Firefox */
body {
  scrollbar-width: thin; /* Thin scrollbar */
  /* scrollbar-color: #c4c4c4 #f0f0f0; Thumb color and track color */
}

/* Container or grid scroll area styling */
.scroll-container {
  max-height: 400px;
  overflow-y: auto;
  overflow-x: hidden;
  border: 1px solid var(--app-border);
  padding: 10px;
  background-color: var(--app-surface);
}

/* =============================================
   DX Accent Color Overrides (theme-aware)
   ============================================= */

/* SVG icons using currentColor inherit this accent */
.dx-button .dx-icon svg [fill="currentColor"] {
  fill: currentColor;
}

[data-theme="dark"] .burlywood-icon .dx-button-content {
  color: var(--iconThemeColor) !important;
}

.dx-checkbox-checked .dx-checkbox-icon,
.dx-checkbox-indeterminate .dx-checkbox-icon {
  color: var(--app-accent) !important;
}

.dx-switch-on-value .dx-switch-handle::before {
  background-color: var(--app-accent) !important;
}

.dx-texteditor.dx-state-focused .dx-texteditor-label {
  color: var(--app-accent) !important;
}

.dx-theme-accent-as-text-color {
  color: var(--app-accent) !important;
}

.dx-theme-accent-as-background-color {
  background-color: var(--app-accent) !important;
}

.dx-theme-accent-as-border-color {
  border-color: var(--app-accent) !important;
}

.dx-list:not(.dx-list-select-decorator-enabled) .dx-list-item.dx-state-focused {
  background-color: var(--app-accent) !important;
  color: var(--app-accent-fg) !important;
}

.dx-tab.dx-tab-selected::after {
  border-bottom-color: var(--app-accent) !important;
}

.dx-loadindicator-segment-inner {
  border-color: var(--app-accent) var(--app-accent) transparent !important;
}

/* =============================================
   Dark Mode (Slate Theme) Overrides
   Overrides both DX darkmoon (#465672) and DX material.orange.dark
   backgrounds to use our Slate palette (#1e1e2e / #2a2a3c).
   ============================================= */

/* --- Page & body --- */
[data-theme="dark"] body,
[data-theme="dark"] html {
  background-color: var(--app-bg) !important;
  color: var(--app-text) !important;
}

[data-theme="dark"] #splash-screen {
  background-color: var(--app-bg) !important;
}

[data-theme="dark"] .logo p {
  color: var(--app-text) !important;
}

/* --- Override darkmoon/material-dark base typography bg --- */
[data-theme="dark"] .dx-theme-generic-typography,
[data-theme="dark"] .dx-theme-material-typography {
  background-color: var(--app-bg) !important;
  color: var(--app-text) !important;
}

/* --- Topbar (index.html shell) --- */
[data-theme="dark"] #topbar {
  box-shadow: 0 1px 0 var(--app-border) !important;
}

[data-theme="dark"] .dx-icon-bell::before {
  color: var(--app-text) !important;
}

/* --- Drawer / Sidebar --- */
[data-theme="dark"] .dx-drawer-panel-content {
  background-color: var(--app-bg) !important;
  box-shadow: 1px 0 0 var(--app-border) !important;
}

[data-theme="dark"] .dx-drawer-content {
  background-color: var(--app-bg) !important;
}

/* ============================
   Docked AI Assistant Panel
   ============================ */
.dx-drawer-content {
  flex-direction: row;
}

#contentBox {
  flex: 1;
  min-width: 0;
  overflow: hidden;
}

#ai-dock {
  width: 380px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  border-left: 1px solid var(--app-border, #dee1e3);
  background: var(--app-bg, #f8f9fa);
  font-family: 'Inter', 'Segoe UI', sans-serif;
  height: calc(100vh - 90px);
  overflow: hidden;
}

.ai-dock-header {
  padding: 12px 16px;
  border-bottom: 1px solid var(--app-border, #dee1e3);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: linear-gradient(135deg, #0f1f2e, #1f3a56);
  flex-shrink: 0;
}

.ai-dock-title {
  color: #ecf3ff;
  font-weight: 600;
  font-size: 13px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.ai-dock-close {
  background: none;
  border: none;
  color: #9eb0cf;
  cursor: pointer;
  font-size: 20px;
  padding: 0 4px;
  line-height: 1;
}

.ai-dock-close:hover {
  color: #ecf3ff;
}

.ai-dock-messages {
  flex: 1;
  overflow-y: auto;
  padding: 16px;
}

.ai-dock-messages::-webkit-scrollbar {
  width: 5px;
}

.ai-dock-messages::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0.15);
  border-radius: 3px;
}

.ai-dock-welcome {
  text-align: center;
  padding: 32px 16px;
  color: var(--app-text-secondary, #6c757d);
}

.ai-dock-actions {
  padding: 12px 16px;
  border-top: 1px solid var(--app-border, #dee1e3);
  max-height: 200px;
  overflow-y: auto;
  flex-shrink: 0;
}

.ai-dock-img-preview {
  padding: 8px 16px;
  border-top: 1px solid var(--app-border, #dee1e3);
  flex-shrink: 0;
}

.ai-dock-input-area {
  padding: 12px 16px;
  border-top: 1px solid var(--app-border, #dee1e3);
  display: flex;
  gap: 8px;
  align-items: flex-end;
  flex-shrink: 0;
}

.ai-dock-attach {
  cursor: pointer;
  padding: 6px;
  display: flex;
  align-items: center;
  color: var(--app-text-secondary, #6c757d);
  opacity: 0.7;
}

.ai-dock-attach:hover {
  opacity: 1;
}

#ai-dock-input {
  flex: 1;
  resize: none;
  border: 1px solid var(--app-border, #dee1e3);
  border-radius: 8px;
  padding: 8px 12px;
  font-size: 13px;
  font-family: inherit;
  max-height: 80px;
  background: var(--app-card-bg, #fff);
  color: var(--app-text, #333);
}

#ai-dock-input:focus {
  outline: none;
  border-color: #d27614;
}

#ai-dock-send {
  background: #d27614;
  border: none;
  border-radius: 8px;
  padding: 8px 14px;
  color: #fff;
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
}

#ai-dock-send:hover {
  background: #c06a10;
}

#ai-dock-send:disabled {
  opacity: 0.6;
  cursor: default;
}

.ai-dock-msg {
  margin-bottom: 12px;
  display: flex;
  flex-direction: column;
}

.ai-dock-msg.user {
  align-items: flex-end;
}

.ai-dock-msg.assistant {
  align-items: flex-start;
}

.ai-dock-bubble {
  padding: 10px 14px;
  max-width: 88%;
  font-size: 13px;
  line-height: 1.55;
  word-break: break-word;
}

.ai-dock-bubble.user {
  background: linear-gradient(135deg, #d27614, #c06a10);
  color: #fff;
  border-radius: 12px 12px 2px 12px;
}

.ai-dock-bubble.assistant {
  background: var(--app-surface, #f0f1f3);
  color: var(--app-text, #333);
  border-radius: 12px 12px 12px 2px;
  border: 1px solid var(--app-border, #dee1e3);
}

.ai-dock-action-card {
  background: var(--app-surface, #f0f1f3);
  border: 1px solid var(--app-border, #dee1e3);
  border-radius: 8px;
  padding: 10px 12px;
  margin-bottom: 6px;
  font-size: 12px;
}

.ai-dock-action-card b {
  color: #d27614;
}

.ai-dock-typing {
  display: flex;
  gap: 4px;
  padding: 2px 0;
}

.ai-dock-typing span {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--app-text-secondary, #999);
  animation: aiDockBounce 1.4s infinite ease-in-out;
}

.ai-dock-typing span:nth-child(2) { animation-delay: .2s; }
.ai-dock-typing span:nth-child(3) { animation-delay: .4s; }

@keyframes aiDockBounce {
  0%, 80%, 100% { transform: scale(0); }
  40% { transform: scale(1); }
}

/* Dark theme overrides */
[data-theme="dark"] #ai-dock {
  background: #0b1424;
  border-left-color: rgba(172, 191, 228, 0.15);
}

[data-theme="dark"] .ai-dock-bubble.assistant {
  background: rgba(255, 255, 255, 0.06);
  color: #cad8f0;
  border-color: rgba(172, 191, 228, 0.1);
}

[data-theme="dark"] #ai-dock-input {
  background: rgba(255, 255, 255, 0.04);
  color: #ecf3ff;
  border-color: rgba(172, 191, 228, 0.2);
}

[data-theme="dark"] .ai-dock-action-card {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(172, 191, 228, 0.15);
}

[data-theme="dark"] .ai-dock-welcome {
  color: #9eb0cf;
}

[data-theme="dark"] .ai-dock-messages::-webkit-scrollbar-thumb {
  background: rgba(158, 176, 207, 0.3);
}

/* AI Dock FAB */
#apx-ai-dock-fab {
  position: fixed;
  bottom: 10px;
  right: 24px;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  --apx-fab-primary: #ffffff;
  --apx-fab-secondary: rgba(255, 255, 255, 0.78);
  transition: right 0.35s cubic-bezier(0.4, 0, 0.2, 1), transform 0.2s ease, background 0.45s ease, box-shadow 0.45s ease;
}

#apx-ai-dock-fab:hover {
  transform: scale(1.08);
}

#apx-ai-dock-fab .apx-sparkle-icon {
  transform-origin: center;
  will-change: transform;
  backface-visibility: hidden;
}

#apx-ai-dock-fab .apx-sparkle-primary,
#apx-ai-dock-fab .apx-sparkle-secondary {
  transition: fill 0.45s ease, opacity 0.45s ease;
}

#apx-ai-dock-fab .apx-sparkle-primary {
  fill: var(--apx-fab-primary);
}

#apx-ai-dock-fab .apx-sparkle-secondary {
  fill: var(--apx-fab-secondary);
}

#apx-ai-dock-fab.apx-fab-closed {
  --apx-fab-primary: #ffffff;
  --apx-fab-secondary: rgba(255, 255, 255, 0.76);
  background: linear-gradient(135deg, var(--app-accent-dark, #d27614), var(--app-accent, #fe7109));
  box-shadow: 0 4px 16px var(--app-accent-shadow, rgba(210, 118, 20, 0.35));
}

#apx-ai-dock-fab.apx-fab-open {
  --apx-fab-primary: #ffffff;
  --apx-fab-secondary: rgba(255, 255, 255, 0.82);
  background: var(--app-dock-header-bg, linear-gradient(135deg, #173b63, #0d8fad));
  box-shadow: 0 4px 16px rgba(13, 143, 173, 0.42);
}

/* Open: full CCW 360° synced with panel slide */
#apx-ai-dock-fab.apx-fab-spin-open .apx-sparkle-icon {
  animation: apxFabOpen 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Close: full CW 360° synced with panel slide */
#apx-ai-dock-fab.apx-fab-spin-close .apx-sparkle-icon {
  animation: apxFabClose 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

@keyframes apxFabOpen {
  from { transform: rotate(0deg); }
  to   { transform: rotate(-360deg); }
}

@keyframes apxFabClose {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

[data-theme="dark"] .dx-accordion-item {
  background-color: var(--app-bg) !important;
  border-color: var(--app-border) !important;
}

/* accordion-item-title handled by --app-header-bg/--app-header-fg vars */

[data-theme="dark"] .dx-treeview-item {
  color: var(--app-text) !important;
}

[data-theme="dark"] .versionBox {
  background-color: var(--app-bg) !important;
  color: var(--app-text-muted) !important;
  box-shadow: none !important;
}

/* --- DX Toolbar: override darkmoon #465672 bg --- */
[data-theme="dark"] .dx-toolbar {
  background-color: transparent !important;
  color: var(--app-text) !important;
}

/* --- DX Editor Cell: override darkmoon #465672 bg --- */
[data-theme="dark"] .dx-editor-cell .dx-texteditor,
[data-theme="dark"] .dx-editor-cell .dx-texteditor .dx-texteditor-input {
  background: transparent !important;
}

/* --- DX DataGrid --- */
[data-theme="dark"] .dx-datagrid {
  background-color: var(--app-bg) !important;
}

[data-theme="dark"] .dx-datagrid-headers {
  background-color: var(--app-bg) !important;
  border-color: var(--app-border) !important;
}

/* dx-header-row handled by --app-header-bg/--app-header-fg vars */

[data-theme="dark"] .dx-datagrid-rowsview .dx-row {
  background-color: var(--app-bg) !important;
  color: var(--app-text) !important;
}

[data-theme="dark"] .dx-datagrid-rowsview .dx-row-alt > td {
  background-color: var(--app-surface) !important;
}

[data-theme="dark"] .dx-datagrid-borders > .dx-datagrid-header-panel,
[data-theme="dark"] .dx-datagrid-borders > .dx-datagrid-rowsview,
[data-theme="dark"] .dx-datagrid-borders > .dx-datagrid-headers {
  border-color: var(--app-border) !important;
}

[data-theme="dark"] .dx-datagrid .dx-column-lines > td {
  border-color: var(--app-border) !important;
}

[data-theme="dark"] .dx-datagrid .dx-row-lines > td {
  border-color: var(--app-border) !important;
}

/* --- DX Form --- */
[data-theme="dark"] .dx-form-group-caption {
  color: var(--app-text) !important;
}

[data-theme="dark"] .dx-field-item-label-text {
  color: var(--app-text-secondary) !important;
}

/* --- DX TextEditors --- */
[data-theme="dark"] .dx-texteditor {
  background-color: transparent !important;
  color: var(--app-text) !important;
}

[data-theme="dark"] .dx-texteditor-input {
  color: var(--app-text) !important;
}

[data-theme="dark"] .dx-texteditor-label {
  color: var(--app-text-muted) !important;
}

[data-theme="dark"] .dx-dropdowneditor-icon {
  color: var(--app-text-secondary) !important;
}

/* --- DX Popup / Overlay --- */
[data-theme="dark"] .dx-popup-wrapper .dx-overlay-content {
  background-color: var(--app-card-bg) !important;
  color: var(--app-text) !important;
}

[data-theme="dark"] .dx-popup-title {
  background-color: var(--app-surface) !important;
  color: var(--app-text) !important;
}

[data-theme="dark"] .dx-popup-bottom {
  background-color: var(--app-card-bg) !important;
}

/* --- DX Context Menu / DropDown --- */
[data-theme="dark"] .dx-context-menu {
  background-color: var(--app-card-bg) !important;
}

[data-theme="dark"] .dx-context-menu .dx-menu-item {
  color: var(--app-text) !important;
}

[data-theme="dark"] .dx-menu-item.dx-state-hover {
  background-color: var(--app-surface-hover) !important;
}

[data-theme="dark"] .dx-dropdownlist-popup-wrapper .dx-list {
  background-color: var(--app-card-bg) !important;
}

[data-theme="dark"] .dx-list-item {
  color: var(--app-text) !important;
}

/* --- Footer --- */
[data-theme="dark"] .footer {
  background-color: var(--app-bg) !important;
  color: var(--app-text-muted) !important;
  border-top-color: var(--app-border) !important;
}

[data-theme="dark"] .footer-content {
  color: var(--app-text-muted) !important;
}

/* --- EasyUI Tabs (non-DX) --- */
[data-theme="dark"] .tabs {
  border-color: var(--app-border) !important;
}

[data-theme="dark"] .tabs-header {
  background-color: transparent !important;
  border-color: var(--app-border) !important;
}

[data-theme="dark"] .tabs li .tabs-inner {
  background-color: transparent !important;
  border-color: transparent !important;
  color: var(--app-text-muted) !important;
}

[data-theme="dark"] .tabs-inner:hover {
  background: var(--app-surface) !important;
  border-bottom: 2px solid var(--app-text-muted) !important;
  border-color: transparent !important;
  border-bottom-color: var(--app-text-muted) !important;
}

[data-theme="dark"] .tabs li.tabs-selected .tabs-inner {
  background-color: transparent !important;
  color: var(--app-accent) !important;
}

[data-theme="dark"] .tabs-tool {
  background-color: transparent !important;
  border-color: var(--app-border) !important;
  border-color: var(--app-border) !important;
}

[data-theme="dark"] .tabs-close {
  filter: invert(0.7);
}

/* --- EasyUI Panels (non-DX) --- */
[data-theme="dark"] .panel-body {
  background-color: var(--app-bg) !important;
  color: var(--app-text) !important;
}

[data-theme="dark"] .panel-body.panel-body-noheader.panel-body-noborder {
  background-color: var(--app-bg) !important;
}

[data-theme="dark"] .panel {
  background-color: var(--app-bg) !important;
  border-color: var(--app-border) !important;
}

/* --- Scroll containers --- */
[data-theme="dark"] .scroll-container {
  background-color: var(--app-surface) !important;
  border-color: var(--app-border) !important;
}

/* --- Icons --- */
[data-theme="dark"] .dx-icon-spindown:before {
  color: var(--app-text-secondary) !important;
}

[data-theme="dark"] .dx-button-mode-text .dx-icon {
  color: var(--app-text-secondary) !important;
}

[data-theme="dark"] .dx-icon-clear {
  color: var(--app-text-muted) !important;
}

[data-theme="dark"] .black-icon .dx-icon {
  color: var(--app-text) !important;
}

/* --- Icon picker grid --- */
[data-theme="dark"] .icon-item {
  color: var(--app-text) !important;
}

[data-theme="dark"] .icon-item:hover {
  border-color: var(--app-border) !important;
}

/* --- Focused cell --- */
[data-theme="dark"] .custom-focused-cell {
  border-color: var(--app-text-muted) !important;
}

/* --- Kendo calendar --- */
[data-theme="dark"] .k-widget.k-calendar {
  background-color: var(--app-card-bg) !important;
  color: var(--app-text) !important;
  border-color: var(--app-border) !important;
}

/* --- Login page --- */
[data-theme="dark"] .login-container {
  background-color: var(--app-card-bg) !important;
  border-color: var(--app-border) !important;
  color: var(--app-text) !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4) !important;
}

[data-theme="dark"] .card-header {
  background-color: var(--app-surface) !important;
  border-bottom-color: var(--app-border) !important;
  color: var(--app-text) !important;
}

[data-theme="dark"] .card-body {
  color: var(--app-text) !important;
}

/* --- DX TabPanel (inside iframes) --- */
[data-theme="dark"] .dx-tabpanel > .dx-tabpanel-tabs .dx-tabs {
  background-color: transparent !important;
}

/* --- DX Accordion borders in darkmoon --- */
[data-theme="dark"] .dx-accordion {
  background-color: var(--app-bg) !important;
}

/* ============================================================
   Non-Amber Theme Polish
   ============================================================ */
html[data-apx-theme]:not([data-apx-theme="amber"]) {
  background: var(--app-bg) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) body {
  background: var(--app-bg) !important;
  color: var(--app-text) !important;
  position: relative;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-theme-generic-typography,
html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-theme-material-typography {
  background-color: var(--app-bg) !important;
  color: var(--app-text) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background: var(--app-shell-glow, none);
}

html[data-apx-theme]:not([data-apx-theme="amber"]) #topbar {
  border-bottom: 1px solid var(--app-topbar-border, var(--app-border-light)) !important;
  box-shadow: var(--app-panel-shadow, 0 10px 24px rgba(15, 23, 42, 0.16)) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-drawer-panel-content {
  border-inline-end: 1px solid var(--app-border) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-accordion-item {
  background: var(--app-accordion-bg, var(--app-toolbar-bg, var(--app-header-bg))) !important;
  border: none !important;
  border-radius: 0 !important;
  overflow: hidden;
  margin-block: 0;
  box-shadow: 0 8px 20px rgba(16, 24, 40, 0.12);
  transition: box-shadow 0.2s ease, border-color 0.2s ease;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-accordion-item.dx-state-hover {
  border-color: var(--app-accent-light, var(--app-accordion-border, var(--app-border))) !important;
  box-shadow: 0 12px 24px rgba(16, 24, 40, 0.14);
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-accordion-item-title {
  background: var(--app-accordion-bg, var(--app-toolbar-bg, var(--app-header-bg))) !important;
  color: var(--app-accordion-fg, var(--app-text, var(--app-header-fg))) !important;
  border: none !important;
  border-radius: 0 !important;
  font-weight: 600;
  letter-spacing: 0.1px;
  padding-block: 11px !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-accordion-item.dx-state-hover > .dx-accordion-item-title,
html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-accordion-item.dx-state-focused > .dx-accordion-item-title,
html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-accordion-item.dx-state-active > .dx-accordion-item-title {
  background: var(--app-accordion-hover-bg, var(--app-surface-hover)) !important;
  color: var(--app-accordion-fg, var(--app-text, var(--app-header-fg))) !important;
  filter: none !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-accordion-item-opened {
  box-shadow: 0 14px 28px rgba(16, 24, 40, 0.18);
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-accordion-item-opened > .dx-accordion-item-title {
  background: var(--app-accordion-open-bg, var(--app-grid-header-bg, var(--app-header-bg))) !important;
  color: var(--app-accordion-open-fg, var(--app-grid-header-fg, var(--app-header-fg))) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-accordion-item-body {
  background: var(--app-card-bg) !important;
  color: var(--app-text) !important;
  border-top: 1px solid var(--app-border-light, var(--app-border)) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-accordion-item-body .dx-treeview-item {
  color: var(--app-text-secondary) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-accordion-item-body .dx-treeview-node.dx-state-hover > .dx-treeview-item {
  background: var(--app-surface-hover) !important;
  color: var(--app-text) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-accordion-item-opened > .dx-accordion-item-title .dx-icon,
html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-accordion-item-title .dx-icon {
  color: inherit !important;
}

html[data-apx-theme="ocean"] .dx-toolbar,
html[data-apx-theme="navy"] .dx-toolbar,
html[data-apx-theme="emerald"] .dx-toolbar,
html[data-apx-theme="slate"] .dx-toolbar,
html[data-apx-theme="plum"] .dx-toolbar,
html[data-apx-theme="obsidian"] .dx-toolbar {
  background: var(--app-bg, var(--app-surface)) !important;
  color: var(--app-text, var(--app-text-secondary)) !important;
  border-bottom: none !important;
  box-shadow: none !important;
}

html[data-apx-theme="navy"][data-apx-theme="navy"] .dx-accordion-item-body {
  background: #edf3f8 !important;
  color: var(--app-text) !important;
}

html[data-apx-theme="navy"][data-apx-theme="navy"] .dx-drawer-panel-content .dx-toolbar {
  background: #edf3f8 !important;
}

html[data-apx-theme="navy"][data-apx-theme="navy"] .dx-datagrid-header-panel,
html[data-apx-theme="navy"][data-apx-theme="navy"] .dx-datagrid-group-panel {
  background: #1f3a56 !important;
  color: #ecf3ff !important;
}

html[data-apx-theme="navy"][data-apx-theme="navy"] .dx-datagrid-group-panel .dx-group-panel-message {
  color: rgba(236, 243, 255, 0.6) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-toolbar .dx-button-mode-text .dx-icon {
  color: var(--app-toolbar-icon, var(--app-text-secondary, var(--app-text))) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-toolbar .dx-toolbar-label,
html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-toolbar .dx-button-text {
  color: var(--app-text, var(--app-text-secondary)) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) #topbar .dx-toolbar {
  background: transparent !important;
  border-bottom: none !important;
  box-shadow: none !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-popup-wrapper .dx-toolbar,
html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-overlay-content .dx-toolbar {
  background: var(--app-card-bg) !important;
  border-bottom: 1px solid var(--app-border) !important;
  box-shadow: none !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid {
  border: none !important;
  border-radius: 0 !important;
  overflow: hidden;
  background-color: var(--app-card-bg) !important;
  box-shadow: none !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid > .dx-datagrid-headers,
html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-header-row {
  background: var(--app-grid-header-bg, var(--app-header-bg)) !important;
  color: var(--app-grid-header-fg, var(--app-header-fg)) !important;
  border-bottom: 1px solid var(--app-toolbar-border, var(--app-border)) !important;
  box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.08), inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid .dx-datagrid-header-panel,
html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid .dx-datagrid-group-panel {
  background: var(--app-bg, var(--app-surface)) !important;
  color: var(--app-text-secondary, var(--app-text)) !important;
  border-bottom: 1px solid var(--app-border-light, var(--app-border)) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid .dx-datagrid-header-panel .dx-toolbar {
  background: transparent !important;
  border-bottom: none !important;
  box-shadow: none !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid .dx-group-panel-message {
  color: var(--app-text-muted, var(--app-text-secondary)) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-header-row > td {
  border-inline-end: 1px solid var(--app-border-light, var(--app-border)) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-header-row .dx-datagrid-text-content,
html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-header-row .dx-column-indicators .dx-sort,
html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid-headers .dx-header-filter {
  color: var(--app-grid-header-fg, var(--app-header-fg)) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid .dx-datagrid-filter-row > td {
  background: var(--app-surface, var(--app-card-bg)) !important;
  color: var(--app-text) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid .dx-datagrid-filter-row .dx-texteditor {
  background: var(--app-card-bg) !important;
  border: 1px solid var(--app-border-light, var(--app-border)) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid .dx-datagrid-filter-row .dx-texteditor-input,
html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid .dx-datagrid-filter-row .dx-placeholder {
  color: var(--app-text, var(--app-text-secondary)) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid .dx-datagrid-filter-row .dx-icon,
html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid .dx-datagrid-filter-row .dx-dropdowneditor-icon {
  color: var(--app-text-secondary, var(--app-text)) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid-rowsview .dx-row-alt > td {
  background-color: var(--app-grid-alt, var(--app-surface)) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid-rowsview .dx-row.dx-state-hover > td {
  background-color: var(--app-grid-hover, var(--app-surface-hover)) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid-rowsview .dx-selection.dx-row:not(.dx-row-focused) > td,
html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid-rowsview .dx-selection.dx-row:not(.dx-row-focused) > tr > td {
  background-color: var(--selectedBackColor) !important;
  color: var(--selectedForeColor) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid-rowsview .dx-selection.dx-row:not(.dx-row-focused):hover > td,
html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid-rowsview .dx-selection.dx-row:not(.dx-row-focused):hover > tr > td {
  background-color: var(--selectedHover, var(--selectedBackColor)) !important;
  color: var(--selectedForeColor) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid .dx-datagrid-total-footer,
html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid .dx-datagrid-total-footer .dx-row > td {
  background: var(--app-surface, var(--app-card-bg)) !important;
  color: var(--app-text-secondary, var(--app-text)) !important;
  border-top: 1px solid var(--app-border, var(--app-border-light)) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-summary-item {
  color: var(--app-text, var(--app-text-secondary)) !important;
}

html[data-apx-theme="ocean"] .dx-datagrid > .dx-datagrid-headers,
html[data-apx-theme="azure"] .dx-datagrid > .dx-datagrid-headers,
html[data-apx-theme="ocean"] .dx-datagrid .dx-header-row,
html[data-apx-theme="azure"] .dx-datagrid .dx-header-row,
html[data-apx-theme="ocean"] .dx-datagrid .dx-header-row > td,
html[data-apx-theme="azure"] .dx-datagrid .dx-header-row > td {
  background: #1f3a56 !important;
  color: #ecf3ff !important;
}

html[data-apx-theme="ocean"] .dx-header-row .dx-datagrid-text-content,
html[data-apx-theme="azure"] .dx-header-row .dx-datagrid-text-content,
html[data-apx-theme="ocean"] .dx-header-row .dx-column-indicators .dx-sort,
html[data-apx-theme="azure"] .dx-header-row .dx-column-indicators .dx-sort,
html[data-apx-theme="ocean"] .dx-datagrid-headers .dx-header-filter,
html[data-apx-theme="azure"] .dx-datagrid-headers .dx-header-filter {
  color: #ecf3ff !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .dx-button-mode-contained.dx-button-default {
  border-color: transparent !important;
  box-shadow: 0 8px 20px var(--app-accent-shadow, rgba(0, 0, 0, 0.2));
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .tabs-header {
  background-color: var(--app-bg) !important;
  border-color: var(--app-border) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .tabs {
  border-color: var(--app-border) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .tabs li .tabs-inner {
  background-color: transparent !important;
  border-color: transparent !important;
  color: var(--app-text-muted) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .tabs li.tabs-selected .tabs-inner {
  background: var(--app-card-bg) !important;
  box-shadow: 0 6px 16px rgba(16, 24, 40, 0.1);
  color: var(--app-accent) !important;
  border-color: transparent !important;
  border-bottom: 2px solid var(--app-accent) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .tabs-tool {
  background-color: transparent !important;
  border-color: var(--app-border) !important;
}

/* Obsidian: override DX material orange accents with gold */
html[data-apx-theme="obsidian"] .dx-texteditor-input-container::after {
  border-bottom-color: var(--app-accent) !important;
}

html[data-apx-theme="obsidian"] .dx-state-focused.dx-texteditor::after,
html[data-apx-theme="obsidian"] .dx-texteditor.dx-state-focused .dx-texteditor-input-container::after {
  border-bottom-color: var(--app-accent) !important;
}

html[data-apx-theme="obsidian"] .dx-list-item.dx-state-active,
html[data-apx-theme="obsidian"] .dx-list-item.dx-state-focused {
  background-color: var(--app-accent-light) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .login-container {
  background: var(--app-login-card-bg, var(--app-card-bg)) !important;
  border-color: var(--app-border) !important;
  border-radius: 14px !important;
  box-shadow: var(--app-login-shadow, 0 24px 48px rgba(16, 24, 40, 0.24)) !important;
  backdrop-filter: blur(6px);
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .card-header {
  background: var(--app-toolbar-bg, var(--app-surface)) !important;
  border-bottom-color: var(--app-border) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .form-instructions {
  color: var(--app-text-secondary) !important;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .ai-dock-header {
  background: var(--app-dock-header-bg, var(--app-topbar-bg));
  border-bottom: 1px solid var(--app-toolbar-border, var(--app-border));
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .ai-dock-title {
  color: var(--app-topbar-fg);
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .ai-dock-close {
  color: var(--app-topbar-fg);
  opacity: 0.72;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .ai-dock-close:hover {
  opacity: 1;
}

html[data-apx-theme]:not([data-apx-theme="amber"]) .ai-dock-action-card b {
  color: var(--app-accent);
}

html[data-apx-theme]:not([data-apx-theme="amber"]) #ai-dock-send {
  background: linear-gradient(135deg, var(--app-accent-dark), var(--app-accent));
  box-shadow: 0 10px 22px var(--app-accent-shadow, rgba(0, 0, 0, 0.2));
}

html[data-apx-theme]:not([data-apx-theme="amber"]) #ai-dock-send:hover {
  background: linear-gradient(135deg, var(--app-accent-hover), var(--app-accent-dark));
}
