/*
    Intrasect Admin Base Theme
    --------------------------
    Purpose:
    - One CSS foundation for the Intrasect.Web.Admin Blazor Web SSR app.
    - Built on Bootstrap 5.3+ color modes.
    - Supports system, light and dark through html[data-bs-theme].
    - Uses app-specific --ix-* tokens and .ix-* utility/components.
    - Designed for tenant management, billing, deployment, security and platform operations.
*/

@font-face {
    font-family: "Inter";
    src: url("../fonts/inter/InterVariable.woff2") format("woff2");
    font-weight: 100 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("../fonts/inter/InterVariable-Italic.woff2") format("woff2");
    font-weight: 100 900;
    font-style: italic;
    font-display: swap;
}

/* =========================================================
   1. Base tokens
   ========================================================= */

:root {
    color-scheme: light dark;

    --ix-font-sans: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

    --ix-radius-xs: .35rem;
    --ix-radius-sm: .55rem;
    --ix-radius-md: .75rem;
    --ix-radius-lg: 1rem;
    --ix-radius-xl: 1.25rem;
    --ix-radius-2xl: 1.5rem;
    --ix-radius-pill: 999px;

    --ix-shadow-xs: 0 1px 2px rgba(15, 23, 42, .06);
    --ix-shadow-sm: 0 7px 18px rgba(15, 23, 42, .08);
    --ix-shadow-md: 0 14px 34px rgba(15, 23, 42, .12);
    --ix-shadow-lg: 0 24px 56px rgba(15, 23, 42, .18);
    --ix-shadow-glow: 0 22px 50px rgba(var(--ix-primary-rgb), .18);

    --ix-transition-fast: 140ms ease;
    --ix-transition-normal: 220ms ease;

    --ix-sidebar-width: 292px;
    --ix-sidebar-collapsed-width: 84px;
    --ix-topbar-height: 70px;
    --ix-content-max-width: 1720px;

    --ix-z-sidebar: 1030;
    --ix-z-topbar: 1025;
    --ix-z-overlay: 1040;
}

/* =========================================================
   2. Light theme
   ========================================================= */

