/* ============================================================
   PharmaSys Design System — Flat Slate/Neutral + Blue Accent
   Plus Jakarta Sans | Sharp edges | Clean borders
   ============================================================ */

/* ==================== LIGHT THEME (default) ==================== */
:root,
[data-bs-theme="light"] {
    /* Primary palette — Slate */
    --ps-primary: #475569;
    --ps-primary-hover: #334155;
    --ps-primary-light: #F1F5F9;
    --ps-primary-rgb: 71, 85, 105;

    /* Accent — Blue (CTA) */
    --ps-accent: #3B82F6;
    --ps-accent-hover: #2563EB;
    --ps-accent-light: #DBEAFE;
    --ps-accent-rgb: 59, 130, 246;

    /* Secondary */
    --ps-secondary: #6B7A99;
    --ps-secondary-light: #EBEEF3;

    /* Semantic */
    --ps-success: #059669;
    --ps-success-light: #D1FAE5;
    --ps-success-rgb: 5, 150, 105;

    --ps-warning: #D97706;
    --ps-warning-light: #FEF3C7;
    --ps-warning-rgb: 217, 119, 6;

    --ps-danger: #DC2626;
    --ps-danger-light: #FEE2E2;
    --ps-danger-rgb: 220, 38, 38;

    --ps-info: #0284C7;
    --ps-info-light: #E0F2FE;
    --ps-info-rgb: 2, 132, 199;

    /* Surfaces — flat white */
    --ps-bg-body: #FFFFFF;
    --ps-bg-card: #FFFFFF;
    --ps-bg-card-hover: #F8FAFC;
    --ps-bg-sidebar: linear-gradient(180deg, #0F172A, #1E293B);
    --ps-bg-sidebar-hover: rgba(255, 255, 255, 0.08);
    --ps-bg-sidebar-active: rgba(255, 255, 255, 0.14);
    --ps-bg-header: #FFFFFF;
    --ps-bg-input: #F8FAFC;
    --ps-bg-table-hover: rgba(71, 85, 105, 0.04);
    --ps-bg-table-stripe: rgba(71, 85, 105, 0.02);

    /* Text */
    --ps-text-primary: #1E293B;
    --ps-text-secondary: #64748B;
    --ps-text-muted: #94A3B8;
    --ps-text-inverse: #FFFFFF;
    --ps-text-sidebar: #94A3B8;
    --ps-text-sidebar-active: #FFFFFF;
    --ps-text-sidebar-heading: #64748B;

    /* Borders */
    --ps-border: #E2E8F0;
    --ps-border-light: #F1F5F9;

    /* Neomorphism shadows — all disabled (flat) */
    --ps-neo-card: none;
    --ps-neo-card-hover: none;
    --ps-neo-inset: none;
    --ps-neo-btn: none;
    --ps-neo-btn-active: none;
    --ps-neo-sm: none;

    /* Flat shadows */
    --ps-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
    --ps-shadow-md: 0 1px 3px rgba(0, 0, 0, 0.1);
    --ps-shadow-lg: 0 4px 6px rgba(0, 0, 0, 0.1);
    --ps-shadow-card: none;

    /* Particles */
    --ps-particles-color: rgba(71, 85, 105, 0.08);
    --ps-particles-glow: rgba(71, 85, 105, 0.15);

    /* Scrollbar */
    --ps-scrollbar-thumb: #CBD5E1;
    --ps-scrollbar-thumb-hover: #94A3B8;

    /* Chart */
    --ps-chart-primary: #3B82F6;
    --ps-chart-grid: #E2E8F0;
}

/* ==================== DARK THEME ==================== */
[data-bs-theme="dark"] {
    --ps-primary: #94A3B8;
    --ps-primary-hover: #CBD5E1;
    --ps-primary-light: #1E293B;
    --ps-primary-rgb: 148, 163, 184;

    --ps-accent: #60A5FA;
    --ps-accent-hover: #93C5FD;
    --ps-accent-light: #1E3A5F;
    --ps-accent-rgb: 96, 165, 250;

    --ps-secondary: #8896B0;
    --ps-secondary-light: #252D3D;

    --ps-success: #34D399;
    --ps-success-light: #1A2E22;
    --ps-success-rgb: 52, 211, 153;

    --ps-warning: #FBBF24;
    --ps-warning-light: #2E2517;
    --ps-warning-rgb: 251, 191, 36;

    --ps-danger: #F87171;
    --ps-danger-light: #2E1A1A;
    --ps-danger-rgb: 248, 113, 113;

    --ps-info: #38BDF8;
    --ps-info-light: #1A2A30;
    --ps-info-rgb: 56, 189, 248;

    /* Surfaces — dark flat */
    --ps-bg-body: #0F172A;
    --ps-bg-card: #1E293B;
    --ps-bg-card-hover: #263548;
    --ps-bg-sidebar: linear-gradient(180deg, #0A1120, #0F172A);
    --ps-bg-sidebar-hover: rgba(255, 255, 255, 0.06);
    --ps-bg-sidebar-active: rgba(96, 165, 250, 0.12);
    --ps-bg-header: #1E293B;
    --ps-bg-input: #0F172A;
    --ps-bg-table-hover: rgba(148, 163, 184, 0.06);
    --ps-bg-table-stripe: rgba(148, 163, 184, 0.03);

    --ps-text-primary: #E2E8F0;
    --ps-text-secondary: #94A3B8;
    --ps-text-muted: #64748B;
    --ps-text-inverse: #0F172A;
    --ps-text-sidebar: #64748B;
    --ps-text-sidebar-active: #E2E8F0;
    --ps-text-sidebar-heading: #475569;

    --ps-border: #334155;
    --ps-border-light: #1E293B;

    /* Neomorphism shadows — all disabled (flat) */
    --ps-neo-card: none;
    --ps-neo-card-hover: none;
    --ps-neo-inset: none;
    --ps-neo-btn: none;
    --ps-neo-btn-active: none;
    --ps-neo-sm: none;

    --ps-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.2);
    --ps-shadow-md: 0 1px 3px rgba(0, 0, 0, 0.3);
    --ps-shadow-lg: 0 4px 6px rgba(0, 0, 0, 0.3);
    --ps-shadow-card: none;

    --ps-particles-color: rgba(96, 165, 250, 0.05);
    --ps-particles-glow: rgba(96, 165, 250, 0.1);

    --ps-scrollbar-thumb: #475569;
    --ps-scrollbar-thumb-hover: #64748B;

    --ps-chart-primary: #60A5FA;
    --ps-chart-grid: #334155;
}

/* ==================== BASE OVERRIDES ==================== */

body {
    background-color: var(--ps-bg-body) !important;
    color: var(--ps-text-primary) !important;
    font-family: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
    font-size: 0.9375rem;
}

/* ==================== CARDS — Flat with borders ==================== */

.card {
    background-color: var(--ps-bg-card) !important;
    border: 1px solid var(--ps-border) !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    transition: background-color 0.2s ease, border-color 0.2s ease;
}

.card:hover {
    background-color: var(--ps-bg-card-hover) !important;
    box-shadow: none !important;
}

/* Exception: gradient cards (dashboard KPI) keep their own style */
.card[style*="background: linear-gradient"],
.card[style*="background:linear-gradient"] {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12) !important;
    border: none !important;
}
.card[style*="background: linear-gradient"]:hover,
.card[style*="background:linear-gradient"]:hover {
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.16) !important;
}

