:root {
    --ao-btn-radius: 0.75rem;
    --ao-btn-shadow: 0 1px 2px rgba(15, 23, 42, 0.16);
    --ao-btn-height: 2.25rem;
    --ao-btn-font-size: 0.875rem;
    --ao-btn-padding-y: 0.35rem;
    --ao-btn-padding-x: 0.85rem;

    /* Premium Teal - Single unified color for light mode */
    --ao-btn-primary-bg: #0d9488;
    --ao-btn-primary-border: #0d9488;
    --ao-btn-primary-fg: #ffffff;
    --ao-btn-primary-hover-bg: #0f766e;
    --ao-btn-primary-hover-border: #0f766e;
    --ao-btn-primary-active-bg: #115e59;
    --ao-btn-primary-active-border: #115e59;
    --ao-btn-primary-ring: rgba(13, 148, 136, 0.4);
    --ao-btn-focus-ring: rgba(13, 148, 136, 0.35);

    /* Add — emerald glow (parallel to refresh style) */
    --ao-btn-add-bg: rgba(16, 185, 129, 0.10);
    --ao-btn-add-border: rgba(16, 185, 129, 0.30);
    --ao-btn-add-fg: #065f46;
    --ao-btn-add-hover-bg: rgba(16, 185, 129, 0.16);
    --ao-btn-add-hover-border: rgba(16, 185, 129, 0.44);
    --ao-btn-add-active-bg: rgba(16, 185, 129, 0.22);
    --ao-btn-add-active-border: rgba(16, 185, 129, 0.52);
    --ao-btn-add-ring: rgba(16, 185, 129, 0.36);

    /* Save/Edit — cobalt glow */
    --ao-btn-edit-bg: rgba(59, 130, 246, 0.10);
    --ao-btn-edit-border: rgba(59, 130, 246, 0.30);
    --ao-btn-edit-fg: #1e3a8a;
    --ao-btn-edit-hover-bg: rgba(59, 130, 246, 0.16);
    --ao-btn-edit-hover-border: rgba(59, 130, 246, 0.44);
    --ao-btn-edit-active-bg: rgba(59, 130, 246, 0.22);
    --ao-btn-edit-active-border: rgba(59, 130, 246, 0.52);
    --ao-btn-edit-ring: rgba(59, 130, 246, 0.36);

    /* Actions — clean ghost / filter style */
    --ao-btn-actions-bg: rgba(255, 255, 255, 0.95);
    --ao-btn-actions-border: rgba(100, 90, 130, 0.18);
    --ao-btn-actions-fg: #3a3252;
    --ao-btn-actions-hover-bg: rgba(79, 70, 229, 0.06);
    --ao-btn-actions-hover-border: rgba(79, 70, 229, 0.28);
    --ao-btn-actions-active-bg: rgba(79, 70, 229, 0.12);
    --ao-btn-actions-active-border: rgba(79, 70, 229, 0.38);
    --ao-btn-actions-ring: rgba(79, 70, 229, 0.28);

    /* Refresh — amber glow (QC Queue baseline) */
    --ao-btn-refresh-bg: rgba(245, 158, 11, 0.09);
    --ao-btn-refresh-border: rgba(245, 158, 11, 0.28);
    --ao-btn-refresh-fg: #92400e;
    --ao-btn-refresh-hover-bg: rgba(245, 158, 11, 0.15);
    --ao-btn-refresh-hover-border: rgba(245, 158, 11, 0.42);
    --ao-btn-refresh-active-bg: rgba(245, 158, 11, 0.20);
    --ao-btn-refresh-active-border: rgba(245, 158, 11, 0.50);
    --ao-btn-refresh-ring: rgba(245, 158, 11, 0.35);

    /* Danger stays red for destructive actions */
    --ao-btn-danger-bg: #dc2626;
    --ao-btn-danger-border: #dc2626;
    --ao-btn-danger-fg: #ffffff;
    --ao-btn-danger-hover-bg: #b91c1c;
    --ao-btn-danger-hover-border: #b91c1c;
    --ao-btn-danger-active-bg: #991b1b;
    --ao-btn-danger-active-border: #991b1b;
    --ao-btn-danger-ring: rgba(220, 38, 38, 0.45);

    --ao-btn-ghost-bg: transparent;
    --ao-btn-ghost-border: #e2e8f0;
    --ao-btn-ghost-fg: #0d9488;
    --ao-btn-ghost-hover-bg: rgba(13, 148, 136, 0.08);
    --ao-btn-ghost-hover-border: #0d9488;
    --ao-btn-ghost-active-bg: rgba(13, 148, 136, 0.16);
    --ao-btn-ghost-active-border: #0f766e;
}

[data-bs-theme="dark"] {
    --ao-btn-shadow: 0 1px 2px rgba(0, 0, 0, 0.45);

    /* Premium Teal - Brighter for dark mode */
    --ao-btn-primary-bg: #14b8a6;
    --ao-btn-primary-border: #14b8a6;
    --ao-btn-primary-fg: #042f2e;
    --ao-btn-primary-hover-bg: #2dd4bf;
    --ao-btn-primary-hover-border: #2dd4bf;
    --ao-btn-primary-active-bg: #5eead4;
    --ao-btn-primary-active-border: #5eead4;
    --ao-btn-primary-ring: rgba(20, 184, 166, 0.5);
    --ao-btn-focus-ring: rgba(20, 184, 166, 0.4);

    --ao-btn-add-bg: rgba(16, 185, 129, 0.16);
    --ao-btn-add-border: rgba(16, 185, 129, 0.30);
    --ao-btn-add-fg: #a7f3d0;
    --ao-btn-add-hover-bg: rgba(16, 185, 129, 0.24);
    --ao-btn-add-hover-border: rgba(16, 185, 129, 0.46);
    --ao-btn-add-active-bg: rgba(16, 185, 129, 0.30);
    --ao-btn-add-active-border: rgba(16, 185, 129, 0.56);
    --ao-btn-add-ring: rgba(16, 185, 129, 0.36);

    --ao-btn-edit-bg: rgba(59, 130, 246, 0.16);
    --ao-btn-edit-border: rgba(96, 165, 250, 0.32);
    --ao-btn-edit-fg: #bfdbfe;
    --ao-btn-edit-hover-bg: rgba(59, 130, 246, 0.24);
    --ao-btn-edit-hover-border: rgba(96, 165, 250, 0.46);
    --ao-btn-edit-active-bg: rgba(59, 130, 246, 0.30);
    --ao-btn-edit-active-border: rgba(96, 165, 250, 0.56);
    --ao-btn-edit-ring: rgba(96, 165, 250, 0.36);

    /* Ghost button for dark mode */
    --ao-btn-ghost-border: #334155;
    --ao-btn-ghost-fg: #14b8a6;
    --ao-btn-ghost-hover-bg: rgba(20, 184, 166, 0.12);
    --ao-btn-ghost-hover-border: #14b8a6;
    --ao-btn-ghost-active-bg: rgba(20, 184, 166, 0.2);
    --ao-btn-ghost-active-border: #2dd4bf;

    /* Actions dark — clean ghost */
    --ao-btn-actions-bg: rgba(30, 41, 59, 0.60);
    --ao-btn-actions-border: rgba(148, 163, 184, 0.12);
    --ao-btn-actions-fg: #cbd5e1;
    --ao-btn-actions-hover-bg: rgba(30, 41, 59, 0.60);
    --ao-btn-actions-hover-border: rgba(99, 102, 241, 0.30);
    --ao-btn-actions-active-bg: rgba(99, 102, 241, 0.15);
    --ao-btn-actions-active-border: rgba(99, 102, 241, 0.40);
    --ao-btn-actions-ring: rgba(99, 102, 241, 0.25);

    /* Refresh dark — amber glow */
    --ao-btn-refresh-bg: rgba(251, 191, 36, 0.14);
    --ao-btn-refresh-border: rgba(251, 191, 36, 0.28);
    --ao-btn-refresh-fg: #fde68a;
    --ao-btn-refresh-hover-bg: rgba(251, 191, 36, 0.22);
    --ao-btn-refresh-hover-border: rgba(251, 191, 36, 0.42);
    --ao-btn-refresh-active-bg: rgba(251, 191, 36, 0.28);
    --ao-btn-refresh-active-border: rgba(251, 191, 36, 0.52);
    --ao-btn-refresh-ring: rgba(251, 191, 36, 0.35);
}

