/* ==========================================================================
   SOS ISP Manager — Global Theme Skin (Iteration 1)
   ------------------------------------------------------------------------
   Loaded LAST in layout.php so it wins specificity battles against legacy
   per-module stylesheets. This file establishes the unified visual system:
   deep indigo/violet gradient sidebar, soft frosted topbar, light blue-grey
   canvas, white rounded cards with soft shadow, gold accent, rounded pill
   buttons, modern tabs with active underline, compact tables, badges, and
   responsive behavior. No markup changes required — every page that goes
   through src/Views/layout.php inherits the look automatically.
   ========================================================================== */

:root {
    /* Brand palette */
    --sos-primary:        #4f46e5;   /* indigo 600 */
    --sos-primary-strong: #4338ca;   /* indigo 700 */
    --sos-primary-soft:   #eef2ff;   /* indigo 50  */
    --sos-violet:         #7c3aed;   /* violet 600 */
    --sos-violet-strong:  #6d28d9;
    --sos-accent:         #f59e0b;   /* gold/amber 500 */
    --sos-accent-strong:  #d97706;

    /* Surfaces */
    --sos-canvas:         #f4f6fb;   /* page background */
    --sos-surface:        #ffffff;
    --sos-surface-muted:  #f8fafc;
    --sos-border:         #e5e7eb;
    --sos-border-strong:  #d1d5db;

    /* Text */
    --sos-text:           #111827;
    --sos-text-muted:     #6b7280;
    --sos-text-soft:      #9ca3af;

    /* States */
    --sos-success:        #16a34a;
    --sos-success-soft:   #dcfce7;
    --sos-danger:         #dc2626;
    --sos-danger-soft:    #fee2e2;
    --sos-warning:        #f59e0b;
    --sos-warning-soft:   #fef3c7;
    --sos-info:           #0ea5e9;
    --sos-info-soft:      #e0f2fe;

    /* Geometry */
    --sos-radius-sm:      8px;
    --sos-radius:         14px;
    --sos-radius-lg:      20px;
    --sos-radius-pill:    999px;

    /* Shadows */
    --sos-shadow-xs:      0 1px 2px rgba(15, 23, 42, 0.04);
    --sos-shadow-sm:      0 2px 6px rgba(15, 23, 42, 0.06);
    --sos-shadow:         0 8px 24px rgba(15, 23, 42, 0.08);
    --sos-shadow-lg:      0 18px 48px rgba(15, 23, 42, 0.12);

    /* Sidebar gradient */
    --sos-sidebar-grad:   linear-gradient(180deg, #312e81 0%, #4f46e5 50%, #7c3aed 100%);

    /* Motion */
    --sos-ease:           cubic-bezier(.2, .7, .25, 1);
    --sos-dur:            220ms;
}

/* Dark mode override (data-theme="dark") -------------------------------- */
html[data-theme="dark"] {
    --sos-canvas:        #0b1020;
    --sos-surface:       #131a2e;
    --sos-surface-muted: #1a2240;
    --sos-border:        #243056;
    --sos-border-strong: #2e3b66;
    --sos-text:          #e7ebf5;
    --sos-text-muted:    #9aa3bf;
    --sos-text-soft:     #6b7494;
    --sos-shadow:        0 8px 24px rgba(0, 0, 0, 0.45);
    --sos-shadow-lg:     0 18px 48px rgba(0, 0, 0, 0.55);
}

/* ============================================================
   1. Page canvas + typography
   ============================================================ */
body.app-shell {
    background: var(--sos-canvas) !important;
    color: var(--sos-text);
    font-family: 'Inter', -apple-system, 'Segoe UI', system-ui, sans-serif;
    -webkit-font-smoothing: antialiased;
}

.app-page-shell {
    background: transparent !important;
}

a { color: var(--sos-primary); }
a:hover { color: var(--sos-primary-strong); }

h1, h2, h3, h4, h5, h6 { color: var(--sos-text); letter-spacing: -0.01em; }

/* ============================================================
   2. Topbar — frosted white with sticky shadow
   ============================================================ */
.app-topbar {
    background: rgba(255, 255, 255, 0.92) !important;
    backdrop-filter: saturate(180%) blur(12px);
    -webkit-backdrop-filter: saturate(180%) blur(12px);
    border-bottom: 1px solid var(--sos-border) !important;
    box-shadow: var(--sos-shadow-xs);
    position: sticky;
    top: 0;
    z-index: 1030;
}
html[data-theme="dark"] .app-topbar {
    background: rgba(19, 26, 46, 0.85) !important;
    border-bottom-color: var(--sos-border) !important;
}

.app-topbar-inner { padding: .55rem 1.25rem; }

.app-brand {
    display: inline-flex;
    align-items: center;
    gap: .65rem;
    text-decoration: none;
}
.app-brand-mark {
    width: 38px; height: 38px;
    border-radius: var(--sos-radius-sm);
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--sos-sidebar-grad);
    color: #fff;
    box-shadow: 0 6px 18px rgba(79, 70, 229, 0.35);
}
.app-brand-mark svg { width: 20px; height: 20px; }
.app-brand-copy strong {
    font-weight: 700;
    color: var(--sos-text);
    letter-spacing: -0.01em;
}
.app-brand-copy small { color: var(--sos-text-muted); }

