.ecm-page {
    padding: 18px;
    background: #f6f8fb;
    min-height: calc(100vh - 40px);
}

.ecm-page,
.legacy-document-page {
    --afri-button-radius: 8px;
    --afri-button-height: 36px;
    --afri-button-gap: 8px;
    color: #172033;
}

.ecm-page .rz-button,
.legacy-document-page .rz-button,
.receiving-page .rz-button,
.toolbar .rz-button {
    min-height: var(--afri-button-height);
    border-radius: var(--afri-button-radius);
    font-weight: 700;
    letter-spacing: 0;
    box-shadow: none;
}

.ecm-page .rz-button .rz-button-text,
.legacy-document-page .rz-button .rz-button-text,
.receiving-page .rz-button .rz-button-text,
.toolbar .rz-button .rz-button-text {
    white-space: nowrap;
}

.legacy-document-page .toolbar,
.ecm-page .toolbar {
    background: transparent;
    border: 0;
}

.legacy-document-page .toolbar-left,
.legacy-document-page .toolbar-right,
.ecm-page .toolbar-left,
.ecm-page .toolbar-right {
    align-items: center;
}

.toolbar .btn,
.modal-actions .btn,
.legacy-document-page .btn,
.ecm-page .btn,
.doc-container .btn,
.doc-icon-toolbar .icon-btn,
.tb-btn,
.ns3-btn {
    min-height: var(--afri-button-height);
    border-radius: var(--afri-button-radius);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--afri-button-gap);
    border: 1px solid #d8e0eb;
    background: #fff;
    color: #172033;
    font-size: 13px;
    font-weight: 700;
    line-height: 1;
    padding: 8px 12px;
    box-shadow: none;
    transition: background .16s ease, border-color .16s ease, color .16s ease, transform .12s ease;
}

.toolbar .btn:hover,
.modal-actions .btn:hover,
.legacy-document-page .btn:hover,
.ecm-page .btn:hover,
.doc-container .btn:hover,
.doc-icon-toolbar .icon-btn:hover,
.tb-btn:hover,
.ns3-btn:hover {
    border-color: #9fb3ce;
    background: #f7fafc;
    color: #0f4c81;
    transform: translateY(-1px);
}

.toolbar .btn:disabled,
.modal-actions .btn:disabled,
.legacy-document-page .btn:disabled,
.ecm-page .btn:disabled,
.doc-container .btn:disabled,
.doc-icon-toolbar .icon-btn:disabled,
.tb-btn:disabled,
.ns3-btn:disabled {
    opacity: .55;
    cursor: not-allowed;
    transform: none;
}

.toolbar .btn.add-new,
.modal-actions .btn.add-new,
.modal-actions .btn.btn-primary,
.legacy-document-page .btn.add-new,
.legacy-document-page .btn.btn-primary,
.ecm-page .btn.add-new,
.ecm-page .btn.btn-primary,
.doc-container .btn.add-new,
.doc-container .btn.btn-primary,
.ns3-btn.primary {
    background: #16a34a;
    border-color: #16a34a;
    color: #fff;
}

.toolbar .btn.export,
.modal-actions .btn.export,
.legacy-document-page .btn.export,
.ecm-page .btn.export,
.doc-container .btn.export {
    background: #0f78bd;
    border-color: #0f78bd;
    color: #fff;
}

.toolbar .btn.import,
.modal-actions .btn.import,
.legacy-document-page .btn.import,
.ecm-page .btn.import,
.doc-container .btn.import {
    background: #475569;
    border-color: #475569;
    color: #fff;
}

.toolbar .btn.filter,
.toolbar .btn.sort,
.modal-actions .btn.filter,
.modal-actions .btn.sort,
.legacy-document-page .btn.filter,
.legacy-document-page .btn.sort,
.ecm-page .btn.filter,
.ecm-page .btn.sort,
.doc-container .btn.filter,
.doc-container .btn.sort {
    background: #fff;
    border-color: #d8e0eb;
    color: #172033;
}

.toolbar .btn.delete,
.modal-actions .btn.delete,
.legacy-document-page .btn.delete,
.ecm-page .btn.delete,
.doc-container .btn.delete {
    background: #fff;
    border-color: #fecaca;
    color: #b91c1c;
}