.card-header {
    border-bottom: 1px solid var(--ps-border) !important;
    background: transparent !important;
}

[data-bs-theme="dark"] .card-header {
    border-bottom-color: var(--ps-border) !important;
}

.card-title, .card-label {
    color: var(--ps-text-primary) !important;
    font-weight: 700;
}

/* ==================== SIDEBAR — Dark gradient ==================== */

#kt_app_sidebar {
    background: var(--ps-bg-sidebar) !important;
    background-color: transparent !important;
    border-right: none !important;
    box-shadow: inset -1px 0 0 rgba(255, 255, 255, 0.06);
}

#kt_app_sidebar .menu-title {
    color: var(--ps-text-sidebar) !important;
    transition: color 0.2s ease;
}

#kt_app_sidebar .menu-link:hover .menu-title,
#kt_app_sidebar .menu-link.active .menu-title {
    color: var(--ps-text-sidebar-active) !important;
}

#kt_app_sidebar .menu-link:hover {
    background-color: var(--ps-bg-sidebar-hover) !important;
    border-radius: 0;
}

#kt_app_sidebar .menu-link.active {
    background-color: var(--ps-bg-sidebar-active) !important;
    border-radius: 0;
}

#kt_app_sidebar .menu-heading {
    color: var(--ps-text-sidebar-heading) !important;
    font-size: 0.6875rem !important;
    letter-spacing: 0.08em;
    font-weight: 700;
}

