/* ========================================================================
   Zentra Design System — ds.css
   Centralized component library with `ds-` prefix.
   ======================================================================== */

/* ─── 1. Design Tokens (CSS Custom Properties) ─── */
:root {
    --ds-primary: #4F5FE0;
    --ds-primary-hover: #5B6AE3;
    --ds-primary-dark: #3A47B8;
    --ds-primary-light: #EEF0FF;

    --ds-danger: #EF4444;
    --ds-danger-dark: #C53030;
    --ds-danger-light: #FEF2F2;

    --ds-success: #10B981;
    --ds-success-dark: #047857;
    --ds-success-light: #ECFDF5;

    --ds-warning: #F59E0B;
    --ds-warning-dark: #D97706;
    --ds-warning-light: #FFFBEB;

    --ds-info: #0EA5E9;
    --ds-info-dark: #0284C7;
    --ds-info-light: #F0F9FF;

    --ds-text-dark: #0F172A;
    --ds-text: #334155;
    --ds-text-muted: #94A3B8;
    --ds-text-light: #64748B;

    --ds-border: #F1F5F9;
    --ds-border-input: #E2E8F0;
    --ds-border-medium: #E8ECF4;

    --ds-bg: #FAFBFE;
    --ds-bg-white: #FFFFFF;
    --ds-bg-hover: #F8FAFC;

    --ds-font: 'Inter', system-ui, -apple-system, sans-serif;
    --ds-radius: 12px;
    --ds-radius-sm: 8px;
    --ds-radius-xs: 7px;

    --ds-shadow-card: 0 1px 3px rgba(15, 23, 42, 0.04);
    --ds-shadow-modal: 0 24px 80px rgba(15, 23, 42, 0.18), 0 0 0 1px rgba(226, 232, 240, 0.5);
}

/* ─── 2. Page Card (z-page__card — duplicated in 33 files) ─── */
.z-page__card {
    background: var(--ds-bg-white);
    border: 1px solid var(--ds-border);
    border-radius: var(--ds-radius);
    box-shadow: var(--ds-shadow-card);
}

.z-page__card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px;
    border-bottom: 1px solid var(--ds-border);
    background: var(--ds-bg);
    flex-wrap: wrap;
    gap: 12px;
}

.z-page__card-header-left {
    display: flex;
    align-items: center;
    gap: 12px;
}

.z-page__card-header-right {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.z-page__card-icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--ds-primary-light);
    border-radius: 10px;
    color: var(--ds-primary);
    font-size: 16px;
}

.z-page__card-title {
    font-size: 15px;
    font-weight: 700;
    color: var(--ds-text-dark);
    margin: 0;
    line-height: 1.3;
}

.z-page__card-subtitle {
    font-size: 12px;
    color: var(--ds-text-muted);
    margin: 2px 0 0;
    line-height: 1.3;
}

.z-page__card-count {
    font-size: 12px;
    font-weight: 500;
    color: var(--ds-text-light);
    background: #F1F5F9;
    padding: 4px 12px;
    border-radius: 9999px;
}

.z-page__card-body {
    padding: 20px;
}

.z-page__card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-top: 1px solid var(--ds-border);
    background: var(--ds-bg);
}

.z-page__card-footer-text {
    font-size: 12px;
    color: var(--ds-text-muted);
}

/* ─── 3. Stats Grid (z-stats-grid — duplicated in 21 files) ─── */
.z-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

@media (max-width: 1200px) {
    .z-stats-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
    .z-stats-grid { grid-template-columns: 1fr; }
}

.z-stat-card {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    background: var(--ds-bg-white);
    border: 1px solid var(--ds-border);
    border-radius: var(--ds-radius);
    padding: 18px 20px;
    box-shadow: var(--ds-shadow-card);
    transition: box-shadow 200ms ease, transform 200ms ease;
}

.z-stat-card:hover {
    box-shadow: 0 4px 8px rgba(15, 23, 42, 0.08);
    transform: translateY(-1px);
}

.z-stat-card__icon {
    width: 42px;
    height: 42px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    flex-shrink: 0;
    font-size: 16px;
}