:root,
[data-bs-theme="light"] {
    --ix-primary: #4f46e5;
    --ix-primary-rgb: 79, 70, 229;
    --ix-primary-soft: #eef2ff;
    --ix-primary-subtle: #e0e7ff;
    --ix-primary-strong: #3730a3;

    --ix-secondary: #06b6d4;
    --ix-secondary-rgb: 6, 182, 212;
    --ix-secondary-soft: #ecfeff;
    --ix-secondary-subtle: #cffafe;
    --ix-secondary-strong: #0e7490;

    --ix-accent: #8b5cf6;
    --ix-accent-rgb: 139, 92, 246;
    --ix-accent-soft: #f3e8ff;
    --ix-accent-strong: #6d28d9;

    --ix-success: #16a34a;
    --ix-success-rgb: 22, 163, 74;
    --ix-success-soft: #ecfdf3;

    --ix-warning: #f59e0b;
    --ix-warning-rgb: 245, 158, 11;
    --ix-warning-soft: #fff7e6;

    --ix-danger: #dc2626;
    --ix-danger-rgb: 220, 38, 38;
    --ix-danger-soft: #fff1f2;

    --ix-info: #0284c7;
    --ix-info-rgb: 2, 132, 199;
    --ix-info-soft: #e0f2fe;

    --ix-app-bg: #f5f7ff;
    --ix-app-bg-rgb: 245, 247, 255;
    --ix-app-gradient:
        radial-gradient(circle at 7% 10%, rgba(var(--ix-primary-rgb), .16), transparent 30%),
        radial-gradient(circle at 88% 6%, rgba(var(--ix-secondary-rgb), .14), transparent 29%),
        radial-gradient(circle at 45% 100%, rgba(var(--ix-accent-rgb), .08), transparent 36%),
        linear-gradient(180deg, #fbfcff 0%, #eef2ff 100%);

    --ix-surface: #ffffff;
    --ix-surface-rgb: 255, 255, 255;
    --ix-surface-soft: #f8faff;
    --ix-surface-muted: #f0f4ff;
    --ix-surface-elevated: #ffffff;

    --ix-border: #dce3f2;
    --ix-border-strong: #c6d1e6;
    --ix-border-soft: rgba(var(--ix-primary-rgb), .14);

    --ix-text: #111827;
    --ix-text-rgb: 17, 24, 39;
    --ix-text-muted: #64748b;
    --ix-text-soft: #94a3b8;
    --ix-heading: #0f172a;

    --ix-sidebar-bg: rgba(255, 255, 255, .9);
    --ix-sidebar-border: rgba(var(--ix-primary-rgb), .15);
    --ix-sidebar-link: #475569;
    --ix-sidebar-link-hover: #1e1b4b;
    --ix-sidebar-link-hover-bg: rgba(var(--ix-primary-rgb), .09);
    --ix-sidebar-link-active: #312e81;
    --ix-sidebar-link-active-bg: linear-gradient(135deg, rgba(var(--ix-primary-rgb), .16), rgba(var(--ix-secondary-rgb), .11));

    --ix-topbar-bg: rgba(255, 255, 255, .84);
    --ix-topbar-border: rgba(var(--ix-primary-rgb), .13);

    --ix-input-bg: #ffffff;
    --ix-input-border: #cbd5e1;
    --ix-input-placeholder: #94a3b8;

    --bs-body-font-family: var(--ix-font-sans);
    --bs-body-bg: var(--ix-app-bg);
    --bs-body-color: var(--ix-text);
    --bs-primary: var(--ix-primary);
    --bs-primary-rgb: var(--ix-primary-rgb);
    --bs-secondary: var(--ix-secondary);
    --bs-secondary-rgb: var(--ix-secondary-rgb);
    --bs-success: var(--ix-success);
    --bs-success-rgb: var(--ix-success-rgb);
    --bs-warning: var(--ix-warning);
    --bs-warning-rgb: var(--ix-warning-rgb);
    --bs-danger: var(--ix-danger);
    --bs-danger-rgb: var(--ix-danger-rgb);
    --bs-info: var(--ix-info);
    --bs-info-rgb: var(--ix-info-rgb);
    --bs-border-color: var(--ix-border);
    --bs-link-color: var(--ix-primary-strong);
    --bs-link-hover-color: #2e1065;
}

/* =========================================================
   3. Dark theme
   ========================================================= */

[data-bs-theme="dark"] {
    --ix-primary: #818cf8;
    --ix-primary-rgb: 129, 140, 248;
    --ix-primary-soft: rgba(129, 140, 248, .14);
    --ix-primary-subtle: rgba(129, 140, 248, .23);
    --ix-primary-strong: #c7d2fe;

    --ix-secondary: #22d3ee;
    --ix-secondary-rgb: 34, 211, 238;
    --ix-secondary-soft: rgba(34, 211, 238, .13);
    --ix-secondary-subtle: rgba(34, 211, 238, .22);
    --ix-secondary-strong: #a5f3fc;

    --ix-accent: #a78bfa;
    --ix-accent-rgb: 167, 139, 250;
    --ix-accent-soft: rgba(167, 139, 250, .14);
    --ix-accent-strong: #ddd6fe;

    --ix-success: #4ade80;
    --ix-success-rgb: 74, 222, 128;
    --ix-success-soft: rgba(74, 222, 128, .12);

    --ix-warning: #fbbf24;
    --ix-warning-rgb: 251, 191, 36;
    --ix-warning-soft: rgba(251, 191, 36, .13);

    --ix-danger: #fb7185;
    --ix-danger-rgb: 251, 113, 133;
    --ix-danger-soft: rgba(251, 113, 133, .13);

    --ix-info: #38bdf8;
    --ix-info-rgb: 56, 189, 248;
    --ix-info-soft: rgba(56, 189, 248, .13);

    --ix-app-bg: #080b19;
    --ix-app-bg-rgb: 8, 11, 25;
    --ix-app-gradient:
        radial-gradient(circle at 7% 10%, rgba(var(--ix-primary-rgb), .15), transparent 31%),
        radial-gradient(circle at 88% 6%, rgba(var(--ix-secondary-rgb), .11), transparent 29%),
        radial-gradient(circle at 45% 100%, rgba(var(--ix-accent-rgb), .10), transparent 38%),
        linear-gradient(180deg, #080b19 0%, #0b1022 100%);

    --ix-surface: #111827;
    --ix-surface-rgb: 17, 24, 39;
    --ix-surface-soft: #151f33;
    --ix-surface-muted: #1f2937;
    --ix-surface-elevated: #111c2e;

    --ix-border: rgba(148, 163, 184, .20);
    --ix-border-strong: rgba(148, 163, 184, .32);
    --ix-border-soft: rgba(var(--ix-primary-rgb), .16);

    --ix-text: #e5e7eb;
    --ix-text-rgb: 229, 231, 235;
    --ix-text-muted: #a1a8b8;
    --ix-text-soft: #737f94;
    --ix-heading: #f8fafc;

    --ix-sidebar-bg: rgba(8, 13, 30, .92);
    --ix-sidebar-border: rgba(var(--ix-primary-rgb), .16);
    --ix-sidebar-link: #bec7d6;
    --ix-sidebar-link-hover: #ffffff;
    --ix-sidebar-link-hover-bg: rgba(var(--ix-primary-rgb), .11);
    --ix-sidebar-link-active: #ffffff;
    --ix-sidebar-link-active-bg: linear-gradient(135deg, rgba(var(--ix-primary-rgb), .22), rgba(var(--ix-secondary-rgb), .12));

    --ix-topbar-bg: rgba(8, 13, 30, .84);
    --ix-topbar-border: rgba(var(--ix-primary-rgb), .16);

    --ix-input-bg: #0b1220;
    --ix-input-border: rgba(148, 163, 184, .30);
    --ix-input-placeholder: #6f7d92;

    --bs-body-bg: var(--ix-app-bg);
    --bs-body-color: var(--ix-text);
    --bs-border-color: var(--ix-border);
    --bs-link-color: var(--ix-primary-strong);
    --bs-link-hover-color: #e0e7ff;
}

/* =========================================================
   4. Global base
   ========================================================= */

html {
    min-height: 100%;
    scroll-behavior: smooth;
}

body {
    min-height: 100vh;
    margin: 0;
    background: var(--ix-app-gradient);
    color: var(--ix-text);
    font-family: var(--ix-font-sans);
    font-size: .95rem;
    line-height: 1.5;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

::selection {
    color: #ffffff;
    background: rgba(var(--ix-primary-rgb), .86);
}

h1, h2, h3, h4, h5, h6 {
    color: var(--ix-heading);
    letter-spacing: -.025em;
}

small,
.small {
    color: var(--ix-text-muted);
}

hr {
    border-color: var(--ix-border);
    opacity: 1;
}

a {
    transition: color var(--ix-transition-fast), background var(--ix-transition-fast), border-color var(--ix-transition-fast);
}

.ix-text-muted { color: var(--ix-text-muted) !important; }
.ix-text-soft { color: var(--ix-text-soft) !important; }
.ix-text-heading { color: var(--ix-heading) !important; }
.ix-money,
.ix-tabular { font-variant-numeric: tabular-nums; }
.ix-fw-black { font-weight: 950 !important; }
.ix-nowrap { white-space: nowrap !important; }
.ix-truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ix-link-muted { color: var(--ix-text-muted); text-decoration: none; }
.ix-link-muted:hover { color: var(--ix-primary-strong); }

/* =========================================================
   5. App shell
   ========================================================= */

.ix-app {
    min-height: 100vh;
    display: flex;
}

.ix-sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    z-index: var(--ix-z-sidebar);
    width: var(--ix-sidebar-width);
    display: flex;
    flex-direction: column;
    background: var(--ix-sidebar-bg);
    border-right: 1px solid var(--ix-sidebar-border);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    transition: width var(--ix-transition-normal), transform var(--ix-transition-normal);
}

.ix-sidebar-header {
    min-height: var(--ix-topbar-height);
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: 1rem 1.1rem;
    border-bottom: 1px solid var(--ix-sidebar-border);
}

.ix-brand-link {
    min-width: 0;
    flex: 1 1 auto;
    display: flex;
    align-items: center;
    gap: .72rem;
    color: inherit;
    text-decoration: none;
}

.ix-brand-link:hover { color: inherit; }

.ix-brand-mark {
    width: 42px;
    height: 42px;
    flex: 0 0 auto;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    background:
        radial-gradient(circle at 25% 20%, rgba(255,255,255,.36), transparent 22px),
        linear-gradient(135deg, var(--ix-primary), var(--ix-secondary));
    box-shadow: 0 14px 24px rgba(var(--ix-primary-rgb), .24);
}

.ix-brand-mark-sm {
    width: 34px;
    height: 34px;
    border-radius: 12px;
}

.ix-brand-text { min-width: 0; }

.ix-brand-title {
    margin: 0;
    font-size: 1.03rem;
    font-weight: 900;
    color: var(--ix-heading);
    line-height: 1.1;
}

.ix-brand-subtitle {
    margin: .15rem 0 0;
    font-size: .73rem;
    color: var(--ix-text-muted);
    line-height: 1.2;
}

.ix-sidebar-toggle { flex: 0 0 auto; }

.ix-sidebar-body {
    flex: 1 1 auto;
    overflow-y: auto;
    padding: .85rem;
}

.ix-sidebar-footer {
    border-top: 1px solid var(--ix-sidebar-border);
    padding: .85rem;
}

.ix-main {
    flex: 1 1 auto;
    min-width: 0;
    margin-left: var(--ix-sidebar-width);
    transition: margin-left var(--ix-transition-normal);
}

.ix-topbar {
    position: sticky;
    top: 0;
    z-index: var(--ix-z-topbar);
    height: var(--ix-topbar-height);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: .85rem 1.25rem;
    background: var(--ix-topbar-bg);
    border-bottom: 1px solid var(--ix-topbar-border);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}

.ix-content {
    width: min(100%, var(--ix-content-max-width));
    margin: 0 auto;
    padding: 1.25rem;
}

.ix-content-narrow { max-width: 1120px; }
.ix-content-wide { max-width: 1920px; }

.ix-topbar-brand {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    color: var(--ix-heading);
    font-weight: 900;
    text-decoration: none;
}

.ix-topbar-center {
    flex: 1 1 520px;
    max-width: 660px;
    margin-inline: auto;
}

.ix-topbar-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: .6rem;
}

/* Sidebar collapsed mode. Add .ix-sidebar-collapsed to body. */
.ix-sidebar-collapsed .ix-sidebar { width: var(--ix-sidebar-collapsed-width); }
.ix-sidebar-collapsed .ix-main { margin-left: var(--ix-sidebar-collapsed-width); }
.ix-sidebar-collapsed .ix-sidebar-header { justify-content: center; padding: .75rem .55rem; }
.ix-sidebar-collapsed .ix-brand-link { display: none; }
.ix-sidebar-collapsed .ix-sidebar-toggle { width: 48px; height: 48px; border-radius: var(--ix-radius-lg); }
.ix-sidebar-collapsed .ix-brand-text,
.ix-sidebar-collapsed .ix-nav-section-title,
.ix-sidebar-collapsed .ix-nav-text,
.ix-sidebar-collapsed .ix-nav-chevron,
.ix-sidebar-collapsed .ix-nav-badge,
.ix-sidebar-collapsed .ix-sidebar-footer .ix-user-meta { display: none !important; }
.ix-sidebar-collapsed .ix-sidebar-body { padding: .75rem .55rem; }
.ix-sidebar-collapsed .ix-nav-shell { gap: .45rem; }
.ix-sidebar-collapsed .ix-nav-section { margin-bottom: .35rem; }
.ix-sidebar-collapsed .ix-nav-link,
.ix-sidebar-collapsed .ix-nav-group-toggle {
    width: 48px;
    height: 48px;
    min-height: 48px;
    margin-inline: auto;
    padding: 0;
    justify-content: center;
    gap: 0;
    border-radius: var(--ix-radius-lg);
}
.ix-sidebar-collapsed .ix-nav-link:hover,
.ix-sidebar-collapsed .ix-nav-group-toggle:hover { transform: none; }
.ix-sidebar-collapsed .ix-nav-icon { width: 48px; min-width: 48px; font-size: 1rem; }
.ix-sidebar-collapsed .ix-nav-submenu,
.ix-sidebar-collapsed .ix-nav-divider { display: none !important; }
.ix-sidebar-collapsed .ix-sidebar-footer { display: flex; align-items: center; justify-content: center; padding: .85rem .55rem; }
.ix-sidebar-collapsed .ix-sidebar-footer > div { justify-content: center; }

/* =========================================================
   6. Navigation
   ========================================================= */

.ix-nav-shell { display: grid; gap: .35rem; }
.ix-nav-section { margin-bottom: .9rem; }

.ix-nav-section-title {
    margin: .65rem .75rem .35rem;
    font-size: .68rem;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: .09em;
    color: var(--ix-text-soft);
}

.ix-nav { display: grid; gap: .22rem; }

.ix-nav-link,
.ix-nav-group-toggle {
    min-height: 42px;
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .62rem .75rem;
    border-radius: var(--ix-radius-md);
    color: var(--ix-sidebar-link);
    text-decoration: none;
    font-weight: 700;
    transition: background var(--ix-transition-fast), color var(--ix-transition-fast), transform var(--ix-transition-fast), box-shadow var(--ix-transition-fast);
}

.ix-nav-link:hover,
.ix-nav-link:focus,
.ix-nav-group-toggle:hover,
.ix-nav-group-toggle:focus {
    color: var(--ix-sidebar-link-hover);
    background: var(--ix-sidebar-link-hover-bg);
    transform: translateX(2px);
}

.ix-nav-link.active,
.ix-nav-link[aria-current="page"] {
    color: var(--ix-sidebar-link-active);
    background: var(--ix-sidebar-link-active-bg);
    box-shadow: inset 0 0 0 1px rgba(var(--ix-primary-rgb), .11);
}

.ix-nav-icon {
    width: 1.35rem;
    min-width: 1.35rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: currentColor;
    opacity: .94;
}

.ix-nav-text {
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ix-nav-badge {
    margin-left: auto;
    font-size: .68rem;
    font-weight: 850;
    padding: .18rem .42rem;
    border-radius: var(--ix-radius-pill);
    color: var(--ix-primary-strong);
    background: var(--ix-primary-soft);
}

.ix-nav-divider {
    height: 1px;
    margin: .65rem .55rem;
    background: var(--ix-border);
}

.ix-nav-group { display: block; }
.ix-nav-group > summary { list-style: none; }
.ix-nav-group > summary::-webkit-details-marker { display: none; }
.ix-nav-group-toggle { cursor: pointer; user-select: none; }
.ix-nav-chevron {
    margin-left: auto;
    font-size: .72rem;
    color: var(--ix-text-soft);
    transition: transform var(--ix-transition-fast);
}
.ix-nav-group[open] .ix-nav-chevron { transform: rotate(180deg); }

.ix-nav-submenu {
    display: grid;
    gap: .18rem;
    padding: .18rem 0 .35rem 2.05rem;
}

.ix-nav-sublink {
    min-height: 36px;
    padding-block: .48rem;
    font-size: .9rem;
    font-weight: 650;
}

.ix-nav-subdot {
    width: .45rem;
    height: .45rem;
    flex: 0 0 auto;
    border-radius: 999px;
    background: var(--ix-border-strong);
}

.ix-nav-sublink.active .ix-nav-subdot,
.ix-nav-sublink[aria-current="page"] .ix-nav-subdot { background: var(--ix-primary); }

/* =========================================================
   7. Page headers, filters and action bars
   ========================================================= */

.ix-page-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.ix-page-eyebrow {
    margin-bottom: .25rem;
    font-size: .75rem;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: .09em;
    color: var(--ix-primary-strong);
}

.ix-page-title {
    margin: 0;
    font-size: clamp(1.45rem, 2vw, 2rem);
    font-weight: 900;
    line-height: 1.12;
}

.ix-page-subtitle {
    max-width: 820px;
    margin: .35rem 0 0;
    color: var(--ix-text-muted);
}

.ix-actionbar {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: .5rem;
}

.ix-filterbar,
.ix-filter-card {
    border: 1px solid var(--ix-border);
    border-radius: var(--ix-radius-xl);
    background: rgba(var(--ix-surface-rgb), .78);
    box-shadow: var(--ix-shadow-xs);
}

.ix-filterbar {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .65rem;
    padding: .85rem;
    margin-bottom: 1rem;
}

.ix-filter-card { margin-bottom: 1rem; overflow: hidden; }
.ix-filter-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    padding: .85rem 1rem;
    border-bottom: 1px solid var(--ix-border);
}
.ix-filter-card-body { padding: 1rem; }
.ix-filter-card[data-ix-filter-collapsed="true"] .ix-filter-card-body { display: none; }

.ix-search-box { position: relative; flex: 1 1 280px; }
.ix-search-box .form-control { padding-left: 2.35rem; }
.ix-search-box-icon {
    position: absolute;
    left: .85rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--ix-text-soft);
    pointer-events: none;
}