#kt_app_sidebar .menu-icon i {
    color: var(--ps-text-sidebar) !important;
}

#kt_app_sidebar .menu-link.active .menu-icon i,
#kt_app_sidebar .menu-link:hover .menu-icon i {
    color: var(--ps-accent) !important;
}

#kt_app_sidebar .bullet-dot {
    background-color: var(--ps-text-sidebar-heading) !important;
}

#kt_app_sidebar .menu-link.active .bullet-dot {
    background-color: var(--ps-accent) !important;
}

/* ==================== HEADER ==================== */

#kt_app_header {
    background-color: var(--ps-bg-header) !important;
    border-bottom: 1px solid var(--ps-border) !important;
    box-shadow: none !important;
}

/* ==================== TABLES ==================== */

.table {
    color: var(--ps-text-primary) !important;
}

.table > thead > tr > th {
    color: var(--ps-text-muted) !important;
    border-bottom-color: var(--ps-border) !important;
    font-size: 0.75rem !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.table > tbody > tr {
    border-bottom-color: var(--ps-border-light) !important;
    transition: background-color 0.15s ease;
    animation: tableRowFadeIn 0.4s ease both;
}

/* Stagger table rows — max 15 rows */
.table > tbody > tr:nth-child(1)  { animation-delay: 0ms; }
.table > tbody > tr:nth-child(2)  { animation-delay: 30ms; }
.table > tbody > tr:nth-child(3)  { animation-delay: 60ms; }
.table > tbody > tr:nth-child(4)  { animation-delay: 90ms; }
.table > tbody > tr:nth-child(5)  { animation-delay: 120ms; }
.table > tbody > tr:nth-child(6)  { animation-delay: 150ms; }
.table > tbody > tr:nth-child(7)  { animation-delay: 180ms; }
.table > tbody > tr:nth-child(8)  { animation-delay: 210ms; }
.table > tbody > tr:nth-child(9)  { animation-delay: 240ms; }
.table > tbody > tr:nth-child(10) { animation-delay: 270ms; }
.table > tbody > tr:nth-child(11) { animation-delay: 300ms; }
.table > tbody > tr:nth-child(12) { animation-delay: 330ms; }
.table > tbody > tr:nth-child(13) { animation-delay: 360ms; }
.table > tbody > tr:nth-child(14) { animation-delay: 390ms; }
.table > tbody > tr:nth-child(15) { animation-delay: 420ms; }

.table-hover > tbody > tr:hover,
.table > tbody > tr:hover {
    background-color: var(--ps-bg-table-hover) !important;
}

.table-row-dashed > tbody > tr {
    border-bottom-style: dashed !important;
    border-bottom-color: var(--ps-border-light) !important;
}

/* ==================== FORMS — Flat with borders ==================== */

.form-control, .form-select {
    background-color: var(--ps-bg-input) !important;
    border: 1px solid var(--ps-border) !important;
    box-shadow: none !important;
    color: var(--ps-text-primary) !important;
    border-radius: 0 !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.form-control-solid, .form-select-solid {
    background-color: var(--ps-bg-input) !important;
    border: 1px solid var(--ps-border) !important;
    box-shadow: none !important;
}

.form-control:focus, .form-select:focus,
.form-control-solid:focus, .form-select-solid:focus {
    border: 1px solid var(--ps-accent) !important;
    box-shadow: 0 0 0 3px rgba(var(--ps-accent-rgb), 0.15) !important;
    background-color: var(--ps-bg-input) !important;
}

.form-label {
    color: var(--ps-text-secondary) !important;
    font-weight: 600 !important;
    font-size: 0.875rem !important;
}

.form-text, .form-hint {
    color: var(--ps-text-muted) !important;
}

.form-check-input:checked {
    background-color: var(--ps-accent) !important;
    border-color: var(--ps-accent) !important;
}

/* ==================== BUTTONS — Flat, no shadows ==================== */

.btn {
    border-radius: 0 !important;
    font-weight: 600;
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.btn-primary {
    background-color: var(--ps-accent) !important;
    border: none !important;
    color: var(--ps-text-inverse) !important;
    box-shadow: none !important;
}
.btn-primary:hover, .btn-primary:focus {
    background-color: var(--ps-accent-hover) !important;
    border: none !important;
    box-shadow: none !important;
}
.btn-primary:active {
    box-shadow: none !important;
}

.btn-light-primary {
    background-color: var(--ps-accent-light) !important;
    color: var(--ps-accent) !important;
    border: none !important;
    box-shadow: none !important;
}
.btn-light-primary:hover {
    background-color: var(--ps-accent) !important;
    color: var(--ps-text-inverse) !important;
}

.btn-success {
    background-color: var(--ps-success) !important;
    border: none !important;
    box-shadow: none !important;
}
.btn-success:hover { background-color: var(--ps-success) !important; filter: brightness(0.9); }
.btn-success:active { box-shadow: none !important; }
.btn-light-success { background-color: var(--ps-success-light) !important; color: var(--ps-success) !important; border: none !important; box-shadow: none !important; }
.btn-light-success:hover { background-color: var(--ps-success) !important; color: var(--ps-text-inverse) !important; }

.btn-danger {
    background-color: var(--ps-danger) !important;
    border: none !important;
    box-shadow: none !important;
}
.btn-danger:hover { background-color: var(--ps-danger) !important; filter: brightness(0.9); }
.btn-danger:active { box-shadow: none !important; }
.btn-light-danger { background-color: var(--ps-danger-light) !important; color: var(--ps-danger) !important; border: none !important; box-shadow: none !important; }
.btn-light-danger:hover { background-color: var(--ps-danger) !important; color: var(--ps-text-inverse) !important; }

.btn-warning {
    background-color: var(--ps-warning) !important;
    border: none !important;
    color: var(--ps-text-inverse) !important;
    box-shadow: none !important;
}
.btn-warning:hover { background-color: var(--ps-warning) !important; filter: brightness(0.9); }
.btn-warning:active { box-shadow: none !important; }
.btn-light-warning { background-color: var(--ps-warning-light) !important; color: var(--ps-warning) !important; border: none !important; box-shadow: none !important; }
.btn-light-warning:hover { background-color: var(--ps-warning) !important; color: var(--ps-text-inverse) !important; }

.btn-info {
    background-color: var(--ps-info) !important;
    border: none !important;
    color: var(--ps-text-inverse) !important;
    box-shadow: none !important;
}
.btn-info:active { box-shadow: none !important; }
.btn-light-info { background-color: var(--ps-info-light) !important; color: var(--ps-info) !important; border: none !important; box-shadow: none !important; }
.btn-light-info:hover { background-color: var(--ps-info) !important; color: var(--ps-text-inverse) !important; }

.btn-light {
    background-color: var(--ps-bg-input) !important;
    color: var(--ps-text-secondary) !important;
    border: 1px solid var(--ps-border) !important;
    box-shadow: none !important;
}
.btn-light:hover {
    background-color: var(--ps-bg-card-hover) !important;
    color: var(--ps-text-primary) !important;
}
.btn-light:active { box-shadow: none !important; }

/* ==================== BADGES ==================== */

.badge {
    border-radius: 0 !important;
}

.badge-light-primary { background-color: var(--ps-accent-light) !important; color: var(--ps-accent) !important; }
.badge-light-success { background-color: var(--ps-success-light) !important; color: var(--ps-success) !important; }
.badge-light-warning { background-color: var(--ps-warning-light) !important; color: var(--ps-warning) !important; }
.badge-light-danger { background-color: var(--ps-danger-light) !important; color: var(--ps-danger) !important; }
.badge-light-info { background-color: var(--ps-info-light) !important; color: var(--ps-info) !important; }
.badge-light-secondary { background-color: var(--ps-secondary-light) !important; color: var(--ps-secondary) !important; }
.badge-light-dark {
    background-color: var(--ps-secondary-light) !important;
    color: var(--ps-text-primary) !important;
}

.badge-primary { background-color: var(--ps-accent) !important; }
.badge-success { background-color: var(--ps-success) !important; }
.badge-warning { background-color: var(--ps-warning) !important; }
.badge-danger { background-color: var(--ps-danger) !important; }
.badge-info { background-color: var(--ps-info) !important; }

/* ==================== TEXT COLORS ==================== */

.text-primary { color: var(--ps-accent) !important; }
.text-success { color: var(--ps-success) !important; }
.text-warning { color: var(--ps-warning) !important; }
.text-danger { color: var(--ps-danger) !important; }
.text-info { color: var(--ps-info) !important; }
.text-muted { color: var(--ps-text-muted) !important; }
.text-gray-500 { color: var(--ps-text-muted) !important; }
.text-gray-600 { color: var(--ps-text-secondary) !important; }
.text-gray-700 { color: var(--ps-text-secondary) !important; }
.text-gray-800 { color: var(--ps-text-primary) !important; }
.text-gray-900 { color: var(--ps-text-primary) !important; }
.text-dark { color: var(--ps-text-primary) !important; }

/* ==================== BACKGROUNDS ==================== */

.bg-light { background-color: var(--ps-bg-input) !important; }
.bg-light-primary { background-color: var(--ps-accent-light) !important; }
.bg-light-success { background-color: var(--ps-success-light) !important; }
.bg-light-warning { background-color: var(--ps-warning-light) !important; }
.bg-light-danger { background-color: var(--ps-danger-light) !important; }
.bg-light-info { background-color: var(--ps-info-light) !important; }
.bg-primary { background-color: var(--ps-accent) !important; }

/* ==================== SEPARATORS ==================== */

.separator {
    border-color: var(--ps-border) !important;
}

/* ==================== SCROLLBARS ==================== */

::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--ps-scrollbar-thumb); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--ps-scrollbar-thumb-hover); }