.z-stat-card__icon--primary { background: var(--ds-primary-light); color: var(--ds-primary); }
.z-stat-card__icon--info    { background: var(--ds-info-light);    color: var(--ds-info); }
.z-stat-card__icon--success { background: var(--ds-success-light); color: var(--ds-success); }
.z-stat-card__icon--warning { background: var(--ds-warning-light); color: var(--ds-warning); }
.z-stat-card__icon--danger  { background: var(--ds-danger-light);  color: var(--ds-danger); }
.z-stat-card__icon--neutral { background: #F1F5F9;                 color: var(--ds-text-light); }

.z-stat-card__content {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.z-stat-card__label {
    font-size: 12px;
    font-weight: 500;
    color: var(--ds-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 2px;
}

.z-stat-card__value {
    font-size: 22px;
    font-weight: 700;
    color: var(--ds-text-dark);
    line-height: 1.2;
    font-variant-numeric: tabular-nums;
}

.z-stat-card__meta {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 6px;
    font-size: 12px;
}

.z-stat-card__trend {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-weight: 500;
}

.z-stat-card__trend--up      { color: var(--ds-success); }
.z-stat-card__trend--info    { color: var(--ds-info); }
.z-stat-card__trend--warning { color: var(--ds-warning); }
.z-stat-card__trend--neutral { color: var(--ds-text-light); }

/* ─── 4. Modal (ds-modal) ─── */
.ds-modal {
    border: none;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: var(--ds-shadow-modal);
}

.ds-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--ds-border);
    background: var(--ds-bg-white);
}

.ds-modal__header--accent {
    background: var(--ds-primary);
    border-bottom: none;
}

.ds-modal__header-left {
    display: flex;
    align-items: center;
    gap: 10px;
}

.ds-modal__icon {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    flex-shrink: 0;
}

.ds-modal__icon--blue   { background: var(--ds-primary-light); color: var(--ds-primary); }
.ds-modal__icon--red    { background: var(--ds-danger-light);  color: #DC2626; }
.ds-modal__icon--green  { background: var(--ds-success-light); color: #059669; }
.ds-modal__icon--white  { background: rgba(255,255,255,0.2);  color: #fff; }
.ds-modal__icon--orange { background: #FFF7ED;                 color: #EA580C; }

.ds-modal__title {
    font-size: 15px;
    font-weight: 700;
    color: var(--ds-text-dark);
    margin: 0;
}

.ds-modal__close {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    border: none;
    background: #F1F5F9;
    color: var(--ds-text-light);
    font-size: 11px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 150ms;
}

.ds-modal__close:hover {
    background: #E2E8F0;
    color: #334155;
}

.ds-modal__close--white {
    background: rgba(255,255,255,0.15);
    color: rgba(255,255,255,0.8);
}

.ds-modal__close--white:hover {
    background: rgba(255,255,255,0.25);
    color: #fff;
}

.ds-modal__body {
    padding: 20px;
}

.ds-modal__footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    padding: 12px 20px;
    border-top: 1px solid var(--ds-border);
    background: var(--ds-bg);
}

.ds-modal__hint {
    font-size: 12px;
    color: var(--ds-text-muted);
    margin-right: auto;
}

.ds-modal__alert {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    padding: 10px 14px;
    border-radius: 8px;
    margin-top: 12px;
}

.ds-modal__alert--danger {
    background: var(--ds-danger-light);
    color: #DC2626;
}

.ds-modal__confirm-icon {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: var(--ds-primary-light);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
}

.ds-modal__confirm-icon i {
    font-size: 22px;
    color: var(--ds-primary);
}

.ds-modal__confirm-title {
    font-size: 16px;
    font-weight: 700;
    color: var(--ds-text-dark);
    margin-bottom: 6px;
}

.ds-modal__success-icon {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--ds-success-light);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
}

.ds-modal__success-icon i {
    font-size: 24px;
    color: var(--ds-success);
}

/* Blue-header modal variant (for Bootstrap modals) */
.modal-content.ds-modal .ds-modal__header,
.ds-modal .modal-header.ds-modal__header {
    background: var(--ds-primary);
    color: white;
    border-bottom: none;
    padding: 16px 24px;
}

.ds-modal .modal-header.ds-modal__header .modal-title,
.ds-modal .ds-modal__header .ds-modal__title {
    font-family: var(--ds-font);
    font-size: 16px;
    font-weight: 600;
    color: white;
}

.ds-modal .modal-header.ds-modal__header .close {
    color: white;
    text-shadow: none;
    opacity: 0.8;
}

.ds-modal .modal-header.ds-modal__header .close:hover {
    opacity: 1;
}

.ds-modal .modal-body.ds-modal__body {
    max-height: calc(100vh - 210px);
    overflow-y: auto;
    padding: 24px !important;
    font-family: var(--ds-font);
}

.ds-modal .modal-footer.ds-modal__footer {
    border-top: 1px solid var(--ds-border);
    padding: 16px 24px;
    background: var(--ds-bg);
}

/* ─── 5. Button (ds-btn) — 3D Skeuomorphic ─── */
.ds-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    padding: 7px 14px;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
    font-family: var(--ds-font);
    border: none;
    cursor: pointer;
    white-space: nowrap;
    position: relative;
    transition: all 120ms ease;
}

.ds-btn:active {
    transform: translateY(1px);
}

.ds-btn--sm {
    padding: 5px 12px;
    font-size: 12px;
    border-radius: var(--ds-radius-xs);
}

.ds-btn--primary {
    background: linear-gradient(180deg, #6B7AED 0%, var(--ds-primary) 100%);
    color: #fff;
    box-shadow: 0 2px 0 var(--ds-primary-dark), 0 3px 8px rgba(79,95,224,0.25);
}

.ds-btn--primary:hover {
    background: linear-gradient(180deg, #7B88F0 0%, var(--ds-primary-hover) 100%);
    box-shadow: 0 2px 0 var(--ds-primary-dark), 0 4px 12px rgba(79,95,224,0.3);
}

.ds-btn--primary:active {
    box-shadow: 0 1px 0 var(--ds-primary-dark), 0 1px 4px rgba(79,95,224,0.2);
    transform: translateY(1px);
}

.ds-btn--outline {
    background: linear-gradient(180deg, #FFFFFF 0%, #F8FAFC 100%);
    color: var(--ds-primary);
    border: 1px solid #D4D8EC;
    box-shadow: 0 2px 0 #E2E5F1, 0 2px 6px rgba(0,0,0,0.04);
}

.ds-btn--outline:hover {
    background: linear-gradient(180deg, #F8FAFF 0%, var(--ds-primary-light) 100%);
    border-color: var(--ds-primary);
    box-shadow: 0 2px 0 #C7CBE4, 0 3px 8px rgba(79,95,224,0.12);
}

.ds-btn--outline:active {
    box-shadow: 0 1px 0 #E2E5F1, 0 1px 3px rgba(0,0,0,0.04);
    transform: translateY(1px);
}

.ds-btn--ghost {
    background: linear-gradient(180deg, #FFFFFF 0%, #F8FAFC 100%);
    color: var(--ds-text-light);
    border: 1px solid #E2E8F0;
    box-shadow: 0 2px 0 #E2E8F0, 0 2px 6px rgba(0,0,0,0.03);
}

.ds-btn--ghost:hover {
    background: linear-gradient(180deg, #F8FAFC 0%, #F1F5F9 100%);
    color: #334155;
    box-shadow: 0 2px 0 #D1D5DB, 0 3px 8px rgba(0,0,0,0.05);
}

.ds-btn--ghost:active {
    box-shadow: 0 1px 0 #E2E8F0, 0 1px 3px rgba(0,0,0,0.03);
    transform: translateY(1px);
}

.ds-btn--danger {
    background: linear-gradient(180deg, #F46B6B 0%, var(--ds-danger) 100%);
    color: #fff;
    box-shadow: 0 2px 0 var(--ds-danger-dark), 0 3px 8px rgba(239,68,68,0.25);
}

.ds-btn--danger:hover {
    background: linear-gradient(180deg, #F87E7E 0%, #F05050 100%);
    box-shadow: 0 2px 0 var(--ds-danger-dark), 0 4px 12px rgba(239,68,68,0.3);
}

.ds-btn--danger:active {
    box-shadow: 0 1px 0 var(--ds-danger-dark), 0 1px 4px rgba(239,68,68,0.2);
    transform: translateY(1px);
}

.ds-btn--success {
    background: linear-gradient(180deg, var(--ds-success) 0%, #059669 100%);
    color: #fff;
    box-shadow: 0 2px 0 var(--ds-success-dark), 0 3px 8px rgba(16,185,129,0.25);
}

.ds-btn--success:hover {
    background: linear-gradient(180deg, #22C790 0%, #0AA87A 100%);
    box-shadow: 0 2px 0 var(--ds-success-dark), 0 4px 12px rgba(16,185,129,0.3);
}

.ds-btn--success:active {
    box-shadow: 0 1px 0 var(--ds-success-dark), 0 1px 4px rgba(16,185,129,0.2);
    transform: translateY(1px);
}

.ds-btn--warning {
    background: linear-gradient(180deg, #FBBF24 0%, var(--ds-warning) 100%);
    color: #fff;
    box-shadow: 0 2px 0 var(--ds-warning-dark), 0 3px 8px rgba(245,158,11,0.25);
}

.ds-btn--warning:hover {
    background: linear-gradient(180deg, #FCD34D 0%, #F59E0B 100%);
    box-shadow: 0 2px 0 var(--ds-warning-dark), 0 4px 12px rgba(245,158,11,0.3);
}

.ds-btn--warning:active {
    box-shadow: 0 1px 0 var(--ds-warning-dark), 0 1px 4px rgba(245,158,11,0.2);
    transform: translateY(1px);
}

.ds-btn--info {
    background: linear-gradient(180deg, #38BDF8 0%, var(--ds-info) 100%);
    color: #fff;
    box-shadow: 0 2px 0 var(--ds-info-dark), 0 3px 8px rgba(14,165,233,0.25);
}

.ds-btn--info:hover {
    background: linear-gradient(180deg, #7DD3FC 0%, #0EA5E9 100%);
    box-shadow: 0 2px 0 var(--ds-info-dark), 0 4px 12px rgba(14,165,233,0.3);
}

.ds-btn--info:active {
    box-shadow: 0 1px 0 var(--ds-info-dark), 0 1px 4px rgba(14,165,233,0.2);
    transform: translateY(1px);
}

.ds-btn--secondary {
    background: linear-gradient(180deg, #F1F5F9 0%, #E2E8F0 100%);
    color: #475569;
    border: 1px solid #CBD5E1;
    box-shadow: 0 2px 0 #CBD5E1, 0 2px 6px rgba(0,0,0,0.03);
}

.ds-btn--secondary:hover {
    background: linear-gradient(180deg, #E2E8F0 0%, #CBD5E1 100%);
    box-shadow: 0 2px 0 #94A3B8, 0 3px 8px rgba(0,0,0,0.05);
}

.ds-btn--secondary:active {
    box-shadow: 0 1px 0 #CBD5E1, 0 1px 3px rgba(0,0,0,0.03);
    transform: translateY(1px);
}

/* ─── 6. Icon Button (ds-btn-icon) ─── */
.ds-btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: var(--ds-radius-xs);
    border: none;
    cursor: pointer;
    font-size: 11px;
    transition: all 120ms ease;
    margin: 0 1px;
}

.ds-btn-icon:active {
    transform: translateY(1px);
}

.ds-btn-icon--primary {
    background: linear-gradient(180deg, #F0F2FF 0%, var(--ds-primary-light) 100%);
    color: var(--ds-primary);
    box-shadow: 0 2px 0 #D4D8EC, 0 1px 3px rgba(79,95,224,0.08);
}

.ds-btn-icon--primary:hover {
    background: linear-gradient(180deg, #6B7AED 0%, var(--ds-primary) 100%);
    color: #fff;
    box-shadow: 0 2px 0 var(--ds-primary-dark), 0 3px 8px rgba(79,95,224,0.2);
}

.ds-btn-icon--danger {
    background: linear-gradient(180deg, #FEF5F5 0%, var(--ds-danger-light) 100%);
    color: #DC2626;
    box-shadow: 0 2px 0 #FECACA, 0 1px 3px rgba(220,38,38,0.08);
}

.ds-btn-icon--danger:hover {
    background: linear-gradient(180deg, #F46B6B 0%, var(--ds-danger) 100%);
    color: #fff;
    box-shadow: 0 2px 0 var(--ds-danger-dark), 0 3px 8px rgba(239,68,68,0.2);
}

.ds-btn-icon--success {
    background: linear-gradient(180deg, #ECFDF5 0%, #D1FAE5 100%);
    color: #059669;
    box-shadow: 0 2px 0 #A7F3D0, 0 1px 3px rgba(16,185,129,0.08);
}

.ds-btn-icon--success:hover {
    background: linear-gradient(180deg, var(--ds-success) 0%, #059669 100%);
    color: #fff;
    box-shadow: 0 2px 0 var(--ds-success-dark), 0 3px 8px rgba(16,185,129,0.2);
}

.ds-btn-icon--warning {
    background: linear-gradient(180deg, #FFF8F0 0%, #FFF7ED 100%);
    color: #EA580C;
    box-shadow: 0 2px 0 #FDDCAF, 0 1px 3px rgba(234,88,12,0.08);
}

.ds-btn-icon--warning:hover {
    background: linear-gradient(180deg, #F47B3E 0%, #EA580C 100%);
    color: #fff;
    box-shadow: 0 2px 0 #C2410C, 0 3px 8px rgba(234,88,12,0.2);
}

.ds-btn-icon--info {
    background: linear-gradient(180deg, #F0F9FF 0%, #EFF8FF 100%);
    color: #0284C7;
    box-shadow: 0 2px 0 #BAE6FD, 0 1px 3px rgba(2,132,199,0.08);
}

.ds-btn-icon--info:hover {
    background: linear-gradient(180deg, #38A3D4 0%, #0284C7 100%);
    color: #fff;
    box-shadow: 0 2px 0 #0369A1, 0 3px 8px rgba(2,132,199,0.2);
}

.ds-btn-icon--ghost {
    background: transparent;
    color: var(--ds-text-light);
    box-shadow: none;
}

.ds-btn-icon--ghost:hover {
    background: #F1F5F9;
    color: #334155;
}

/* ─── 7. Form (ds-input) ─── */
.ds-input {
    padding: 7px 10px;
    border-radius: var(--ds-radius-xs);
    border: 1px solid var(--ds-border-input);
    font-size: 13px;
    font-family: var(--ds-font);
    color: var(--ds-text);
    transition: border-color 150ms, box-shadow 150ms;
    height: auto;
}

.ds-input:focus {
    border-color: var(--ds-primary);
    box-shadow: 0 0 0 3px rgba(79, 95, 224, 0.1);
    outline: none;
}

.ds-field-error {
    border-color: var(--ds-danger) !important;
    box-shadow: 0 0 0 3px rgba(239,68,68,0.08) !important;
}

.ds-field-error:focus {
    border-color: #DC2626 !important;
    box-shadow: 0 0 0 3px rgba(220,38,38,0.12) !important;
}

.ds-error-msg {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 11px;
    font-weight: 600;
    color: var(--ds-danger);
    margin-top: 4px;
}

.ds-error-msg i {
    font-size: 10px;
}

.ds-form-error-banner {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 600;
    color: var(--ds-danger);
    background: var(--ds-danger-light);
    padding: 10px 14px;
    border-radius: 8px;
    margin-bottom: 16px;
    border: 1px solid #FECACA;
}

.ds-form-error-banner i {
    font-size: 14px;
}

/* Form group overrides for consistent sizing */
.ds-form-group label,
.z-form-card .form-group label {
    font-size: 13px;
    font-weight: 500;
    color: #475569;
    margin-bottom: 4px;
}

.ds-form-group .form-control,
.z-form-card .form-control {
    font-size: 13px;
    border-color: var(--ds-border-input);
    border-radius: var(--ds-radius-xs);
    padding: 7px 10px;
    height: auto;
}

.ds-form-group .form-control:focus,
.z-form-card .form-control:focus {
    border-color: var(--ds-primary);
    box-shadow: 0 0 0 3px rgba(79, 95, 224, 0.1);
}

/* ─── 8. DevExtreme Grid Overrides ─── */
.dx-datagrid {
    font-family: var(--ds-font) !important;
    border: 1px solid var(--ds-border) !important;
    border-radius: var(--ds-radius) !important;
    overflow: hidden;
}

.dx-datagrid .dx-datagrid-headers {
    background: var(--ds-bg) !important;
    border-bottom: 1px solid var(--ds-border) !important;
}

.dx-datagrid .dx-datagrid-headers .dx-header-row td {
    font-family: var(--ds-font) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    color: var(--ds-text-light) !important;
    padding: 12px 16px !important;
    border-bottom: 1px solid var(--ds-border) !important;
}

.dx-datagrid .dx-datagrid-rowsview .dx-row {
    font-family: var(--ds-font) !important;
    font-size: 13px !important;
    color: var(--ds-text) !important;
    transition: background 100ms ease;
}

.dx-datagrid .dx-datagrid-rowsview .dx-row:hover {
    background: var(--ds-bg) !important;
}

.dx-datagrid .dx-datagrid-rowsview .dx-row td {
    padding: 10px 16px !important;
    vertical-align: middle !important;
    border-bottom: 1px solid var(--ds-border) !important;
}

.dx-datagrid .dx-datagrid-rowsview .dx-row.dx-row-alt {
    background: var(--ds-bg-hover) !important;
}

/* Toolbar buttons */
.dx-datagrid .dx-toolbar .dx-button.dx-button-has-icon.dx-button-has-text,
.dx-datagrid .dx-toolbar .dx-button.dx-button-has-icon {
    border-radius: var(--ds-radius-sm) !important;
    font-family: var(--ds-font) !important;
    font-weight: 600 !important;
    font-size: 13px !important;
}

/* Search box */
.dx-datagrid .dx-toolbar .dx-searchbox .dx-texteditor {
    border-radius: var(--ds-radius-sm) !important;
    border: 1px solid var(--ds-border-input) !important;
}

.dx-datagrid .dx-toolbar .dx-searchbox .dx-texteditor input {
    font-size: 13px !important;
    font-family: var(--ds-font) !important;
}

/* Pagination */
.dx-datagrid .dx-datagrid-pager {
    border-top: 1px solid var(--ds-border) !important;
    background: var(--ds-bg) !important;
}

.dx-datagrid .dx-datagrid-pager .dx-page-sizes .dx-page-size,
.dx-datagrid .dx-datagrid-pager .dx-pages .dx-page {
    border-radius: var(--ds-radius-xs) !important;
    font-family: var(--ds-font) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
}

/* DevExtreme Popup */
.dx-popup-wrapper .dx-overlay-content {
    border-radius: 16px !important;
    box-shadow: 0 24px 48px rgba(15, 23, 42, 0.18) !important;
    font-family: var(--ds-font) !important;
}

.dx-popup-wrapper .dx-popup-content {
    font-family: var(--ds-font) !important;
    padding: 20px 24px !important;
}

.dx-popup-wrapper .dx-popup-title {
    font-family: var(--ds-font) !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    background: var(--ds-bg) !important;
    border-bottom: 1px solid var(--ds-border) !important;
    padding: 18px 24px !important;
}

.dx-popup-title .dx-toolbar-label {
    font-size: 16px !important;
    font-weight: 600 !important;
    color: var(--ds-text-dark) !important;
}

.dx-popup-wrapper .dx-popup-bottom {
    background: var(--ds-bg) !important;
    border-top: 1px solid var(--ds-border) !important;
}

/* DevExtreme Form */
.dx-form .dx-field-item-label {
    font-family: var(--ds-font) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: #475569 !important;
}

.dx-form .dx-texteditor .dx-texteditor-input {
    font-family: var(--ds-font) !important;
    font-size: 13px !important;
}

/* ─── 9. Backward Compatibility Aliases ─── */
/* io-modal aliases */
.io-modal { border: none; border-radius: 16px; overflow: hidden; box-shadow: var(--ds-shadow-modal); }
.io-modal__header { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid var(--ds-border); background: var(--ds-bg-white); }
.io-modal__header--accent { background: var(--ds-primary); border-bottom: none; }
.io-modal__header-left { display: flex; align-items: center; gap: 10px; }
.io-modal__icon { width: 32px; height: 32px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 13px; flex-shrink: 0; }
.io-modal__icon--blue { background: var(--ds-primary-light); color: var(--ds-primary); }
.io-modal__icon--red { background: var(--ds-danger-light); color: #DC2626; }
.io-modal__icon--green { background: var(--ds-success-light); color: #059669; }
.io-modal__icon--white { background: rgba(255,255,255,0.2); color: #fff; }
.io-modal__title { font-size: 15px; font-weight: 700; color: var(--ds-text-dark); margin: 0; }
.io-modal__close { width: 28px; height: 28px; border-radius: 6px; border: none; background: #F1F5F9; color: var(--ds-text-light); font-size: 11px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 150ms; }
.io-modal__close:hover { background: #E2E8F0; color: #334155; }
.io-modal__close--white { background: rgba(255,255,255,0.15); color: rgba(255,255,255,0.8); }
.io-modal__close--white:hover { background: rgba(255,255,255,0.25); color: #fff; }
.io-modal__body { padding: 20px; }
.io-modal__footer { display: flex; align-items: center; justify-content: flex-end; gap: 8px; padding: 12px 20px; border-top: 1px solid var(--ds-border); background: var(--ds-bg); }
.io-modal__hint { font-size: 12px; color: var(--ds-text-muted); margin-right: auto; }
.io-modal__alert { display: flex; align-items: center; gap: 8px; font-size: 12px; padding: 10px 14px; border-radius: 8px; margin-top: 12px; }
.io-modal__alert--danger { background: var(--ds-danger-light); color: #DC2626; }
.io-modal__confirm-icon { width: 52px; height: 52px; border-radius: 50%; background: var(--ds-primary-light); display: inline-flex; align-items: center; justify-content: center; margin-bottom: 16px; }
.io-modal__confirm-icon i { font-size: 22px; color: var(--ds-primary); }
.io-modal__confirm-title { font-size: 16px; font-weight: 700; color: var(--ds-text-dark); margin-bottom: 6px; }
.io-modal__success-icon { width: 56px; height: 56px; border-radius: 50%; background: var(--ds-success-light); display: inline-flex; align-items: center; justify-content: center; margin-bottom: 16px; }
.io-modal__success-icon i { font-size: 24px; color: var(--ds-success); }

/* io-btn aliases */
.io-btn { display: inline-flex; align-items: center; justify-content: center; gap: 5px; padding: 7px 14px; border-radius: 8px; font-size: 13px; font-weight: 600; border: none; cursor: pointer; white-space: nowrap; position: relative; transition: all 120ms ease; }
.io-btn:active { transform: translateY(1px); }
.io-btn--sm { padding: 5px 12px; font-size: 12px; border-radius: 7px; }
.io-btn--primary { background: linear-gradient(180deg, #6B7AED 0%, #4F5FE0 100%); color: #fff; box-shadow: 0 2px 0 #3A47B8, 0 3px 8px rgba(79,95,224,0.25); }
.io-btn--primary:hover { background: linear-gradient(180deg, #7B88F0 0%, #5B6AE3 100%); box-shadow: 0 2px 0 #3A47B8, 0 4px 12px rgba(79,95,224,0.3); }
.io-btn--primary:active { box-shadow: 0 1px 0 #3A47B8, 0 1px 4px rgba(79,95,224,0.2); transform: translateY(1px); }
.io-btn--outline { background: linear-gradient(180deg, #FFFFFF 0%, #F8FAFC 100%); color: #4F5FE0; border: 1px solid #D4D8EC; box-shadow: 0 2px 0 #E2E5F1, 0 2px 6px rgba(0,0,0,0.04); }
.io-btn--outline:hover { background: linear-gradient(180deg, #F8FAFF 0%, #EEF0FF 100%); border-color: #4F5FE0; box-shadow: 0 2px 0 #C7CBE4, 0 3px 8px rgba(79,95,224,0.12); }
.io-btn--outline:active { box-shadow: 0 1px 0 #E2E5F1, 0 1px 3px rgba(0,0,0,0.04); transform: translateY(1px); }
.io-btn--ghost { background: linear-gradient(180deg, #FFFFFF 0%, #F8FAFC 100%); color: #64748B; border: 1px solid #E2E8F0; box-shadow: 0 2px 0 #E2E8F0, 0 2px 6px rgba(0,0,0,0.03); }
.io-btn--ghost:hover { background: linear-gradient(180deg, #F8FAFC 0%, #F1F5F9 100%); color: #334155; box-shadow: 0 2px 0 #D1D5DB, 0 3px 8px rgba(0,0,0,0.05); }
.io-btn--ghost:active { box-shadow: 0 1px 0 #E2E8F0, 0 1px 3px rgba(0,0,0,0.03); transform: translateY(1px); }
.io-btn--danger { background: linear-gradient(180deg, #F46B6B 0%, #EF4444 100%); color: #fff; box-shadow: 0 2px 0 #C53030, 0 3px 8px rgba(239,68,68,0.25); }
.io-btn--danger:hover { background: linear-gradient(180deg, #F87E7E 0%, #F05050 100%); box-shadow: 0 2px 0 #C53030, 0 4px 12px rgba(239,68,68,0.3); }
.io-btn--danger:active { box-shadow: 0 1px 0 #C53030, 0 1px 4px rgba(239,68,68,0.2); transform: translateY(1px); }
.io-btn--success { background: linear-gradient(180deg, #10B981 0%, #059669 100%); color: #fff; box-shadow: 0 2px 0 #047857, 0 3px 8px rgba(16,185,129,0.25); }
.io-btn--success:hover { background: linear-gradient(180deg, #22C790 0%, #0AA87A 100%); box-shadow: 0 2px 0 #047857, 0 4px 12px rgba(16,185,129,0.3); }
.io-btn--success:active { box-shadow: 0 1px 0 #047857, 0 1px 4px rgba(16,185,129,0.2); transform: translateY(1px); }

/* io-order-action-btn aliases */
.io-order-action-btn { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; border-radius: 7px; border: none; cursor: pointer; font-size: 11px; transition: all 120ms ease; margin: 0 1px; }
.io-order-action-btn:active { transform: translateY(1px); }
.io-order-action-btn--detail { background: linear-gradient(180deg, #F0F2FF 0%, #EEF0FF 100%); color: #4F5FE0; box-shadow: 0 2px 0 #D4D8EC, 0 1px 3px rgba(79,95,224,0.08); }
.io-order-action-btn--detail:hover { background: linear-gradient(180deg, #6B7AED 0%, #4F5FE0 100%); color: #fff; box-shadow: 0 2px 0 #3A47B8, 0 3px 8px rgba(79,95,224,0.2); }
.io-order-action-btn--invoice { background: linear-gradient(180deg, #F0F2FF 0%, #EEF0FF 100%); color: #4F5FE0; box-shadow: 0 2px 0 #D4D8EC, 0 1px 3px rgba(79,95,224,0.08); }
.io-order-action-btn--invoice:hover { background: linear-gradient(180deg, #6B7AED 0%, #4F5FE0 100%); color: #fff; box-shadow: 0 2px 0 #3A47B8, 0 3px 8px rgba(79,95,224,0.2); }
.io-order-action-btn--edit { background: linear-gradient(180deg, #FFF8F0 0%, #FFF7ED 100%); color: #EA580C; box-shadow: 0 2px 0 #FDDCAF, 0 1px 3px rgba(234,88,12,0.08); }
.io-order-action-btn--edit:hover { background: linear-gradient(180deg, #F47B3E 0%, #EA580C 100%); color: #fff; box-shadow: 0 2px 0 #C2410C, 0 3px 8px rgba(234,88,12,0.2); }
.io-order-action-btn--delete { background: linear-gradient(180deg, #FEF5F5 0%, #FEF2F2 100%); color: #DC2626; box-shadow: 0 2px 0 #FECACA, 0 1px 3px rgba(220,38,38,0.08); }
.io-order-action-btn--delete:hover { background: linear-gradient(180deg, #F46B6B 0%, #EF4444 100%); color: #fff; box-shadow: 0 2px 0 #C53030, 0 3px 8px rgba(239,68,68,0.2); }
.io-order-action-btn--print { background: linear-gradient(180deg, #F0F9FF 0%, #EFF8FF 100%); color: #0284C7; box-shadow: 0 2px 0 #BAE6FD, 0 1px 3px rgba(2,132,199,0.08); }
.io-order-action-btn--print:hover { background: linear-gradient(180deg, #38A3D4 0%, #0284C7 100%); color: #fff; box-shadow: 0 2px 0 #0369A1, 0 3px 8px rgba(2,132,199,0.2); }

/* io-field-error aliases */
.io-field-error { border-color: #EF4444 !important; box-shadow: 0 0 0 3px rgba(239,68,68,0.08) !important; }
.io-field-error:focus { border-color: #DC2626 !important; box-shadow: 0 0 0 3px rgba(220,38,38,0.12) !important; }
.io-error-msg { display: flex; align-items: center; gap: 4px; font-size: 11px; font-weight: 600; color: #EF4444; margin-top: 4px; }
.io-error-msg i { font-size: 10px; }
.io-form-error-banner { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; color: #EF4444; background: #FEF2F2; padding: 10px 14px; border-radius: 8px; margin-bottom: 16px; border: 1px solid #FECACA; }
.io-form-error-banner i { font-size: 14px; }

/* btn-icon-only aliases */
.btn-icon-only { display: inline-flex; align-items: center; justify-content: center; border-radius: 8px; border: none; transition: all 150ms ease; }
.btn-icon-only.btn-primary { background-color: #EEF0FF; color: #4F5FE0; }
.btn-icon-only.btn-primary:hover { background-color: #4F5FE0; color: #FFFFFF; box-shadow: 0 2px 8px rgba(79, 95, 224, 0.30); }
.btn-icon-only.btn-info { background-color: #F0F9FF; color: #0EA5E9; }
.btn-icon-only.btn-info:hover { background-color: #0EA5E9; color: #FFFFFF; }
.btn-icon-only.btn-danger { background-color: #FEF2F2; color: #EF4444; }
.btn-icon-only.btn-danger:hover { background-color: #EF4444; color: #FFFFFF; }
.btn-icon-only.btn-success { background-color: #ECFDF5; color: #10B981; }
.btn-icon-only.btn-success:hover { background-color: #10B981; color: #FFFFFF; }
.btn-icon-only.btn-warning { background-color: #FFFBEB; color: #F59E0B; }
.btn-icon-only.btn-warning:hover { background-color: #F59E0B; color: #FFFFFF; }

/* ─── 10. Backward Compatibility — fin-* aliases (finance.css) ─── */

/* fin-btn */
.fin-btn { display: inline-flex; align-items: center; gap: 6px; padding: 8px 16px; font-size: 13px; font-weight: 600; font-family: var(--ds-font); border: none; border-radius: var(--ds-radius-sm); cursor: pointer; transition: all 150ms ease; white-space: nowrap; }
.fin-btn--success { background: #10B981; color: #fff; }
.fin-btn--success:hover { background: #059669; box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3); }
.fin-btn--secondary { background: #F1F4FB; color: #475569; border: 1px solid #E8ECF4; }
.fin-btn--secondary:hover { background: #E8ECF4; }
.fin-btn--info { background: #4F5FE0; color: #fff; }
.fin-btn--info:hover { background: #4351C7; box-shadow: 0 4px 12px rgba(79, 95, 224, 0.3); }
.fin-btn--sm { padding: 5px 12px; font-size: 12px; border-radius: 6px; }

/* fin-modal */
.fin-modal { border: none; border-radius: 12px; overflow: hidden; }
.fin-modal-header { background: #FAFBFE; border-bottom: 1px solid #E8ECF4; padding: 16px 20px; }
.fin-modal-header h5 { font-size: 15px; font-weight: 600; color: #1E293B; margin: 0; }
.fin-modal-body { padding: 20px; }
.fin-modal-footer { border-top: 1px solid #E8ECF4; padding: 12px 20px; }

/* fin-stats-grid */
.fin-stats-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 16px; }
.fin-stat-card { background: #fff; border-radius: 10px; border: 1px solid #E8ECF4; padding: 18px 20px; box-shadow: 0 4px 12px rgba(15, 23, 42, 0.06); transition: box-shadow 150ms ease; }
.fin-stat-card:hover { box-shadow: 0 6px 20px rgba(15, 23, 42, 0.1); }
.fin-stat-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.fin-stat-label { font-size: 11px; font-weight: 600; color: #94A3B8; text-transform: uppercase; letter-spacing: 0.05em; }
.fin-stat-icon { width: 36px; height: 36px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 14px; }
.fin-stat-icon--piutang { background: #FEE2E2; color: #EF4444; }
.fin-stat-icon--belum { background: #FEF3C7; color: #F59E0B; }
.fin-stat-icon--lunas { background: #D1FAE5; color: #10B981; }
.fin-stat-value { font-size: 22px; font-weight: 700; line-height: 1.2; }
.fin-stat-value--danger { color: #EF4444; }
.fin-stat-value--warning { color: #D97706; }
.fin-stat-value--success { color: #10B981; }

/* fin-form inputs */
.fin-form-input,
.fin-form-select,
.fin-form-textarea { width: 100%; padding: 9px 12px; font-size: 13px; font-family: var(--ds-font); color: #475569; background: #FAFBFE; border: 1px solid #E2E8F0; border-radius: 8px; outline: none; transition: border-color 150ms ease, box-shadow 150ms ease; }
.fin-form-input:focus,
.fin-form-select:focus,
.fin-form-textarea:focus { border-color: #4F5FE0; box-shadow: 0 0 0 3px rgba(79, 95, 224, 0.1); }
.fin-form-textarea { resize: vertical; min-height: 60px; }

/* fin-pagination */
.fin-pagination { display: flex; align-items: center; justify-content: space-between; padding: 12px 20px; border-top: 1px solid #E8ECF4; background: #FAFBFE; flex-wrap: wrap; gap: 8px; }
.fin-pagination-info { font-size: 12px; color: #94A3B8; font-weight: 450; }
.fin-pagination-controls { display: flex; align-items: center; gap: 4px; }
.fin-page-btn { min-width: 32px; height: 32px; border-radius: 8px; border: 1px solid #E2E8F0; background: #fff; font-size: 12px; font-weight: 500; font-family: var(--ds-font); color: #475569; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; transition: all 150ms ease; padding: 0 8px; }
.fin-page-btn:hover:not(:disabled) { background: #F1F4FB; border-color: #4F5FE0; color: #4F5FE0; }
.fin-page-btn.active { background: #4F5FE0; border-color: #4F5FE0; color: #fff; font-weight: 600; }
.fin-page-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.fin-page-dots { min-width: 28px; height: 32px; display: inline-flex; align-items: center; justify-content: center; font-size: 12px; color: #94A3B8; letter-spacing: 2px; }

/* ─── 11. Backward Compatibility — ship-* aliases (shipping.css) ─── */

/* ship-btn */
.ship-btn { display: inline-flex; align-items: center; gap: 6px; padding: 7px 14px; border-radius: 8px; border: 1px solid #E2E8F0; background: #fff; font-size: 12px; font-weight: 500; color: #475569; cursor: pointer; transition: all 150ms ease; white-space: nowrap; }
.ship-btn:hover { background: #F1F4FB; border-color: #4F5FE0; color: #4F5FE0; }
.ship-btn i { font-size: 11px; }
.ship-btn--primary { background: #4F5FE0; border-color: #4F5FE0; color: #fff; }
.ship-btn--primary:hover { background: #4351C7; border-color: #4351C7; color: #fff; }
.ship-btn--surat { border-color: #6366F1; color: #6366F1; background: #EEF2FF; }
.ship-btn--surat:hover { background: #6366F1; color: #fff; }

/* ship-modal */
.ship-modal-content { border: none; border-radius: 14px; overflow: hidden; }
.ship-modal-header { background: #FAFBFE; border-bottom: 1px solid #E8ECF4; padding: 16px 24px; display: flex; align-items: center; justify-content: space-between; }
.ship-modal-header-left { display: flex; align-items: center; gap: 12px; }
.ship-modal-icon { width: 36px; height: 36px; border-radius: 8px; background: #EEF2FF; display: flex; align-items: center; justify-content: center; color: #4F5FE0; font-size: 14px; }
.ship-modal-title { font-size: 15px !important; font-weight: 700; color: #1E293B; }
.ship-modal-subtitle { font-size: 12px; color: #94A3B8; font-weight: 450; }
.ship-modal-close { width: 32px; height: 32px; border-radius: 8px; background: transparent; border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; color: #94A3B8; transition: all 150ms ease; font-size: 14px; }
.ship-modal-close:hover { background: #F1F5F9; color: #475569; }
.ship-modal-body { padding: 20px 24px; }

/* ship-stats-grid */
.ship-stats-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 20px; }
.ship-stat-card { background: #fff; border-radius: 12px; padding: 20px; display: flex; align-items: center; gap: 16px; border: 1px solid #E8ECF4; transition: box-shadow 150ms ease; cursor: pointer; }
.ship-stat-card:hover { box-shadow: 0 4px 12px rgba(15, 23, 42, 0.06); }
.ship-stat-card.active { border-color: #4F5FE0; box-shadow: 0 0 0 1px #4F5FE0; }
.ship-stat-icon { width: 44px; height: 44px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; }
.ship-stat-icon--ready { background: #ECFDF5; color: #10B981; }
.ship-stat-icon--pending { background: #FFF7ED; color: #F59E0B; }
.ship-stat-icon--sent { background: #EEF2FF; color: #6366F1; }
.ship-stat-info { display: flex; flex-direction: column; gap: 2px; }
.ship-stat-value { font-size: 22px; font-weight: 700; color: #1E293B; line-height: 1.2; }
.ship-stat-label { font-size: 12px; font-weight: 500; color: #94A3B8; }

/* ship-main-card */
.ship-main-card { background: #fff; border-radius: 12px; border: 1px solid #E8ECF4; overflow: hidden; }
.ship-main-header { display: flex; align-items: center; justify-content: space-between; padding: 16px 24px; border-bottom: 1px solid #E8ECF4; flex-wrap: wrap; gap: 12px; }
.ship-main-header-left { display: flex; align-items: center; gap: 12px; }
.ship-main-icon { width: 36px; height: 36px; border-radius: 8px; background: #EEF2FF; display: flex; align-items: center; justify-content: center; color: #4F5FE0; font-size: 15px; }
.ship-main-title { font-size: 15px; font-weight: 700; color: #1E293B; line-height: 1.2; }
.ship-main-subtitle { font-size: 12px; color: #94A3B8; font-weight: 450; }
.ship-main-header-right { display: flex; align-items: center; gap: 10px; }

/* ship-form inputs */
.ship-form-select,
.ship-form-input,
.ship-form-textarea { border-radius: 8px; border: 1px solid #E2E8F0; font-size: 13px; color: #334155; padding: 8px 12px; transition: all 150ms ease; }
.ship-form-select:focus,
.ship-form-input:focus,
.ship-form-textarea:focus { border-color: #4F5FE0; box-shadow: 0 0 0 3px rgba(79, 95, 224, 0.1); }
.ship-form-textarea { resize: vertical; min-height: 70px; }

/* ship-pagination */
.ship-pagination { display: flex; align-items: center; justify-content: space-between; padding: 12px 24px; border-top: 1px solid #E8ECF4; background: #FAFBFE; flex-wrap: wrap; gap: 8px; }
.ship-pagination-info { font-size: 12px; color: #94A3B8; font-weight: 450; }
.ship-pagination-controls { display: flex; align-items: center; gap: 4px; }
.ship-page-btn { min-width: 32px; height: 32px; border-radius: 8px; border: 1px solid #E2E8F0; background: #fff; font-size: 12px; font-weight: 500; color: #475569; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; transition: all 150ms ease; padding: 0 8px; }
.ship-page-btn:hover:not(:disabled) { background: #F1F4FB; border-color: #4F5FE0; color: #4F5FE0; }
.ship-page-btn.active { background: #4F5FE0; border-color: #4F5FE0; color: #fff; font-weight: 600; }
.ship-page-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.ship-page-dots { min-width: 28px; height: 32px; display: inline-flex; align-items: center; justify-content: center; font-size: 12px; color: #94A3B8; letter-spacing: 2px; }

/* ─── 12. Backward Compatibility — sa-* aliases (sales-analytics.css) ─── */

/* sa-modal-header */
.sa-modal-header { background: #10B981; color: #fff; border-radius: 0; }
.sa-modal-header .modal-title { font-weight: 600; }

/* sa-summary-grid */
.sa-summary-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 24px; }
@media (max-width: 1024px) { .sa-summary-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .sa-summary-grid { grid-template-columns: 1fr; } }
.sa-summary-card { background: #fff; border-radius: 10px; padding: 20px; border: 1px solid #E8ECF4; border-left: 4px solid transparent; transition: box-shadow .15s; }
.sa-summary-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,.06); }
.sa-summary-card--teal { border-left-color: #10B981; }
.sa-summary-card--orange { border-left-color: #F59E0B; }
.sa-summary-card--red { border-left-color: #EF4444; }
.sa-summary-card__label { font-size: 11px; font-weight: 700; color: #94A3B8; text-transform: uppercase; letter-spacing: .06em; margin-bottom: 8px; }
.sa-summary-card--teal .sa-summary-card__value { color: #10B981; }
.sa-summary-card--orange .sa-summary-card__value { color: #F59E0B; }
.sa-summary-card--red .sa-summary-card__value { color: #EF4444; }
.sa-summary-card__value { font-size: 24px; font-weight: 700; color: #1E293B; line-height: 1.2; }

/* sa-table */
.sa-table-wrap { overflow-x: auto; }
.sa-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.sa-table thead th { background: #F8FAFC; color: #64748B; font-weight: 600; font-size: 11px; text-transform: uppercase; letter-spacing: .04em; padding: 10px 12px; border-bottom: 1px solid #E8ECF4; text-align: left; white-space: nowrap; }
.sa-table .text-right { text-align: right; }
.sa-table .text-center { text-align: center; }
.sa-table tbody td { padding: 12px; border-bottom: 1px solid #F1F5F9; color: #334155; vertical-align: middle; }
.sa-table tbody tr:hover { background: #FAFBFE; }
.sa-table tbody tr:last-child td { border-bottom: none; }
.sa-table tfoot td { padding: 12px; font-weight: 700; color: #1E293B; border-top: 2px solid #E8ECF4; background: #F0FDF4; }