.ao-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    font-weight: 600;
    font-size: var(--ao-btn-font-size);
    line-height: 1.15;
    padding: var(--ao-btn-padding-y) var(--ao-btn-padding-x);
    border-radius: var(--ao-btn-radius);
    box-shadow: var(--ao-btn-shadow);
    border: 1px solid transparent;
    text-decoration: none;
    transition: background-color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease, transform 0.05s ease;
    cursor: pointer;
    min-height: var(--ao-btn-height);
}

.ao-toolbar,
.ao-toolbar-row,
.ao-actions-row,
.page-header-actions {
    --ao-btn-radius: 0.75rem;
}

.ao-btn:hover {
    text-decoration: none;
}

.ao-btn:focus,
.ao-btn:focus-visible {
    box-shadow: var(--ao-btn-shadow), 0 0 0 0.2rem var(--ao-btn-focus-ring);
    text-decoration: none;
}

.ao-btn:disabled,
.ao-btn.disabled {
    opacity: 0.6;
    filter: saturate(0.8);
    box-shadow: none;
    cursor: not-allowed;
}

.ao-toolbar-btn {
    min-height: var(--ao-btn-height);
}

.ao-btn .bi {
    font-size: 1rem;
    line-height: 1;
}


.ao-btn-toolbar {
    min-height: var(--ao-btn-height) !important;
    padding: var(--ao-btn-padding-y) var(--ao-btn-padding-x) !important;
    border-radius: var(--ao-btn-radius) !important;
    transition: background-color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease !important;
}

.ao-btn-toolbar:hover:not(:disabled):not(.disabled) {
    transform: none;
}

.ao-btn-toolbar:active:not(:disabled):not(.disabled) {
    transform: translateY(0);
}

.ao-btn-primary {
    background: var(--ao-btn-primary-bg) !important;
    border-color: var(--ao-btn-primary-border) !important;
    color: var(--ao-btn-primary-fg) !important;
}

.ao-btn-secondary {
    background: var(--ao-btn-actions-bg) !important;
    border-color: var(--ao-btn-actions-border) !important;
    color: var(--ao-btn-actions-fg) !important;
}

.ao-btn-danger {
    background: var(--ao-btn-danger-bg) !important;
    border-color: var(--ao-btn-danger-border) !important;
    color: var(--ao-btn-danger-fg) !important;
}

.ao-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.82rem;
    font-weight: 700;
    line-height: 1;
    padding: 0.28rem 0.65rem;
    border-radius: 999px;
    border: 1px solid transparent;
}

.ao-pill-lg {
    font-size: 0.9rem;
    padding: 0.34rem 0.78rem;
}

.ao-pill-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95rem;
    line-height: 1;
}

.ao-pill-lg .ao-pill-icon {
    font-size: 1.05rem;
}

.ao-pill-success {
    color: var(--bs-success-text-emphasis, #166534);
    background: var(--bs-success-bg-subtle, rgba(34, 197, 94, 0.14));
    border-color: var(--bs-success-border-subtle, rgba(34, 197, 94, 0.34));
}

.ao-pill-warning {
    color: var(--bs-warning-text-emphasis, #92400e);
    background: var(--bs-warning-bg-subtle, rgba(245, 158, 11, 0.18));
    border-color: var(--bs-warning-border-subtle, rgba(245, 158, 11, 0.38));
}

.ao-pill-danger {
    color: var(--bs-danger-text-emphasis, #991b1b);
    background: var(--bs-danger-bg-subtle, rgba(239, 68, 68, 0.16));
    border-color: var(--bs-danger-border-subtle, rgba(239, 68, 68, 0.36));
}

.ao-pill-info {
    color: var(--bs-info-text-emphasis, #0c4a6e);
    background: var(--bs-info-bg-subtle, rgba(14, 165, 233, 0.16));
    border-color: var(--bs-info-border-subtle, rgba(14, 165, 233, 0.36));
}

.ao-strip {
    border-radius: 0.68rem;
    padding: 0.62rem 0.9rem;
    background: linear-gradient(180deg, rgba(15, 23, 42, 0.70) 0%, rgba(15, 23, 42, 0.58) 100%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05), 0 6px 16px rgba(2, 6, 23, 0.18);
}

.ao-strip-accent-warning {
    border-left: 3px solid rgba(245, 158, 11, 0.78);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05), 0 6px 16px rgba(2, 6, 23, 0.18), 0 0 0 1px rgba(245, 158, 11, 0.16);
}

.ao-strip-accent-info {
    border-left: 3px solid rgba(56, 189, 248, 0.72);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05), 0 6px 16px rgba(2, 6, 23, 0.18), 0 0 0 1px rgba(56, 189, 248, 0.14);
}

.ao-strip-marker {
    display: inline-flex;
    align-items: center;
    gap: 0.42rem;
    font-size: 0.9rem;
    font-weight: 700;
    line-height: 1;
    padding: 0.34rem 0.8rem;
    border-radius: 999px;
    border: 1px solid transparent;
}

.ao-strip-marker .ao-pill-icon {
    font-size: 1.06rem;
}

.ao-strip-marker-warning {
    color: #fef3c7;
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.26), rgba(217, 119, 6, 0.18));
    border-color: rgba(245, 158, 11, 0.42);
    box-shadow: 0 0 0 1px rgba(245, 158, 11, 0.12), 0 4px 10px rgba(245, 158, 11, 0.2);
}

.ao-strip-marker-info {
    color: #dbeafe;
    background: linear-gradient(135deg, rgba(14, 165, 233, 0.24), rgba(59, 130, 246, 0.18));
    border-color: rgba(56, 189, 248, 0.40);
    box-shadow: 0 0 0 1px rgba(56, 189, 248, 0.10), 0 4px 10px rgba(14, 165, 233, 0.18);
}

.ao-pill-premium-success {
    color: #ecfdf5;
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.26), rgba(22, 163, 74, 0.18));
    border-color: rgba(74, 222, 128, 0.38);
    box-shadow: 0 0 0 1px rgba(34, 197, 94, 0.10), 0 3px 9px rgba(22, 163, 74, 0.20);
}

.ao-pill-premium-warning {
    color: #fef3c7;
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.28), rgba(217, 119, 6, 0.20));
    border-color: rgba(245, 158, 11, 0.42);
    box-shadow: 0 0 0 1px rgba(245, 158, 11, 0.12), 0 3px 9px rgba(245, 158, 11, 0.22);
}

[data-bs-theme="dark"] .ao-strip {
    background: linear-gradient(180deg, rgba(15, 23, 42, 0.84) 0%, rgba(2, 6, 23, 0.74) 100%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04), 0 8px 20px rgba(0, 0, 0, 0.45);
}

[data-bs-theme="dark"] .ao-strip-marker-warning,
[data-bs-theme="dark"] .ao-pill-premium-warning {
    color: #fde68a;
}

[data-bs-theme="dark"] .ao-strip-marker-info {
    color: #bfdbfe;
}
.ao-btn-sm {
    --ao-btn-padding-y: 0.25rem;
    --ao-btn-padding-x: 0.7rem;
    --ao-btn-font-size: 0.8rem;
    --ao-btn-height: 2rem;
}

.ao-toolbar :is(.ao-toolbar-btn, .ao-btn),
.ao-toolbar-actions :is(.ao-toolbar-btn, .ao-btn),
.ao-toolbar-row :is(.ao-toolbar-btn, .ao-btn),
.ao-actions-row :is(.ao-toolbar-btn, .ao-btn),
.page-header-actions :is(.ao-toolbar-btn, .ao-btn),
.home-quick-actions :is(.ao-toolbar-btn, .ao-btn) {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.ao-toolbar .dxbl-btn.ao-btn,
.ao-toolbar :is(.ao-btn, .ao-toolbar-btn) .dxbl-btn,
.dxbl-btn.ao-btn,
.ao-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    line-height: 1 !important;
}

