/* =========================================================
 * app-polish.css — system-wide visual polish + animations
 * Loaded globally by src/Views/layout.php so every page in
 * Billing / CRM / NOC / FieldOps / HR / Inventory / Dashboard
 * inherits the same modern, sleek, premium feel that the
 * inventory dashboard pioneered — without touching any view.
 *
 * Hooks (ALL OPTIONAL — every selector targets classes already
 * widely used across the codebase):
 *   .app-reveal                  reveal-on-scroll fade+rise
 *   .page-section-card / .card   gentle hover lift + shine
 *   .app-metric-card             premium KPI tile (gradient rail,
 *                                hover glow, count-up via JS)
 *   .metric-value                auto-animated number on first
 *                                view when contents parse as a number
 *   .app-kpi-grid                staggered child reveal
 *   .card[class*="-hero"]        hero shimmer + safe contrast
 *   .table tbody tr              soft row highlight on hover
 *   .btn                         consistent micro-interaction
 * ========================================================= */

/* ---------- Reveal-on-scroll (also auto-applied via JS) ---- */
.app-reveal {
    opacity: 0;
    transform: translate3d(0, 14px, 0);
    transition:
        opacity .55s cubic-bezier(.22,.61,.36,1),
        transform .55s cubic-bezier(.22,.61,.36,1);
    will-change: opacity, transform;
}
.app-reveal.is-visible {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}
/* Stagger children inside KPI rows / grids */
.app-kpi-grid > .app-reveal,
.app-kpi-grid .col,
.app-kpi-grid [class*="col-"] {
    --app-reveal-delay: 0ms;
}
.app-kpi-grid > *:nth-child(1) { --app-reveal-delay: 0ms; }
.app-kpi-grid > *:nth-child(2) { --app-reveal-delay: 70ms; }
.app-kpi-grid > *:nth-child(3) { --app-reveal-delay: 140ms; }
.app-kpi-grid > *:nth-child(4) { --app-reveal-delay: 210ms; }
.app-kpi-grid > *:nth-child(5) { --app-reveal-delay: 280ms; }
.app-kpi-grid > *:nth-child(6) { --app-reveal-delay: 350ms; }
.app-kpi-grid > *:nth-child(7) { --app-reveal-delay: 420ms; }
.app-kpi-grid > *:nth-child(8) { --app-reveal-delay: 490ms; }
.app-reveal { transition-delay: var(--app-reveal-delay, 0ms); }

@media (prefers-reduced-motion: reduce) {
    .app-reveal { opacity: 1; transform: none; transition: none; }
    .app-count-up { animation: none !important; }
}

/* ---------- Card hover lift + subtle shine ---------------- */
html[data-theme] .page-section-card,
html[data-theme] .module-card,
html[data-theme] .app-metric-card,
html[data-theme] .dashboard-stat-card {
    position: relative;
    transition:
        transform .22s cubic-bezier(.22,.61,.36,1),
        box-shadow .22s cubic-bezier(.22,.61,.36,1),
        border-color .22s ease;
}
html[data-theme] .page-section-card:hover,
html[data-theme] .module-card:hover,
html[data-theme] .app-metric-card:hover,
html[data-theme] .dashboard-stat-card:hover {
    transform: translateY(-3px);
    box-shadow:
        0 22px 50px rgba(15, 23, 42, 0.10),
        0 4px 12px rgba(15, 23, 42, 0.06);
}

/* Anchor wrapper cards (clickable KPIs) get cursor + brighter hover */
html[data-theme] a.page-section-card,
html[data-theme] a.app-metric-card,
html[data-theme] a.module-card {
    cursor: pointer;
}
html[data-theme] a.app-metric-card::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--primary) 14%, transparent),
        transparent 55%);
    opacity: 0;
    transition: opacity .22s ease;
    pointer-events: none;
}
html[data-theme] a.app-metric-card:hover::after { opacity: 1; }