.app-topbar-context-kicker {
    text-transform: uppercase;
    font-size: .68rem;
    letter-spacing: .12em;
    color: var(--sos-text-soft);
}
.app-topbar-context strong { color: var(--sos-text); }

.app-topbar-theme-form {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .25rem .5rem;
    border-radius: var(--sos-radius-pill);
    background: var(--sos-surface-muted);
    border: 1px solid var(--sos-border);
}
.app-topbar-theme-form .form-select {
    border: none;
    background: transparent;
    color: var(--sos-text);
    box-shadow: none;
}

.app-user-chip {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    padding: .3rem .65rem .3rem .35rem;
    border-radius: var(--sos-radius-pill);
    background: var(--sos-surface-muted);
    border: 1px solid var(--sos-border);
    text-decoration: none;
    transition: background var(--sos-dur) var(--sos-ease);
}
.app-user-chip:hover { background: var(--sos-primary-soft); }
.app-user-avatar {
    width: 32px; height: 32px;
    border-radius: 50%;
    background: var(--sos-sidebar-grad);
    color: #fff;
    display: inline-flex; align-items: center; justify-content: center;
    font-weight: 700;
    font-size: .9rem;
}
.app-user-copy strong { color: var(--sos-text); font-size: .85rem; line-height: 1; }
.app-user-copy small { color: var(--sos-text-muted); text-transform: capitalize; font-size: .7rem; }

/* ============================================================
   3. Sidebar — deep indigo→violet gradient
   ============================================================ */
.app-sidebar.app-sidebar-modern {
    background: var(--sos-sidebar-grad) !important;
    color: #fff;
    border-right: none !important;
    box-shadow: var(--sos-shadow-lg);
}