/* ==================== ALERTS — Flat with left border ==================== */

.alert-danger {
    background-color: var(--ps-danger-light) !important;
    border: none !important;
    border-left: 3px solid var(--ps-danger) !important;
    box-shadow: none !important;
    color: var(--ps-danger) !important;
    border-radius: 0 !important;
}
.alert-success {
    background-color: var(--ps-success-light) !important;
    border: none !important;
    border-left: 3px solid var(--ps-success) !important;
    box-shadow: none !important;
    color: var(--ps-success) !important;
    border-radius: 0 !important;
}
.alert-warning {
    background-color: var(--ps-warning-light) !important;
    border: none !important;
    border-left: 3px solid var(--ps-warning) !important;
    box-shadow: none !important;
    color: var(--ps-warning) !important;
    border-radius: 0 !important;
}
.alert-info {
    background-color: var(--ps-info-light) !important;
    border: none !important;
    border-left: 3px solid var(--ps-info) !important;
    box-shadow: none !important;
    color: var(--ps-info) !important;
    border-radius: 0 !important;
}

/* ==================== NOTICE BANNERS ==================== */

.notice.border-primary { border-color: var(--ps-accent) !important; }
.notice.border-warning { border-color: var(--ps-warning) !important; }
.notice.border-info { border-color: var(--ps-info) !important; }