.legacy-document-page .form-control,
.legacy-document-page .form-select,
.doc-container input:not([type="checkbox"]),
.doc-container select,
.doc-container textarea {
    border: 1px solid #d8e0eb;
    border-radius: 8px;
    min-height: 36px;
    box-shadow: none;
}

.legacy-document-page .form-control:focus,
.legacy-document-page .form-select:focus,
.doc-container input:not([type="checkbox"]):focus,
.doc-container select:focus,
.doc-container textarea:focus {
    border-color: #0f78bd;
    box-shadow: 0 0 0 3px rgba(15, 120, 189, .14);
    outline: none;
}

.ecm-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 16px;
}

.doc-container.legacy-document-page {
    background: #f6f8fb;
    border-radius: 0;
    padding: 14px;
    min-height: calc(100vh - 40px);
}

.legacy-document-page .doc-top,
.legacy-document-page .doc-body,
.legacy-document-page .doc-properties,
.legacy-document-page .doc-preview,
.legacy-document-page .doc-sidebar,
.legacy-document-page .doc-content,
.legacy-document-page .modal-box,
.legacy-document-page .modal-content {
    border: 1px solid #dce3ee;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 4px 14px rgba(15, 23, 42, .06);
}

.legacy-document-page .modal-box.modal-wide {
    width: min(920px, calc(100vw - 32px));
}

.legacy-document-page .modal-box.modal-wide .ns3-table-wrap {
    max-height: 60vh;
}

.legacy-document-page .doc-top {
    padding: 10px;
    margin-bottom: 12px;
}

.legacy-document-page .doc-body {
    align-items: stretch;
    gap: 12px;
    padding: 12px;
}

.legacy-document-page .doc-tabs {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}

.legacy-document-page .tab-item {
    border: 1px solid transparent;
    border-radius: 8px;
    background: transparent;
    color: #475569;
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 8px 12px;
    font-weight: 800;
    cursor: pointer;
}

.legacy-document-page .tab-item:hover,
.legacy-document-page .tab-item.active {
    background: #eaf2ff;
    border-color: #bfd7f4;
    color: #0f4c81;
}

.legacy-document-page .doc-icon-toolbar {
    border: 0;
    background: transparent;
    gap: 10px;
    flex-wrap: wrap;
}

.legacy-document-page .icon-group {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}

.legacy-document-page .icon-btn {
    width: 36px;
    min-width: 36px;
    padding: 0;
}

.legacy-document-page .doc-paging {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #64748b;
    font-size: 13px;
    flex-wrap: wrap;
}

.legacy-document-page .doc-count,
.legacy-document-page .selection-info {
    border-radius: 999px;
    background: #eef4fb;
    color: #0f4c81;
    font-weight: 700;
    padding: 5px 10px;
}

.legacy-document-page .sidebar-header,
.legacy-document-page .preview-header,
.legacy-document-page .properties-header {
    color: #172033;
    font-weight: 800;
}

.legacy-document-page .ns3-table-wrap,
.legacy-document-page .table-scroll-container {
    border: 1px solid #dce3ee;
    border-radius: 8px;
    background: #fff;
    overflow: auto;
}

.legacy-document-page .ns3-table,
.legacy-document-page .styled-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
}

.legacy-document-page .ns3-table th,
.legacy-document-page .styled-table th {
    background: #f2f6fb;
    color: #172033;
    font-weight: 800;
    border-bottom: 1px solid #dce3ee;
}

.legacy-document-page .ns3-table td,
.legacy-document-page .ns3-table th,
.legacy-document-page .styled-table td,
.legacy-document-page .styled-table th {
    padding: 10px 12px;
    vertical-align: middle;
}

.legacy-document-page .ns3-table tbody tr:hover,
.legacy-document-page .styled-table tbody tr:hover {
    background: #f8fbff;
}

.legacy-document-page .ns3-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
    margin: 14px 0;
}

.legacy-document-page .ns3-stat-card {
    border: 1px solid #dce3ee;
    border-radius: 8px;
    background: #fff;
    padding: 14px;
    box-shadow: 0 4px 14px rgba(15, 23, 42, .06);
}

.legacy-document-page .ns3-stat-title {
    color: #64748b;
    font-size: .82rem;
    font-weight: 800;
    text-transform: uppercase;
}