.ao-toolbar :is(.ao-toolbar-btn, .ao-btn) .dxbl-btn-content,
.ao-toolbar-actions :is(.ao-toolbar-btn, .ao-btn) .dxbl-btn-content,
.ao-toolbar-row :is(.ao-toolbar-btn, .ao-btn) .dxbl-btn-content,
.ao-actions-row :is(.ao-toolbar-btn, .ao-btn) .dxbl-btn-content,
.page-header-actions :is(.ao-toolbar-btn, .ao-btn) .dxbl-btn-content,
.home-quick-actions :is(.ao-toolbar-btn, .ao-btn) .dxbl-btn-content {
    display: flex !important;
    align-items: center !important;
    line-height: 1 !important;
}

.ao-toolbar :is(.ao-btn, .ao-toolbar-btn) .dxbl-btn-content,
.ao-toolbar :is(.ao-btn, .ao-toolbar-btn) .dxbl-btn-text {
    display: flex !important;
    align-items: center !important;
    line-height: 1 !important;
}

.ao-toolbar :is(.dxbl-btn, .btn, button).ao-btn .dxbl-btn-content {
    align-items: center !important;
}

.ao-toolbar :is(.dxbl-btn.ao-btn, .btn.ao-btn, button.ao-btn),
.ao-toolbar-actions :is(.dxbl-btn.ao-btn, .btn.ao-btn, button.ao-btn),
.ao-toolbar-row :is(.dxbl-btn.ao-btn, .btn.ao-btn, button.ao-btn),
.ao-actions-row :is(.dxbl-btn.ao-btn, .btn.ao-btn, button.ao-btn),
.page-header-actions :is(.dxbl-btn.ao-btn, .btn.ao-btn, button.ao-btn) {
    font-size: var(--ao-btn-font-size);
    height: var(--ao-btn-height) !important;
    min-height: var(--ao-btn-height) !important;
}

.ao-toolbar :is(.dxbl-btn.ao-btn, .btn.ao-btn, button.ao-btn) {
    font-size: var(--ao-btn-font-size);
    height: var(--ao-btn-height) !important;
    min-height: var(--ao-btn-height) !important;
}

.ao-toolbar-actions :is(.dxbl-btn.ao-btn, .btn.ao-btn),
.ao-toolbar-row :is(.dxbl-btn.ao-btn, .btn.ao-btn),
.ao-actions-row :is(.dxbl-btn.ao-btn, .btn.ao-btn),
.page-header-actions :is(.dxbl-btn.ao-btn, .btn.ao-btn) {
    padding: var(--ao-btn-padding-y) var(--ao-btn-padding-x) !important;
    border-radius: var(--ao-btn-radius) !important;
}

.ao-toolbar :is(.dxbl-btn.ao-btn, .btn.ao-btn) {
    padding: var(--ao-btn-padding-y) var(--ao-btn-padding-x) !important;
    border-radius: var(--ao-btn-radius) !important;
}

.ao-toolbar-actions :is(.dxbl-btn.ao-btn, .btn.ao-btn) .dxbl-btn-content,
.ao-toolbar-row :is(.dxbl-btn.ao-btn, .btn.ao-btn) .dxbl-btn-content,
.ao-actions-row :is(.dxbl-btn.ao-btn, .btn.ao-btn) .dxbl-btn-content,
.page-header-actions :is(.dxbl-btn.ao-btn, .btn.ao-btn) .dxbl-btn-content {
    gap: 0.5rem;
    display: flex;
    align-items: center;
    height: 100%;
}

.ao-toolbar :is(.ao-toolbar-btn, .ao-btn),
.ao-toolbar-actions :is(.ao-toolbar-btn, .ao-btn),
.ao-toolbar-row :is(.ao-toolbar-btn, .ao-btn),
.ao-actions-row :is(.ao-toolbar-btn, .ao-btn) {
    height: var(--ao-btn-height) !important;
    min-height: var(--ao-btn-height) !important;
}

.ao-toolbar-field .input-group > .btn,
.ao-toolbar-field .input-group > .dxbl-btn,
.ao-form-field .input-group > .btn,
.ao-form-field .input-group > .dxbl-btn {
    background-color: var(--ao-card-bg);
    border-color: var(--card-border-color);
    color: inherit;
    box-shadow: none;
}

.ao-toolbar-field .input-group > .btn:hover,
.ao-toolbar-field .input-group > .dxbl-btn:hover,
.ao-form-field .input-group > .btn:hover,
.ao-form-field .input-group > .dxbl-btn:hover {
    background-color: rgba(148, 163, 184, 0.18);
}

.ao-toolbar-sep {
    display: none !important;
}

.ao-toolbar-btn.btn-danger,
.ao-toolbar-btn.dxbl-btn-danger,
.ao-actions-row .btn-danger,
.ao-actions-row .dxbl-btn-danger {
    background-color: var(--ao-btn-danger-bg) !important;
    border-color: var(--ao-btn-danger-border) !important;
    color: var(--ao-btn-danger-fg) !important;
}

.ao-toolbar-btn.btn-danger:hover,
.ao-toolbar-btn.dxbl-btn-danger:hover,
.ao-actions-row .btn-danger:hover,
.ao-actions-row .dxbl-btn-danger:hover {
    background-color: var(--ao-btn-danger-hover-bg) !important;
    border-color: var(--ao-btn-danger-hover-border) !important;
    color: var(--ao-btn-danger-fg) !important;
}

.ao-toolbar-btn.btn-danger:active,
.ao-toolbar-btn.btn-danger.active,
.ao-toolbar-btn.dxbl-btn-danger:active,
.ao-toolbar-btn.dxbl-btn-danger.active,
.ao-actions-row .btn-danger:active,
.ao-actions-row .btn-danger.active,
.ao-actions-row .dxbl-btn-danger:active,
.ao-actions-row .dxbl-btn-danger.active {
    background-color: var(--ao-btn-danger-active-bg) !important;
    border-color: var(--ao-btn-danger-active-border) !important;
    color: var(--ao-btn-danger-fg) !important;
}

[data-bs-theme="light"] :is(.ao-toolbar-actions, .ao-toolbar-row, .ao-actions-row, .page-header-actions) :is(.btn.btn-primary, .btn.btn-success, .dxbl-btn.dxbl-btn-primary, .dxbl-btn.dxbl-btn-success) {
    background-color: var(--ao-btn-add-bg) !important;
    border-color: var(--ao-btn-add-border) !important;
    color: var(--ao-btn-add-fg) !important;
}

[data-bs-theme="light"] :is(.ao-toolbar-actions, .ao-toolbar-row, .ao-actions-row, .page-header-actions) :is(.btn.btn-primary:hover, .btn.btn-success:hover, .dxbl-btn.dxbl-btn-primary:hover, .dxbl-btn.dxbl-btn-success:hover) {
    background-color: var(--ao-btn-add-hover-bg) !important;
    border-color: var(--ao-btn-add-hover-border) !important;
    color: var(--ao-btn-add-fg) !important;
}

[data-bs-theme="light"] :is(.ao-toolbar-actions, .ao-toolbar-row, .ao-actions-row, .page-header-actions) :is(.btn.btn-primary:active, .btn.btn-success:active, .btn.btn-primary.active, .btn.btn-success.active, .btn.btn-primary.show, .btn.btn-success.show, .dxbl-btn.dxbl-btn-primary:active, .dxbl-btn.dxbl-btn-success:active, .dxbl-btn.dxbl-btn-primary.active, .dxbl-btn.dxbl-btn-success.active) {
    background-color: var(--ao-btn-add-active-bg) !important;
    border-color: var(--ao-btn-add-active-border) !important;
    color: var(--ao-btn-add-fg) !important;
}

[data-bs-theme="light"] :is(.ao-toolbar-actions, .ao-toolbar-row, .ao-actions-row, .page-header-actions) :is(.btn.btn-secondary, .btn.btn-outline-secondary, .dxbl-btn.dxbl-btn-secondary, .dxbl-btn.dxbl-btn-outline-secondary, .dxbl-btn.dxbl-btn-outline) {
    background-color: var(--ao-btn-actions-bg) !important;
    border-color: var(--ao-btn-actions-border) !important;
    color: var(--ao-btn-actions-fg) !important;
}