/* ==================== FOOTER ==================== */

#kt_app_footer {
    background-color: var(--ps-bg-card) !important;
    border-top: 1px solid var(--ps-border) !important;
    box-shadow: none !important;
}

/* ==================== TOOLBAR ==================== */

#kt_app_toolbar {
    background-color: transparent !important;
}

.page-heading {
    color: var(--ps-text-primary) !important;
    font-weight: 800;
}

.breadcrumb-item.text-muted,
.breadcrumb-item.text-muted a {
    color: var(--ps-text-muted) !important;
}
.breadcrumb-item.text-muted a:hover {
    color: var(--ps-accent) !important;
}

/* ==================== DROPDOWN MENUS ==================== */

.menu-sub-dropdown {
    background-color: var(--ps-bg-card) !important;
    border: 1px solid var(--ps-border) !important;
    box-shadow: var(--ps-shadow-md) !important;
    border-radius: 0 !important;
}

.menu-link:hover {
    background-color: var(--ps-bg-table-hover) !important;
}

/* ==================== MODALS ==================== */

.modal-content {
    background-color: var(--ps-bg-card) !important;
    border: 1px solid var(--ps-border) !important;
    box-shadow: var(--ps-shadow-lg) !important;
    border-radius: 0 !important;
}
.modal-header {
    border-bottom-color: var(--ps-border) !important;
}
.modal-footer {
    border-top-color: var(--ps-border) !important;
}
[data-bs-theme="dark"] .modal-header {
    border-bottom-color: var(--ps-border) !important;
}
[data-bs-theme="dark"] .modal-footer {
    border-top-color: var(--ps-border) !important;
}