/* =========================================================
   8. Bootstrap component refinements
   ========================================================= */

.btn {
    border-radius: var(--ix-radius-md);
    font-weight: 750;
    box-shadow: none !important;
}

.btn-primary {
    --bs-btn-bg: var(--ix-primary);
    --bs-btn-border-color: var(--ix-primary);
    --bs-btn-hover-bg: var(--ix-primary-strong);
    --bs-btn-hover-border-color: var(--ix-primary-strong);
    --bs-btn-active-bg: var(--ix-primary-strong);
    --bs-btn-active-border-color: var(--ix-primary-strong);
}

.btn-outline-primary {
    --bs-btn-color: var(--ix-primary-strong);
    --bs-btn-border-color: rgba(var(--ix-primary-rgb), .42);
    --bs-btn-hover-bg: var(--ix-primary);
    --bs-btn-hover-border-color: var(--ix-primary);
}

.btn-light {
    --bs-btn-bg: var(--ix-surface);
    --bs-btn-color: var(--ix-text);
    --bs-btn-border-color: var(--ix-border);
    --bs-btn-hover-bg: var(--ix-surface-muted);
    --bs-btn-hover-color: var(--ix-heading);
    --bs-btn-hover-border-color: var(--ix-border-strong);
}

.btn-soft-primary,
.btn-soft-secondary,
.btn-soft-accent,
.btn-soft-success,
.btn-soft-warning,
.btn-soft-danger,
.btn-soft-info {
    border-color: transparent;
}