[data-bs-theme="light"] :is(.ao-toolbar-actions, .ao-toolbar-row, .ao-actions-row, .page-header-actions) :is(.btn.btn-secondary:hover, .btn.btn-outline-secondary:hover, .dxbl-btn.dxbl-btn-secondary:hover, .dxbl-btn.dxbl-btn-outline-secondary:hover, .dxbl-btn.dxbl-btn-outline:hover) {
    background-color: var(--ao-btn-actions-hover-bg) !important;
    border-color: var(--ao-btn-actions-hover-border) !important;
    color: var(--ao-btn-actions-fg) !important;
}

[data-bs-theme="light"] :is(.ao-toolbar-actions, .ao-toolbar-row, .ao-actions-row, .page-header-actions) :is(.btn.btn-secondary:active, .btn.btn-outline-secondary:active, .btn.btn-secondary.active, .btn.btn-outline-secondary.active, .btn.btn-secondary.show, .btn.btn-outline-secondary.show, .dxbl-btn.dxbl-btn-secondary:active, .dxbl-btn.dxbl-btn-outline-secondary:active, .dxbl-btn.dxbl-btn-secondary.active, .dxbl-btn.dxbl-btn-outline-secondary.active) {
    background-color: var(--ao-btn-actions-active-bg) !important;
    border-color: var(--ao-btn-actions-active-border) !important;
    color: var(--ao-btn-actions-fg) !important;
}

[data-bs-theme="light"] :is(.ao-toolbar-actions, .ao-toolbar-row, .ao-actions-row, .page-header-actions) :is(.btn.btn-danger, .btn.btn-outline-danger, .dxbl-btn.dxbl-btn-danger, .dxbl-btn.dxbl-btn-outline-danger) {
    background-color: var(--ao-btn-danger-bg) !important;
    border-color: var(--ao-btn-danger-border) !important;
    color: var(--ao-btn-danger-fg) !important;
}

[data-bs-theme="light"] :is(.ao-toolbar-actions, .ao-toolbar-row, .ao-actions-row, .page-header-actions) :is(.btn.btn-danger:hover, .btn.btn-outline-danger:hover, .dxbl-btn.dxbl-btn-danger:hover, .dxbl-btn.dxbl-btn-outline-danger:hover) {
    background-color: var(--ao-btn-danger-hover-bg) !important;
    border-color: var(--ao-btn-danger-hover-border) !important;
    color: var(--ao-btn-danger-fg) !important;
}

[data-bs-theme="light"] :is(.ao-toolbar-actions, .ao-toolbar-row, .ao-actions-row, .page-header-actions) :is(.btn.btn-danger:active, .btn.btn-outline-danger:active, .btn.btn-danger.active, .btn.btn-outline-danger.active, .btn.btn-danger.show, .btn.btn-outline-danger.show, .dxbl-btn.dxbl-btn-danger:active, .dxbl-btn.dxbl-btn-outline-danger:active, .dxbl-btn.dxbl-btn-danger.active, .dxbl-btn.dxbl-btn-outline-danger.active) {
    background-color: var(--ao-btn-danger-active-bg) !important;
    border-color: var(--ao-btn-danger-active-border) !important;
    color: var(--ao-btn-danger-fg) !important;
}

.dxbl-btn.ao-btn {
    min-height: var(--ao-btn-height) !important;
    padding: var(--ao-btn-padding-y) var(--ao-btn-padding-x) !important;
    font-size: var(--ao-btn-font-size) !important;
    border-radius: var(--ao-btn-radius) !important;
}

.dxbl-btn.ao-btn:not(.dxbl-btn-link),
.btn.ao-btn:not(.btn-link) {
    font-size: var(--ao-btn-font-size) !important;
    min-height: var(--ao-btn-height) !important;
    padding: var(--ao-btn-padding-y) var(--ao-btn-padding-x) !important;
    border-radius: var(--ao-btn-radius) !important;
}

.ao-btn--add,
.ao-btn-add {
    --ao-btn-focus-ring: var(--ao-btn-add-ring);
    background: var(--ao-btn-add-bg) !important;
    border-color: var(--ao-btn-add-border) !important;
    color: var(--ao-btn-add-fg) !important;
    box-shadow:
        0 1px 3px rgba(30, 20, 60, 0.07),
        0 0 0 1px rgba(16, 185, 129, 0.10),
        inset 0 1px 0 rgba(255, 255, 255, 0.80) !important;
}

.ao-btn--add:hover,
.ao-btn-add:hover {
    background: var(--ao-btn-add-hover-bg) !important;
    border-color: var(--ao-btn-add-hover-border) !important;
    color: var(--ao-btn-add-fg) !important;
    box-shadow:
        0 6px 20px rgba(16, 185, 129, 0.14),
        0 0 0 1px rgba(16, 185, 129, 0.26),
        inset 0 1px 0 rgba(255, 255, 255, 0.65) !important;
    transform: translateY(-2px);
}



.ao-btn--execute {
    --ao-btn-focus-ring: rgba(168, 85, 247, 0.38);
    background: linear-gradient(135deg, #7c3aed 0%, #6366f1 55%, #2563eb 100%) !important;
    border-color: rgba(99, 102, 241, 0.45) !important;
    color: #ffffff !important;
    box-shadow:
        0 2px 10px rgba(99, 102, 241, 0.28),
        0 0 0 1px rgba(99, 102, 241, 0.18) !important;
}

.ao-btn--execute:hover {
    background: linear-gradient(135deg, #6d28d9 0%, #4f46e5 55%, #1d4ed8 100%) !important;
    color: #ffffff !important;
    transform: translateY(-2px) !important;
    box-shadow:
        0 8px 22px rgba(99, 102, 241, 0.35),
        0 0 0 1px rgba(99, 102, 241, 0.28) !important;
}

.ao-btn--execute:active,
.ao-btn--execute.active,
.ao-btn--execute.show {
    transform: translateY(0.5px) !important;
    box-shadow: inset 0 2px 5px rgba(0, 0, 0, 0.18), 0 0 0 1px rgba(99, 102, 241, 0.25) !important;
}

.ao-btn--add:active,
.ao-btn--add.active,
.ao-btn--add.show,
.ao-btn-add:active,
.ao-btn-add.active,
.ao-btn-add.show {
    background: var(--ao-btn-add-active-bg) !important;
    border-color: var(--ao-btn-add-active-border) !important;
    color: var(--ao-btn-add-fg) !important;
    transform: translateY(0.5px) !important;
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.08) !important;
}

.ao-btn--edit,
.ao-btn-edit,
.ao-btn--save,
.ao-btn-save {
    --ao-btn-focus-ring: var(--ao-btn-edit-ring);
    background: var(--ao-btn-edit-bg) !important;
    border-color: var(--ao-btn-edit-border) !important;
    color: var(--ao-btn-edit-fg) !important;
    box-shadow:
        0 1px 3px rgba(30, 20, 60, 0.07),
        0 0 0 1px rgba(59, 130, 246, 0.10),
        inset 0 1px 0 rgba(255, 255, 255, 0.80) !important;
}

.ao-btn--edit:hover,
.ao-btn-edit:hover,
.ao-btn--save:hover,
.ao-btn-save:hover {
    background: var(--ao-btn-edit-hover-bg) !important;
    border-color: var(--ao-btn-edit-hover-border) !important;
    color: var(--ao-btn-edit-fg) !important;
    box-shadow:
        0 6px 20px rgba(59, 130, 246, 0.14),
        0 0 0 1px rgba(59, 130, 246, 0.26),
        inset 0 1px 0 rgba(255, 255, 255, 0.65) !important;
    transform: translateY(-2px);
}

.ao-btn--edit:active,
.ao-btn--edit.active,
.ao-btn--edit.show,
.ao-btn-edit:active,
.ao-btn-edit.active,
.ao-btn-edit.show,
.ao-btn--save:active,
.ao-btn--save.active,
.ao-btn--save.show,
.ao-btn-save:active,
.ao-btn-save.active,
.ao-btn-save.show {
    background: var(--ao-btn-edit-active-bg) !important;
    border-color: var(--ao-btn-edit-active-border) !important;
    color: var(--ao-btn-edit-fg) !important;
    transform: translateY(0.5px) !important;
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.08) !important;
}