/* ==================== PAGINATION ==================== */

.page-link {
    background-color: var(--ps-bg-card) !important;
    border: 1px solid var(--ps-border) !important;
    box-shadow: none !important;
    color: var(--ps-text-secondary) !important;
    border-radius: 0 !important;
    margin: 0 2px;
}
.page-link:hover {
    background-color: var(--ps-accent-light) !important;
    color: var(--ps-accent) !important;
    border-color: var(--ps-accent) !important;
}
.page-item.active .page-link {
    background-color: var(--ps-accent) !important;
    border: 1px solid var(--ps-accent) !important;
    color: var(--ps-text-inverse) !important;
    box-shadow: none !important;
}

/* ==================== HOVER ELEVATE ==================== */

.hover-elevate-up {
    transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}
.hover-elevate-up:hover {
    transform: translateY(-2px);
    box-shadow: var(--ps-shadow-md) !important;
}

/* ==================== SELECT2 ==================== */

.select2-container--bootstrap-5 .select2-selection {
    background-color: var(--ps-bg-input) !important;
    border: 1px solid var(--ps-border) !important;
    box-shadow: none !important;
    color: var(--ps-text-primary) !important;
    border-radius: 0 !important;
}
.select2-container--bootstrap-5 .select2-dropdown {
    background-color: var(--ps-bg-card) !important;
    border: 1px solid var(--ps-border) !important;
    box-shadow: var(--ps-shadow-md) !important;
    border-radius: 0 !important;
}
.select2-container--bootstrap-5 .select2-results__option--highlighted {
    background-color: var(--ps-accent-light) !important;
    color: var(--ps-accent) !important;
}

/* ==================== SWEETALERT2 DARK ==================== */

[data-bs-theme="dark"] .swal2-popup {
    background-color: var(--ps-bg-card) !important;
    color: var(--ps-text-primary) !important;
    box-shadow: var(--ps-shadow-lg) !important;
}
[data-bs-theme="dark"] .swal2-title {
    color: var(--ps-text-primary) !important;
}
[data-bs-theme="dark"] .swal2-html-container {
    color: var(--ps-text-secondary) !important;
}

/* ==================== THEME TOGGLE ==================== */