.btn-soft-primary { color: var(--ix-primary-strong); background: var(--ix-primary-soft); }
.btn-soft-primary:hover { color: #ffffff; background: var(--ix-primary); }
.btn-soft-secondary { color: var(--ix-secondary-strong); background: var(--ix-secondary-soft); }
.btn-soft-secondary:hover { color: #07111d; background: var(--ix-secondary); }
.btn-soft-accent { color: var(--ix-accent-strong); background: var(--ix-accent-soft); }
.btn-soft-accent:hover { color: #ffffff; background: var(--ix-accent); }
.btn-soft-success { color: var(--ix-success); background: var(--ix-success-soft); }
.btn-soft-success:hover { color: #ffffff; background: var(--ix-success); }
.btn-soft-warning { color: var(--ix-warning); background: var(--ix-warning-soft); }
.btn-soft-warning:hover { color: #111827; background: var(--ix-warning); }
.btn-soft-danger { color: var(--ix-danger); background: var(--ix-danger-soft); }
.btn-soft-danger:hover { color: #ffffff; background: var(--ix-danger); }
.btn-soft-info { color: var(--ix-info); background: var(--ix-info-soft); }
.btn-soft-info:hover { color: #ffffff; background: var(--ix-info); }

.ix-icon-btn {
    width: 2.42rem;
    height: 2.42rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--ix-border);
    border-radius: var(--ix-radius-md);
    color: var(--ix-text-muted);
    background: var(--ix-surface);
}
.ix-icon-btn:hover {
    color: var(--ix-primary-strong);
    border-color: rgba(var(--ix-primary-rgb), .35);
    background: var(--ix-primary-soft);
}

.form-label {
    margin-bottom: .35rem;
    font-weight: 750;
    color: var(--ix-heading);
}

.form-control,
.form-select {
    border-radius: var(--ix-radius-md);
    border-color: var(--ix-input-border);
    background-color: var(--ix-input-bg);
    color: var(--ix-text);
    transition: border-color var(--ix-transition-fast), box-shadow var(--ix-transition-fast), background-color var(--ix-transition-fast);
}

.form-control::placeholder { color: var(--ix-input-placeholder); }
.form-control:focus,
.form-select:focus {
    border-color: rgba(var(--ix-primary-rgb), .72);
    box-shadow: 0 0 0 .22rem rgba(var(--ix-primary-rgb), .14);
}
.form-text { color: var(--ix-text-muted); }
.input-group-text {
    border-color: var(--ix-input-border);
    background: var(--ix-surface-soft);
    color: var(--ix-text-muted);
    border-radius: var(--ix-radius-md);
}

.dropdown-menu {
    border-color: var(--ix-border);
    border-radius: var(--ix-radius-lg);
    background: var(--ix-surface-elevated);
    box-shadow: var(--ix-shadow-md);
}
.dropdown-item { border-radius: var(--ix-radius-sm); color: var(--ix-text); }
.dropdown-item:hover,
.dropdown-item:focus { color: var(--ix-heading); background: var(--ix-primary-soft); }
.dropdown-divider { border-color: var(--ix-border); }

.modal-content {
    border-color: var(--ix-border);
    border-radius: var(--ix-radius-2xl);
    background: var(--ix-surface);
    box-shadow: var(--ix-shadow-lg);
}
.modal-header,
.modal-footer { border-color: var(--ix-border); }
.offcanvas { background: var(--ix-surface); color: var(--ix-text); }
.alert { border-radius: var(--ix-radius-lg); }

.nav-tabs { border-color: var(--ix-border); }
.nav-tabs .nav-link {
    color: var(--ix-text-muted);
    border-radius: var(--ix-radius-md) var(--ix-radius-md) 0 0;
    font-weight: 750;
}
.nav-tabs .nav-link:hover { border-color: transparent; color: var(--ix-primary-strong); }
.nav-tabs .nav-link.active {
    color: var(--ix-heading);
    background: var(--ix-surface);
    border-color: var(--ix-border) var(--ix-border) var(--ix-surface);
}

.pagination { --bs-pagination-border-color: var(--ix-border); --bs-pagination-bg: var(--ix-surface); }
.page-link { color: var(--ix-primary-strong); }
.active > .page-link,
.page-link.active { background: var(--ix-primary); border-color: var(--ix-primary); }

/* =========================================================
   9. Cards and surfaces
   ========================================================= */

.ix-card,
.ix-section-card,
.ix-table-card,
.ix-surface {
    border: 1px solid var(--ix-border);
    border-radius: var(--ix-radius-xl);
    background: rgba(var(--ix-surface-rgb), .88);
    box-shadow: var(--ix-shadow-xs);
}

.ix-card-elevated { box-shadow: var(--ix-shadow-sm); }

.ix-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.1rem;
    border-bottom: 1px solid var(--ix-border);
}

.ix-card-title { margin: 0; font-size: 1rem; font-weight: 900; color: var(--ix-heading); }
.ix-card-subtitle { margin: .15rem 0 0; color: var(--ix-text-muted); font-size: .86rem; }
.ix-card-body { padding: 1.1rem; }
.ix-card-footer {
    padding: .9rem 1.1rem;
    border-top: 1px solid var(--ix-border);
    background: rgba(var(--ix-app-bg-rgb), .38);
    border-radius: 0 0 var(--ix-radius-xl) var(--ix-radius-xl);
}

.ix-section-card { overflow: hidden; }
.ix-section-card + .ix-section-card { margin-top: 1rem; }
.ix-section-title { margin: 0; font-size: .95rem; font-weight: 900; }
.ix-section-description { margin: .2rem 0 0; color: var(--ix-text-muted); font-size: .86rem; }

/* =========================================================
   10. Data tables
   ========================================================= */

.ix-table-card { overflow: hidden; }
.ix-table-wrap { width: 100%; overflow-x: auto; }
.table.ix-table { margin-bottom: 0; vertical-align: middle; }
.table.ix-table > :not(caption) > * > * {
    padding: .82rem .95rem;
    color: var(--ix-text);
    background: transparent;
    border-bottom-color: var(--ix-border);
}
.table.ix-table thead th {
    font-size: .72rem;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--ix-text-muted);
    background: rgba(var(--ix-app-bg-rgb), .62);
    white-space: nowrap;
}
.table.ix-table tbody tr { transition: background var(--ix-transition-fast); }
.table.ix-table tbody tr:hover { background: rgba(var(--ix-primary-rgb), .055); }
.ix-table-actions { display: flex; align-items: center; justify-content: flex-end; gap: .35rem; white-space: nowrap; }
.ix-row-title { font-weight: 850; color: var(--ix-heading); }
.ix-row-subtitle { margin-top: .12rem; font-size: .82rem; color: var(--ix-text-muted); }
.ix-click-row { cursor: pointer; }
.ix-click-row:focus-within,
.ix-click-row:hover { outline: none; }

/* =========================================================
   11. Badges, chips and status indicators
   ========================================================= */

.ix-badge {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    min-height: 1.55rem;
    padding: .18rem .55rem;
    border-radius: var(--ix-radius-pill);
    font-size: .72rem;
    font-weight: 850;
    line-height: 1;
    border: 1px solid transparent;
    white-space: nowrap;
}
.ix-badge-primary { color: var(--ix-primary-strong); background: var(--ix-primary-soft); border-color: rgba(var(--ix-primary-rgb), .20); }
.ix-badge-secondary { color: var(--ix-secondary-strong); background: var(--ix-secondary-soft); border-color: rgba(var(--ix-secondary-rgb), .20); }
.ix-badge-accent { color: var(--ix-accent-strong); background: var(--ix-accent-soft); border-color: rgba(var(--ix-accent-rgb), .20); }
.ix-badge-success { color: var(--ix-success); background: var(--ix-success-soft); border-color: rgba(var(--ix-success-rgb), .20); }
.ix-badge-warning { color: var(--ix-warning); background: var(--ix-warning-soft); border-color: rgba(var(--ix-warning-rgb), .24); }
.ix-badge-danger { color: var(--ix-danger); background: var(--ix-danger-soft); border-color: rgba(var(--ix-danger-rgb), .22); }
.ix-badge-info { color: var(--ix-info); background: var(--ix-info-soft); border-color: rgba(var(--ix-info-rgb), .22); }
.ix-badge-muted { color: var(--ix-text-muted); background: var(--ix-surface-muted); border-color: var(--ix-border); }

.ix-chip {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    min-height: 2rem;
    padding: .35rem .75rem;
    border: 1px solid var(--ix-border);
    border-radius: var(--ix-radius-pill);
    color: var(--ix-text);
    background: var(--ix-surface);
    text-decoration: none;
    font-weight: 750;
}
.ix-chip:hover,
.ix-chip.active {
    color: var(--ix-primary-strong);
    border-color: rgba(var(--ix-primary-rgb), .35);
    background: var(--ix-primary-soft);
}

.ix-status-dot {
    width: .55rem;
    height: .55rem;
    display: inline-block;
    border-radius: 50%;
    background: var(--ix-text-soft);
    box-shadow: 0 0 0 .18rem rgba(var(--ix-text-rgb), .08);
}
.ix-status-dot.success { background: var(--ix-success); box-shadow: 0 0 0 .18rem rgba(var(--ix-success-rgb), .13); }
.ix-status-dot.warning { background: var(--ix-warning); box-shadow: 0 0 0 .18rem rgba(var(--ix-warning-rgb), .13); }
.ix-status-dot.danger { background: var(--ix-danger); box-shadow: 0 0 0 .18rem rgba(var(--ix-danger-rgb), .13); }
.ix-status-dot.primary { background: var(--ix-primary); box-shadow: 0 0 0 .18rem rgba(var(--ix-primary-rgb), .13); }
.ix-status-dot.info { background: var(--ix-info); box-shadow: 0 0 0 .18rem rgba(var(--ix-info-rgb), .13); }

/* =========================================================
   12. Dashboard, metrics and platform ops cards
   ========================================================= */

.ix-metric-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1rem; }
.ix-metric-card {
    position: relative;
    overflow: hidden;
    border: 1px solid var(--ix-border);
    border-radius: var(--ix-radius-xl);
    background: rgba(var(--ix-surface-rgb), .88);
    padding: 1rem;
    box-shadow: var(--ix-shadow-xs);
}
.ix-metric-card::after {
    content: "";
    position: absolute;
    inset: auto -24px -42px auto;
    width: 120px;
    height: 120px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(var(--ix-primary-rgb), .13), transparent 64%);
    pointer-events: none;
}
.ix-metric-label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    margin-bottom: .7rem;
    color: var(--ix-text-muted);
    font-size: .78rem;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: .06em;
}
.ix-metric-value {
    margin: 0;
    color: var(--ix-heading);
    font-size: clamp(1.45rem, 2.1vw, 2.1rem);
    font-weight: 950;
    letter-spacing: -.045em;
    line-height: 1;
}
.ix-metric-note { margin-top: .45rem; color: var(--ix-text-muted); font-size: .84rem; }
.ix-metric-icon {
    width: 2.35rem;
    height: 2.35rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: .9rem;
    color: var(--ix-primary-strong);
    background: var(--ix-primary-soft);
}

.ix-home-loading {
    min-height: calc(100vh - var(--ix-topbar-height) - 4rem);
    display: grid;
    place-items: center;
}

.ix-hero {
    position: relative;
    overflow: hidden;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 1.25rem;
    align-items: stretch;
    border: 1px solid var(--ix-border);
    border-radius: var(--ix-radius-2xl);
    background:
        radial-gradient(circle at 10% 20%, rgba(var(--ix-primary-rgb), .19), transparent 28%),
        radial-gradient(circle at 85% 10%, rgba(var(--ix-secondary-rgb), .16), transparent 30%),
        rgba(var(--ix-surface-rgb), .86);
    box-shadow: var(--ix-shadow-sm);
    padding: 1.35rem;
}
.ix-hero::after {
    content: "";
    position: absolute;
    width: 360px;
    height: 360px;
    right: -140px;
    bottom: -210px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(var(--ix-primary-rgb), .22), transparent 64%);
    pointer-events: none;
}
.ix-hero-copy,
.ix-hero-panel { position: relative; z-index: 1; }
.ix-hero-title {
    margin: 0;
    max-width: 820px;
    color: var(--ix-heading);
    font-size: clamp(1.7rem, 3vw, 3rem);
    font-weight: 950;
    letter-spacing: -.06em;
    line-height: 1;
}
.ix-hero-subtitle { max-width: 760px; margin: .75rem 0 0; color: var(--ix-text-muted); font-size: 1.02rem; }
.ix-hero-actions { display: flex; flex-wrap: wrap; gap: .55rem; margin-top: 1.25rem; }
.ix-hero-panel {
    display: grid;
    align-content: space-between;
    gap: 1rem;
    border: 1px solid var(--ix-border);
    border-radius: var(--ix-radius-xl);
    background: rgba(var(--ix-surface-rgb), .74);
    padding: 1rem;
    box-shadow: var(--ix-shadow-xs);
}
.ix-hero-date { color: var(--ix-text-muted); font-size: .8rem; font-weight: 850; text-transform: uppercase; letter-spacing: .07em; }