.ao-btn--actions,
.ao-btn-actions {
    --ao-btn-focus-ring: var(--ao-btn-actions-ring);
    background: var(--ao-btn-actions-bg) !important;
    border-color: var(--ao-btn-actions-border) !important;
    color: var(--ao-btn-actions-fg) !important;
    box-shadow:
        0 1px 3px rgba(30, 20, 60, 0.07),
        0 0 0 1px rgba(100, 90, 130, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.90) !important;
    transition: all 0.18s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.ao-btn--actions:hover,
.ao-btn-actions:hover {
    background: var(--ao-btn-actions-hover-bg) !important;
    border-color: var(--ao-btn-actions-hover-border) !important;
    color: var(--ao-btn-actions-fg) !important;
    box-shadow:
        0 6px 20px rgba(79, 70, 229, 0.10),
        0 0 0 1px rgba(79, 70, 229, 0.18),
        inset 0 1px 0 rgba(255, 255, 255, 0.65) !important;
    transform: translateY(-2px);
}

.ao-btn--actions:active,
.ao-btn--actions.active,
.ao-btn--actions.show,
.ao-btn-actions:active,
.ao-btn-actions.active,
.ao-btn-actions.show {
    background: var(--ao-btn-actions-active-bg) !important;
    border-color: var(--ao-btn-actions-active-border) !important;
    color: var(--ao-btn-actions-fg) !important;
    transform: translateY(0.5px) !important;
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.08) !important;
}

[data-bs-theme="dark"] .ao-btn--actions,
[data-bs-theme="dark"] .ao-btn-actions {
    box-shadow:
        0 1px 2px rgba(0, 0, 0, 0.20),
        0 0 0 1px rgba(148, 163, 184, 0.05),
        inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
}

[data-bs-theme="dark"] .ao-btn--actions:hover,
[data-bs-theme="dark"] .ao-btn-actions:hover {
    border-color: rgba(99, 102, 241, 0.30) !important;
    box-shadow:
        0 4px 14px rgba(99, 102, 241, 0.16),
        0 0 0 1px rgba(99, 102, 241, 0.25),
        inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
}