.theme-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 0;
    border: 1px solid var(--ps-border);
    background-color: var(--ps-bg-input);
    color: var(--ps-text-secondary);
    cursor: pointer;
    box-shadow: none;
    transition: border-color 0.2s ease, color 0.2s ease;
}
.theme-toggle:hover {
    color: var(--ps-accent);
    border-color: var(--ps-accent);
    box-shadow: none !important;
}
.theme-toggle:active {
    box-shadow: none !important;
}
.theme-toggle .icon-sun,
.theme-toggle .icon-moon {
    transition: opacity 0.2s ease, transform 0.3s ease;
}
[data-bs-theme="light"] .theme-toggle .icon-sun { display: none; }
[data-bs-theme="light"] .theme-toggle .icon-moon { display: block; }
[data-bs-theme="dark"] .theme-toggle .icon-sun { display: block; }
[data-bs-theme="dark"] .theme-toggle .icon-moon { display: none; }

/* ==================== STAT CARD ==================== */

.stat-card {
    position: relative;
    overflow: hidden;
    border-radius: 0 !important;
}
.stat-card .stat-icon {
    width: 48px;
    height: 48px;
    border-radius: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    flex-shrink: 0;
}
.stat-card .stat-value {
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.2;
    color: var(--ps-text-primary);
}
.stat-card .stat-label {
    font-size: 0.8125rem;
    color: var(--ps-text-muted);
    font-weight: 500;
    margin-top: 0.25rem;
}
.stat-card.stat-card-link {
    cursor: pointer;
    text-decoration: none;
}
.stat-card.stat-card-link:hover {
    background-color: var(--ps-bg-card-hover) !important;
}

/* ==================== FILTER BAR ==================== */

.filter-bar {
    background-color: var(--ps-bg-card);
    border: 1px solid var(--ps-border);
    box-shadow: none;
    border-radius: 0;
    padding: 1rem 1.25rem;
    margin-bottom: 1.25rem;
}

/* ==================== DETAIL ROW ==================== */

.detail-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.5rem 0;
}
.detail-row + .detail-row {
    border-top: 1px dashed var(--ps-border-light);
}
.detail-row .detail-label {
    font-size: 0.8125rem;
    color: var(--ps-text-muted);
    font-weight: 500;
}
.detail-row .detail-value {
    font-weight: 600;
    color: var(--ps-text-primary);
    text-align: right;
}

/* ==================== ANIMATIONS ==================== */

@keyframes cardFadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes tableRowFadeIn {
    from {
        opacity: 0;
        transform: translateY(5px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Card fade-in with stagger per column */
.row > [class*="col-"] > .card,
.row > [class*="col"] > .card {
    animation: cardFadeIn 0.5s ease both;
}
.row > [class*="col"]:nth-child(1) > .card { animation-delay: 0ms; }
.row > [class*="col"]:nth-child(2) > .card { animation-delay: 50ms; }
.row > [class*="col"]:nth-child(3) > .card { animation-delay: 100ms; }
.row > [class*="col"]:nth-child(4) > .card { animation-delay: 150ms; }
.row > [class*="col"]:nth-child(5) > .card { animation-delay: 200ms; }
.row > [class*="col"]:nth-child(6) > .card { animation-delay: 250ms; }
.row > [class*="col"]:nth-child(7) > .card { animation-delay: 300ms; }
.row > [class*="col"]:nth-child(8) > .card { animation-delay: 350ms; }

/* ==================== TRANSITIONS ==================== */

* {
    transition-property: background-color, border-color, color, box-shadow;
    transition-duration: 0s;
}

body, .card, #kt_app_header, #kt_app_sidebar, #kt_app_footer,
.form-control, .form-select, .btn, .badge, .table, .modal-content,
.separator, .page-link, .alert, .menu-sub-dropdown, .stat-card {
    transition-duration: 0.3s;
    transition-timing-function: ease;
}

/* Prevent transition flash on page load */
body.no-transitions * {
    transition-duration: 0s !important;
}

/* ==================== PRINT ==================== */

@media print {
    .card {
        box-shadow: none !important;
        border: 1px solid #ddd !important;
    }
    .table > tbody > tr { animation: none !important; }
}