.ix-health-list,
.ix-mini-list { display: grid; gap: .55rem; }
.ix-health-item,
.ix-mini-list-item {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .75rem;
    border: 1px solid var(--ix-border);
    border-radius: var(--ix-radius-lg);
    color: var(--ix-text);
    background: rgba(var(--ix-app-bg-rgb), .34);
    text-decoration: none;
    transition: border-color var(--ix-transition-fast), background var(--ix-transition-fast), transform var(--ix-transition-fast);
}
.ix-health-item:hover,
.ix-mini-list-item:hover { border-color: rgba(var(--ix-primary-rgb), .32); background: var(--ix-primary-soft); transform: translateY(-1px); }
.ix-health-item strong { display: block; color: var(--ix-heading); font-size: 1.15rem; font-weight: 950; line-height: 1; }
.ix-health-item small { display: block; margin-top: .12rem; color: var(--ix-text-muted); font-weight: 650; }
.ix-health-icon,
.ix-mini-list-icon {
    width: 2.45rem;
    height: 2.45rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: .9rem;
    flex: 0 0 auto;
}
.ix-health-icon.primary,
.ix-mini-list-icon { color: var(--ix-primary-strong); background: var(--ix-primary-soft); }
.ix-health-icon.secondary { color: var(--ix-secondary-strong); background: var(--ix-secondary-soft); }
.ix-health-icon.warning { color: var(--ix-warning); background: var(--ix-warning-soft); }
.ix-health-icon.danger { color: var(--ix-danger); background: var(--ix-danger-soft); }
.ix-health-icon.success { color: var(--ix-success); background: var(--ix-success-soft); }