.legacy-document-page .ns3-stat-value {
    color: #172033;
    font-size: 1.65rem;
    font-weight: 900;
}

.ecm-title {
    margin: 0;
    font-size: 1.35rem;
    font-weight: 700;
    color: #172033;
}

.ecm-subtitle {
    margin: 4px 0 0;
    color: #657083;
    font-size: .92rem;
}

.ecm-metrics {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
    margin-bottom: 16px;
}

.ecm-metric {
    background: #fff;
    border: 1px solid #dce3ee;
    border-radius: 8px;
    padding: 14px;
}

.ecm-metric-label {
    color: #657083;
    font-size: .82rem;
    text-transform: uppercase;
}

.ecm-metric-value {
    margin-top: 6px;
    font-size: 1.65rem;
    font-weight: 800;
    color: #172033;
}

.ecm-panel {
    background: #fff;
    border: 1px solid #dce3ee;
    border-radius: 8px;
    padding: 14px;
    margin-bottom: 16px;
}

.ecm-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 14px;
}

.ecm-form-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
    margin-bottom: 12px;
}

.ecm-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 12px;
}

.ecm-badge {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 4px 10px;
    background: #e9eef7;
    color: #334155;
    font-size: .8rem;
    font-weight: 700;
}

.ecm-badge.overdue {
    background: #fee2e2;
    color: #991b1b;
}

.ecm-badge.ok {
    background: #dcfce7;
    color: #166534;
}

.ecm-dropzone {
    border: 1px dashed #9fb0c8;
    background: #f8fafc;
    border-radius: 8px;
    padding: 16px;
}

.ecm-note {
    color: #64748b;
    font-size: .85rem;
    margin-top: 6px;
}

.settings-shell {
    display: grid;
    grid-template-columns: 240px minmax(0, 1fr);
    gap: 16px;
}

.settings-nav {
    align-self: start;
    background: #fff;
    border: 1px solid #dce3ee;
    border-radius: 8px;
    padding: 8px;
    position: sticky;
    top: 12px;
}

.settings-nav-item {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 10px;
    border: 0;
    border-radius: 6px;
    background: transparent;
    color: #334155;
    font-weight: 700;
    padding: 11px 12px;
    text-align: left;
}

.settings-nav-item:hover,
.settings-nav-item.active {
    background: #eaf2ff;
    color: #0f4c81;
}

.settings-content {
    min-width: 0;
}

.settings-section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 14px;
}

.settings-section-head h2,
.settings-card h3 {
    margin: 0;
    color: #172033;
}

.settings-section-head p,
.settings-card p {
    color: #64748b;
    margin: 4px 0 0;
}

.settings-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 12px;
}

.settings-card {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr);
    gap: 12px;
    align-items: start;
    border: 1px solid #dce3ee;
    border-radius: 8px;
    padding: 14px;
    background: #fbfdff;
}

.settings-card > i {
    color: #0f78bd;
    font-size: 1.2rem;
    margin-top: 3px;
}

.settings-card .rz-button {
    grid-column: 2;
    justify-self: start;
}

.settings-toggle {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #334155;
    font-weight: 700;
}

.settings-provider-help {
    display: flex;
    flex-direction: column;
    gap: 3px;
    border: 1px solid #dce3ee;
    border-radius: 8px;
    background: #f8fafc;
    padding: 10px 12px;
    color: #64748b;
    font-size: .9rem;
}

.settings-provider-help strong {
    color: #172033;
}

.settings-row-actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
}

.settings-path-filter {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    flex-wrap: wrap;
}

@media (max-width: 760px) {
    .ecm-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .settings-shell {
        grid-template-columns: 1fr;
    }

    .settings-nav {
        position: static;
    }

    .settings-section-head {
        flex-direction: column;
    }
}

/* ================================================================
   GLOBAL BUTTON RULE ENFORCEMENT
   Keep this at the end because document/page CSS is loaded after the
   shared button file. It restores the required ribbon button system
   for classic .btn, Bootstrap button aliases, and Radzen buttons.
   ================================================================ */