/* ---------- Premium KPI tile rail (color-coded) ----------- */
html[data-theme] .app-metric-card,
html[data-theme] .dashboard-stat-card {
    overflow: hidden;
    isolation: isolate;
}
html[data-theme] .app-metric-card::before,
html[data-theme] .dashboard-stat-card::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 4px;
    background: linear-gradient(180deg, var(--primary), var(--accent));
    border-radius: inherit 0 0 inherit;
    opacity: .85;
}
html[data-theme] .app-metric-card.tone-success::before,
html[data-theme] .dashboard-stat-card.tone-success::before { background: linear-gradient(180deg, #16a34a, #4ade80); }
html[data-theme] .app-metric-card.tone-warning::before,
html[data-theme] .dashboard-stat-card.tone-warning::before { background: linear-gradient(180deg, #d97706, #fbbf24); }
html[data-theme] .app-metric-card.tone-danger::before,
html[data-theme] .dashboard-stat-card.tone-danger::before  { background: linear-gradient(180deg, #dc2626, #f87171); }
html[data-theme] .app-metric-card.tone-info::before,
html[data-theme] .dashboard-stat-card.tone-info::before    { background: linear-gradient(180deg, #0ea5e9, #38bdf8); }
html[data-theme] .app-metric-card.tone-purple::before,
html[data-theme] .dashboard-stat-card.tone-purple::before  { background: linear-gradient(180deg, #7c3aed, #a78bfa); }

/* metric-value count-up + tabular figures for clean ticking */
html[data-theme] .metric-value,
html[data-theme] [data-app-count] {
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum" 1;
    letter-spacing: -.015em;
}

/* ---------- Hero card polish (works with all *-hero) ------ */
html[data-theme] .card[class*="-hero"],
html[data-theme] section[class*="-hero"] {
    position: relative;
    overflow: hidden;
}
html[data-theme] .card[class*="-hero"]::after,
html[data-theme] section[class*="-hero"]::after {
    content: "";
    position: absolute;
    top: -50%;
    right: -20%;
    width: 60%;
    height: 200%;
    background: linear-gradient(115deg,
        transparent 35%,
        rgba(255,255,255,0.06) 50%,
        transparent 65%);
    transform: translateX(-30%) rotate(8deg);
    pointer-events: none;
    animation: appHeroShine 8s ease-in-out infinite;
}
@keyframes appHeroShine {
    0%, 100% { transform: translateX(-30%) rotate(8deg); opacity: 0; }
    50%      { transform: translateX( 60%) rotate(8deg); opacity: 1; }
}

/* ---------- Card header refinement ------------------------ */
html[data-theme] .page-section-card > .card-header,
html[data-theme] .module-card > .card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    padding: .9rem 1.15rem;
    font-weight: 700;
    letter-spacing: -.005em;
}
html[data-theme] .page-section-card > .card-header::before {
    content: "";
    display: inline-block;
    width: 4px;
    height: 18px;
    border-radius: 2px;
    background: linear-gradient(180deg, var(--primary), var(--accent));
    margin-right: .65rem;
    flex-shrink: 0;
}

/* ---------- Tables: soft hover + sticky-ish header --------- */
html[data-theme] .page-section-card .table,
html[data-theme] .module-card .table {
    margin-bottom: 0;
}
html[data-theme] .table tbody tr {
    transition: background .18s ease, transform .18s ease;
}
html[data-theme] .table tbody tr:hover {
    background: color-mix(in srgb, var(--primary) 6%, transparent) !important;
}

/* ---------- Buttons: tactile micro-interaction ------------ */
html[data-theme] .btn {
    transition:
        transform .15s cubic-bezier(.22,.61,.36,1),
        box-shadow .15s ease,
        background .15s ease,
        border-color .15s ease,
        color .15s ease,
        filter .15s ease;
}
html[data-theme] .btn:hover {
    transform: translateY(-1px);
}
html[data-theme] .btn:active {
    transform: translateY(0);
}
html[data-theme] .btn-primary,
html[data-theme] .btn-success,
html[data-theme] .btn-warning,
html[data-theme] .btn-danger {
    box-shadow: 0 8px 18px rgba(15, 23, 42, .08);
}
html[data-theme] .btn-primary:hover,
html[data-theme] .btn-success:hover,
html[data-theme] .btn-warning:hover,
html[data-theme] .btn-danger:hover {
    box-shadow: 0 14px 26px rgba(15, 23, 42, .12);
    filter: brightness(1.04);
}

/* ---------- Form polish ----------------------------------- */
html[data-theme] .form-control,
html[data-theme] .form-select,
html[data-theme] textarea {
    transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

/* ---------- Inline pulse dot ------------------------------ */
.app-pulse-dot {
    display: inline-block;
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--success, #22c55e);
    box-shadow: 0 0 0 0 color-mix(in srgb, var(--success, #22c55e) 60%, transparent);
    animation: appPulse 1.6s ease-out infinite;
}
@keyframes appPulse {
    0%   { box-shadow: 0 0 0 0   color-mix(in srgb, var(--success, #22c55e) 55%, transparent); }
    70%  { box-shadow: 0 0 0 10px color-mix(in srgb, var(--success, #22c55e) 0%, transparent); }
    100% { box-shadow: 0 0 0 0   color-mix(in srgb, var(--success, #22c55e) 0%, transparent); }
}

/* ---------- Skeleton shimmer (for any [data-app-skeleton]) - */
[data-app-skeleton] {
    background: linear-gradient(90deg,
        color-mix(in srgb, var(--surface-2) 70%, transparent) 0%,
        color-mix(in srgb, var(--surface-2) 35%, transparent) 50%,
        color-mix(in srgb, var(--surface-2) 70%, transparent) 100%);
    background-size: 200% 100%;
    animation: appSkeleton 1.4s ease-in-out infinite;
    border-radius: 8px;
    color: transparent !important;
    pointer-events: none;
}
@keyframes appSkeleton {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* ---------- Toast (auto-mounted by app-polish.js) --------- */
.app-toast-host {
    position: fixed;
    z-index: 4000;
    right: 18px;
    bottom: 18px;
    display: grid;
    gap: .55rem;
    pointer-events: none;
}
.app-toast {
    pointer-events: auto;
    min-width: 240px;
    max-width: 360px;
    padding: .7rem .9rem;
    border-radius: 12px;
    background: var(--card-bg, #fff);
    color: var(--text, #0f172a);
    border: 1px solid var(--border, #e5e7eb);
    border-left: 4px solid var(--primary, #2563eb);
    box-shadow: 0 18px 40px rgba(15, 23, 42, .14);
    font-size: .9rem;
    transform: translateY(8px);
    opacity: 0;
    transition: opacity .22s ease, transform .22s ease;
}
.app-toast.is-visible { opacity: 1; transform: translateY(0); }
.app-toast.tone-success { border-left-color: var(--success, #22c55e); }
.app-toast.tone-warning { border-left-color: var(--warning, #f59e0b); }
.app-toast.tone-danger  { border-left-color: var(--danger,  #ef4444); }

/* ---------- Auto-save indicator --------------------------- */
.app-autosave-pill {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .25rem .6rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--primary) 10%, transparent);
    color: var(--primary, #2563eb);
    font-size: .74rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
}
.app-autosave-pill::before {
    content: "";
    width: 6px; height: 6px; border-radius: 50%;
    background: var(--primary, #2563eb);
}
.app-autosave-pill.is-saving { color: var(--warning, #f59e0b); background: color-mix(in srgb, var(--warning, #f59e0b) 12%, transparent); }
.app-autosave-pill.is-saving::before { background: var(--warning, #f59e0b); animation: appPulse 1.2s infinite; }
.app-autosave-pill.is-saved  { color: var(--success, #22c55e); background: color-mix(in srgb, var(--success, #22c55e) 12%, transparent); }
.app-autosave-pill.is-saved::before  { background: var(--success, #22c55e); }

/* ---------- Responsive nudges ----------------------------- */
@media (max-width: 767.98px) {
    html[data-theme] .page-section-card:hover,
    html[data-theme] .module-card:hover,
    html[data-theme] .app-metric-card:hover {
        transform: none;
    }
    html[data-theme] .card[class*="-hero"]::after { display: none; }
}

/* =========================================================
 * v2 — Lively polish layer for Billing & Finance pages
 * Auto-applies to every page that uses the existing class
 * namespaces (.bw-*, .finance-*, .advance-*, .inventory-*,
 * .hr-*, .invoice-*, .sl-*, .budget-*) — no view edits needed.
 * ========================================================= */

/* ---------- Universal stat-card lift + gradient rail ------ */
html[data-theme] .bw-stat-card,
html[data-theme] .finance-pill,
html[data-theme] .finance-kpi,
html[data-theme] .finance-insight,
html[data-theme] .advance-stat-card,
html[data-theme] .inventory-stat-card,
html[data-theme] .hr-stat-card,
html[data-theme] .sl-stat-card,
html[data-theme] .crmd-stat-card,
html[data-theme] .crml-kpi,
html[data-theme] .noc-stat-card,
html[data-theme] .invoice-kpi-card {
    position: relative;
    overflow: hidden;
    transition:
        transform .24s cubic-bezier(.22,.61,.36,1),
        box-shadow .24s cubic-bezier(.22,.61,.36,1),
        border-color .24s ease;
}
html[data-theme] .bw-stat-card::before,
html[data-theme] .finance-pill::before,
html[data-theme] .finance-kpi::before,
html[data-theme] .advance-stat-card::before,
html[data-theme] .inventory-stat-card::before,
html[data-theme] .hr-stat-card::before {
    content: "";
    position: absolute;
    inset: auto 0 0 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, rgba(59,130,246,.55), rgba(20,184,166,.55), transparent);
    transform: scaleX(.2);
    transform-origin: left;
    transition: transform .55s cubic-bezier(.22,.61,.36,1);
    opacity: .65;
}
html[data-theme] .bw-stat-card:hover,
html[data-theme] .finance-pill:hover,
html[data-theme] .finance-kpi:hover,
html[data-theme] .finance-insight:hover,
html[data-theme] .advance-stat-card:hover,
html[data-theme] .inventory-stat-card:hover,
html[data-theme] .hr-stat-card:hover,
html[data-theme] .sl-stat-card:hover,
html[data-theme] .crmd-stat-card:hover,
html[data-theme] .crml-kpi:hover,
html[data-theme] .noc-stat-card:hover,
html[data-theme] .invoice-kpi-card:hover {
    transform: translateY(-4px);
    box-shadow:
        0 24px 56px rgba(15, 23, 42, 0.12),
        0 6px 14px rgba(15, 23, 42, 0.06);
    border-color: rgba(59,130,246,.28);
}
html[data-theme] .bw-stat-card:hover::before,
html[data-theme] .finance-pill:hover::before,
html[data-theme] .finance-kpi:hover::before,
html[data-theme] .advance-stat-card:hover::before,
html[data-theme] .inventory-stat-card:hover::before,
html[data-theme] .hr-stat-card:hover::before {
    transform: scaleX(1);
}

/* ---------- Hero shimmer (sweep across) ------------------- */
@keyframes appHeroSweep {
    0%   { transform: translateX(-120%) skewX(-18deg); opacity: 0; }
    35%  { opacity: .55; }
    70%  { opacity: .25; }
    100% { transform: translateX(220%) skewX(-18deg); opacity: 0; }
}
html[data-theme] .bw-hero,
html[data-theme] .finance-hero,
html[data-theme] .advance-hero,
html[data-theme] .inventory-hero,
html[data-theme] .hr-hero,
html[data-theme] .crmd-hero,
html[data-theme] .crml-hero,
html[data-theme] .crmw-hero,
html[data-theme] .noc-hero,
html[data-theme] .fwo-hero {
    position: relative;
    overflow: hidden;
}
html[data-theme] .bw-hero::after,
html[data-theme] .finance-hero::after,
html[data-theme] .advance-hero::after,
html[data-theme] .inventory-hero::after,
html[data-theme] .hr-hero::after,
html[data-theme] .crmd-hero::after,
html[data-theme] .crml-hero::after,
html[data-theme] .noc-hero::after,
html[data-theme] .fwo-hero::after {
    content: "";
    position: absolute;
    top: 0; bottom: 0; left: 0;
    width: 36%;
    background: linear-gradient(
        90deg,
        transparent,
        rgba(255, 255, 255, 0.55),
        transparent
    );
    pointer-events: none;
    animation: appHeroSweep 5.6s ease-in-out 1.2s infinite;
    mix-blend-mode: overlay;
}

/* ---------- Sticky table headers across workspaces -------- */
html[data-theme] .bw-table thead th,
html[data-theme] .invoice-table thead th,
html[data-theme] .advance-table thead th,
html[data-theme] .inventory-table thead th,
html[data-theme] .sl-table thead th,
html[data-theme] .hr-table-shell-body table thead th,
html[data-theme] .page-section-card .table-responsive table thead th {
    position: sticky;
    top: 0;
    z-index: 2;
    -webkit-backdrop-filter: blur(6px);
    backdrop-filter: blur(6px);
}

/* ---------- Smooth row hover with gradient kiss ----------- */
html[data-theme] .bw-table tbody tr,
html[data-theme] .invoice-table tbody tr,
html[data-theme] .advance-table tbody tr,
html[data-theme] .inventory-table tbody tr,
html[data-theme] .sl-table tbody tr,
html[data-theme] .page-section-card .table tbody tr {
    transition: background-color .18s ease, transform .18s ease, box-shadow .18s ease;
}
html[data-theme] .bw-table tbody tr:hover,
html[data-theme] .invoice-table tbody tr:hover,
html[data-theme] .advance-table tbody tr:hover,
html[data-theme] .inventory-table tbody tr:hover,
html[data-theme] .sl-table tbody tr:hover,
html[data-theme] .page-section-card .table tbody tr:hover {
    background: linear-gradient(90deg, rgba(59,130,246,.06), rgba(20,184,166,.04));
    box-shadow: inset 3px 0 0 rgba(59,130,246,.45);
}

/* ---------- KPI value count-up pop-in --------------------- */
@keyframes appKpiPop {
    0%   { transform: scale(.92); opacity: 0; }
    65%  { transform: scale(1.04); opacity: 1; }
    100% { transform: scale(1); }
}
html[data-theme] .bw-stat-card.is-visible .bw-stat-card__value,
html[data-theme] .finance-pill.is-visible strong,
html[data-theme] .finance-kpi.is-visible .display-5,
html[data-theme] .advance-stat-card.is-visible strong,
html[data-theme] .inventory-stat-card.is-visible strong,
html[data-theme] .hr-stat-card.is-visible .hr-stat-value {
    display: inline-block;
    animation: appKpiPop .55s cubic-bezier(.22,.61,.36,1) both;
}

/* ---------- Status badge pulse for danger / warning ------- */
@keyframes appBadgePulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.45); }
    50%      { box-shadow: 0 0 0 6px rgba(239, 68, 68, 0); }
}
@keyframes appBadgePulseWarn {
    0%, 100% { box-shadow: 0 0 0 0 rgba(245, 158, 11, 0.45); }
    50%      { box-shadow: 0 0 0 6px rgba(245, 158, 11, 0); }
}
html[data-theme] .badge.bg-danger,
html[data-theme] .badge.text-bg-danger,
html[data-theme] .sl-badge--danger {
    animation: appBadgePulse 2.2s ease-in-out infinite;
}
html[data-theme] .badge.bg-warning,
html[data-theme] .badge.text-bg-warning,
html[data-theme] .sl-badge--warning {
    animation: appBadgePulseWarn 2.4s ease-in-out infinite;
}

/* ---------- Form focus ring (premium glow) ---------------- */
html[data-theme] .bw-board .form-control:focus,
html[data-theme] .bw-board .form-select:focus,
html[data-theme] .advance-board .form-control:focus,
html[data-theme] .advance-board .form-select:focus,
html[data-theme] .inventory-workspace .form-control:focus,
html[data-theme] .inventory-workspace .form-select:focus,
html[data-theme] .hr-workspace .form-control:focus,
html[data-theme] .hr-workspace .form-select:focus,
html[data-theme] .container-fluid .page-section-card .form-control:focus,
html[data-theme] .container-fluid .page-section-card .form-select:focus {
    border-color: rgba(59, 130, 246, .55);
    box-shadow:
        0 0 0 4px rgba(59, 130, 246, .14),
        0 4px 12px rgba(59, 130, 246, .08);
    transition: border-color .15s ease, box-shadow .2s ease;
}

/* ---------- Button micro-interaction ---------------------- */
html[data-theme] .bw-board .btn,
html[data-theme] .advance-board .btn,
html[data-theme] .inventory-workspace .btn,
html[data-theme] .hr-workspace .btn,
html[data-theme] .finance-hero ~ * .btn,
html[data-theme] .container-fluid .page-section-card .btn {
    transition:
        transform .15s cubic-bezier(.22,.61,.36,1),
        box-shadow .18s ease,
        filter .15s ease;
}
html[data-theme] .bw-board .btn:not(.btn-link):hover,
html[data-theme] .advance-board .btn:not(.btn-link):hover,
html[data-theme] .inventory-workspace .btn:not(.btn-link):hover,
html[data-theme] .hr-workspace .btn:not(.btn-link):hover,
html[data-theme] .container-fluid .page-section-card .btn:not(.btn-link):hover {
    transform: translateY(-2px);
    filter: brightness(1.04);
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.12);
}
html[data-theme] .bw-board .btn:not(.btn-link):active,
html[data-theme] .advance-board .btn:not(.btn-link):active,
html[data-theme] .inventory-workspace .btn:not(.btn-link):active,
html[data-theme] .hr-workspace .btn:not(.btn-link):active {
    transform: translateY(0);
}

/* ---------- Section card unified hover lift --------------- */
html[data-theme] .bw-form-card,
html[data-theme] .bw-table-card,
html[data-theme] .bw-lane-card,
html[data-theme] .advance-detail-card,
html[data-theme] .advance-intel-card,
html[data-theme] .advance-lane-card,
html[data-theme] .advance-table-card,
html[data-theme] .inventory-card,
html[data-theme] .hr-panel,
html[data-theme] .hr-form-shell,
html[data-theme] .hr-table-shell {
    transition:
        transform .22s cubic-bezier(.22,.61,.36,1),
        box-shadow .22s cubic-bezier(.22,.61,.36,1);
}
html[data-theme] .bw-form-card:hover,
html[data-theme] .bw-table-card:hover,
html[data-theme] .bw-lane-card:hover,
html[data-theme] .advance-detail-card:hover,
html[data-theme] .advance-intel-card:hover,
html[data-theme] .advance-lane-card:hover,
html[data-theme] .inventory-card:hover,
html[data-theme] .hr-panel:hover,
html[data-theme] .hr-form-shell:hover,
html[data-theme] .hr-table-shell:hover {
    transform: translateY(-2px);
    box-shadow: 0 22px 48px rgba(15, 23, 42, 0.10);
}

/* ---------- Animated progress bars ------------------------ */
@keyframes appProgressShine {
    0%   { background-position: -200% 0; }
    100% { background-position: 200% 0; }
}
html[data-theme] .advance-progress span,
html[data-theme] .hr-progress-bar,
html[data-theme] .progress-bar {
    background-image: linear-gradient(
        90deg,
        currentColor 0%,
        rgba(255, 255, 255, .35) 35%,
        currentColor 70%
    );
    background-size: 200% 100%;
    animation: appProgressShine 2.6s linear infinite;
}

/* ---------- Chip / pill sheen ----------------------------- */
@keyframes appChipSheen {
    0%, 92%, 100% { background-position: 200% 0; }
    50%           { background-position: -50% 0; }
}
html[data-theme] .bw-chip,
html[data-theme] .advance-chip,
html[data-theme] .inventory-chip,
html[data-theme] .hr-kicker,
html[data-theme] .hr-meta-pill,
html[data-theme] .finance-eyebrow {
    background-image: linear-gradient(
        100deg,
        rgba(255,255,255,.0) 30%,
        rgba(59,130,246,.16) 50%,
        rgba(255,255,255,.0) 70%
    );
    background-size: 220% 100%;
    background-position: 200% 0;
    background-repeat: no-repeat;
    animation: appChipSheen 5.5s ease-in-out infinite;
}

/* ---------- Stagger on KPI grids found by JS -------------- */
html[data-theme] .row.app-kpi-stagger > * { --app-reveal-delay: 0ms; }
html[data-theme] .row.app-kpi-stagger > *:nth-child(2) { --app-reveal-delay: 70ms; }
html[data-theme] .row.app-kpi-stagger > *:nth-child(3) { --app-reveal-delay: 140ms; }
html[data-theme] .row.app-kpi-stagger > *:nth-child(4) { --app-reveal-delay: 210ms; }
html[data-theme] .row.app-kpi-stagger > *:nth-child(5) { --app-reveal-delay: 280ms; }
html[data-theme] .row.app-kpi-stagger > *:nth-child(6) { --app-reveal-delay: 350ms; }
html[data-theme] .row.app-kpi-stagger > *:nth-child(7) { --app-reveal-delay: 420ms; }
html[data-theme] .row.app-kpi-stagger > *:nth-child(8) { --app-reveal-delay: 490ms; }

/* ---------- Empty-state polish ---------------------------- */
html[data-theme] .bw-empty-state,
html[data-theme] .advance-empty-state,
html[data-theme] .inventory-empty-state,
html[data-theme] .hr-empty-state {
    background:
        repeating-linear-gradient(
            -45deg,
            rgba(148, 163, 184, .04) 0,
            rgba(148, 163, 184, .04) 10px,
            transparent 10px,
            transparent 20px
        );
    border: 1px dashed rgba(148, 163, 184, .28);
    border-radius: 1rem;
    transition: background .25s ease, border-color .25s ease;
}
html[data-theme] .bw-empty-state:hover,
html[data-theme] .advance-empty-state:hover,
html[data-theme] .inventory-empty-state:hover,
html[data-theme] .hr-empty-state:hover {
    border-color: rgba(59, 130, 246, .38);
}

/* ---------- Reduced-motion respect ------------------------ */
@media (prefers-reduced-motion: reduce) {
    html[data-theme] .bw-hero::after,
    html[data-theme] .finance-hero::after,
    html[data-theme] .advance-hero::after,
    html[data-theme] .inventory-hero::after,
    html[data-theme] .hr-hero::after,
    html[data-theme] .crmd-hero::after,
    html[data-theme] .crml-hero::after,
    html[data-theme] .noc-hero::after,
    html[data-theme] .fwo-hero::after,
    html[data-theme] .advance-progress span,
    html[data-theme] .hr-progress-bar,
    html[data-theme] .progress-bar,
    html[data-theme] .bw-chip,
    html[data-theme] .advance-chip,
    html[data-theme] .inventory-chip,
    html[data-theme] .hr-kicker,
    html[data-theme] .badge.bg-danger,
    html[data-theme] .badge.bg-warning {
        animation: none !important;
    }
}

/* =========================================================
 * Safety net — guarantee reveal targets become visible even
 * if JS is delayed, blocked, or cached. Pure CSS animation
 * runs on its own and overrides the opacity:0 default.
 * ========================================================= */
@keyframes appAutoReveal {
    from { opacity: 0; transform: translate3d(0, 14px, 0); }
    to   { opacity: 1; transform: none; }
}
.aw-reveal,
.app-reveal,
.bw-reveal,
.hr-reveal,
.inventory-reveal,
.crmw-reveal,
.crml-reveal,
.crmc-reveal,
.crmd-reveal,
.fwo-reveal,
.ops-reveal,
.crmr-reveal,
.noc-reveal {
    animation: appAutoReveal .55s cubic-bezier(.22,.61,.36,1) .15s both;
}
@media (prefers-reduced-motion: reduce) {
    .aw-reveal,
    .app-reveal,
    .bw-reveal,
    .hr-reveal,
    .inventory-reveal,
    .crmw-reveal,
    .crml-reveal,
    .crmc-reveal,
    .crmd-reveal,
    .fwo-reveal,
    .ops-reveal,
    .crmr-reveal,
    .noc-reveal {
        animation: none;
        opacity: 1 !important;
        transform: none !important;
    }
}