.ix-mini-list-content { flex: 1 1 auto; min-width: 0; }
.ix-mini-list-content strong,
.ix-mini-list-content small { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ix-mini-list-content strong { color: var(--ix-heading); }
.ix-mini-list-content small { color: var(--ix-text-muted); }

.ix-quick-actions { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .65rem; }
.ix-quick-action {
    min-height: 5.5rem;
    display: grid;
    align-content: center;
    justify-items: start;
    gap: .5rem;
    padding: .85rem;
    border: 1px solid var(--ix-border);
    border-radius: var(--ix-radius-lg);
    color: var(--ix-text);
    background: rgba(var(--ix-app-bg-rgb), .34);
    text-decoration: none;
    font-weight: 850;
}
.ix-quick-action i { color: var(--ix-primary-strong); font-size: 1.2rem; }
.ix-quick-action:hover { color: var(--ix-primary-strong); border-color: rgba(var(--ix-primary-rgb), .34); background: var(--ix-primary-soft); }

.ix-ops-grid { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(320px, .65fr); gap: 1rem; }
.ix-two-col-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
.ix-three-col-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1rem; }
.ix-money-board { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: .85rem; }
.ix-money-board > div {
    border: 1px solid var(--ix-border);
    border-radius: var(--ix-radius-lg);
    background: rgba(var(--ix-app-bg-rgb), .42);
    padding: .95rem;
}
.ix-money-board-label { margin-bottom: .45rem; color: var(--ix-text-muted); font-size: .72rem; font-weight: 850; text-transform: uppercase; letter-spacing: .06em; }
.ix-money-board-value { color: var(--ix-heading); font-size: 1.25rem; font-weight: 950; letter-spacing: -.035em; font-variant-numeric: tabular-nums; }

/* =========================================================
   13. Tenant, billing, deployment and security helpers
   ========================================================= */

.ix-tenant-card {
    position: relative;
    overflow: hidden;
    border: 1px solid var(--ix-border);
    border-radius: var(--ix-radius-xl);
    background: rgba(var(--ix-surface-rgb), .88);
    box-shadow: var(--ix-shadow-xs);
    padding: 1rem;
}
.ix-tenant-card::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 3px;
    background: linear-gradient(90deg, var(--ix-primary), var(--ix-secondary), var(--ix-accent));
}
.ix-tenant-logo {
    width: 2.75rem;
    height: 2.75rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 1rem;
    color: #ffffff;
    background: linear-gradient(135deg, var(--ix-primary), var(--ix-accent));
    font-weight: 950;
}
.ix-tenant-title { margin: 0; color: var(--ix-heading); font-weight: 900; }
.ix-tenant-meta { color: var(--ix-text-muted); font-size: .84rem; }

.ix-plan-card {
    border: 1px solid var(--ix-border);
    border-radius: var(--ix-radius-xl);
    background: var(--ix-surface);
    padding: 1rem;
}
.ix-plan-price { font-size: 2rem; font-weight: 950; letter-spacing: -.06em; color: var(--ix-heading); }
.ix-plan-period { color: var(--ix-text-muted); font-size: .86rem; }