.app-sidebar-inner { color: #fff; }

.app-sidebar-header {
    color: rgba(255,255,255,.7);
}
.app-sidebar-title { color: rgba(255,255,255,.65); font-weight: 600; letter-spacing: .08em; }

.app-sidebar-brandline { padding: .5rem .9rem 1rem; border-bottom: 1px solid rgba(255,255,255,.12); }
.app-sidebar-brand {
    display: inline-flex; gap: .65rem; align-items: center;
    text-decoration: none; color: #fff;
}
.app-sidebar-logo {
    width: 40px; height: 40px;
    border-radius: var(--sos-radius-sm);
    background: rgba(255,255,255,.16);
    display: inline-flex; align-items: center; justify-content: center;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.18);
}
.app-sidebar-kicker { color: rgba(255,255,255,.7); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; }
.app-sidebar-brand-copy strong { color: #fff; }

/* group cards */
.sidebar-group-card {
    background: transparent;
    border: none;
    margin: 2px 8px;
    border-radius: var(--sos-radius);
    color: rgba(255,255,255,.85);
}
.sidebar-group-card.is-active { background: rgba(255,255,255,.10); }
.sidebar-group-card.is-open   { background: rgba(255,255,255,.06); }

.sidebar-parent {
    display: flex; align-items: center; gap: .65rem;
    width: 100%;
    background: transparent;
    border: none;
    color: inherit;
    padding: .65rem .85rem;
    border-radius: var(--sos-radius);
    cursor: pointer;
    transition: background var(--sos-dur) var(--sos-ease), color var(--sos-dur) var(--sos-ease);
    text-align: left;
}
.sidebar-parent:hover { background: rgba(255,255,255,.10); color: #fff; }
.sidebar-parent svg, .sidebar-parent-chevron svg { width: 18px; height: 18px; }
.sidebar-parent-label { flex: 1; font-weight: 600; font-size: .92rem; }
.sidebar-parent-chevron { opacity: .8; transition: transform var(--sos-dur) var(--sos-ease); }
.sidebar-group-card.is-open > .sidebar-parent .sidebar-parent-chevron { transform: rotate(90deg); }

.sidebar-children {
    overflow: hidden;
    max-height: 0;
    transition: max-height .35s var(--sos-ease);
}
.sidebar-group-card.is-open .sidebar-children { max-height: 800px; }
.sidebar-child-rail { padding: .25rem .35rem .55rem 2.2rem; display: flex; flex-direction: column; gap: 2px; border-left: 2px solid rgba(255,255,255,.12); margin-left: 1.1rem; }
.sidebar-child {
    display: flex; align-items: center; gap: .5rem;
    padding: .5rem .8rem;
    border-radius: var(--sos-radius-pill);
    color: rgba(255,255,255,.78);
    text-decoration: none;
    font-size: .87rem;
    transition: background var(--sos-dur) var(--sos-ease), color var(--sos-dur) var(--sos-ease);
}
.sidebar-child:hover { background: rgba(255,255,255,.12); color: #fff; }
.sidebar-child.is-active {
    background: linear-gradient(90deg, rgba(255,255,255,.22), rgba(255,255,255,.10));
    color: #fff;
    font-weight: 600;
    box-shadow: inset 3px 0 0 var(--sos-accent);
}
.sidebar-child svg { width: 16px; height: 16px; opacity: .9; }

.app-sidebar-footer {
    border-top: 1px solid rgba(255,255,255,.12);
    color: rgba(255,255,255,.7);
    padding: .85rem 1rem;
    font-size: .78rem;
}
.app-sidebar-footer-label { text-transform: uppercase; letter-spacing: .12em; opacity: .7; }
.app-sidebar-footer-value { color: #fff; font-weight: 600; }

/* ============================================================
   4. Breadcrumb
   ============================================================ */
.module-breadcrumb {
    display: flex; align-items: center; gap: .45rem;
    padding: .9rem 0 .25rem;
    font-size: .82rem;
    color: var(--sos-text-muted);
}
.module-breadcrumb a { color: var(--sos-text-muted); text-decoration: none; }
.module-breadcrumb a:hover { color: var(--sos-primary); }
.module-breadcrumb strong { color: var(--sos-text); }

/* ============================================================
   5. Cards (Bootstrap .card + workspace section cards)
   ============================================================ */
.card,
.page-section-card,
.app-section-card,
.module-card,
.app-metric-card,
.bw-form-card, .bw-table-card, .bw-lane-card, .bw-stat-card,
.advance-detail-card, .advance-intel-card, .advance-lane-card, .advance-table-card, .advance-form-card, .advance-stat-card,
.inventory-card, .inventory-stat-card,
.hr-panel, .hr-form-shell, .hr-table-shell, .hr-stat-card,
.finance-pill, .finance-kpi, .finance-insight, .finance-action-card, .finance-feed-item, .finance-method-item, .finance-mini-panel, .finance-chart-shell, .finance-register-card, .finance-filter-shell, .finance-kpi-card,
.invoice-source-card, .invoice-command-card, .invoice-kpi-card,
.package-source-card, .package-command-card, .package-kpi-card,
.crml-kpi, .crmd-stat-card, .sl-stat-card, .noc-stat-card {
    background: var(--sos-surface) !important;
    border: 1px solid var(--sos-border) !important;
    border-radius: var(--sos-radius-lg) !important;
    box-shadow: var(--sos-shadow-sm) !important;
    transition: box-shadow var(--sos-dur) var(--sos-ease), transform var(--sos-dur) var(--sos-ease);
}
.card:hover,
.page-section-card:hover,
.module-card:hover,
.app-metric-card:hover,
.finance-kpi-card:hover,
.bw-stat-card:hover,
.hr-stat-card:hover,
.inventory-stat-card:hover,
.advance-stat-card:hover,
.crml-kpi:hover,
.crmd-stat-card:hover,
.noc-stat-card:hover {
    box-shadow: var(--sos-shadow) !important;
    transform: translateY(-2px);
}

.card-header {
    background: transparent !important;
    border-bottom: 1px solid var(--sos-border) !important;
    font-weight: 600;
    color: var(--sos-text);
    padding: 1rem 1.25rem;
}
.card-body { padding: 1.25rem; }

/* ============================================================
   6. Buttons — rounded pill, gradient primary, hover lift
   ============================================================ */
.btn {
    border-radius: var(--sos-radius-pill);
    padding: .5rem 1.1rem;
    font-weight: 600;
    letter-spacing: .01em;
    transition: transform var(--sos-dur) var(--sos-ease), box-shadow var(--sos-dur) var(--sos-ease), background var(--sos-dur) var(--sos-ease);
    border-width: 1px;
}
.btn-sm { padding: .35rem .85rem; font-size: .82rem; }
.btn-lg { padding: .7rem 1.4rem; font-size: 1rem; }
.btn:focus, .btn:focus-visible { box-shadow: 0 0 0 4px rgba(79, 70, 229, .18); }

.btn-primary {
    background: linear-gradient(135deg, var(--sos-primary) 0%, var(--sos-violet) 100%) !important;
    border-color: transparent !important;
    color: #fff !important;
    box-shadow: 0 6px 18px rgba(79, 70, 229, .25);
}
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 10px 22px rgba(79, 70, 229, .32); }

.btn-secondary {
    background: var(--sos-surface-muted) !important;
    color: var(--sos-text) !important;
    border-color: var(--sos-border) !important;
}
.btn-secondary:hover { background: var(--sos-primary-soft) !important; color: var(--sos-primary-strong) !important; }

.btn-success { background: var(--sos-success) !important; border-color: var(--sos-success) !important; color: #fff !important; }
.btn-danger  { background: var(--sos-danger) !important;  border-color: var(--sos-danger) !important;  color: #fff !important; }
.btn-warning { background: var(--sos-warning) !important; border-color: var(--sos-warning) !important; color: #1f2937 !important; }
.btn-info    { background: var(--sos-info) !important;    border-color: var(--sos-info) !important;    color: #fff !important; }

.btn-outline-primary   { color: var(--sos-primary) !important;   border-color: var(--sos-primary) !important; }
.btn-outline-primary:hover   { background: var(--sos-primary) !important;   color: #fff !important; }
.btn-outline-secondary { color: var(--sos-text-muted) !important; border-color: var(--sos-border) !important; background: transparent !important; }
.btn-outline-secondary:hover { background: var(--sos-surface-muted) !important; color: var(--sos-text) !important; }
.btn-outline-success   { color: var(--sos-success) !important;   border-color: var(--sos-success) !important; }
.btn-outline-success:hover   { background: var(--sos-success) !important;   color: #fff !important; }
.btn-outline-danger    { color: var(--sos-danger) !important;    border-color: var(--sos-danger) !important; }
.btn-outline-danger:hover    { background: var(--sos-danger) !important;    color: #fff !important; }

/* ============================================================
   7. Forms — clean inputs with focus ring
   ============================================================ */
.form-control,
.form-select,
.input-group-text {
    border-radius: var(--sos-radius-sm);
    border: 1px solid var(--sos-border);
    background: var(--sos-surface);
    color: var(--sos-text);
    padding: .55rem .8rem;
    transition: border-color var(--sos-dur) var(--sos-ease), box-shadow var(--sos-dur) var(--sos-ease);
}
.form-control:focus, .form-select:focus {
    border-color: var(--sos-primary);
    box-shadow: 0 0 0 4px rgba(79, 70, 229, .15);
    background: var(--sos-surface);
    color: var(--sos-text);
}
.form-label { color: var(--sos-text); font-weight: 600; font-size: .85rem; margin-bottom: .35rem; }
.form-text { color: var(--sos-text-muted); }

.input-group-text {
    background: var(--sos-surface-muted);
    color: var(--sos-text-muted);
}

/* ============================================================
   8. Tables — light, compact, modern
   ============================================================ */
.table {
    --bs-table-bg: transparent;
    color: var(--sos-text);
    border-color: var(--sos-border);
    margin-bottom: 0;
}
.table > :not(caption) > * > * {
    background: transparent;
    border-bottom: 1px solid var(--sos-border);
    color: var(--sos-text);
    padding: .85rem 1rem;
    vertical-align: middle;
}
.table thead th {
    background: var(--sos-surface-muted) !important;
    color: var(--sos-text-muted);
    font-weight: 600;
    text-transform: uppercase;
    font-size: .72rem;
    letter-spacing: .08em;
    border-bottom: 1px solid var(--sos-border) !important;
}
.table-hover > tbody > tr:hover > * {
    background: var(--sos-primary-soft) !important;
    color: var(--sos-text);
}
.table-striped > tbody > tr:nth-of-type(odd) > * {
    background: var(--sos-surface-muted);
}
.table-responsive {
    border-radius: var(--sos-radius);
    border: 1px solid var(--sos-border);
    background: var(--sos-surface);
    overflow: hidden;
}

/* ============================================================
   9. Badges — soft, rounded, status-aware
   ============================================================ */
.badge {
    border-radius: var(--sos-radius-pill);
    font-weight: 600;
    padding: .35em .7em;
    font-size: .72rem;
    letter-spacing: .02em;
}
.badge.bg-primary,  .text-bg-primary  { background: var(--sos-primary-soft) !important; color: var(--sos-primary-strong) !important; }
.badge.bg-success,  .text-bg-success  { background: var(--sos-success-soft) !important; color: var(--sos-success) !important; }
.badge.bg-danger,   .text-bg-danger   { background: var(--sos-danger-soft) !important;  color: var(--sos-danger) !important; }
.badge.bg-warning,  .text-bg-warning  { background: var(--sos-warning-soft) !important; color: var(--sos-warning-strong, #b45309) !important; }
.badge.bg-info,     .text-bg-info     { background: var(--sos-info-soft) !important;    color: var(--sos-info) !important; }
.badge.bg-secondary,.text-bg-secondary{ background: var(--sos-surface-muted) !important; color: var(--sos-text-muted) !important; border: 1px solid var(--sos-border); }
.badge.bg-dark,     .text-bg-dark     { background: var(--sos-text) !important; color: #fff !important; }

/* ============================================================
   10. Alerts — full width, soft tinted
   ============================================================ */
.alert {
    border-radius: var(--sos-radius);
    border: 1px solid transparent;
    padding: .9rem 1.1rem;
    box-shadow: var(--sos-shadow-xs);
}
.alert-primary { background: var(--sos-primary-soft); color: var(--sos-primary-strong); border-color: rgba(79, 70, 229, .18); }
.alert-success { background: var(--sos-success-soft); color: #166534; border-color: rgba(22, 163, 74, .25); }
.alert-danger  { background: var(--sos-danger-soft);  color: #991b1b; border-color: rgba(220, 38, 38, .25); }
.alert-warning { background: var(--sos-warning-soft); color: #92400e; border-color: rgba(245, 158, 11, .28); }
.alert-info    { background: var(--sos-info-soft);    color: #075985; border-color: rgba(14, 165, 233, .28); }

/* ============================================================
   11. Tabs — modern underline with badges
   ============================================================ */
.nav-tabs {
    border-bottom: 1px solid var(--sos-border);
    gap: .25rem;
}
.nav-tabs .nav-link {
    border: none;
    color: var(--sos-text-muted);
    font-weight: 600;
    padding: .7rem 1rem;
    border-radius: 0;
    border-bottom: 2px solid transparent;
    background: transparent;
    transition: color var(--sos-dur) var(--sos-ease), border-color var(--sos-dur) var(--sos-ease);
    display: inline-flex;
    align-items: center;
    gap: .5rem;
}
.nav-tabs .nav-link:hover { color: var(--sos-primary); border-bottom-color: var(--sos-border-strong); }
.nav-tabs .nav-link.active {
    color: var(--sos-primary-strong) !important;
    background: transparent !important;
    border-bottom-color: var(--sos-primary) !important;
}
.nav-tabs .nav-link .badge { margin-left: .25rem; }

.nav-pills .nav-link {
    border-radius: var(--sos-radius-pill);
    color: var(--sos-text-muted);
    font-weight: 600;
}
.nav-pills .nav-link.active {
    background: linear-gradient(135deg, var(--sos-primary), var(--sos-violet)) !important;
    color: #fff !important;
}

/* ============================================================
   12. Modals + Offcanvas
   ============================================================ */
.modal-content {
    border: none;
    border-radius: var(--sos-radius-lg);
    box-shadow: var(--sos-shadow-lg);
    background: var(--sos-surface);
}
.modal-header {
    border-bottom: 1px solid var(--sos-border);
    padding: 1rem 1.25rem;
}
.modal-footer {
    border-top: 1px solid var(--sos-border);
    padding: .85rem 1.25rem;
}
.offcanvas {
    border: none;
    box-shadow: var(--sos-shadow-lg);
}

/* ============================================================
   13. Pagination
   ============================================================ */
.pagination .page-link {
    color: var(--sos-text);
    border-color: var(--sos-border);
    border-radius: var(--sos-radius-sm) !important;
    margin: 0 2px;
    padding: .45rem .75rem;
    background: var(--sos-surface);
}
.pagination .page-link:hover { background: var(--sos-primary-soft); color: var(--sos-primary-strong); border-color: var(--sos-primary-soft); }
.pagination .page-item.active .page-link {
    background: var(--sos-primary);
    color: #fff;
    border-color: var(--sos-primary);
}

/* ============================================================
   14. Progress bars + spinners
   ============================================================ */
.progress {
    background: var(--sos-surface-muted);
    border-radius: var(--sos-radius-pill);
    height: 8px;
    overflow: hidden;
}
.progress-bar {
    background: linear-gradient(135deg, var(--sos-primary), var(--sos-violet));
}
.spinner-border, .spinner-grow { color: var(--sos-primary); }

/* ============================================================
   15. KPI / metric tiles — unify all module KPI conventions
   ============================================================ */
.app-metric-card,
.bw-stat-card,
.hr-stat-card,
.inventory-stat-card,
.advance-stat-card,
.crml-kpi,
.crmd-stat-card,
.sl-stat-card,
.noc-stat-card,
.finance-kpi-card,
.invoice-kpi-card,
.package-kpi-card {
    padding: 1.1rem 1.25rem;
    border-radius: var(--sos-radius-lg);
    background: var(--sos-surface);
    border: 1px solid var(--sos-border);
    box-shadow: var(--sos-shadow-sm);
    position: relative;
    overflow: hidden;
}
.app-metric-card::before,
.bw-stat-card::before,
.hr-stat-card::before,
.inventory-stat-card::before,
.advance-stat-card::before,
.finance-kpi-card::before,
.invoice-kpi-card::before,
.package-kpi-card::before,
.crml-kpi::before,
.noc-stat-card::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 4px;
    background: linear-gradient(180deg, var(--sos-primary), var(--sos-violet));
    border-radius: 4px 0 0 4px;
}

/* ============================================================
   16. Hero banners — keep gradient, soften surface
   ============================================================ */
.invoice-intelligence-hero,
.finance-hero,
.package-intelligence-hero,
.app-workspace-hero,
.module-hero {
    border-radius: var(--sos-radius-lg) !important;
    box-shadow: var(--sos-shadow-lg) !important;
    color: #fff !important;
    background: linear-gradient(135deg, #312e81 0%, #4f46e5 45%, #7c3aed 100%) !important;
    overflow: hidden;
    position: relative;
}
.invoice-intelligence-hero h1,
.invoice-intelligence-hero h2,
.finance-hero h1,
.finance-hero h2,
.package-intelligence-hero h1,
.package-intelligence-hero h2,
.app-workspace-hero h1,
.app-workspace-hero h2,
.module-hero h1,
.module-hero h2 { color: #fff !important; }

/* ============================================================
   17. Chips / pills used across modules
   ============================================================ */
.invoice-chip-link, .finance-chip-link, .package-chip-link, .module-chip,
.app-chip {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .35rem .75rem;
    border-radius: var(--sos-radius-pill);
    background: var(--sos-primary-soft);
    color: var(--sos-primary-strong);
    text-decoration: none;
    font-size: .78rem;
    font-weight: 600;
    transition: background var(--sos-dur) var(--sos-ease);
}
.invoice-chip-link:hover, .finance-chip-link:hover, .package-chip-link:hover, .app-chip:hover {
    background: var(--sos-primary);
    color: #fff;
}

/* ============================================================
   18. Dropdowns
   ============================================================ */
.dropdown-menu {
    border: 1px solid var(--sos-border);
    border-radius: var(--sos-radius);
    box-shadow: var(--sos-shadow);
    padding: .35rem;
    background: var(--sos-surface);
}
.dropdown-item {
    border-radius: var(--sos-radius-sm);
    padding: .5rem .75rem;
    color: var(--sos-text);
}
.dropdown-item:hover, .dropdown-item:focus {
    background: var(--sos-primary-soft);
    color: var(--sos-primary-strong);
}

/* ============================================================
   19. Footer
   ============================================================ */
.app-footer {
    background: transparent;
    color: var(--sos-text-muted);
    border-top: 1px solid var(--sos-border);
}

/* ============================================================
   20. Responsive — sidebar collapse, padding tightening
   ============================================================ */
@media (max-width: 991.98px) {
    .app-page-shell { padding: 1rem; }
    .app-sidebar.app-sidebar-modern {
        position: fixed; top: 0; left: 0; bottom: 0;
        width: 280px; max-width: 85vw;
        transform: translateX(-100%);
        transition: transform .3s var(--sos-ease);
        z-index: 1050;
    }
    .app-sidebar.app-sidebar-modern.is-open { transform: translateX(0); }
    .app-sidebar-backdrop {
        position: fixed; inset: 0;
        background: rgba(15, 23, 42, .55);
        z-index: 1045;
        opacity: 0; pointer-events: none;
        transition: opacity .3s var(--sos-ease);
    }
    .app-sidebar-backdrop.is-visible { opacity: 1; pointer-events: auto; }
}

@media (max-width: 575.98px) {
    .app-topbar-inner { padding: .45rem .75rem; }
    .app-brand-copy small { display: none; }
    .app-topbar-context { display: none !important; }
    .app-user-copy { display: none; }
}

/* ============================================================
   21. Reduced motion respect
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        transition-duration: .001ms !important;
        animation-duration: .001ms !important;
    }
}

/* ============================================================
   22. Util — empty / loading states
   ============================================================ */
.app-empty-state {
    text-align: center;
    padding: 3rem 1.5rem;
    color: var(--sos-text-muted);
    background: var(--sos-surface);
    border: 1px dashed var(--sos-border-strong);
    border-radius: var(--sos-radius-lg);
}
.app-loading-pill {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .35rem .8rem;
    border-radius: var(--sos-radius-pill);
    background: var(--sos-primary-soft);
    color: var(--sos-primary-strong);
    font-size: .78rem;
    font-weight: 600;
}
.app-loading-pill::before {
    content: "";
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--sos-primary);
    animation: sosPulse 1.2s ease-in-out infinite;
}
@keyframes sosPulse {
    0%, 100% { opacity: .35; transform: scale(.8); }
    50%      { opacity: 1;   transform: scale(1.15); }
}

/* ============================================================
   23. Soft scrollbars (webkit/blink only)
   ============================================================ */
.app-sidebar-scroll::-webkit-scrollbar,
.table-responsive::-webkit-scrollbar { width: 8px; height: 8px; }
.app-sidebar-scroll::-webkit-scrollbar-thumb { background: rgba(255,255,255,.18); border-radius: 8px; }
.app-sidebar-scroll::-webkit-scrollbar-track { background: transparent; }
.table-responsive::-webkit-scrollbar-thumb { background: var(--sos-border-strong); border-radius: 8px; }

/* ============================================================
   24. PREMIUM SHELLS — re-skin .aw-snapshot family used by NOC,
   HR, Invoice and other premium dashboards so they sit on the
   SOS indigo→violet palette and match the rest of the system.
   ============================================================ */
.aw-snapshot.is-premium {
    background: linear-gradient(135deg, #1e1b4b 0%, #312e81 35%, #4f46e5 70%, #7c3aed 100%) !important;
    color: #fff !important;
    border-radius: var(--sos-radius-lg) !important;
    box-shadow: var(--sos-shadow-lg) !important;
    border: none !important;
    padding: 1.75rem !important;
    overflow: hidden;
    position: relative;
}
.aw-snapshot.is-premium::before {
    content: "";
    position: absolute;
    inset: -40% -20% auto auto;
    width: 480px; height: 480px;
    background: radial-gradient(circle, rgba(245, 158, 11, .25), transparent 60%);
    pointer-events: none;
    animation: sosHeroDrift 12s ease-in-out infinite alternate;
}
@keyframes sosHeroDrift {
    0%   { transform: translate3d(0, 0, 0) scale(1); opacity: .8; }
    100% { transform: translate3d(-40px, 30px, 0) scale(1.1); opacity: 1; }
}

.aw-snapshot.is-premium .aw-snapshot__kicker {
    color: var(--sos-accent) !important;
    text-transform: uppercase;
    letter-spacing: .14em;
    font-size: .72rem;
    font-weight: 700;
}
.aw-snapshot.is-premium .aw-snapshot__title {
    color: #fff !important;
    font-weight: 800;
    letter-spacing: -0.02em;
    margin: .35rem 0 .55rem;
}
.aw-snapshot.is-premium .aw-snapshot__copy { color: rgba(255,255,255,.82) !important; }

.aw-snapshot.is-premium .btn-primary {
    background: #fff !important;
    color: var(--sos-primary-strong) !important;
    border-color: #fff !important;
    box-shadow: 0 6px 18px rgba(0,0,0,.18);
}
.aw-snapshot.is-premium .btn-outline-secondary {
    background: rgba(255,255,255,.10) !important;
    color: #fff !important;
    border-color: rgba(255,255,255,.30) !important;
}
.aw-snapshot.is-premium .btn-outline-secondary:hover {
    background: rgba(255,255,255,.22) !important;
    color: #fff !important;
}

/* Gauge ring + center copy */
.aw-snapshot.is-premium .aw-gauge {
    background: conic-gradient(var(--sos-accent) calc(var(--aw-gauge-pct, 50) * 1%), rgba(255,255,255,.18) 0);
    border-radius: 50%;
    padding: 8px;
    box-shadow: 0 12px 30px rgba(0,0,0,.25);
}
.aw-snapshot.is-premium .aw-gauge__inner {
    background: rgba(15, 23, 42, .55);
    backdrop-filter: blur(6px);
    border-radius: 50%;
    color: #fff;
    width: 100%; height: 100%;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    aspect-ratio: 1/1;
}
.aw-snapshot.is-premium .aw-gauge__inner strong { font-size: 1.8rem; font-weight: 800; }
.aw-snapshot.is-premium .aw-gauge__inner span { font-size: .7rem; opacity: .8; text-transform: uppercase; letter-spacing: .1em; }

/* Legend rows */
.aw-snapshot.is-premium .aw-focus__legend-row {
    color: rgba(255,255,255,.85);
    font-size: .85rem;
    display: flex; align-items: center; gap: .5rem;
    padding: .15rem 0;
}
.aw-snapshot.is-premium .aw-focus__legend-row small { color: #fff; font-weight: 600; }
.aw-legend-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
.aw-legend-dot.is-good  { background: #22c55e; box-shadow: 0 0 0 3px rgba(34,197,94,.25); }
.aw-legend-dot.is-watch { background: var(--sos-accent); box-shadow: 0 0 0 3px rgba(245,158,11,.25); }
.aw-legend-dot.is-risk  { background: #ef4444; box-shadow: 0 0 0 3px rgba(239,68,68,.25); }
.aw-legend-dot.is-info  { background: #38bdf8; box-shadow: 0 0 0 3px rgba(56,189,248,.25); }

/* Ribbon KPI cells (white-on-dark) */
.aw-snapshot.is-premium .aw-ribbon {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: .75rem;
    margin-bottom: 1rem;
}
.aw-snapshot.is-premium .aw-ribbon__cell {
    background: rgba(255,255,255,.08) !important;
    border: 1px solid rgba(255,255,255,.14) !important;
    border-radius: var(--sos-radius) !important;
    padding: .85rem !important;
    color: #fff !important;
    backdrop-filter: blur(8px);
    transition: transform var(--sos-dur) var(--sos-ease), background var(--sos-dur) var(--sos-ease);
    position: relative;
    overflow: hidden;
}
.aw-snapshot.is-premium .aw-ribbon__cell:hover {
    background: rgba(255,255,255,.14) !important;
    transform: translateY(-3px);
}
.aw-snapshot.is-premium .aw-ribbon__cell span { color: rgba(255,255,255,.7); font-size: .72rem; text-transform: uppercase; letter-spacing: .08em; }
.aw-snapshot.is-premium .aw-ribbon__cell strong { color: #fff; font-size: 1.4rem; font-weight: 800; display: block; margin-top: .15rem; }
.aw-snapshot.is-premium .aw-ribbon__cell small { color: rgba(255,255,255,.65); font-size: .72rem; display: block; margin-top: .2rem; }
.aw-snapshot.is-premium .aw-ribbon__cell.is-good   { box-shadow: inset 3px 0 0 #22c55e; }
.aw-snapshot.is-premium .aw-ribbon__cell.is-watch  { box-shadow: inset 3px 0 0 var(--sos-accent); }
.aw-snapshot.is-premium .aw-ribbon__cell.is-risk   { box-shadow: inset 3px 0 0 #ef4444; }
.aw-snapshot.is-premium .aw-ribbon__cell.is-info   { box-shadow: inset 3px 0 0 #38bdf8; }
.aw-snapshot.is-premium .aw-ribbon__cell.is-primary{ box-shadow: inset 3px 0 0 var(--sos-accent); }

.aw-snapshot.is-premium .aw-spark {
    width: 100%; height: 22px;
    margin-top: .3rem;
    opacity: .9;
}

/* Pipeline */
.aw-snapshot.is-premium .aw-pipeline {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
    gap: .5rem;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: var(--sos-radius);
    padding: .75rem;
}
.aw-snapshot.is-premium .aw-pipeline__step {
    background: rgba(255,255,255,.06);
    border-radius: var(--sos-radius-sm);
    padding: .55rem .65rem;
    color: #fff;
    transition: background var(--sos-dur) var(--sos-ease);
}
.aw-snapshot.is-premium .aw-pipeline__step:hover { background: rgba(255,255,255,.14); }
.aw-snapshot.is-premium .aw-pipeline__label { color: rgba(255,255,255,.7); font-size: .7rem; text-transform: uppercase; letter-spacing: .08em; }
.aw-snapshot.is-premium .aw-pipeline__value { color: #fff; font-weight: 800; font-size: 1.05rem; display: block; margin: .1rem 0; }
.aw-snapshot.is-premium .aw-pipeline__meta  { color: rgba(255,255,255,.6); font-size: .7rem; }
.aw-snapshot.is-premium .aw-pipeline__step.is-active { background: rgba(245,158,11,.20); box-shadow: inset 0 0 0 1px rgba(245,158,11,.45); }
.aw-snapshot.is-premium .aw-pipeline__step.is-risk   { background: rgba(239,68,68,.20);  box-shadow: inset 0 0 0 1px rgba(239,68,68,.45); }
.aw-snapshot.is-premium .aw-pipeline__step.is-watch  { background: rgba(245,158,11,.18); box-shadow: inset 0 0 0 1px rgba(245,158,11,.40); }
.aw-snapshot.is-premium .aw-pipeline__step.is-done   { background: rgba(34,197,94,.18); box-shadow: inset 0 0 0 1px rgba(34,197,94,.35); }

/* ============================================================
   25. Layout for premium snapshot focus + side
   ============================================================ */
.aw-snapshot.is-premium {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.3fr);
    gap: 1.5rem;
    align-items: start;
}
.aw-snapshot.is-premium .aw-focus { display: flex; flex-direction: column; gap: 1rem; }
.aw-snapshot.is-premium .aw-focus__head { color: #fff; }
.aw-snapshot.is-premium .aw-focus__gauge { display: grid; grid-template-columns: 140px 1fr; gap: 1rem; align-items: center; }
.aw-snapshot.is-premium .aw-gauge--xl { width: 130px; height: 130px; }
.aw-snapshot.is-premium .aw-focus__legend { display: grid; gap: .35rem; }
.aw-snapshot.is-premium .aw-focus__ctas { display: flex; flex-wrap: wrap; gap: .5rem; }
.aw-snapshot.is-premium .aw-side { display: flex; flex-direction: column; gap: .85rem; min-width: 0; }

@media (max-width: 991.98px) {
    .aw-snapshot.is-premium { grid-template-columns: 1fr; padding: 1.25rem !important; }
    .aw-snapshot.is-premium .aw-focus__gauge { grid-template-columns: 110px 1fr; }
    .aw-snapshot.is-premium .aw-gauge--xl { width: 110px; height: 110px; }
}

/* ============================================================
   26. Reveal animation kept on premium snapshot
   ============================================================ */
.aw-reveal { animation: sosFadeUp .55s var(--sos-ease) both; }
@keyframes sosFadeUp {
    from { opacity: 0; transform: translate3d(0, 16px, 0); }
    to   { opacity: 1; transform: translate3d(0, 0, 0); }
}
.aw-snapshot.is-premium .aw-ribbon__cell:nth-child(1) { animation: sosFadeUp .45s var(--sos-ease) .05s both; }
.aw-snapshot.is-premium .aw-ribbon__cell:nth-child(2) { animation: sosFadeUp .45s var(--sos-ease) .12s both; }
.aw-snapshot.is-premium .aw-ribbon__cell:nth-child(3) { animation: sosFadeUp .45s var(--sos-ease) .19s both; }
.aw-snapshot.is-premium .aw-ribbon__cell:nth-child(4) { animation: sosFadeUp .45s var(--sos-ease) .26s both; }
.aw-snapshot.is-premium .aw-ribbon__cell:nth-child(5) { animation: sosFadeUp .45s var(--sos-ease) .33s both; }
.aw-snapshot.is-premium .aw-ribbon__cell:nth-child(6) { animation: sosFadeUp .45s var(--sos-ease) .40s both; }

/* ============================================================
   27. Invoice register table + filter shell polish
   ============================================================ */
.invoice-workspace .invoice-filter-shell,
.invoice-workspace .invoice-register-card {
    background: var(--sos-surface);
    border: 1px solid var(--sos-border);
    border-radius: var(--sos-radius-lg);
    box-shadow: var(--sos-shadow-sm);
    padding: 1.25rem;
}
.invoice-workspace .invoice-filter-shell .form-control,
.invoice-workspace .invoice-filter-shell .form-select {
    border-radius: var(--sos-radius-sm);
}

/* ============================================================
   28. Page section title row used on all three dashboards
   ============================================================ */
.section-head {
    display: flex; align-items: center; justify-content: space-between;
    gap: 1rem;
    margin: 1.5rem 0 .75rem;
}
.section-head h3 { margin: 0; font-weight: 700; color: var(--sos-text); font-size: 1.05rem; }
.section-head .section-tools { display: inline-flex; gap: .5rem; }