.btn,
.rz-button:not(.grid-line-icon-btn):not(.rz-fileupload-choose) {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    min-height: var(--btn-height) !important;
    padding: 0 var(--btn-padding-x) !important;
    font-size: .95rem !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    text-decoration: none !important;
    font-family: inherit !important;
    cursor: pointer;
    border-radius: 0 !important;
    background: var(--btn-bg-white) !important;
    color: var(--c, var(--btn-color-primary)) !important;
    border-top: var(--btn-border-width) solid var(--c, var(--btn-color-primary)) !important;
    border-right: var(--btn-border-width) solid var(--c, var(--btn-color-primary)) !important;
    border-bottom: var(--btn-border-width) solid var(--c, var(--btn-color-primary)) !important;
    border-left: var(--btn-border-left-width) solid var(--c, var(--btn-color-primary)) !important;
    box-shadow: none !important;
    transition: border-left-width var(--btn-transition), background-color var(--btn-transition), border-color var(--btn-transition), color var(--btn-transition), filter var(--btn-transition) !important;
}

.btn:hover,
.rz-button:not(.grid-line-icon-btn):not(.rz-fileupload-choose):hover {
    border-left-width: var(--btn-border-width) !important;
    background: var(--btn-bg-white) !important;
    color: var(--c, var(--btn-color-primary)) !important;
    transform: none !important;
}

.btn i,
.rz-button .rz-button-icon-left,
.rz-button .rz-button-icon-right,
.rz-button .rzi {
    font-size: 13px !important;
    line-height: 1 !important;
}

.btn:focus-visible,
.rz-button:focus-visible {
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(15, 23, 42, .08) !important;
}

.btn:disabled,
.btn[disabled],
.rz-button:disabled,
.rz-state-disabled.rz-button {
    opacity: .55 !important;
    cursor: not-allowed !important;
    filter: grayscale(.2);
}

.btn.primary,
.btn.add-new,
.btn.add,
.btn.btn-primary,
.btn.btn-outline-primary,
.btn-primary-icon,
.rz-button.rz-primary,
.rz-button.rz-button-primary {
    --c: var(--btn-color-primary);
}

.btn.secondary,
.btn.btn-secondary,
.btn.btn-outline-secondary,
.rz-button.rz-secondary,
.rz-button.rz-button-secondary,
.rz-button.rz-light,
.rz-button.rz-button-light {
    --c: var(--btn-color-secondary);
}

.btn.success,
.btn.approve,
.btn.apply,
.btn.confirm,
.btn.btn-success,
.btn.btn-outline-success,
.rz-button.rz-success,
.rz-button.rz-button-success {
    --c: var(--btn-color-success);
}

.btn.danger,
.btn.delete,
.btn.cancel,
.btn.pdf,
.btn.btn-danger,
.btn.btn-outline-danger,
.rz-button.rz-danger,
.rz-button.rz-button-danger {
    --c: var(--btn-color-danger);
}

.btn.warning,
.btn.on-hold,
.btn.btn-warning,
.btn.btn-outline-warning,
.rz-button.rz-warning,
.rz-button.rz-button-warning {
    --c: var(--btn-color-warning);
}

.btn.edit {
    --c: var(--btn-color-edit);
}

.btn.print {
    --c: var(--btn-color-print);
}

.btn.filter {
    --c: var(--btn-color-filter);
}

.btn.sort {
    --c: var(--btn-color-sort);
}

.btn.export {
    --c: var(--btn-color-export);
}

.btn.import,
.rz-button.rz-info,
.rz-button.rz-button-info,
.btn.btn-info,
.btn.btn-outline-info {
    --c: var(--btn-color-import);
}