.ao-btn--floating {
    --ao-btn-focus-ring: var(--ao-btn-actions-ring);
    border-radius: var(--ao-btn-radius) !important;
    box-shadow:
        0 1px 3px rgba(30, 20, 60, 0.07),
        0 0 0 1px rgba(100, 90, 130, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.90) !important;
    transition: all 0.18s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.ao-btn--floating.ao-btn-secondary {
    background: var(--ao-btn-actions-bg) !important;
    border-color: var(--ao-btn-actions-border) !important;
    color: var(--ao-btn-actions-fg) !important;
}

.ao-btn--floating:hover:not(:disabled):not(.disabled) {
    border-color: rgba(79, 70, 229, 0.28) !important;
    box-shadow:
        0 6px 20px rgba(79, 70, 229, 0.10),
        0 0 0 1px rgba(79, 70, 229, 0.18),
        inset 0 1px 0 rgba(255, 255, 255, 0.65) !important;
    transform: translateY(-2px);
}

.ao-btn--floating:active:not(:disabled):not(.disabled),
.ao-btn--floating.active:not(:disabled):not(.disabled),
.ao-btn--floating.show:not(:disabled):not(.disabled) {
    transform: translateY(-0.75px) !important;
    box-shadow:
        0 3px 10px rgba(79, 70, 229, 0.08),
        0 0 0 1px rgba(79, 70, 229, 0.14),
        inset 0 2px 4px rgba(0, 0, 0, 0.08) !important;
}

.ao-btn--floating:focus-visible {
    box-shadow:
        0 1px 3px rgba(30, 20, 60, 0.07),
        0 0 0 1px rgba(79, 70, 229, 0.24),
        inset 0 1px 0 rgba(255, 255, 255, 0.90),
        0 0 0 0.2rem rgba(79, 70, 229, 0.34) !important;
}

[data-bs-theme="dark"] .ao-btn--floating {
    box-shadow:
        0 1px 2px rgba(0, 0, 0, 0.20),
        0 0 0 1px rgba(148, 163, 184, 0.05),
        inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
}

[data-bs-theme="dark"] .ao-btn--floating:hover:not(:disabled):not(.disabled) {
    border-color: rgba(99, 102, 241, 0.30) !important;
    box-shadow:
        0 4px 14px rgba(99, 102, 241, 0.16),
        0 0 0 1px rgba(99, 102, 241, 0.25),
        inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
}

[data-bs-theme="dark"] .ao-btn--floating:active:not(:disabled):not(.disabled),
[data-bs-theme="dark"] .ao-btn--floating.active:not(:disabled):not(.disabled),
[data-bs-theme="dark"] .ao-btn--floating.show:not(:disabled):not(.disabled) {
    box-shadow:
        0 2px 8px rgba(99, 102, 241, 0.14),
        0 0 0 1px rgba(99, 102, 241, 0.18),
        inset 0 2px 4px rgba(0, 0, 0, 0.35) !important;
}

[data-bs-theme="dark"] .ao-btn--floating:focus-visible {
    box-shadow:
        0 1px 2px rgba(0, 0, 0, 0.20),
        0 0 0 1px rgba(99, 102, 241, 0.30),
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        0 0 0 0.2rem rgba(99, 102, 241, 0.34) !important;
}

.ao-btn--delete,
.ao-btn-danger,
.dxbl-btn.ao-btn--delete,
.dxbl-btn.ao-btn-danger {
    --ao-btn-focus-ring: var(--ao-btn-danger-ring);
    background-color: var(--ao-btn-danger-bg) !important;
    border-color: var(--ao-btn-danger-border) !important;
    color: var(--ao-btn-danger-fg) !important;
    box-shadow:
        0 1px 3px rgba(30, 20, 60, 0.07),
        0 0 0 1px rgba(239, 68, 68, 0.10) !important;
    transition: all 0.18s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.ao-btn--delete:hover,
.ao-btn-danger:hover,
.dxbl-btn.ao-btn--delete:hover,
.dxbl-btn.ao-btn-danger:hover {
    background-color: var(--ao-btn-danger-hover-bg) !important;
    border-color: var(--ao-btn-danger-hover-border) !important;
    color: var(--ao-btn-danger-fg) !important;
    box-shadow:
        0 6px 20px rgba(239, 68, 68, 0.14),
        0 0 0 1px rgba(239, 68, 68, 0.26) !important;
    transform: translateY(-2px) !important;
}

/* DevExpress danger buttons in grids may use internal hover classes; keep lift effect consistent with Edit. */
.ao-grid-actions .dxbl-btn.ao-btn--delete.dxbl-btn-danger:hover,
.ao-grid-actions .dxbl-btn.ao-btn--delete.dxbl-btn-danger.dxbl-btn-hover,
.ao-grid-actions .dxbl-btn.ao-btn-danger.dxbl-btn-danger:hover,
.ao-grid-actions .dxbl-btn.ao-btn-danger.dxbl-btn-danger.dxbl-btn-hover {
    box-shadow:
        0 6px 20px rgba(239, 68, 68, 0.14),
        0 0 0 1px rgba(239, 68, 68, 0.26) !important;
    transform: translateY(-2px) !important;
}

.ao-btn--delete:active,
.ao-btn--delete.active,
.ao-btn--delete.show,
.ao-btn-danger:active,
.ao-btn-danger.active,
.ao-btn-danger.show {
    background-color: var(--ao-btn-danger-active-bg) !important;
    border-color: var(--ao-btn-danger-active-border) !important;
    color: var(--ao-btn-danger-fg) !important;
}

.ao-btn--refresh {
    --ao-btn-focus-ring: var(--ao-btn-refresh-ring);
    background: var(--ao-btn-refresh-bg) !important;
    border-color: var(--ao-btn-refresh-border) !important;
    color: var(--ao-btn-refresh-fg) !important;
    box-shadow:
        0 1px 3px rgba(30, 20, 60, 0.07),
        0 0 0 1px rgba(245, 158, 11, 0.10),
        inset 0 1px 0 rgba(255, 255, 255, 0.80) !important;
    transition: all 0.18s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.ao-btn--refresh:hover {
    background: var(--ao-btn-refresh-hover-bg) !important;
    border-color: var(--ao-btn-refresh-hover-border) !important;
    color: var(--ao-btn-refresh-fg) !important;
    box-shadow:
        0 6px 20px rgba(245, 158, 11, 0.14),
        0 0 0 1px rgba(245, 158, 11, 0.26),
        inset 0 1px 0 rgba(255, 255, 255, 0.65) !important;
    transform: translateY(-2px);
}

.ao-btn--refresh:active,
.ao-btn--refresh.active,
.ao-btn--refresh.show {
    background: var(--ao-btn-refresh-active-bg) !important;
    border-color: var(--ao-btn-refresh-active-border) !important;
    color: var(--ao-btn-refresh-fg) !important;
    transform: translateY(0.5px) !important;
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.08) !important;
}

[data-bs-theme="dark"] .ao-btn--refresh {
    box-shadow:
        0 1px 3px rgba(0, 0, 0, 0.25),
        0 0 0 1px rgba(251, 191, 36, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
}


[data-bs-theme="dark"] .ao-btn--add,
[data-bs-theme="dark"] .ao-btn-add {
    box-shadow:
        0 1px 3px rgba(0, 0, 0, 0.25),
        0 0 0 1px rgba(16, 185, 129, 0.14),
        inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
}

[data-bs-theme="dark"] .ao-btn--add:hover,
[data-bs-theme="dark"] .ao-btn-add:hover {
    color: #d1fae5 !important;
    box-shadow:
        0 6px 20px rgba(16, 185, 129, 0.20),
        0 0 0 1px rgba(16, 185, 129, 0.30),
        inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
}

[data-bs-theme="dark"] .ao-btn--edit,
[data-bs-theme="dark"] .ao-btn-edit,
[data-bs-theme="dark"] .ao-btn--save,
[data-bs-theme="dark"] .ao-btn-save {
    box-shadow:
        0 1px 3px rgba(0, 0, 0, 0.25),
        0 0 0 1px rgba(96, 165, 250, 0.14),
        inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
}

[data-bs-theme="dark"] .ao-btn--edit:hover,
[data-bs-theme="dark"] .ao-btn-edit:hover,
[data-bs-theme="dark"] .ao-btn--save:hover,
[data-bs-theme="dark"] .ao-btn-save:hover {
    color: #dbeafe !important;
    box-shadow:
        0 6px 20px rgba(96, 165, 250, 0.20),
        0 0 0 1px rgba(96, 165, 250, 0.30),
        inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
}

[data-bs-theme="dark"] .ao-btn--refresh:hover {
    color: #fef3c7 !important;
    box-shadow:
        0 6px 20px rgba(251, 191, 36, 0.18),
        0 0 0 1px rgba(251, 191, 36, 0.30),
        inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
}

.ao-btn--raisedglow {
    --ao-btn-shadow-base:
        0 1px 3px rgba(30, 20, 60, 0.07),
        0 0 0 1px rgba(100, 90, 130, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.90);
    --ao-btn-shadow-glow:
        0 6px 20px rgba(79, 70, 229, 0.10),
        0 0 0 1px rgba(79, 70, 229, 0.18);
    --ao-btn-shadow-glow-active:
        0 3px 10px rgba(79, 70, 229, 0.08),
        0 0 0 1px rgba(79, 70, 229, 0.14);
    box-shadow: var(--ao-btn-shadow-base) !important;
    transition: box-shadow 0.18s cubic-bezier(0.4, 0, 0.2, 1), transform 0.18s cubic-bezier(0.4, 0, 0.2, 1), border-color 0.18s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.ao-btn--raisedglow:hover:not(:disabled):not(.disabled) {
    box-shadow: var(--ao-btn-shadow-base), var(--ao-btn-shadow-glow) !important;
    transform: translateY(-2px);
}

.ao-btn--raisedglow:active:not(:disabled):not(.disabled),
.ao-btn--raisedglow.active:not(:disabled):not(.disabled),
.ao-btn--raisedglow.show:not(:disabled):not(.disabled) {
    box-shadow: var(--ao-btn-shadow-base), var(--ao-btn-shadow-glow-active) !important;
    transform: translateY(-0.75px) !important;
}

.ao-btn--raisedglow:focus-visible {
    box-shadow: var(--ao-btn-shadow-base), 0 0 0 0.2rem var(--ao-btn-focus-ring, rgba(79, 70, 229, 0.34)) !important;
}

.ao-btn--raisedglow.ao-btn--refresh {
    --ao-btn-shadow-glow:
        0 6px 20px rgba(245, 158, 11, 0.14),
        0 0 0 1px rgba(245, 158, 11, 0.26);
    --ao-btn-shadow-glow-active:
        0 3px 10px rgba(245, 158, 11, 0.10),
        0 0 0 1px rgba(245, 158, 11, 0.18);
}

.ao-btn--raisedglow.ao-btn--add,
.ao-btn--raisedglow.ao-btn-add {
    --ao-btn-shadow-glow:
        0 6px 20px rgba(16, 185, 129, 0.14),
        0 0 0 1px rgba(16, 185, 129, 0.26);
    --ao-btn-shadow-glow-active:
        0 3px 10px rgba(16, 185, 129, 0.10),
        0 0 0 1px rgba(16, 185, 129, 0.18);
}

.ao-btn--raisedglow.ao-btn--execute {
    --ao-btn-shadow-base:
        0 2px 10px rgba(99, 102, 241, 0.28),
        0 0 0 1px rgba(99, 102, 241, 0.18);
    --ao-btn-shadow-glow:
        0 8px 22px rgba(99, 102, 241, 0.35),
        0 0 0 1px rgba(99, 102, 241, 0.28);
    --ao-btn-shadow-glow-active:
        0 4px 12px rgba(99, 102, 241, 0.22),
        0 0 0 1px rgba(99, 102, 241, 0.24);
}

.ao-btn--raisedglow.ao-btn--edit,
.ao-btn--raisedglow.ao-btn-edit,
.ao-btn--raisedglow.ao-btn--save,
.ao-btn--raisedglow.ao-btn-save {
    --ao-btn-shadow-glow:
        0 6px 20px rgba(59, 130, 246, 0.14),
        0 0 0 1px rgba(59, 130, 246, 0.26);
    --ao-btn-shadow-glow-active:
        0 3px 10px rgba(59, 130, 246, 0.10),
        0 0 0 1px rgba(59, 130, 246, 0.18);
}

.ao-btn--raisedglow.ao-btn--delete,
.ao-btn--raisedglow.ao-btn-danger {
    --ao-btn-shadow-glow:
        0 6px 20px rgba(239, 68, 68, 0.14),
        0 0 0 1px rgba(239, 68, 68, 0.26);
    --ao-btn-shadow-glow-active:
        0 3px 10px rgba(239, 68, 68, 0.10),
        0 0 0 1px rgba(239, 68, 68, 0.18);
}

[data-bs-theme="dark"] .ao-btn--raisedglow,
:root[data-theme="dark"] .ao-btn--raisedglow {
    --ao-btn-shadow-base:
        0 1px 2px rgba(0, 0, 0, 0.20),
        0 0 0 1px rgba(148, 163, 184, 0.05),
        inset 0 1px 0 rgba(255, 255, 255, 0.04);
    --ao-btn-shadow-glow:
        0 4px 14px rgba(99, 102, 241, 0.16),
        0 0 0 1px rgba(99, 102, 241, 0.25);
    --ao-btn-shadow-glow-active:
        0 2px 8px rgba(99, 102, 241, 0.14),
        0 0 0 1px rgba(99, 102, 241, 0.18);
}

[data-bs-theme="dark"] .ao-btn--raisedglow.ao-btn--refresh,
:root[data-theme="dark"] .ao-btn--raisedglow.ao-btn--refresh {
    --ao-btn-shadow-glow:
        0 6px 20px rgba(251, 191, 36, 0.18),
        0 0 0 1px rgba(251, 191, 36, 0.30);
    --ao-btn-shadow-glow-active:
        0 3px 10px rgba(251, 191, 36, 0.14),
        0 0 0 1px rgba(251, 191, 36, 0.22);
}

[data-bs-theme="dark"] .ao-btn--raisedglow.ao-btn--add,
[data-bs-theme="dark"] .ao-btn--raisedglow.ao-btn-add,
:root[data-theme="dark"] .ao-btn--raisedglow.ao-btn--add,
:root[data-theme="dark"] .ao-btn--raisedglow.ao-btn-add {
    --ao-btn-shadow-glow:
        0 6px 20px rgba(16, 185, 129, 0.20),
        0 0 0 1px rgba(16, 185, 129, 0.30);
    --ao-btn-shadow-glow-active:
        0 3px 10px rgba(16, 185, 129, 0.16),
        0 0 0 1px rgba(16, 185, 129, 0.22);
}

[data-bs-theme="dark"] .ao-btn--raisedglow.ao-btn--execute,
:root[data-theme="dark"] .ao-btn--raisedglow.ao-btn--execute {
    --ao-btn-shadow-base:
        0 2px 10px rgba(99, 102, 241, 0.30),
        0 0 0 1px rgba(99, 102, 241, 0.22);
    --ao-btn-shadow-glow:
        0 8px 22px rgba(99, 102, 241, 0.40),
        0 0 0 1px rgba(99, 102, 241, 0.30);
    --ao-btn-shadow-glow-active:
        0 4px 12px rgba(99, 102, 241, 0.26),
        0 0 0 1px rgba(99, 102, 241, 0.24);
}

[data-bs-theme="dark"] .ao-btn--raisedglow.ao-btn--edit,
[data-bs-theme="dark"] .ao-btn--raisedglow.ao-btn-edit,
[data-bs-theme="dark"] .ao-btn--raisedglow.ao-btn--save,
[data-bs-theme="dark"] .ao-btn--raisedglow.ao-btn-save,
:root[data-theme="dark"] .ao-btn--raisedglow.ao-btn--edit,
:root[data-theme="dark"] .ao-btn--raisedglow.ao-btn-edit,
:root[data-theme="dark"] .ao-btn--raisedglow.ao-btn--save,
:root[data-theme="dark"] .ao-btn--raisedglow.ao-btn-save {
    --ao-btn-shadow-glow:
        0 6px 20px rgba(96, 165, 250, 0.20),
        0 0 0 1px rgba(96, 165, 250, 0.30);
    --ao-btn-shadow-glow-active:
        0 3px 10px rgba(96, 165, 250, 0.16),
        0 0 0 1px rgba(96, 165, 250, 0.22);
}

[data-bs-theme="dark"] .ao-btn--raisedglow.ao-btn--delete,
[data-bs-theme="dark"] .ao-btn--raisedglow.ao-btn-danger,
:root[data-theme="dark"] .ao-btn--raisedglow.ao-btn--delete,
:root[data-theme="dark"] .ao-btn--raisedglow.ao-btn-danger {
    --ao-btn-shadow-glow:
        0 6px 20px rgba(239, 68, 68, 0.20),
        0 0 0 1px rgba(239, 68, 68, 0.30);
    --ao-btn-shadow-glow-active:
        0 3px 10px rgba(239, 68, 68, 0.16),
        0 0 0 1px rgba(239, 68, 68, 0.22);
}

.ao-btn--ghost,
.ao-btn-ghost {
    background-color: var(--ao-btn-ghost-bg) !important;
    border-color: var(--ao-btn-ghost-border) !important;
    color: var(--ao-btn-ghost-fg) !important;
    box-shadow: none;
}

.ao-btn--ghost:hover,
.ao-btn-ghost:hover {
    background-color: var(--ao-btn-ghost-hover-bg) !important;
    border-color: var(--ao-btn-ghost-hover-border) !important;
    color: var(--ao-btn-ghost-fg) !important;
}

.ao-btn--ghost:active,
.ao-btn--ghost.active,
.ao-btn--ghost.show,
.ao-btn-ghost:active,
.ao-btn-ghost.active,
.ao-btn-ghost.show {
    background-color: var(--ao-btn-ghost-active-bg) !important;
    border-color: var(--ao-btn-ghost-active-border) !important;
    color: var(--ao-btn-ghost-fg) !important;
}

/* Alert banner buttons */
.alert .btn {
    border-radius: var(--ao-btn-radius) !important;
}

.ao-details-actions-row :is(.dxbl-btn.ao-btn, .btn.ao-btn):not(.ao-btn-sm),
.lot-details-actions :is(.dxbl-btn.ao-btn, .btn.ao-btn):not(.ao-btn-sm),
.items-details-actions :is(.dxbl-btn.ao-btn, .btn.ao-btn):not(.ao-btn-sm),
.batches-selected-actions :is(.dxbl-btn.ao-btn, .btn.ao-btn):not(.ao-btn-sm),
.purchaseorders-selected-actions :is(.dxbl-btn.ao-btn, .btn.ao-btn):not(.ao-btn-sm) {
    --ao-btn-height: 2.25rem;
    --ao-btn-font-size: 0.875rem;
    --ao-btn-padding-y: 0.35rem;
    --ao-btn-padding-x: 0.85rem;
}

.ao-action-btn {
    min-width: 84px;
    min-height: var(--ao-btn-height, 2rem);
}

.ao-action-group {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.ao-action-group--nowrap {
    flex-wrap: nowrap;
}

.ao-details-actions-row--nowrap {
    flex-wrap: nowrap;
    white-space: nowrap;
}

.ao-action-separator {
    color: var(--bs-gray-500, #6c757d);
    font-weight: 600;
}

.ao-toolbar :is(.dxbl-dropdown-button.ao-btn, .dxbl-dropdown-button.ao-toolbar-btn) .dxbl-btn,
.ao-toolbar-row :is(.dxbl-dropdown-button.ao-btn, .dxbl-dropdown-button.ao-toolbar-btn) .dxbl-btn,
.ao-actions-row :is(.dxbl-dropdown-button.ao-btn, .dxbl-dropdown-button.ao-toolbar-btn) .dxbl-btn {
    min-height: var(--ao-btn-height, 2rem) !important;
    height: var(--ao-btn-height, 2rem) !important;
}

.ao-toolbar :is(.dxbl-dropdown-button.ao-btn, .dxbl-dropdown-button.ao-toolbar-btn) .dxbl-btn + .dxbl-btn,
.ao-toolbar-row :is(.dxbl-dropdown-button.ao-btn, .dxbl-dropdown-button.ao-toolbar-btn) .dxbl-btn + .dxbl-btn,
.ao-actions-row :is(.dxbl-dropdown-button.ao-btn, .dxbl-dropdown-button.ao-toolbar-btn) .dxbl-btn + .dxbl-btn {
    width: var(--ao-btn-height, 2rem) !important;
    min-width: var(--ao-btn-height, 2rem) !important;
    padding: 0 !important;
    border-radius: 0 var(--ao-btn-radius, 0.75rem) var(--ao-btn-radius, 0.75rem) 0 !important;
}

/* ═══════════════════════════════════════════════════════════════
   BUTTON VARIANT DEMOS — 5 styles to choose from
   Apply ao-btn-v1 through ao-btn-v5 to preview each style.
   ═══════════════════════════════════════════════════════════════ */

/* V1: "Indigo Solid" — Clean solid color, professional & confident */
.ao-btn-v1, .ao-btn-v1.ao-btn--actions, .ao-btn-v1.ao-btn--refresh, .ao-btn-v1.ao-btn-ghost {
    background: #4f46e5 !important;
    border-color: #4f46e5 !important;
    color: #fff !important;
    box-shadow: 0 1px 3px rgba(79, 70, 229, 0.24), inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
    border-radius: 0.55rem !important;
}
.ao-btn-v1:hover {
    background: #4338ca !important;
    border-color: #4338ca !important;
    box-shadow: 0 4px 12px rgba(79, 70, 229, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
}
.ao-btn-v1:active {
    background: #3730a3 !important;
    border-color: #3730a3 !important;
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.12) !important;
}
[data-bs-theme="dark"] .ao-btn-v1, [data-bs-theme="dark"] .ao-btn-v1.ao-btn--actions, [data-bs-theme="dark"] .ao-btn-v1.ao-btn--refresh, [data-bs-theme="dark"] .ao-btn-v1.ao-btn-ghost {
    background: #6366f1 !important;
    border-color: #6366f1 !important;
    color: #fff !important;
    box-shadow: 0 1px 3px rgba(99, 102, 241, 0.30) !important;
}
[data-bs-theme="dark"] .ao-btn-v1:hover {
    background: #818cf8 !important;
    border-color: #818cf8 !important;
}

/* V2: "Glass Frost" — Translucent with subtle border, modern glassmorphism */
.ao-btn-v2, .ao-btn-v2.ao-btn--actions, .ao-btn-v2.ao-btn--refresh, .ao-btn-v2.ao-btn-ghost {
    background: rgba(79, 70, 229, 0.08) !important;
    border: 1px solid rgba(79, 70, 229, 0.20) !important;
    color: #4f46e5 !important;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    box-shadow: 0 1px 2px rgba(79, 70, 229, 0.06) !important;
    border-radius: 0.55rem !important;
}
.ao-btn-v2:hover {
    background: rgba(79, 70, 229, 0.14) !important;
    border-color: rgba(79, 70, 229, 0.32) !important;
    box-shadow: 0 2px 8px rgba(79, 70, 229, 0.12) !important;
}
.ao-btn-v2:active {
    background: rgba(79, 70, 229, 0.20) !important;
}
[data-bs-theme="dark"] .ao-btn-v2, [data-bs-theme="dark"] .ao-btn-v2.ao-btn--actions, [data-bs-theme="dark"] .ao-btn-v2.ao-btn--refresh, [data-bs-theme="dark"] .ao-btn-v2.ao-btn-ghost {
    background: rgba(129, 140, 248, 0.10) !important;
    border-color: rgba(129, 140, 248, 0.24) !important;
    color: #a5b4fc !important;
}
[data-bs-theme="dark"] .ao-btn-v2:hover {
    background: rgba(129, 140, 248, 0.18) !important;
    border-color: rgba(129, 140, 248, 0.36) !important;
}

/* V3: "Outline + Fill" — Clean outline, fills with color on hover */
.ao-btn-v3, .ao-btn-v3.ao-btn--actions, .ao-btn-v3.ao-btn--refresh, .ao-btn-v3.ao-btn-ghost {
    background: transparent !important;
    border: 1.5px solid #4f46e5 !important;
    color: #4f46e5 !important;
    box-shadow: none !important;
    border-radius: 0.55rem !important;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
}
.ao-btn-v3:hover {
    background: #4f46e5 !important;
    color: #fff !important;
    box-shadow: 0 4px 12px rgba(79, 70, 229, 0.25) !important;
}
.ao-btn-v3:active {
    background: #4338ca !important;
    border-color: #4338ca !important;
    color: #fff !important;
}
[data-bs-theme="dark"] .ao-btn-v3, [data-bs-theme="dark"] .ao-btn-v3.ao-btn--actions, [data-bs-theme="dark"] .ao-btn-v3.ao-btn--refresh, [data-bs-theme="dark"] .ao-btn-v3.ao-btn-ghost {
    border-color: #a5b4fc !important;
    color: #a5b4fc !important;
    background: transparent !important;
}
[data-bs-theme="dark"] .ao-btn-v3:hover {
    background: #6366f1 !important;
    border-color: #6366f1 !important;
    color: #fff !important;
}

/* V4: "Soft Tint" — Soft pastel background, no border, friendly feel */
.ao-btn-v4, .ao-btn-v4.ao-btn--actions, .ao-btn-v4.ao-btn--refresh, .ao-btn-v4.ao-btn-ghost {
    background: rgba(79, 70, 229, 0.10) !important;
    border: 1px solid transparent !important;
    color: #4f46e5 !important;
    box-shadow: none !important;
    border-radius: 0.55rem !important;
}
.ao-btn-v4:hover {
    background: rgba(79, 70, 229, 0.18) !important;
    box-shadow: 0 2px 6px rgba(79, 70, 229, 0.10) !important;
}
.ao-btn-v4:active {
    background: rgba(79, 70, 229, 0.26) !important;
}
[data-bs-theme="dark"] .ao-btn-v4, [data-bs-theme="dark"] .ao-btn-v4.ao-btn--actions, [data-bs-theme="dark"] .ao-btn-v4.ao-btn--refresh, [data-bs-theme="dark"] .ao-btn-v4.ao-btn-ghost {
    background: rgba(129, 140, 248, 0.12) !important;
    color: #c7d2fe !important;
}
[data-bs-theme="dark"] .ao-btn-v4:hover {
    background: rgba(129, 140, 248, 0.22) !important;
}

/* V5: "Pill Gradient" — Gradient pill with glow, premium & eye-catching */
.ao-btn-v5, .ao-btn-v5.ao-btn--actions, .ao-btn-v5.ao-btn--refresh, .ao-btn-v5.ao-btn-ghost {
    background: linear-gradient(135deg, #4f46e5 0%, #6366f1 40%, #3b82f6 100%) !important;
    border: none !important;
    color: #fff !important;
    border-radius: 999px !important;
    box-shadow: 0 2px 8px rgba(79, 70, 229, 0.28), 0 0 0 1px rgba(79, 70, 229, 0.08) !important;
    padding-left: 1.1rem !important;
    padding-right: 1.1rem !important;
}
.ao-btn-v5:hover {
    background: linear-gradient(135deg, #4338ca 0%, #4f46e5 40%, #2563eb 100%) !important;
    box-shadow: 0 4px 16px rgba(79, 70, 229, 0.35), 0 0 0 1px rgba(79, 70, 229, 0.12) !important;
    transform: translateY(-1px);
}
.ao-btn-v5:active {
    transform: translateY(0px);
    box-shadow: 0 1px 4px rgba(79, 70, 229, 0.20) !important;
}
[data-bs-theme="dark"] .ao-btn-v5, [data-bs-theme="dark"] .ao-btn-v5.ao-btn--actions, [data-bs-theme="dark"] .ao-btn-v5.ao-btn--refresh, [data-bs-theme="dark"] .ao-btn-v5.ao-btn-ghost {
    background: linear-gradient(135deg, #6366f1 0%, #818cf8 40%, #60a5fa 100%) !important;
    box-shadow: 0 2px 8px rgba(99, 102, 241, 0.32) !important;
}
[data-bs-theme="dark"] .ao-btn-v5:hover {
    background: linear-gradient(135deg, #818cf8 0%, #a5b4fc 40%, #93c5fd 100%) !important;
    box-shadow: 0 4px 16px rgba(99, 102, 241, 0.40) !important;
}

/* ═══════════════════════════════════════════════════════════════
   DEVEXPRESS COMBOBOX — seamless dropdown button fix
   ═══════════════════════════════════════════════════════════════ */
.ao-toolbar-control.dxbl-combobox,
.ao-toolbar-control.dxbl-text-edit {
    border-radius: 0.55rem;
    overflow: hidden;
}

.ao-toolbar .dxbl-combobox,
.ao-toolbar-field .dxbl-combobox,
.ao-toolbar .dxbl-text-edit,
.ao-toolbar-field .dxbl-text-edit {
    border-radius: 0.55rem;
    overflow: hidden;
    border: 1px solid rgba(120, 110, 145, 0.20);
}

[data-bs-theme="dark"] .ao-toolbar .dxbl-combobox,
[data-bs-theme="dark"] .ao-toolbar-field .dxbl-combobox,
[data-bs-theme="dark"] .ao-toolbar .dxbl-text-edit,
[data-bs-theme="dark"] .ao-toolbar-field .dxbl-text-edit {
    border-color: rgba(148, 163, 184, 0.16);
}

.ao-toolbar .dxbl-combobox .dxbl-btn,
.ao-toolbar-field .dxbl-combobox .dxbl-btn {
    border: none !important;
    background: transparent !important;
    box-shadow: none !important;
    border-left: 1px solid rgba(120, 110, 145, 0.12) !important;
    border-radius: 0 !important;
    margin: 0 !important;
    padding: 0 0.4rem !important;
}

[data-bs-theme="dark"] .ao-toolbar .dxbl-combobox .dxbl-btn,
[data-bs-theme="dark"] .ao-toolbar-field .dxbl-combobox .dxbl-btn {
    border-left-color: rgba(148, 163, 184, 0.10) !important;
}


/* Final override: keep DELETE lift consistent with EDIT in grid action columns. */
.ao-grid-actions :is(.ao-btn--delete, .ao-btn-danger).dxbl-btn:not(.dxbl-btn-disabled):is(:hover, .dxbl-btn-hover),
.ao-grid-actions :is(.ao-btn--delete, .ao-btn-danger):not(:disabled):hover {
    transform: translateY(-2px) !important;
    box-shadow:
        0 6px 20px rgba(239, 68, 68, 0.14),
        0 0 0 1px rgba(239, 68, 68, 0.26) !important;
}