.ix-deploy-stepper { display: flex; align-items: center; gap: .5rem; overflow-x: auto; padding-bottom: .25rem; }
.ix-deploy-step {
    min-width: 150px;
    display: flex;
    align-items: center;
    gap: .55rem;
    border: 1px solid var(--ix-border);
    border-radius: var(--ix-radius-pill);
    background: var(--ix-surface);
    padding: .55rem .75rem;
    color: var(--ix-text-muted);
    font-size: .82rem;
    font-weight: 800;
    white-space: nowrap;
}
.ix-deploy-step.done { color: var(--ix-success); background: var(--ix-success-soft); border-color: rgba(var(--ix-success-rgb), .24); }
.ix-deploy-step.active { color: var(--ix-primary-strong); background: var(--ix-primary-soft); border-color: rgba(var(--ix-primary-rgb), .28); }
.ix-deploy-step.failed { color: var(--ix-danger); background: var(--ix-danger-soft); border-color: rgba(var(--ix-danger-rgb), .24); }

.ix-node-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1rem; }
.ix-node-card {
    border: 1px solid var(--ix-border);
    border-radius: var(--ix-radius-xl);
    background: rgba(var(--ix-surface-rgb), .88);
    padding: 1rem;
}
.ix-node-meter { height: .55rem; overflow: hidden; border-radius: var(--ix-radius-pill); background: var(--ix-surface-muted); }
.ix-node-meter > span { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--ix-primary), var(--ix-secondary)); }

.ix-audit-timeline { position: relative; display: grid; gap: .75rem; padding-left: 1rem; }
.ix-audit-timeline::before { content: ""; position: absolute; left: .28rem; top: .2rem; bottom: .2rem; width: 1px; background: var(--ix-border); }
.ix-audit-item { position: relative; border: 1px solid var(--ix-border); border-radius: var(--ix-radius-lg); background: var(--ix-surface); padding: .85rem; }
.ix-audit-item::before { content: ""; position: absolute; left: -1.02rem; top: 1rem; width: .55rem; height: .55rem; border-radius: 999px; background: var(--ix-primary); box-shadow: 0 0 0 .2rem var(--ix-primary-soft); }
.ix-audit-title { margin: 0; color: var(--ix-heading); font-weight: 850; }
.ix-audit-meta { color: var(--ix-text-muted); font-size: .82rem; }

/* =========================================================
   14. CRUD forms and details
   ========================================================= */

.ix-form-grid { display: grid; grid-template-columns: repeat(12, minmax(0, 1fr)); gap: 1rem; }
.ix-col-12 { grid-column: span 12; }
.ix-col-10 { grid-column: span 10; }
.ix-col-9 { grid-column: span 9; }
.ix-col-8 { grid-column: span 8; }
.ix-col-7 { grid-column: span 7; }
.ix-col-6 { grid-column: span 6; }
.ix-col-5 { grid-column: span 5; }
.ix-col-4 { grid-column: span 4; }
.ix-col-3 { grid-column: span 3; }
.ix-col-2 { grid-column: span 2; }
.ix-required::after { content: " *"; color: var(--ix-danger); }

.ix-validation-summary {
    border: 1px solid rgba(var(--ix-danger-rgb), .24);
    border-radius: var(--ix-radius-lg);
    color: var(--ix-danger);
    background: var(--ix-danger-soft);
    padding: .85rem 1rem;
}
.field-validation-error,
.validation-message { display: block; margin-top: .28rem; color: var(--ix-danger); font-size: .82rem; font-weight: 650; }
.input-validation-error { border-color: rgba(var(--ix-danger-rgb), .72) !important; }

.ix-detail-list { display: grid; gap: .9rem; margin: 0; }
.ix-detail-list > div { display: grid; gap: .18rem; padding-bottom: .85rem; border-bottom: 1px solid var(--ix-border); }
.ix-detail-list > div:last-child { padding-bottom: 0; border-bottom: 0; }
.ix-detail-list dt { color: var(--ix-text-muted); font-size: .72rem; font-weight: 850; text-transform: uppercase; letter-spacing: .06em; }
.ix-detail-list dd { margin: 0; color: var(--ix-heading); font-weight: 800; overflow-wrap: anywhere; }

/* =========================================================
   15. Boards, empty states and loading
   ========================================================= */

.ix-board {
    display: grid;
    grid-template-columns: repeat(4, minmax(260px, 1fr));
    gap: 1rem;
    align-items: start;
    overflow-x: auto;
    padding-bottom: .25rem;
}
.ix-board-column {
    border: 1px solid var(--ix-border);
    border-radius: var(--ix-radius-xl);
    background: rgba(var(--ix-surface-rgb), .72);
    min-height: 360px;
}
.ix-board-header { display: flex; align-items: center; justify-content: space-between; gap: .75rem; padding: .9rem; border-bottom: 1px solid var(--ix-border); }
.ix-board-title { margin: 0; font-size: .9rem; font-weight: 900; }
.ix-board-body { display: grid; gap: .65rem; padding: .85rem; }
.ix-board-card { border: 1px solid var(--ix-border); border-radius: var(--ix-radius-lg); background: var(--ix-surface); padding: .85rem; box-shadow: var(--ix-shadow-xs); }
.ix-board-card:hover { border-color: rgba(var(--ix-primary-rgb), .36); }
.ix-board-card-title { margin: 0; font-weight: 850; color: var(--ix-heading); }
.ix-board-card-meta { margin-top: .35rem; color: var(--ix-text-muted); font-size: .84rem; }

.ix-empty-state {
    border: 1px dashed var(--ix-border-strong);
    border-radius: var(--ix-radius-xl);
    background: rgba(var(--ix-surface-rgb), .62);
    padding: 2rem 1.25rem;
    text-align: center;
}
.ix-empty-icon {
    width: 3rem;
    height: 3rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: .75rem;
    border-radius: var(--ix-radius-lg);
    color: var(--ix-primary-strong);
    background: var(--ix-primary-soft);
}
.ix-empty-title { margin: 0; font-weight: 900; }
.ix-empty-text { max-width: 520px; margin: .35rem auto 0; color: var(--ix-text-muted); }

.ix-skeleton { position: relative; overflow: hidden; border-radius: var(--ix-radius-sm); background: var(--ix-surface-muted); }
.ix-skeleton::after {
    content: "";
    position: absolute;
    inset: 0;
    transform: translateX(-100%);
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, .18), transparent);
    animation: ix-skeleton 1.2s infinite;
}
@keyframes ix-skeleton { 100% { transform: translateX(100%); } }