.btn.ghost,
.rz-button.btn.ghost {
    background: transparent !important;
    color: var(--muted, #64748b) !important;
    border: none !important;
    padding: 0 10px !important;
    min-height: var(--btn-height) !important;
}

.btn.ghost:hover,
.rz-button.btn.ghost:hover {
    background: rgba(15, 23, 42, .06) !important;
    color: var(--ink, #0f172a) !important;
}

.btn.ghost.icon-only,
.rz-button.btn.ghost.icon-only {
    min-width: 32px !important;
    width: 32px !important;
    height: 32px !important;
    min-height: 32px !important;
    padding: 0 !important;
    font-size: 13px !important;
}

.btn.ghost.icon-only:hover,
.rz-button.btn.ghost.icon-only:hover {
    color: var(--btn-color-danger) !important;
}

.grid-line-icon-btn,
.rz-button.grid-line-icon-btn {
    min-width: 28px !important;
    width: 28px !important;
    height: 28px !important;
    min-height: 28px !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    border-radius: 6px !important;
    color: gray !important;
}

/* ================================================================
   Enterprise workflow pages
   ================================================================ */

.workflow-command-center,
.workflow-analytics-page {
    color: var(--ink);
}

.queue-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 16px;
}

.queue-tabs,
.workflow-action-strip,
.panel-title-row,
.analytics-strip {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.queue-tabs {
    flex: 1;
}

.ecm-search-bar {
    min-width: 280px;
    max-width: 420px;
    flex: 1;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 9px 12px;
    border: 1px solid var(--border-1);
    background: var(--bg-panel);
}

.ecm-search-bar i {
    color: var(--muted);
    font-size: 13px;
}

.task-title {
    font-weight: 650;
    color: var(--ink);
    line-height: 1.25;
}

.task-subtitle {
    margin-top: 3px;
    font-size: 12px;
    color: var(--muted);
}

.claim-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 9px;
    border: 1px solid var(--border-1);
    background: var(--surface-2);
    color: var(--muted);
    font-size: 12px;
    font-weight: 600;
}

.claim-chip.mine {
    background: #e6f4ea;
    border-color: #bfe3c8;
    color: #15803d;
}

.claim-chip.locked {
    background: #fff7ed;
    border-color: #fed7aa;
    color: #c2410c;
}

.claim-chip.free {
    background: #eff6ff;
    border-color: #bfdbfe;
    color: #1d4ed8;
}

.ecm-badge.pending,
.ecm-badge.info,
.ecm-badge.danger {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 0 9px;
    font-size: 12px;
    font-weight: 650;
}

.ecm-badge.pending {
    background: #f8fafc;
    color: #475569;
    border: 1px solid #cbd5e1;
}

.ecm-badge.info {
    background: #eff6ff;
    color: #1d4ed8;
    border: 1px solid #bfdbfe;
}

.ecm-badge.danger {
    background: #fef2f2;
    color: #dc2626;
    border: 1px solid #fecaca;
}

.workflow-action-strip {
    row-gap: 6px;
}

.workflow-action-modal .modal-header-row h3 {
    margin: 0;
    font-size: 1.05rem;
}

.tab-form-grid.single {
    grid-template-columns: 1fr;
}

.analytics-strip {
    align-items: stretch;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 16px;
    margin-bottom: 16px;
}

.ecm-grid.wide {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    align-items: start;
}

.panel-title-row {
    justify-content: space-between;
    margin-bottom: 12px;
}

.panel-title-row .ecm-section-title {
    margin: 0;
}

.panel-note {
    color: var(--muted);
    font-size: 12px;
}

.ecm-metric.danger .ecm-metric-value {
    color: var(--danger);
}

@media (max-width: 980px) {
    .queue-toolbar {
        align-items: stretch;
        flex-direction: column;
    }

    .ecm-search-bar {
        max-width: none;
        min-width: 0;
        width: 100%;
    }

    .analytics-strip,
    .ecm-grid.wide {
        grid-template-columns: 1fr;
    }
}

/* ================================================================
   Workflow grid — compact icon-button action strip
   ================================================================ */

.wf-action-strip {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-wrap: wrap;
}

/* thin vertical separator between button groups */
.wf-divider {
    width: 1px;
    height: 18px;
    background: #e2e8f0;
    flex-shrink: 0;
    margin: 0 2px;
    align-self: center;
}

/* base icon button */
.wf-act-btn {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    min-width: 30px;
    border-radius: 7px;
    border: 1px solid #e2e8f0;
    font-size: 12px;
    cursor: pointer;
    background: #f8fafc;
    color: #64748b;
    padding: 0;
    line-height: 1;
    transition: background .14s, border-color .14s, box-shadow .12s, transform .1s;
    /* reset any global .btn styles that might bleed in */
    text-decoration: none;
}

.wf-act-btn:hover:not(:disabled) {
    transform: translateY(-1px);
    box-shadow: 0 2px 6px rgba(15, 23, 42, .12);
}

.wf-act-btn:disabled {
    opacity: .35;
    cursor: not-allowed;
    transform: none !important;
}

/* ── Color variants ─────────────────────────────────── */
.wf-act-btn.wf-claim   { background: #eff6ff; color: #1d4ed8; border-color: #bfdbfe; }
.wf-act-btn.wf-claim:hover:not(:disabled)   { background: #dbeafe; border-color: #93c5fd; }

.wf-act-btn.wf-release { background: #f8fafc; color: #475569; border-color: #cbd5e1; }
.wf-act-btn.wf-release:hover:not(:disabled) { background: #f1f5f9; border-color: #94a3b8; }

.wf-act-btn.wf-approve { background: #f0fdf4; color: #15803d; border-color: #86efac; }
.wf-act-btn.wf-approve:hover:not(:disabled) { background: #dcfce7; border-color: #4ade80; }

.wf-act-btn.wf-reject  { background: #fef2f2; color: #b91c1c; border-color: #fca5a5; }
.wf-act-btn.wf-reject:hover:not(:disabled)  { background: #fee2e2; border-color: #f87171; }

.wf-act-btn.wf-return  { background: #fffbeb; color: #b45309; border-color: #fcd34d; }
.wf-act-btn.wf-return:hover:not(:disabled)  { background: #fef3c7; border-color: #fbbf24; }

.wf-act-btn.wf-escalate { background: #fff7ed; color: #c2410c; border-color: #fdba74; }
.wf-act-btn.wf-escalate:hover:not(:disabled) { background: #ffedd5; border-color: #fb923c; }

.wf-act-btn.wf-delegate,
.wf-act-btn.wf-assign  { background: #faf5ff; color: #7c3aed; border-color: #d8b4fe; }
.wf-act-btn.wf-delegate:hover:not(:disabled),
.wf-act-btn.wf-assign:hover:not(:disabled)  { background: #f3e8ff; border-color: #c084fc; }

.wf-act-btn.wf-reassign { background: #f0fdfa; color: #0f766e; border-color: #5eead4; }
.wf-act-btn.wf-reassign:hover:not(:disabled) { background: #ccfbf1; border-color: #2dd4bf; }

.wf-act-btn.wf-comment,
.wf-act-btn.wf-review  { background: #eff6ff; color: #2563eb; border-color: #93c5fd; }
.wf-act-btn.wf-comment:hover:not(:disabled),
.wf-act-btn.wf-review:hover:not(:disabled)  { background: #dbeafe; border-color: #60a5fa; }

.wf-act-btn.wf-publish { background: #ecfdf5; color: #059669; border-color: #6ee7b7; }
.wf-act-btn.wf-publish:hover:not(:disabled) { background: #d1fae5; border-color: #34d399; }

.wf-act-btn.wf-archive { background: #f8fafc; color: #64748b; border-color: #cbd5e1; }
.wf-act-btn.wf-archive:hover:not(:disabled) { background: #f1f5f9; border-color: #94a3b8; }

.wf-act-btn.wf-default { background: #f8fafc; color: #64748b; border-color: #e2e8f0; }
.wf-act-btn.wf-default:hover:not(:disabled) { background: #f1f5f9; }

/* ── Animated tooltip via data-tip ──────────────────── */
.wf-act-btn[data-tip]::after {
    content: attr(data-tip);
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%) scale(.88);
    background: #1e293b;
    color: #f1f5f9;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .2px;
    padding: 4px 9px;
    border-radius: 6px;
    white-space: nowrap;
    pointer-events: none;
    opacity: 0;
    transition: opacity .15s ease, transform .15s ease;
    z-index: 60;
}

.wf-act-btn[data-tip]::before {
    content: '';
    position: absolute;
    bottom: calc(100% + 3px);
    left: 50%;
    transform: translateX(-50%) scale(.88);
    border: 5px solid transparent;
    border-top-color: #1e293b;
    pointer-events: none;
    opacity: 0;
    transition: opacity .15s ease, transform .15s ease;
    z-index: 60;
}

.wf-act-btn[data-tip]:hover:not(:disabled)::after,
.wf-act-btn[data-tip]:hover:not(:disabled)::before {
    opacity: 1;
    transform: translateX(-50%) scale(1);
}