.ix-scrollbar-thin { scrollbar-width: thin; scrollbar-color: rgba(var(--ix-primary-rgb), .45) transparent; }
.ix-scrollbar-thin::-webkit-scrollbar { width: 8px; height: 8px; }
.ix-scrollbar-thin::-webkit-scrollbar-thumb { border-radius: var(--ix-radius-pill); background: rgba(var(--ix-primary-rgb), .45); }

/* =========================================================
   16. Auth shell
   ========================================================= */

.ix-auth-page {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 1.25rem;
    background: var(--ix-app-gradient);
}
.ix-auth-page::before {
    content: "";
    position: fixed;
    inset: 0;
    background:
        radial-gradient(circle at 16% 18%, rgba(var(--ix-primary-rgb), .18), transparent 28%),
        radial-gradient(circle at 82% 20%, rgba(var(--ix-secondary-rgb), .15), transparent 26%),
        radial-gradient(circle at 50% 92%, rgba(var(--ix-accent-rgb), .12), transparent 34%);
    pointer-events: none;
}
.ix-auth-card {
    position: relative;
    z-index: 2;
    width: min(100%, 470px);
    border: 1px solid var(--ix-border);
    border-radius: var(--ix-radius-2xl);
    background: rgba(var(--ix-surface-rgb), .9);
    box-shadow: var(--ix-shadow-lg);
    overflow: hidden;
}
.ix-auth-hero { padding: 1.4rem 1.4rem 1rem; background: linear-gradient(135deg, rgba(var(--ix-primary-rgb), .15), rgba(var(--ix-secondary-rgb), .10)); border-bottom: 1px solid var(--ix-border); }
.ix-auth-body { padding: 1.4rem; }
.ix-auth-title { margin: .9rem 0 .25rem; font-weight: 950; letter-spacing: -.045em; }
.ix-auth-subtitle { margin: 0; color: var(--ix-text-muted); }

/* =========================================================
   17. Theme toggle and user account controls
   ========================================================= */

.ix-theme-toggle {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    padding: .25rem;
    border: 1px solid var(--ix-border);
    border-radius: var(--ix-radius-pill);
    background: var(--ix-surface);
}
.ix-theme-option {
    min-width: 2.1rem;
    height: 2.1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    border-radius: var(--ix-radius-pill);
    color: var(--ix-text-muted);
    background: transparent;
    transition: background var(--ix-transition-fast), color var(--ix-transition-fast);
}
.ix-theme-option:hover { color: var(--ix-heading); background: var(--ix-surface-muted); }
.ix-theme-option.active { color: #ffffff; background: linear-gradient(135deg, var(--ix-primary), var(--ix-secondary)); }

.ix-user-button {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    border: 1px solid var(--ix-border);
    border-radius: var(--ix-radius-pill);
    color: var(--ix-text);
    background: var(--ix-surface);
    font-weight: 750;
}
.ix-user-button:hover { border-color: rgba(var(--ix-primary-rgb), .34); background: var(--ix-primary-soft); }
.ix-user-avatar {
    width: 1.8rem;
    height: 1.8rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    color: #ffffff;
    background: linear-gradient(135deg, var(--ix-primary), var(--ix-secondary));
}

.ix-offcanvas { border-right: 1px solid var(--ix-border); }
.ix-offcanvas .offcanvas-header { border-bottom: 1px solid var(--ix-border); }

#blazor-error-ui {
    display: none;
    position: fixed;
    left: 1rem;
    right: 1rem;
    bottom: 1rem;
    z-index: 2000;
    padding: .85rem 1rem;
    border: 1px solid rgba(var(--ix-danger-rgb), .25);
    border-radius: var(--ix-radius-lg);
    color: var(--ix-danger);
    background: var(--ix-danger-soft);
    box-shadow: var(--ix-shadow-md);
}
#blazor-error-ui .reload { margin-left: .75rem; font-weight: 800; }
#blazor-error-ui .dismiss { float: right; cursor: pointer; }

/* =========================================================
   18. Responsive behavior
   ========================================================= */

@media (max-width: 1399.98px) {
    .ix-node-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 1199.98px) {
    .ix-metric-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .ix-board { grid-template-columns: repeat(4, minmax(280px, 320px)); }
    .ix-hero,
    .ix-ops-grid { grid-template-columns: 1fr; }
    .ix-two-col-grid,
    .ix-three-col-grid { grid-template-columns: 1fr; }
}

@media (max-width: 991.98px) {
    .ix-sidebar { transform: translateX(-100%); box-shadow: var(--ix-shadow-lg); }
    .ix-sidebar-open .ix-sidebar { transform: translateX(0); }
    .ix-main,
    .ix-sidebar-collapsed .ix-main { margin-left: 0; }
    .ix-content { padding: 1rem; }
    .ix-page-header { flex-direction: column; align-items: stretch; }
    .ix-actionbar { justify-content: flex-start; }
    .ix-form-grid { grid-template-columns: repeat(6, minmax(0, 1fr)); }
    .ix-col-12,
    .ix-col-10,
    .ix-col-9,
    .ix-col-8,
    .ix-col-7,
    .ix-col-6,
    .ix-col-5,
    .ix-col-4,
    .ix-col-3,
    .ix-col-2 { grid-column: span 6; }
}

@media (max-width: 767.98px) {
    .ix-money-board,
    .ix-node-grid { grid-template-columns: 1fr; }
}

@media (max-width: 575.98px) {
    body { font-size: .92rem; }
    .ix-topbar { padding-inline: .85rem; }
    .ix-topbar-actions { gap: .35rem; }
    .ix-theme-toggle { display: none; }
    .ix-user-button { padding-inline: .35rem; }
    .ix-content { padding: .85rem; }
    .ix-metric-grid { grid-template-columns: 1fr; }
    .ix-filterbar { align-items: stretch; }
    .ix-filterbar .form-control,
    .ix-filterbar .form-select,
    .ix-filterbar .btn,
    .ix-search-box { width: 100%; min-width: 0; }
    .ix-form-grid { grid-template-columns: 1fr; }
    .ix-col-12,
    .ix-col-10,
    .ix-col-9,
    .ix-col-8,
    .ix-col-7,
    .ix-col-6,
    .ix-col-5,
    .ix-col-4,
    .ix-col-3,
    .ix-col-2 { grid-column: span 1; }
    .ix-quick-actions { grid-template-columns: 1fr; }
    .ix-hero { padding: 1rem; }
}

/* =========================================================
   19. Print cleanup
   ========================================================= */

@media print {
    body { background: #ffffff !important; color: #000000 !important; }
    .ix-sidebar,
    .ix-topbar,
    .ix-actionbar,
    .btn,
    .dropdown,
    .modal,
    .offcanvas { display: none !important; }
    .ix-main { margin-left: 0 !important; }
    .ix-content { width: 100% !important; max-width: none !important; padding: 0 !important; }
    .ix-card,
    .ix-table-card,
    .ix-section-card { border-color: #cccccc !important; box-shadow: none !important; }
}
