/*
 * ServerSentry — application stylesheet
 *
 * Design intent: light, airy, modern dashboard with bright accent colours.
 * Single CSS file (no framework runtime) — keeps load times fast.
 * Uses CSS variables so the palette can be themed without rebuilding.
 */

:root {
    --bg:               #f5f7fb;
    --bg-elev:          #ffffff;
    --bg-soft:          #eef1f8;
    --surface-hover:    #f8fafc;
    --border:           #e4e8f0;
    --border-strong:    #d4d9e4;

    --text:             #0f172a;
    --text-muted:       #64748b;
    --text-soft:        #94a3b8;

    --primary:          #3b82f6;
    --primary-dark:     #2563eb;
    --primary-soft:     #dbeafe;

    --success:          #10b981;
    --success-soft:     #d1fae5;
    --warning:          #f59e0b;
    --warning-soft:     #fef3c7;
    --danger:           #ef4444;
    --danger-soft:      #fee2e2;
    --info:             #06b6d4;
    --info-soft:        #cffafe;
    --accent:           #8b5cf6;
    --accent-soft:      #ede9fe;

    --radius-sm:        6px;
    --radius:           10px;
    --radius-lg:        16px;

    --shadow-sm:        0 1px 2px rgba(15,23,42,0.06);
    --shadow:           0 4px 12px rgba(15,23,42,0.06), 0 1px 2px rgba(15,23,42,0.04);
    --shadow-lg:        0 12px 30px rgba(15,23,42,0.08), 0 2px 6px rgba(15,23,42,0.05);

    --font-sans:        'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --font-mono:        'JetBrains Mono', 'SF Mono', Consolas, monospace;
}

* { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    font-family: var(--font-sans);
    color: var(--text);
    background: var(--bg);
    -webkit-font-smoothing: antialiased;
    font-size: 14px;
    line-height: 1.5;
}

a { color: var(--primary); text-decoration: none; }
a:hover { color: var(--primary-dark); }

/* ============ LAYOUT ============ */

.app-layout {
    display: grid;
    grid-template-columns: 240px 1fr;
    min-height: 100vh;
}

.sidebar {
    background: var(--bg-elev);
    border-right: 1px solid var(--border);
    padding: 22px 16px;
    position: sticky; top: 0;
    height: 100vh;
    overflow-y: auto;
}

.sidebar-brand {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 17px;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 28px;
    padding: 4px 8px;
}
.sidebar-brand .brand-dot {
    width: 30px; height: 30px;
    border-radius: 8px;
    background: linear-gradient(135deg, var(--primary), var(--accent));
    display: grid; place-items: center;
    color: #fff;
    font-size: 16px;
    box-shadow: 0 4px 14px rgba(59,130,246,0.35);
}
.sidebar-section {
    text-transform: uppercase;
    font-size: 11px;
    letter-spacing: 0.06em;
    color: var(--text-soft);
    margin: 22px 12px 8px;
    font-weight: 600;
}
.nav-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 12px;
    border-radius: var(--radius-sm);
    color: var(--text-muted);
    font-weight: 500;
    margin-bottom: 2px;
    transition: all 0.15s ease;
}
.nav-item:hover { background: var(--bg-soft); color: var(--text); }
.nav-item.active {
    background: var(--primary-soft);
    color: var(--primary-dark);
    font-weight: 600;
}
.nav-item .icon { font-size: 16px; width: 18px; text-align: center; }

.topbar {
    background: var(--bg-elev);
    border-bottom: 1px solid var(--border);
    padding: 14px 28px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: sticky; top: 0; z-index: 10;
}
.topbar h1 {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
}
.topbar .user-chip {
    display: flex; align-items: center; gap: 10px;
    padding: 6px 12px 6px 6px;
    border-radius: 999px;
    background: var(--bg-soft);
    font-size: 13px;
    color: var(--text-muted);
}
.topbar .avatar {
    width: 28px; height: 28px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--primary), var(--accent));
    color: #fff;
    display: grid; place-items: center;
    font-size: 12px; font-weight: 600;
}

.content { padding: 24px 28px; }

/* ============ CARDS ============ */

.card {
    background: var(--bg-elev);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 20px;
    box-shadow: var(--shadow-sm);
}
.card-header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 18px;
}
.card-header h3 {
    margin: 0; font-size: 15px; font-weight: 600; color: var(--text);
}
.card-header .subtitle { color: var(--text-muted); font-size: 12px; }

/* Summary stat cards */
.stats-grid {
    display: grid;
    /* Force exactly 3 columns on screens wide enough; falls back gracefully:
       3 cols ≥ 960px, 2 cols ≥ 640px, 1 col below.
       6 stat cards = 2 rows of 3 on desktop. Each card has plenty of breathing
       room (~280-380px wide depending on viewport) so labels and values are
       never truncated. */
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-bottom: 24px;
}
@media (max-width: 960px) {
    .stats-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
    .stats-grid { grid-template-columns: 1fr; }
}
.stat-card {
    background: var(--bg-elev);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 18px 78px 18px 18px;  /* reserve right space for icon-bg */
    position: relative;
    overflow: hidden;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 102px;
}
.stat-card:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.stat-card .label {
    color: var(--text-muted);
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 8px;
    /* No truncation — let the label show in full. "ACTIVE ALERTS" is the
       longest label and fits comfortably at 11px in 180px+ of space. */
}
.stat-card .value {
    font-size: 26px;
    font-weight: 700;
    color: var(--text);
    line-height: 1.15;
    display: flex;
    align-items: baseline;
    gap: 4px;
    flex-wrap: wrap;
}
.stat-card .value > span {
    font-size: 14px !important;
    color: var(--text-muted);
    white-space: nowrap;
}
.stat-card .delta {
    font-size: 11px;
    margin-top: 6px;
    color: var(--text-muted);
    line-height: 1.45;
    word-wrap: break-word;
    overflow-wrap: break-word;
}
.stat-card .icon-bg {
    position: absolute;
    top: 16px; right: 16px;
    width: 40px; height: 40px;
    border-radius: 10px;
    display: grid; place-items: center;
    font-size: 18px;
}
.stat-card.primary  .icon-bg { background: var(--primary-soft); color: var(--primary-dark); }
.stat-card.success  .icon-bg { background: var(--success-soft); color: var(--success); }
.stat-card.warning  .icon-bg { background: var(--warning-soft); color: var(--warning); }
.stat-card.danger   .icon-bg { background: var(--danger-soft);  color: var(--danger);  }
.stat-card.info     .icon-bg { background: var(--info-soft);    color: var(--info);    }
.stat-card.accent   .icon-bg { background: var(--accent-soft);  color: var(--accent);  }

/* ============ GRID HELPERS ============ */

.grid-2 { display: grid; grid-template-columns: 2fr 1fr; gap: 20px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.grid-1-1 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }

@media (max-width: 1100px) {
    .grid-2, .grid-3, .grid-1-1 { grid-template-columns: 1fr; }
}

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

.table-wrap { overflow-x: auto; }
table.data {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}
table.data th {
    text-align: left;
    padding: 10px 14px;
    color: var(--text-muted);
    font-weight: 600;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-bottom: 1px solid var(--border);
}
table.data td {
    padding: 12px 14px;
    border-bottom: 1px solid var(--border);
}
table.data tbody tr:hover { background: var(--surface-hover); }
table.data tr:last-child td { border-bottom: none; }

/* ============ BADGES & STATUS PILLS ============ */

.badge {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 3px 10px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.badge.success { background: var(--success-soft); color: var(--success); }
.badge.warning { background: var(--warning-soft); color: #b45309; }
.badge.danger  { background: var(--danger-soft);  color: var(--danger);  }
.badge.info    { background: var(--info-soft);    color: #0e7490; }
.badge.neutral { background: var(--bg-soft);      color: var(--text-muted); }
.badge.primary { background: var(--primary-soft); color: var(--primary-dark); }

.status-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    display: inline-block;
    margin-right: 6px;
}
.status-dot.online   { background: var(--success); box-shadow: 0 0 0 3px var(--success-soft); }
.status-dot.warning  { background: var(--warning); box-shadow: 0 0 0 3px var(--warning-soft); }
.status-dot.critical { background: var(--danger);  box-shadow: 0 0 0 3px var(--danger-soft); }
.status-dot.offline  { background: var(--text-soft); }

/* ============ BUTTONS ============ */

.btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 8px 14px;
    border: 1px solid var(--border);
    background: var(--bg-elev);
    color: var(--text);
    border-radius: var(--radius-sm);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.15s ease;
    font-family: var(--font-sans);
}
.btn:hover { background: var(--surface-hover); border-color: var(--border-strong); }
.btn.primary  { background: var(--primary); color: #fff; border-color: var(--primary); }
.btn.primary:hover { background: var(--primary-dark); border-color: var(--primary-dark); }
.btn.success  { background: var(--success); color: #fff; border-color: var(--success); }
.btn.danger   { background: var(--danger);  color: #fff; border-color: var(--danger);  }
.btn.danger:hover { background: #dc2626; }
.btn.ghost    { background: transparent; }
.btn.sm       { padding: 5px 10px; font-size: 12px; }

/* ============ FORMS ============ */

.form-group { margin-bottom: 16px; }
.form-label {
    display: block;
    font-size: 12px;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 6px;
}
.form-control {
    width: 100%;
    padding: 9px 12px;
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-sm);
    background: var(--bg-elev);
    color: var(--text);
    font-size: 14px;
    font-family: var(--font-sans);
    transition: all 0.15s ease;
}
.form-control:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(59,130,246,0.15);
}
.form-help { font-size: 12px; color: var(--text-muted); margin-top: 4px; }
.form-error { font-size: 12px; color: var(--danger); margin-top: 4px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }

/* ============ ALERTS / FLASH ============ */

.flash {
    padding: 12px 16px;
    border-radius: var(--radius);
    font-size: 13px;
    margin-bottom: 16px;
    display: flex; align-items: center; gap: 8px;
    border: 1px solid;
}
.flash.success { background: var(--success-soft); border-color: #a7f3d0; color: #065f46; }
.flash.error   { background: var(--danger-soft);  border-color: #fecaca; color: #991b1b; }
.flash.info    { background: var(--info-soft);    border-color: #a5f3fc; color: #155e75; }
.flash.warning { background: var(--warning-soft); border-color: #fde68a; color: #92400e; }

/* ============ AUTH PAGES ============ */

.auth-shell {
    min-height: 100vh;
    display: grid; place-items: center;
    background:
        radial-gradient(circle at 20% 20%, rgba(59,130,246,0.15), transparent 40%),
        radial-gradient(circle at 80% 80%, rgba(139,92,246,0.15), transparent 40%),
        var(--bg);
    padding: 24px;
}
.auth-card {
    background: var(--bg-elev);
    border-radius: var(--radius-lg);
    padding: 38px;
    width: 100%; max-width: 420px;
    box-shadow: var(--shadow-lg);
    border: 1px solid var(--border);
}
.auth-brand {
    display: flex; align-items: center; gap: 12px;
    margin-bottom: 28px;
}
.auth-brand .brand-dot {
    width: 38px; height: 38px;
    border-radius: 10px;
    background: linear-gradient(135deg, var(--primary), var(--accent));
    display: grid; place-items: center;
    color: #fff; font-size: 18px;
    box-shadow: 0 6px 18px rgba(59,130,246,0.4);
}
.auth-brand .brand-name { font-size: 18px; font-weight: 700; }
.auth-card h2 { margin: 0 0 6px; font-size: 22px; }
.auth-card .subtitle { color: var(--text-muted); margin-bottom: 22px; }

/* ============ PROGRESS BARS ============ */

.progress {
    width: 100%; height: 6px;
    background: var(--bg-soft);
    border-radius: 999px;
    overflow: hidden;
}
.progress > .bar { height: 100%; border-radius: 999px; transition: width 0.4s ease; }
.progress .bar.green  { background: var(--success); }
.progress .bar.amber  { background: var(--warning); }
.progress .bar.red    { background: var(--danger); }
.progress .bar.blue   { background: var(--primary); }

/* ============ TABS ============ */

.tabs {
    display: flex; gap: 4px;
    border-bottom: 1px solid var(--border);
    margin-bottom: 18px;
}
.tab {
    padding: 10px 16px;
    color: var(--text-muted);
    font-weight: 500;
    border-bottom: 2px solid transparent;
    cursor: pointer;
    font-size: 13px;
}
.tab.active { color: var(--primary-dark); border-bottom-color: var(--primary); }
.tab:hover { color: var(--text); }

/* ============ MISC ============ */

.text-muted { color: var(--text-muted); }
.text-soft  { color: var(--text-soft); }
.text-success { color: var(--success); }
.text-warning { color: var(--warning); }
.text-danger  { color: var(--danger); }
.mono { font-family: var(--font-mono); }
.flex { display: flex; align-items: center; gap: 8px; }
.flex-between { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.gap-1 { gap: 6px; } .gap-2 { gap: 12px; } .gap-3 { gap: 18px; }
.mt-2 { margin-top: 12px; } .mt-3 { margin-top: 18px; } .mt-4 { margin-top: 24px; }
.mb-2 { margin-bottom: 12px; } .mb-3 { margin-bottom: 18px; }
.text-right { text-align: right; }

/* Page header */
.page-header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 22px; gap: 16px;
}
.page-header h2 { margin: 0; font-size: 22px; font-weight: 700; }
.page-header .subtitle { color: var(--text-muted); font-size: 13px; margin-top: 4px; }

/* Dropdown */
.dropdown { position: relative; display: inline-block; }
.dropdown-menu {
    position: absolute; top: calc(100% + 4px); right: 0;
    background: var(--bg-elev);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    min-width: 180px;
    padding: 6px;
    z-index: 20;
    display: none;
}
.dropdown.open .dropdown-menu { display: block; }
.dropdown-item {
    display: block;
    padding: 8px 12px;
    border-radius: var(--radius-sm);
    color: var(--text);
    font-size: 13px;
}
.dropdown-item:hover { background: var(--bg-soft); }

/* Empty state */
.empty {
    text-align: center;
    padding: 40px 20px;
    color: var(--text-muted);
}
.empty .icon-lg {
    font-size: 38px; margin-bottom: 10px; opacity: 0.5;
}

/* ===== Form sections & utilities ===== */
.form-section {
    border-bottom: 1px solid var(--border);
    padding-bottom: 20px;
    margin-bottom: 24px;
}
.form-section:last-of-type { border-bottom: none; padding-bottom: 0; }
.form-section-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--text);
    margin: 0 0 12px;
}
.form-section-help {
    font-size: 12px;
    color: var(--text-muted);
    margin: -8px 0 16px;
}
.form-actions {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    padding-top: 16px;
    border-top: 1px solid var(--border);
    margin-top: 8px;
}
.required { color: var(--danger); margin-left: 2px; }
.has-error { border-color: var(--danger) !important; }
.form-input-sm {
    padding: 6px 10px !important;
    font-size: 12px !important;
    height: auto !important;
}
.checkbox-row {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
}
.checkbox {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    font-size: 13px;
    color: var(--text);
}
.checkbox input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: var(--primary);
    cursor: pointer;
}

/* ===== Pagination ===== */
.pagination-wrap {
    padding: 16px;
    border-top: 1px solid var(--border);
    display: flex;
    justify-content: center;
}
.pagination-wrap nav { display: flex; gap: 4px; }
.pagination-wrap a, .pagination-wrap span {
    padding: 6px 12px;
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--text);
    font-size: 13px;
    text-decoration: none;
    background: var(--surface);
}
.pagination-wrap a:hover { background: var(--bg); }
.pagination-wrap span[aria-current], .pagination-wrap .active span {
    background: var(--primary);
    color: white;
    border-color: var(--primary);
}

/* ===== Project cards ===== */
.project-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 20px;
    transition: all 0.15s;
}
.project-card:hover {
    box-shadow: 0 4px 12px rgba(0,0,0,0.06);
    transform: translateY(-2px);
}
.project-card-head {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
}
.project-color-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
}
.project-card-title {
    font-size: 16px;
    font-weight: 600;
    margin: 0;
}
.project-card-title a { color: var(--text); text-decoration: none; }
.project-card-title a:hover { color: var(--primary); }
.project-card-desc {
    font-size: 13px;
    color: var(--text-muted);
    margin: 0 0 16px;
    min-height: 36px;
}
.project-stats {
    display: flex;
    gap: 16px;
    padding: 12px 0;
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
}
.project-stat {
    display: flex;
    flex-direction: column;
}
.project-stat-value {
    font-size: 20px;
    font-weight: 700;
    color: var(--text);
}
.project-stat-label {
    font-size: 11px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-top: 2px;
}
.project-card-foot {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 12px;
}

/* ===== User assignment ===== */
.user-assign-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 8px;
    max-height: 360px;
    overflow-y: auto;
}
.user-assign-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px 10px;
    border-radius: 6px;
    cursor: pointer;
    transition: background 0.1s;
}
.user-assign-row:hover { background: var(--bg); }
.user-assign-row input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: var(--primary);
}
.user-assign-info {
    flex: 1;
}
.user-assign-name {
    font-size: 13px;
    font-weight: 500;
    color: var(--text);
}
.user-assign-email {
    font-size: 11px;
    color: var(--text-muted);
}

/* ===== User list ===== */
.user-list { display: flex; flex-direction: column; gap: 4px; padding: 4px 0; }
.user-list-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    border-radius: 8px;
    transition: background 0.1s;
}
.user-list-row:hover { background: var(--bg); }
.user-list-name {
    font-size: 13px;
    font-weight: 500;
    color: var(--text);
}
.user-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--primary), var(--accent));
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 13px;
    flex-shrink: 0;
}

/* ===== Misc ===== */
.page-breadcrumb {
    display: flex;
    gap: 8px;
    align-items: center;
    font-size: 12px;
    color: var(--text-muted);
}
.page-breadcrumb a {
    color: var(--text-muted);
    text-decoration: none;
}
.page-breadcrumb a:hover { color: var(--primary); }
.filter-bar { display: flex; gap: 8px; align-items: center; }
.info-block { padding: 4px; }
.info-list {
    margin: 12px 0;
    padding-left: 20px;
    color: var(--text);
    line-height: 1.7;
    font-size: 13px;
}
.info-list li { margin-bottom: 4px; }
.quick-range {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}
.text-success { color: var(--success); }
.text-warning { color: var(--warning); }
.text-danger  { color: var(--danger); }
.text-sm { font-size: 12px; }
.text-muted { color: var(--text-muted); }
.link { color: var(--primary); text-decoration: none; font-weight: 500; }
.link:hover { text-decoration: underline; }

/* ===== Tabs (Inventory) ===== */
.tabs-bar {
    display: flex;
    gap: 4px;
    border-bottom: 2px solid var(--border);
    margin-bottom: 20px;
    overflow-x: auto;
}
.tab-btn {
    padding: 10px 18px;
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    color: var(--text-muted);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.15s;
    white-space: nowrap;
}
.tab-btn:hover { color: var(--text); }
.tab-btn.active {
    color: var(--primary);
    border-bottom-color: var(--primary);
}
.tab-pane { display: none; }
.tab-pane.active { display: block; }

/* ===== Key/Value grid (SSH, Firewall, Panel meta) ===== */
.kv-grid {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.kv-row {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 16px;
    padding: 10px 4px;
    border-bottom: 1px solid var(--border);
    align-items: center;
}
.kv-row:last-child { border-bottom: none; }
.kv-key {
    font-size: 12px;
    color: var(--text-muted);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.kv-val { font-size: 13px; color: var(--text); }
.kv-val .badge { margin-right: 4px; }
.kv-val code.inline-code { margin-right: 6px; }

.inline-code {
    background: var(--bg);
    padding: 2px 6px;
    border-radius: 4px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    color: var(--text);
    border: 1px solid var(--border);
}

/* ===== Panel distribution list ===== */
.panel-distribution {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 8px 0;
}
.panel-dist-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px 12px;
    border-radius: 6px;
    transition: background 0.1s;
}
.panel-dist-row:hover { background: var(--bg); }
.panel-dist-dot {
    width: 12px;
    height: 12px;
    border-radius: 3px;
    flex-shrink: 0;
}
.panel-dist-name {
    flex: 1;
    font-size: 13px;
    font-weight: 500;
    color: var(--text);
}
.panel-dist-count {
    font-size: 12px;
    color: var(--text-muted);
}

/* Suspended row highlighting */
tr.row-suspended {
    background: rgba(239, 68, 68, 0.04);
}
tr.row-suspended td:first-child { color: var(--danger); }

/* badge-info / badge-muted variants */
.badge-info { background: #dbeafe; color: #1e40af; }
.badge-muted { background: #f3f4f6; color: #4b5563; }
.status-dot-info { background: #3b82f6; }
.status-dot-muted { background: #9ca3af; }

/* ===== Lucide icon styling in sidebar ===== */
.sidebar .nav-item {
    display: flex;
    align-items: center;
    gap: 12px;
}
.sidebar .nav-item i[data-lucide],
.sidebar .nav-item svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    stroke-width: 1.8;
    color: currentColor;
    opacity: 0.85;
}
.sidebar .nav-item.active i[data-lucide],
.sidebar .nav-item.active svg {
    opacity: 1;
}
.sidebar .nav-sub {
    padding-left: 32px;
    font-size: 13px;
    opacity: 0.78;
}
.sidebar .nav-sub i[data-lucide] {
    width: 14px; height: 14px;
}

/* ===== Brand mark (animated SVG hexagon) ===== */
.sidebar-brand .brand-mark {
    width: 28px; height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.sidebar-brand .brand-mark svg {
    width: 100%;
    height: 100%;
    filter: drop-shadow(0 1px 2px rgba(59, 130, 246, 0.3));
}

/* ===== Code blocks (used in agent install guide) ===== */
.code-block {
    background: #0f172a;
    color: #e2e8f0;
    padding: 14px 16px;
    border-radius: 6px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    line-height: 1.55;
    overflow-x: auto;
    margin: 10px 0;
    white-space: pre;
}
.code-block em {
    color: #fbbf24;
    font-style: normal;
}
.install-block { padding: 4px 4px 8px; }
.install-block h4 {
    margin-top: 18px; margin-bottom: 8px;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--text-muted);
}
.install-block ul, .install-block ol {
    line-height: 1.7;
    margin: 8px 0 8px 20px;
}
.install-block ul li, .install-block ol li { margin-bottom: 4px; }

/* ===== Stat-card icon — embed Lucide-friendly sizing ===== */
.stat-card-icon i[data-lucide],
.stat-card-icon svg {
    width: 22px; height: 22px;
    stroke-width: 2;
}

/* ===== Inventory tab icons ===== */
.tab-btn i[data-lucide] {
    width: 14px; height: 14px;
    margin-right: 6px;
    vertical-align: -2px;
    opacity: 0.7;
}
.tab-btn.active i[data-lucide] { opacity: 1; }

/* ===== Wizard (Add Server) ===== */
.wizard-shell {
    max-width: 920px;
    margin: 0 auto;
}
.wizard-steps {
    display: flex;
    gap: 0;
    list-style: none;
    margin: 0 0 24px;
    padding: 0;
    counter-reset: step;
}
.wizard-steps .wz-step {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 12px 8px;
    cursor: default;
    position: relative;
    color: var(--text-muted);
    font-size: 12px;
    transition: color 0.15s;
}
.wizard-steps .wz-step::after {
    content: '';
    position: absolute;
    top: 33px;
    left: 60%;
    width: 80%;
    height: 2px;
    background: var(--border);
    z-index: 0;
}
.wizard-steps .wz-step:last-child::after { display: none; }
.wizard-steps .wz-step.done::after { background: var(--primary); }

.wz-circle {
    position: relative;
    z-index: 1;
    width: 38px; height: 38px;
    border-radius: 50%;
    background: white;
    border: 2px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    color: var(--text-muted);
    transition: all 0.2s;
}
.wz-circle i[data-lucide], .wz-circle svg {
    width: 18px; height: 18px;
}
.wz-step.active .wz-circle {
    border-color: var(--primary);
    background: var(--primary);
    color: white;
    box-shadow: 0 4px 14px rgba(59, 130, 246, 0.3);
}
.wz-step.done .wz-circle {
    border-color: var(--primary);
    background: var(--primary);
    color: white;
}
.wz-step.done {
    color: var(--text);
    cursor: pointer;
}
.wz-step.active { color: var(--primary); font-weight: 600; }

.wizard-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 32px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
    transition: transform 0.2s;
}
.wizard-card.shake {
    animation: wzShake 0.4s;
}
@keyframes wzShake {
    0%, 100% { transform: translateX(0); }
    20%, 60% { transform: translateX(-6px); }
    40%, 80% { transform: translateX(6px); }
}

.wz-pane { display: none; }
.wz-pane.active { display: block; animation: wzFade 0.25s; }
@keyframes wzFade {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
}
.wz-title {
    font-size: 20px;
    font-weight: 600;
    color: var(--text);
    margin: 0 0 6px;
    display: flex;
    align-items: center;
    gap: 10px;
}
.wz-title i[data-lucide] { color: var(--primary); }
.wz-help {
    color: var(--text-muted);
    font-size: 13px;
    margin: 0 0 24px;
    line-height: 1.5;
}

.wz-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 32px;
    padding-top: 20px;
    border-top: 1px solid var(--border);
}
.wz-footer-right { display: flex; gap: 8px; }
.wz-footer .btn i[data-lucide] { width: 14px; height: 14px; vertical-align: -2px; }

/* OS picker cards */
.os-cards {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}
.os-card {
    cursor: pointer;
    display: block;
}
.os-card input { display: none; }
.os-card-inner {
    border: 2px solid var(--border);
    border-radius: 10px;
    padding: 22px 20px;
    text-align: center;
    transition: all 0.15s;
    background: var(--surface);
}
.os-card-inner:hover { border-color: var(--text-muted); }
.os-card input:checked + .os-card-inner {
    border-color: var(--primary);
    background: rgba(59, 130, 246, 0.04);
    box-shadow: 0 2px 8px rgba(59, 130, 246, 0.1);
}
.os-icon {
    font-size: 36px;
    margin-bottom: 8px;
    line-height: 1;
}
.os-name { font-size: 16px; font-weight: 600; color: var(--text); margin-bottom: 4px; }
.os-sub { font-size: 12px; color: var(--text-muted); }

/* Chip radios (environment) */
.chip-group { display: flex; flex-wrap: wrap; gap: 8px; }
.chip-radio { cursor: pointer; }
.chip-radio input { display: none; }
.chip-radio span {
    display: inline-block;
    padding: 8px 16px;
    border: 1px solid var(--border);
    border-radius: 20px;
    background: var(--surface);
    color: var(--text);
    font-size: 13px;
    transition: all 0.15s;
}
.chip-radio:hover span { border-color: var(--text-muted); }
.chip-radio input:checked + span {
    background: var(--primary);
    color: white;
    border-color: var(--primary);
}

/* Provider cards */
.provider-cards {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 8px;
}
.provider-card { cursor: pointer; }
.provider-card input { display: none; }
.provider-card-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 14px 8px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface);
    color: var(--text-muted);
    font-size: 12px;
    font-weight: 500;
    transition: all 0.15s;
}
.provider-card-inner i[data-lucide] {
    width: 22px; height: 22px;
}
.provider-card:hover .provider-card-inner { border-color: var(--text-muted); }
.provider-card input:checked + .provider-card-inner {
    border-color: var(--primary);
    background: rgba(59, 130, 246, 0.06);
    color: var(--primary);
}
@media (max-width: 720px) {
    .provider-cards { grid-template-columns: repeat(2, 1fr); }
}

/* Control panel cards */
.cp-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}
@media (min-width: 720px) {
    .cp-grid { grid-template-columns: repeat(2, 1fr); }
}
.cp-card { cursor: pointer; }
.cp-card input { display: none; }
.cp-card-inner {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    border: 1.5px solid var(--border);
    border-radius: 8px;
    background: var(--surface);
    transition: all 0.15s;
}
.cp-card:hover .cp-card-inner { border-color: var(--text-muted); }
.cp-card input:checked + .cp-card-inner {
    border-color: var(--primary);
    background: rgba(59, 130, 246, 0.04);
    box-shadow: 0 2px 8px rgba(59, 130, 246, 0.08);
}
.cp-card-dot {
    width: 38px; height: 38px;
    border-radius: 8px;
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.cp-card-dot i[data-lucide] {
    width: 18px; height: 18px;
}
.cp-card-name { font-size: 14px; font-weight: 600; color: var(--text); }
.cp-card-desc { font-size: 12px; color: var(--text-muted); margin-top: 2px; }

/* Review */
.review-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4px 24px;
    background: var(--bg);
    border-radius: 8px;
    padding: 12px;
}
@media (max-width: 720px) {
    .review-grid { grid-template-columns: 1fr; }
}
.review-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 12px;
    border-bottom: 1px solid var(--border);
}
.review-row:last-child, .review-row:nth-last-child(2) { border-bottom: none; }
.review-key { font-size: 12px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.4px; }
.review-val { font-size: 13px; color: var(--text); font-weight: 500; }

/* Tip box */
.wz-tip {
    margin-top: 24px;
    display: flex;
    gap: 12px;
    padding: 16px 18px;
    background: linear-gradient(to right, rgba(59,130,246,0.06), rgba(139,92,246,0.04));
    border: 1px solid rgba(59,130,246,0.2);
    border-radius: 10px;
    align-items: flex-start;
}
.wz-tip i[data-lucide] {
    color: var(--primary);
    flex-shrink: 0;
    width: 22px; height: 22px;
    margin-top: 2px;
}
.wz-tip strong { color: var(--text); display: block; margin-bottom: 4px; font-size: 13px; }
.wz-tip p { margin: 0; font-size: 13px; color: var(--text-muted); line-height: 1.5; }

/* ==================================================================
   24x7Tech bright theme overrides
   ================================================================== */

:root {
    /* Brighter, more saturated brand colors with vibrant gradient pairs */
    --primary:          #2563eb;
    --primary-dark:     #1d4ed8;
    --primary-light:    #60a5fa;
    --primary-soft:     #dbeafe;
    --primary-glow:     rgba(37, 99, 235, 0.35);

    --success:          #10b981;
    --success-bright:   #34d399;
    --success-soft:     #d1fae5;

    --warning:          #f59e0b;
    --warning-bright:   #fbbf24;
    --warning-soft:     #fef3c7;

    --danger:           #ef4444;
    --danger-bright:    #f87171;
    --danger-soft:      #fee2e2;

    --info:             #0ea5e9;
    --info-bright:      #38bdf8;
    --info-soft:        #e0f2fe;

    --accent:           #a855f7;
    --accent-bright:    #c084fc;
    --accent-soft:      #f3e8ff;

    --pink:             #ec4899;
    --pink-bright:      #f472b6;
    --orange:           #f97316;
    --orange-bright:    #fb923c;
    --teal:             #14b8a6;
    --teal-bright:      #2dd4bf;

    /* Vivid gradients used in headers, brand mark, hero stat cards */
    --grad-primary:   linear-gradient(135deg, #2563eb 0%, #a855f7 100%);
    --grad-success:   linear-gradient(135deg, #10b981 0%, #34d399 100%);
    --grad-warning:   linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%);
    --grad-danger:    linear-gradient(135deg, #ef4444 0%, #fb7185 100%);
    --grad-info:      linear-gradient(135deg, #0ea5e9 0%, #38bdf8 100%);
    --grad-accent:    linear-gradient(135deg, #a855f7 0%, #ec4899 100%);
    --grad-orange:    linear-gradient(135deg, #f97316 0%, #fbbf24 100%);
    --grad-teal:      linear-gradient(135deg, #14b8a6 0%, #2dd4bf 100%);

    --grad-page-bg:   linear-gradient(180deg, #eef2ff 0%, #f5f7fb 220px, #f5f7fb 100%);
}

body { background: var(--grad-page-bg) fixed; }

/* Stat-card hero refresh — bright gradient icon cells, subtle hover lift */
.stat-card {
    border: 1px solid var(--border);
    background: var(--bg-elev);
    border-radius: 14px;
    padding: 18px;
    display: flex;
    align-items: center;
    gap: 14px;
    transition: transform 0.18s, box-shadow 0.18s, border-color 0.18s;
    position: relative;
    overflow: hidden;
}
.stat-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, transparent 60%, rgba(37, 99, 235, 0.05) 100%);
    pointer-events: none;
}
.stat-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 28px rgba(15, 23, 42, 0.08);
    border-color: var(--primary-light);
}
.stat-card-icon {
    width: 48px; height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    flex-shrink: 0;
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}
.stat-card-icon i[data-lucide], .stat-card-icon svg {
    width: 24px; height: 24px;
    stroke-width: 2.2;
}
.stat-card-value {
    font-size: 26px;
    font-weight: 700;
    color: var(--text);
    background: var(--grad-primary);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}
.stat-card-label {
    font-size: 11px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.6px;
    font-weight: 600;
    margin-bottom: 2px;
}

/* Bright gradient icon backgrounds */
.icon-bg-primary { background: var(--grad-primary); }
.icon-bg-success { background: var(--grad-success); }
.icon-bg-warning { background: var(--grad-warning); }
.icon-bg-danger  { background: var(--grad-danger); }
.icon-bg-info    { background: var(--grad-info); }
.icon-bg-accent  { background: var(--grad-accent); }
.icon-bg-orange  { background: var(--grad-orange); }
.icon-bg-teal    { background: var(--grad-teal); }

/* Sidebar refresh */
.sidebar {
    background: linear-gradient(180deg, #ffffff 0%, #fafbff 100%);
    border-right: 1px solid var(--border);
}
.sidebar-brand {
    background: var(--grad-primary);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    font-weight: 700;
    letter-spacing: -0.3px;
}
.nav-item.active {
    background: linear-gradient(90deg, rgba(37, 99, 235, 0.12) 0%, rgba(168, 85, 247, 0.05) 100%);
    color: var(--primary);
    border-left: 3px solid var(--primary);
    padding-left: 13px;
}
.nav-item.active i[data-lucide] { color: var(--primary); }

/* Card title accent bar */
.card-header {
    border-bottom: 1px solid var(--border);
    padding-bottom: 12px;
    margin-bottom: 16px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
}
.card-title {
    font-size: 15px;
    font-weight: 600;
    margin: 0;
    color: var(--text);
    display: flex;
    align-items: center;
    gap: 10px;
}
.card-title::before {
    content: '';
    width: 4px;
    height: 18px;
    border-radius: 4px;
    background: var(--grad-primary);
}

/* Bright primary buttons */
.btn-primary {
    background: var(--grad-primary);
    color: white;
    border: none;
    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.25);
}
.btn-primary:hover {
    box-shadow: 0 6px 18px rgba(37, 99, 235, 0.35);
    transform: translateY(-1px);
}
.btn-success {
    background: var(--grad-success);
    color: white;
    border: none;
}
.btn-danger {
    background: var(--grad-danger);
    color: white;
    border: none;
}

/* Vibrant badges */
.badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
    line-height: 1.3;
}
.badge-primary  { background: var(--primary-soft);  color: var(--primary-dark); }
.badge-success  { background: var(--success-soft);  color: #047857; }
.badge-warning  { background: var(--warning-soft);  color: #92400e; }
.badge-danger   { background: var(--danger-soft);   color: #991b1b; }
.badge-info     { background: var(--info-soft);     color: #075985; }
.badge-accent   { background: var(--accent-soft);   color: #6b21a8; }
.badge-muted    { background: #f1f5f9;              color: #475569; }

/* Page header gradient accent */
.page-header {
    position: relative;
    padding-bottom: 20px;
    margin-bottom: 20px;
    border-bottom: 1px solid var(--border);
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 16px;
}
.page-header::after {
    content: '';
    position: absolute;
    left: 0; bottom: -1px;
    width: 80px;
    height: 3px;
    background: var(--grad-primary);
    border-radius: 3px;
}
.page-title {
    font-size: 22px;
    font-weight: 700;
    color: var(--text);
    margin: 0 0 4px;
}
.page-subtitle {
    color: var(--text-muted);
    font-size: 13px;
    margin: 0;
}

/* Tables — colored header strip */
table.data thead {
    background: linear-gradient(180deg, #fafbff 0%, #f1f5fb 100%);
}
table.data th {
    color: var(--text-muted);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: 600;
    padding: 12px 14px;
    border-bottom: 2px solid var(--border);
    text-align: left;
}
table.data td {
    padding: 11px 14px;
    border-bottom: 1px solid var(--border);
    font-size: 13px;
}
table.data tr:hover td { background: rgba(37, 99, 235, 0.02); }

/* Project color dots — slightly stronger glow */
.project-color-dot { box-shadow: 0 0 8px currentColor; }

/* Status dot variants — solid glow */
.status-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    display: inline-block;
}
.status-dot-success, .status-dot.online   { background: var(--success-bright); box-shadow: 0 0 6px var(--success-bright); }
.status-dot-warning, .status-dot.warning  { background: var(--warning-bright); box-shadow: 0 0 6px var(--warning-bright); }
.status-dot-danger,  .status-dot.critical { background: var(--danger-bright);  box-shadow: 0 0 6px var(--danger-bright); }
.status-dot-info, .status-dot.info        { background: var(--info-bright);    box-shadow: 0 0 6px var(--info-bright); }
.status-dot-muted, .status-dot.offline    { background: #94a3b8; }

/* Subtle scroll improvements */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: #cbd5e1; border-radius: 6px; border: 2px solid transparent; background-clip: padding-box; }
::-webkit-scrollbar-thumb:hover { background: #94a3b8; background-clip: padding-box; border: 2px solid transparent; }

/* ===== Hardware tab styles ===== */
.hw-stat {
    background: linear-gradient(135deg, #f8fafc 0%, #eef2ff 100%);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 14px 16px;
}
.hw-stat-label {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--text-muted);
    margin-bottom: 4px;
    font-weight: 600;
}
.hw-stat-value {
    font-size: 22px;
    font-weight: 700;
    color: var(--text);
    background: var(--grad-primary);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}
.hw-stat-unit {
    font-size: 13px;
    font-weight: 500;
    color: var(--text-muted);
    -webkit-text-fill-color: var(--text-muted);
}

/* ===== Network interface cards ===== */
.nic-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.nic-card {
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 14px 16px;
    background: var(--bg-elev);
    transition: border-color 0.15s, box-shadow 0.15s;
    border-left-width: 4px;
}
.nic-card.nic-up        { border-left-color: var(--success-bright); }
.nic-card.nic-down      { border-left-color: var(--text-soft); opacity: 0.85; }
.nic-card.nic-loopback  { border-left-color: var(--info-bright);    opacity: 0.9; }
.nic-card.nic-virtual   { border-left-color: var(--accent-bright);  opacity: 0.9; }
.nic-card:hover         { box-shadow: 0 4px 12px rgba(0,0,0,0.05); }

.nic-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 10px;
}
.nic-name {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 15px;
}
.nic-name i[data-lucide] { color: var(--primary); width: 18px; height: 18px; }
.nic-meta {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    font-size: 12px;
    color: var(--text-muted);
}
.nic-meta span { display: inline-flex; align-items: center; gap: 4px; }

.nic-ips {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-top: 8px;
    padding-top: 10px;
    border-top: 1px dashed var(--border);
}
@media (max-width: 720px) {
    .nic-ips { grid-template-columns: 1fr; }
}
.nic-ip-title {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    font-weight: 700;
    color: var(--text-muted);
    margin-bottom: 4px;
}
.nic-ip-row {
    display: flex;
    align-items: baseline;
    gap: 8px;
    padding: 3px 0;
}
.nic-ip-addr {
    font-size: 13px;
    background: var(--primary-soft);
    color: var(--primary-dark);
    border-color: var(--primary-light);
    font-weight: 600;
}

/* =====================================================================
   Aggressive visual upgrade — gradient cards, glowing icons, bright tables
   ===================================================================== */

/* Stat cards — much more vibrant with gradient borders and animated glow */
.stat-card {
    border: none;
    background: linear-gradient(white, white) padding-box,
                linear-gradient(135deg, #e0e7ff 0%, #fce7f3 100%) border-box;
    border: 2px solid transparent;
    border-radius: 16px;
    padding: 18px;
    position: relative;
    overflow: hidden;
}
.stat-card::after {
    content: '';
    position: absolute;
    top: -50%;
    right: -30%;
    width: 200px;
    height: 200px;
    background: radial-gradient(circle, rgba(168, 85, 247, 0.08) 0%, transparent 70%);
    pointer-events: none;
    animation: cardGlow 6s ease-in-out infinite alternate;
}
@keyframes cardGlow {
    0%   { transform: translate(0, 0) scale(1); }
    100% { transform: translate(-20px, 20px) scale(1.2); }
}
.stat-card-icon {
    width: 56px; height: 56px;
    border-radius: 14px;
    box-shadow: 0 8px 20px rgba(37, 99, 235, 0.25),
                inset 0 1px 0 rgba(255, 255, 255, 0.3);
    position: relative;
}
.stat-card-icon::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(135deg, rgba(255,255,255,0.25) 0%, transparent 50%);
    pointer-events: none;
}
.stat-card-icon i[data-lucide], .stat-card-icon svg {
    width: 28px !important; height: 28px !important;
    stroke-width: 2.4 !important;
    filter: drop-shadow(0 1px 2px rgba(0,0,0,0.15));
}

/* Tables — striped rows + colorful headers */
table.data {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    border-radius: 12px;
    overflow: hidden;
    background: white;
}
table.data thead {
    background: linear-gradient(90deg, #ede9fe 0%, #dbeafe 50%, #e0f2fe 100%);
}
table.data thead th {
    color: #5b21b6;
    font-weight: 700;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.7px;
    padding: 14px 16px;
    border-bottom: none;
    text-align: left;
    position: relative;
}
table.data thead th:first-child { padding-left: 18px; }
table.data tbody tr:nth-child(even) {
    background: #fafbff;
}
table.data tbody tr:hover {
    background: linear-gradient(90deg, rgba(168, 85, 247, 0.06), rgba(37, 99, 235, 0.04));
}
table.data tbody td {
    padding: 13px 16px;
    border-bottom: 1px solid #f0f3f8;
    font-size: 13px;
    color: #1f2937;
}
table.data tbody td:first-child { padding-left: 18px; }
table.data tbody tr:last-child td { border-bottom: none; }

/* Inline code chips — colorful */
.inline-code {
    background: linear-gradient(135deg, #f0f4ff 0%, #faf5ff 100%);
    color: #5b21b6;
    border: 1px solid #e0e7ff;
    padding: 3px 8px;
    border-radius: 6px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 11.5px;
    font-weight: 500;
}

/* Badges — even more vivid with glows */
.badge {
    padding: 4px 11px;
    border-radius: 14px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.2px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.08);
}
.badge-primary  { background: linear-gradient(135deg, #dbeafe, #bfdbfe); color: #1e40af; }
.badge-success  { background: linear-gradient(135deg, #d1fae5, #a7f3d0); color: #065f46; }
.badge-warning  { background: linear-gradient(135deg, #fef3c7, #fde68a); color: #92400e; }
.badge-danger   { background: linear-gradient(135deg, #fee2e2, #fecaca); color: #991b1b; }
.badge-info     { background: linear-gradient(135deg, #cffafe, #a5f3fc); color: #155e75; }
.badge-accent   { background: linear-gradient(135deg, #f3e8ff, #e9d5ff); color: #6b21a8; }
.badge-muted    { background: linear-gradient(135deg, #f1f5f9, #e2e8f0); color: #475569; }

/* Page header — gradient title + gradient backdrop */
.page-header {
    padding: 24px 28px;
    background: linear-gradient(135deg, #ffffff 0%, #f5f3ff 50%, #ffe4f0 100%);
    border-radius: 16px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
    border: 1px solid #ede9fe;
    margin-bottom: 24px;
}
.page-header::after { display: none; }
.page-title {
    font-size: 26px;
    font-weight: 800;
    background: linear-gradient(135deg, #4f46e5 0%, #ec4899 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    margin: 0 0 4px;
    letter-spacing: -0.5px;
}

/* Card — soft elevated look */
.card {
    background: white;
    border: 1px solid #ede9fe;
    border-radius: 14px;
    padding: 20px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.03);
    transition: box-shadow 0.2s;
}
.card:hover {
    box-shadow: 0 4px 16px rgba(168, 85, 247, 0.08);
}
.card-title {
    font-size: 15px;
    font-weight: 700;
    color: #1f2937;
}
.card-title::before {
    width: 4px; height: 20px;
    border-radius: 4px;
    background: linear-gradient(180deg, #2563eb 0%, #ec4899 100%);
    box-shadow: 0 0 8px rgba(168, 85, 247, 0.4);
}

/* Hardware section — vibrant card variants */
.hw-stat {
    background: linear-gradient(135deg, #f0f4ff 0%, #fef3c7 100%);
    border: 1px solid #e0e7ff;
    border-radius: 14px;
    padding: 18px;
    position: relative;
    overflow: hidden;
}
.hw-stat::before {
    content: '';
    position: absolute;
    top: -20px; right: -20px;
    width: 80px; height: 80px;
    background: radial-gradient(circle, rgba(168, 85, 247, 0.15) 0%, transparent 60%);
}
.hw-stat-value {
    font-size: 28px;
    font-weight: 800;
    background: linear-gradient(135deg, #4f46e5 0%, #ec4899 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* NIC cards — bright with gradient left border and pulse animation when up */
.nic-card {
    background: linear-gradient(135deg, #ffffff 0%, #fafbff 100%);
    border: 1px solid #e0e7ff;
    border-left-width: 5px;
    border-radius: 12px;
    padding: 16px 18px;
    transition: all 0.2s;
}
.nic-card.nic-up {
    border-left-color: #10b981;
    box-shadow: 0 0 0 1px rgba(16, 185, 129, 0.1), 0 4px 12px rgba(16, 185, 129, 0.08);
}
.nic-card.nic-up::before {
    content: '';
    position: absolute;
    left: -3px; top: 50%;
    width: 3px; height: 30px;
    margin-top: -15px;
    background: #10b981;
    border-radius: 3px;
    box-shadow: 0 0 12px #10b981;
    animation: nicPulse 2s ease-in-out infinite;
}
@keyframes nicPulse {
    0%, 100% { opacity: 1; }
    50%      { opacity: 0.4; }
}
.nic-card.nic-down     { border-left-color: #94a3b8; opacity: 0.85; }
.nic-card.nic-loopback { border-left-color: #0ea5e9; }
.nic-card.nic-virtual  { border-left-color: #a855f7; }
.nic-card { position: relative; }

.nic-name i[data-lucide] {
    color: white;
    background: linear-gradient(135deg, #2563eb, #a855f7);
    border-radius: 8px;
    padding: 6px;
    width: 28px !important; height: 28px !important;
    box-shadow: 0 2px 6px rgba(37, 99, 235, 0.3);
}

.nic-ip-addr {
    background: linear-gradient(135deg, #ddd6fe, #fce7f3) !important;
    color: #5b21b6 !important;
    border-color: #c4b5fd !important;
    font-weight: 700 !important;
    box-shadow: 0 1px 4px rgba(168, 85, 247, 0.15);
}

/* Tab buttons — colorful active state */
.tab-btn {
    border-radius: 8px 8px 0 0;
    margin-bottom: -2px;
    color: #64748b;
    transition: all 0.15s;
}
.tab-btn:hover {
    color: #2563eb;
    background: linear-gradient(180deg, transparent 0%, rgba(168, 85, 247, 0.05) 100%);
}
.tab-btn.active {
    color: #2563eb;
    background: linear-gradient(180deg, #ede9fe 0%, transparent 100%);
    border-bottom: 3px solid #2563eb;
    font-weight: 700;
}
.tab-btn.active i[data-lucide] { color: #2563eb; }
.tabs-bar {
    background: linear-gradient(180deg, #fafbff 0%, transparent 100%);
    border-bottom: 2px solid #e0e7ff;
    padding: 4px 4px 0;
    border-radius: 8px 8px 0 0;
}

/* Sidebar — bright background with depth */
.sidebar {
    background: linear-gradient(180deg, #ffffff 0%, #f5f3ff 50%, #fff1f2 100%);
    border-right: none;
    box-shadow: 1px 0 3px rgba(0,0,0,0.03);
}
.nav-item {
    padding: 10px 16px;
    margin: 2px 8px;
    border-radius: 8px;
    transition: all 0.15s;
    font-weight: 500;
}
.nav-item:hover {
    background: linear-gradient(90deg, #ede9fe 0%, transparent 100%);
    color: #5b21b6;
    transform: translateX(2px);
}
.nav-item i[data-lucide] {
    color: #94a3b8;
}
.nav-item:hover i[data-lucide] { color: #5b21b6; }
.nav-item.active {
    background: linear-gradient(90deg, #ede9fe 0%, #fce7f3 100%);
    color: #5b21b6;
    border-left: none;
    padding-left: 16px;
    box-shadow: 0 2px 6px rgba(168, 85, 247, 0.15);
    font-weight: 700;
}
.nav-item.active i[data-lucide] {
    color: #ec4899;
    filter: drop-shadow(0 0 4px rgba(236, 72, 153, 0.3));
}

/* Empty state — colorful */
.empty-state {
    text-align: center;
    padding: 40px 20px;
    background: linear-gradient(180deg, #fafbff 0%, #fff 100%);
    border-radius: 12px;
}
.empty-state-icon {
    font-size: 48px;
    margin-bottom: 12px;
    background: linear-gradient(135deg, #2563eb, #ec4899);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    filter: drop-shadow(0 2px 4px rgba(168, 85, 247, 0.2));
}

/* Status dots — bigger and glowing */
.status-dot {
    width: 9px; height: 9px;
    margin-right: 4px;
}

/* Project color dots — soft glow */
.project-color-dot {
    box-shadow: 0 0 12px currentColor, 0 0 4px currentColor;
}

/* KV grid (SSH/Firewall/System info) — bright stripes */
.kv-row {
    padding: 11px 12px;
    border-radius: 8px;
    margin-bottom: 2px;
}
.kv-row:nth-child(odd) {
    background: linear-gradient(90deg, #fafbff 0%, transparent 100%);
}
.kv-key {
    font-weight: 700;
    color: #6b21a8;
}

/* Badge for "well-known" / "local-only" — very bright */
.badge.badge-info {
    background: linear-gradient(135deg, #cffafe, #67e8f9);
    color: #155e75;
    font-weight: 700;
}

/* Scrollbar — gradient */
::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, #a855f7, #ec4899);
    border-radius: 6px;
    border: 2px solid transparent;
    background-clip: padding-box;
}

/* Helpful warning banner inside tabs */
.hw-warning {
    display: flex;
    gap: 14px;
    padding: 18px 20px;
    background: linear-gradient(135deg, #fef3c7 0%, #fce7f3 100%);
    border: 1px solid #fbbf24;
    border-radius: 12px;
    margin-bottom: 16px;
    align-items: flex-start;
}
.hw-warning i[data-lucide] {
    width: 28px; height: 28px;
    color: #d97706;
    flex-shrink: 0;
    margin-top: 2px;
    filter: drop-shadow(0 0 4px rgba(251, 191, 36, 0.5));
}
.hw-warning strong {
    color: #92400e;
    font-size: 14px;
    display: block;
    margin-bottom: 4px;
}
.hw-warning p { margin: 4px 0; font-size: 13px; color: #78350f; line-height: 1.5; }
.hw-warning ul { margin: 6px 0 6px 20px; line-height: 1.7; font-size: 13px; color: #78350f; }
.hw-warning ul li { margin-bottom: 3px; }
.hw-warning code.inline-code {
    background: rgba(255, 255, 255, 0.6);
    color: #7c2d12;
    border-color: #fbbf24;
}

/* =====================================================================
   Modern 4-Color Vibrant Theme: Red · Blue · Yellow · Green gradients
   Applied across stat cards, badges, icons, tables, charts.
   ===================================================================== */

:root {
    /* Core 4-tone palette */
    --c-blue:        #3b82f6;
    --c-blue-light:  #60a5fa;
    --c-blue-deep:   #1d4ed8;
    --c-blue-soft:   #dbeafe;

    --c-green:       #10b981;
    --c-green-light: #34d399;
    --c-green-deep:  #047857;
    --c-green-soft:  #d1fae5;

    --c-yellow:      #f59e0b;
    --c-yellow-light:#fbbf24;
    --c-yellow-deep: #b45309;
    --c-yellow-soft: #fef3c7;

    --c-red:         #ef4444;
    --c-red-light:   #f87171;
    --c-red-deep:    #b91c1c;
    --c-red-soft:    #fee2e2;

    /* Distinct gradient pairs for stat cards in sequence */
    --grad-blue:     linear-gradient(135deg, #3b82f6 0%, #60a5fa 100%);
    --grad-green:    linear-gradient(135deg, #10b981 0%, #34d399 100%);
    --grad-yellow:   linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%);
    --grad-red:      linear-gradient(135deg, #ef4444 0%, #f87171 100%);

    /* Multi-color rainbow for the page header backdrop */
    --grad-rainbow:  linear-gradient(90deg, #3b82f6 0%, #10b981 33%, #f59e0b 66%, #ef4444 100%);
    --grad-rainbow-soft: linear-gradient(135deg, #dbeafe 0%, #d1fae5 33%, #fef3c7 66%, #fee2e2 100%);
}

/* ===== Stat cards — auto-color by position, all bright ===== */
.grid-3 .stat-card:nth-of-type(4n+1) .stat-card-icon { background: var(--grad-blue);   box-shadow: 0 8px 20px rgba(59,130,246,0.35); }
.grid-3 .stat-card:nth-of-type(4n+2) .stat-card-icon { background: var(--grad-green);  box-shadow: 0 8px 20px rgba(16,185,129,0.35); }
.grid-3 .stat-card:nth-of-type(4n+3) .stat-card-icon { background: var(--grad-yellow); box-shadow: 0 8px 20px rgba(245,158,11,0.35); }
.grid-3 .stat-card:nth-of-type(4n+4) .stat-card-icon { background: var(--grad-red);    box-shadow: 0 8px 20px rgba(239,68,68,0.35); }
.grid-3 .stat-card:nth-of-type(4n+5) .stat-card-icon { background: var(--grad-blue);   box-shadow: 0 8px 20px rgba(59,130,246,0.35); }
.grid-3 .stat-card:nth-of-type(4n+6) .stat-card-icon { background: var(--grad-green);  box-shadow: 0 8px 20px rgba(16,185,129,0.35); }

/* Each stat card gets a colored top accent stripe */
.stat-card { border-top: 4px solid transparent; }
.grid-3 .stat-card:nth-of-type(4n+1) { border-top-color: #3b82f6; }
.grid-3 .stat-card:nth-of-type(4n+2) { border-top-color: #10b981; }
.grid-3 .stat-card:nth-of-type(4n+3) { border-top-color: #f59e0b; }
.grid-3 .stat-card:nth-of-type(4n+4) { border-top-color: #ef4444; }
.grid-3 .stat-card:nth-of-type(4n+5) { border-top-color: #3b82f6; }
.grid-3 .stat-card:nth-of-type(4n+6) { border-top-color: #10b981; }

/* Stat value text — gradient by position */
.grid-3 .stat-card:nth-of-type(4n+1) .stat-card-value { background: var(--grad-blue);   -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.grid-3 .stat-card:nth-of-type(4n+2) .stat-card-value { background: var(--grad-green);  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.grid-3 .stat-card:nth-of-type(4n+3) .stat-card-value { background: var(--grad-yellow); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.grid-3 .stat-card:nth-of-type(4n+4) .stat-card-value { background: var(--grad-red);    -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.grid-3 .stat-card:nth-of-type(4n+5) .stat-card-value { background: var(--grad-blue);   -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.grid-3 .stat-card:nth-of-type(4n+6) .stat-card-value { background: var(--grad-green);  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }

/* ===== Tables — colorful headers, alternating rows, hover effect ===== */
table.data {
    background: white;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
table.data thead {
    background: linear-gradient(90deg, #dbeafe 0%, #d1fae5 33%, #fef3c7 66%, #fee2e2 100%);
}
table.data thead th {
    color: #1e293b;
    font-weight: 700;
    font-size: 11px;
    letter-spacing: 0.6px;
    text-transform: uppercase;
    padding: 13px 16px;
    border-bottom: 3px solid;
    border-image: linear-gradient(90deg, #3b82f6 0%, #10b981 33%, #f59e0b 66%, #ef4444 100%) 1;
    text-align: left;
}
table.data tbody tr { transition: background 0.12s; }
table.data tbody tr:nth-child(even) { background: #fafbff; }
table.data tbody tr:hover {
    background: linear-gradient(90deg, rgba(59,130,246,0.06), rgba(16,185,129,0.04), rgba(245,158,11,0.04), rgba(239,68,68,0.06));
}
table.data tbody td { padding: 12px 16px; border-bottom: 1px solid #eef2f7; font-size: 13px; }

/* Status dots — saturated and glowing */
.status-dot, .status-dot-success, .status-dot-warning, .status-dot-danger,
.status-dot-info, .status-dot-muted, .status-dot-primary,
.status-dot.online, .status-dot.warning, .status-dot.critical, .status-dot.offline {
    width: 9px; height: 9px;
    border-radius: 50%;
    display: inline-block;
    margin-right: 5px;
}
.status-dot.online,  .status-dot-success { background: #10b981; box-shadow: 0 0 8px #10b981; }
.status-dot.warning, .status-dot-warning { background: #f59e0b; box-shadow: 0 0 8px #f59e0b; }
.status-dot.critical,.status-dot-danger  { background: #ef4444; box-shadow: 0 0 8px #ef4444; }
.status-dot-info,    .status-dot-primary { background: #3b82f6; box-shadow: 0 0 8px #3b82f6; }
.status-dot.offline, .status-dot-muted   { background: #94a3b8; }

/* ===== Badges — vivid 4-color set ===== */
.badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 3px 10px;
    border-radius: 14px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.2px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}
.badge-primary, .badge-info {
    background: linear-gradient(135deg, #dbeafe, #bfdbfe);
    color: #1e40af;
    border: 1px solid #93c5fd;
}
.badge-success {
    background: linear-gradient(135deg, #d1fae5, #a7f3d0);
    color: #065f46;
    border: 1px solid #6ee7b7;
}
.badge-warning {
    background: linear-gradient(135deg, #fef3c7, #fde68a);
    color: #92400e;
    border: 1px solid #fcd34d;
}
.badge-danger {
    background: linear-gradient(135deg, #fee2e2, #fecaca);
    color: #991b1b;
    border: 1px solid #fca5a5;
}
.badge-accent {
    background: linear-gradient(135deg, #ede9fe, #ddd6fe);
    color: #5b21b6;
    border: 1px solid #c4b5fd;
}
.badge-muted {
    background: linear-gradient(135deg, #f1f5f9, #e2e8f0);
    color: #475569;
    border: 1px solid #cbd5e1;
}

/* Sidebar nav — colorful icons by item */
.nav-item i[data-lucide] {
    width: 18px; height: 18px;
    stroke-width: 2;
    transition: all 0.15s;
}
.nav-item:nth-of-type(1) i[data-lucide] { color: #3b82f6; } /* dashboard - blue */
.nav-item:nth-of-type(2) i[data-lucide] { color: #10b981; } /* servers - green */
.nav-item:nth-of-type(3) i[data-lucide] { color: #a855f7; } /* projects - purple */
.nav-item:nth-of-type(4) i[data-lucide] { color: #f59e0b; } /* updates - yellow */
.nav-item:nth-of-type(5) i[data-lucide] { color: #ec4899; } /* inventory - pink */
.nav-item:nth-of-type(6) i[data-lucide] { color: #06b6d4; } /* domains - cyan */
.nav-item:nth-of-type(7) i[data-lucide] { color: #ef4444; } /* reports - red */
.nav-item:nth-of-type(8) i[data-lucide] { color: #14b8a6; } /* users / help */
.nav-item:nth-of-type(9) i[data-lucide] { color: #8b5cf6; }

.nav-item:hover i[data-lucide] {
    transform: scale(1.15);
    filter: drop-shadow(0 0 6px currentColor);
}
.nav-item.active i[data-lucide] {
    filter: drop-shadow(0 0 8px currentColor);
}

/* ===== Buttons — primary uses brand gradient, others colored ===== */
.btn { font-weight: 600; }
.btn.primary, .btn-primary {
    background: linear-gradient(135deg, #3b82f6 0%, #6366f1 50%, #a855f7 100%);
    color: white;
    border: none;
    box-shadow: 0 4px 12px rgba(99,102,241,0.35);
}
.btn.primary:hover, .btn-primary:hover {
    box-shadow: 0 6px 20px rgba(99,102,241,0.5);
    transform: translateY(-1px);
}
.btn-success {
    background: var(--grad-green);
    color: white;
    border: none;
    box-shadow: 0 4px 12px rgba(16,185,129,0.3);
}
.btn-danger, .btn.danger {
    background: var(--grad-red);
    color: white;
    border: none;
    box-shadow: 0 4px 12px rgba(239,68,68,0.3);
}

/* ===== Cards — soft border with colored top stripe based on category ===== */
.card { border: 1px solid #e2e8f0; }

/* Card header title bar gets gradient pill */
.card-title::before {
    background: linear-gradient(180deg, #3b82f6 0%, #10b981 33%, #f59e0b 66%, #ef4444 100%);
    box-shadow: 0 0 8px rgba(99, 102, 241, 0.4);
}

/* Page header — soft rainbow gradient backdrop */
.page-header {
    background: linear-gradient(135deg, #eff6ff 0%, #ecfdf5 33%, #fffbeb 66%, #fef2f2 100%);
    border: 1px solid #e0e7ff;
    border-radius: 16px;
    padding: 22px 26px;
    margin-bottom: 22px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.page-header::after { display: none; }

/* Project cards — color-rotate by position */
.grid-3 .project-card:nth-of-type(4n+1) { border-top: 3px solid #3b82f6; }
.grid-3 .project-card:nth-of-type(4n+2) { border-top: 3px solid #10b981; }
.grid-3 .project-card:nth-of-type(4n+3) { border-top: 3px solid #f59e0b; }
.grid-3 .project-card:nth-of-type(4n+4) { border-top: 3px solid #ef4444; }

/* Tab bar — bright gradient underline on active */
.tabs-bar {
    background: linear-gradient(180deg, #f8fafc 0%, transparent 100%);
    border-bottom: 2px solid #e2e8f0;
}
.tab-btn.active {
    border-bottom: 3px solid;
    border-image: linear-gradient(90deg, #3b82f6, #10b981, #f59e0b, #ef4444) 1;
    color: #1e293b;
    background: linear-gradient(180deg, rgba(99,102,241,0.06) 0%, transparent 100%);
    font-weight: 700;
}

/* Service category color tags */
.badge[data-cat="web"]      { background: linear-gradient(135deg, #dbeafe, #bfdbfe); color: #1e40af; }
.badge[data-cat="database"] { background: linear-gradient(135deg, #d1fae5, #a7f3d0); color: #065f46; }
.badge[data-cat="mail"]     { background: linear-gradient(135deg, #fef3c7, #fde68a); color: #92400e; }
.badge[data-cat="dns"]      { background: linear-gradient(135deg, #ede9fe, #ddd6fe); color: #5b21b6; }
.badge[data-cat="ftp"]      { background: linear-gradient(135deg, #fce7f3, #fbcfe8); color: #831843; }
.badge[data-cat="cache"]    { background: linear-gradient(135deg, #fee2e2, #fecaca); color: #991b1b; }
.badge[data-cat="security"] { background: linear-gradient(135deg, #cffafe, #a5f3fc); color: #155e75; }

/* Hardware tab stats — color-rotate */
.grid-3 > .hw-stat:nth-of-type(3n+1) {
    background: linear-gradient(135deg, #dbeafe 0%, #ffffff 100%);
    border-color: #93c5fd;
}
.grid-3 > .hw-stat:nth-of-type(3n+2) {
    background: linear-gradient(135deg, #d1fae5 0%, #ffffff 100%);
    border-color: #6ee7b7;
}
.grid-3 > .hw-stat:nth-of-type(3n+3) {
    background: linear-gradient(135deg, #fef3c7 0%, #ffffff 100%);
    border-color: #fcd34d;
}

/* NIC IP chips — bright gradient */
.nic-ip-addr {
    background: linear-gradient(135deg, #dbeafe, #d1fae5) !important;
    color: #1e3a8a !important;
    border-color: #93c5fd !important;
    font-weight: 700 !important;
}

/* KV grid alt-stripe with subtle colors */
.kv-row:nth-child(odd)  { background: linear-gradient(90deg, #f8fafc 0%, transparent 70%); }
.kv-row:nth-child(even) { background: linear-gradient(90deg, #fef3c7 0%, transparent 70%); opacity: 0.95; }

/* Progress bars — colorful gradient */
.progress {
    background: #e2e8f0;
    border-radius: 6px;
    overflow: hidden;
    height: 8px;
}
.progress-bar {
    height: 100%;
    border-radius: 6px;
    transition: width 0.4s ease;
}
.progress-bar.green  { background: var(--grad-green); }
.progress-bar.amber, .progress-bar.yellow  { background: var(--grad-yellow); }
.progress-bar.red    { background: var(--grad-red); }
.progress-bar.blue   { background: var(--grad-blue); }

/* Text helpers */
.text-success { color: #10b981 !important; }
.text-warning { color: #f59e0b !important; }
.text-danger  { color: #ef4444 !important; }
.text-info    { color: #3b82f6 !important; }

/* Dashboard — make summary stat cards span the rainbow visibly */
.grid-3 { gap: 14px; }
.grid-2 { gap: 14px; }

/* Inventory show — stat icons get distinct colors per type */
.tab-pane[data-pane="hardware"] .hw-stat:nth-child(1) .hw-stat-value { background: var(--grad-blue);   -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.tab-pane[data-pane="hardware"] .hw-stat:nth-child(2) .hw-stat-value { background: var(--grad-green);  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.tab-pane[data-pane="hardware"] .hw-stat:nth-child(3) .hw-stat-value { background: var(--grad-yellow); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }

/* Soft body background using all 4 colors as gentle radials */
body {
    background:
        radial-gradient(circle at 0% 0%,   rgba(59,130,246,0.05)   0%, transparent 30%),
        radial-gradient(circle at 100% 0%, rgba(16,185,129,0.05)   0%, transparent 30%),
        radial-gradient(circle at 0% 100%, rgba(245,158,11,0.05)   0%, transparent 30%),
        radial-gradient(circle at 100% 100%, rgba(239,68,68,0.05)  0%, transparent 30%),
        #fafbff fixed;
}

/* Sidebar brand gradient — full rainbow */
.sidebar-brand,
.brand-name {
    background: linear-gradient(90deg, #3b82f6 0%, #10b981 33%, #f59e0b 66%, #ef4444 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    font-weight: 800;
}

/* Auth shell — rainbow background */
.auth-shell {
    background:
        radial-gradient(circle at 20% 20%, rgba(59,130,246,0.18) 0%, transparent 35%),
        radial-gradient(circle at 80% 30%, rgba(16,185,129,0.18) 0%, transparent 35%),
        radial-gradient(circle at 30% 80%, rgba(245,158,11,0.18) 0%, transparent 35%),
        radial-gradient(circle at 80% 80%, rgba(239,68,68,0.18)  0%, transparent 35%),
        #f5f7fb;
}
.auth-card {
    border-top: 4px solid;
    border-image: linear-gradient(90deg, #3b82f6 0%, #10b981 33%, #f59e0b 66%, #ef4444 100%) 1;
}
.auth-brand .brand-mark {
    width: 44px; height: 44px;
    display: inline-flex;
}
.auth-brand .brand-mark svg {
    width: 100%;
    height: 100%;
    filter: drop-shadow(0 4px 8px rgba(99,102,241,0.4));
}

/* Top user chip — colorful avatar */
.user-chip .avatar {
    background: linear-gradient(135deg, #3b82f6 0%, #ec4899 100%);
    box-shadow: 0 2px 8px rgba(99,102,241,0.3);
}

/* Form inputs — focus glow */
.form-input:focus, .form-control:focus {
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59,130,246,0.15);
    outline: none;
}

/* Pagination — colorful */
.pagination-wrap a {
    transition: all 0.15s;
}
.pagination-wrap a:hover {
    background: linear-gradient(135deg, #dbeafe, #d1fae5);
    border-color: #3b82f6;
    color: #1e40af;
}
.pagination-wrap span[aria-current],
.pagination-wrap .active span {
    background: linear-gradient(135deg, #3b82f6 0%, #6366f1 100%);
    color: white;
    border-color: #3b82f6;
    box-shadow: 0 2px 6px rgba(99,102,241,0.3);
}

/* =====================================================================
   Pagination — replaces Laravel 11's default Tailwind paginator which
   was rendering oversized inline SVG arrows.
   ===================================================================== */

.pagination-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
    justify-content: space-between;
    padding: 16px 4px;
    border-top: 1px solid #eef2f7;
    margin-top: 4px;
}
.pagination-list {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    list-style: none;
    padding: 0;
    margin: 0;
}
.pagination-list li {
    list-style: none;
}
.pagination-list a,
.pagination-list span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    padding: 0 12px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: white;
    color: #475569;
    font-size: 13px;
    font-weight: 500;
    text-decoration: none;
    transition: all 0.12s ease;
}
.pagination-list a:hover {
    border-color: #3b82f6;
    color: #1e40af;
    background: linear-gradient(135deg, #dbeafe, #d1fae5);
    transform: translateY(-1px);
}
.pagination-list .pg-current span {
    background: linear-gradient(135deg, #3b82f6 0%, #6366f1 50%, #a855f7 100%);
    color: white;
    border-color: #3b82f6;
    font-weight: 700;
    box-shadow: 0 2px 8px rgba(99, 102, 241, 0.35);
}
.pagination-list .pg-disabled span {
    color: #cbd5e1;
    background: #f8fafc;
    cursor: not-allowed;
    border-color: #e2e8f0;
}
.pagination-summary {
    color: #64748b;
    font-size: 12.5px;
}
.pagination-summary strong { color: #1e293b; font-weight: 700; }

/* Hard cap on any stray SVG inside our pagination wrapper — defense in
   depth so an old cached Tailwind paginator can never blow up the layout. */
.pagination-wrap svg,
.pagination-nav svg,
nav[role="navigation"] svg {
    width: 18px !important;
    height: 18px !important;
}

/* Wrap container — give pagination a consistent box at the bottom of tables */
.pagination-wrap {
    padding: 0 16px;
}

/* =====================================================================
   Hard cap on ANY stray <svg> inside ANY pagination/nav, even Laravel's
   default Tailwind paginator. This is a defense-in-depth rule so an
   undeployed paginator override can't blow up the page.
   ===================================================================== */
nav[role="navigation"] svg,
.pagination-nav svg,
.pagination svg,
nav.pagination svg,
[aria-label="Pagination"] svg {
    width: 18px !important;
    height: 18px !important;
    max-width: 18px !important;
    max-height: 18px !important;
    display: inline-block !important;
    flex-shrink: 0 !important;
}

/* When Laravel's default paginator slips through — make its links look
   passable instead of input-shaped */
nav[role="navigation"] [aria-label="Pagination"],
nav[role="navigation"] > div {
    display: flex !important;
    flex-wrap: wrap;
    gap: 4px;
    align-items: center;
    justify-content: center;
}
nav[role="navigation"] a,
nav[role="navigation"] span:not([aria-hidden="true"]) {
    min-width: 36px;
    height: 36px;
    padding: 0 12px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: white;
    font-size: 13px;
    font-weight: 500;
    color: #475569;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
nav[role="navigation"] [aria-current="page"] span {
    background: linear-gradient(135deg, #3b82f6, #6366f1, #a855f7) !important;
    color: white !important;
    border-color: #3b82f6 !important;
    font-weight: 700 !important;
}
nav[role="navigation"] [aria-disabled="true"] span {
    color: #cbd5e1 !important;
    background: #f8fafc !important;
}

/* Block input-like styling that Tailwind paginator's "Showing X to Y of Z"
   gets when there's no Tailwind to render the spans correctly. */
nav[role="navigation"] p span,
nav[role="navigation"] p strong {
    background: transparent !important;
    border: none !important;
    padding: 0 4px !important;
    height: auto !important;
    min-width: 0 !important;
    font-weight: 700;
    color: #1e293b;
}

/* =====================================================================
   Stat-card layout fix — must be last so it overrides earlier rules.
   The dashboard and inventory pages share this pattern:
     <div class="stat-card">
       <div class="stat-card-icon">...</div>
       <div class="stat-card-body">
         <div class="stat-card-label">...</div>
         <div class="stat-card-value">...</div>
         <div class="stat-card-delta">...</div>
       </div>
     </div>
   ===================================================================== */

.stat-card {
    display: flex !important;
    flex-direction: row !important;
    align-items: flex-start !important;
    gap: 16px !important;
    padding: 18px 20px !important;
    min-height: 96px;
}
.stat-card-icon {
    flex-shrink: 0 !important;
    width: 52px !important;
    height: 52px !important;
    border-radius: 14px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: white !important;
    box-shadow: 0 6px 16px rgba(37, 99, 235, 0.25);
}
.stat-card-icon i[data-lucide],
.stat-card-icon svg {
    width: 26px !important;
    height: 26px !important;
    stroke-width: 2.2 !important;
    color: white !important;
    filter: drop-shadow(0 1px 2px rgba(0,0,0,0.15));
}
.stat-card-body {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.stat-card-label {
    font-size: 11px !important;
    color: var(--text-muted, #64748b) !important;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    font-weight: 600;
    margin: 0 0 6px;
    line-height: 1.3;
}
.stat-card-value {
    font-size: 28px !important;
    font-weight: 800 !important;
    line-height: 1.1 !important;
    margin: 0 0 4px;
}
.stat-card-delta,
.stat-card-body .text-muted,
.stat-card-body .text-sm {
    font-size: 12px !important;
    color: var(--text-muted, #64748b) !important;
    line-height: 1.4;
    margin: 0;
}

/* Container for .grid-3 — make sure cards never expand to single row */
.grid-3 {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 16px !important;
}
@media (max-width: 1100px) {
    .grid-3 { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 640px) {
    .grid-3 { grid-template-columns: 1fr !important; }
}

/* ===== Icon buttons (kill query, delete message) ===== */
.btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px; height: 30px;
    border-radius: 6px;
    border: 1px solid #e2e8f0;
    background: white;
    cursor: pointer;
    color: #64748b;
    transition: all 0.15s;
    margin-right: 4px;
}
.btn-icon:hover { transform: translateY(-1px); }
.btn-icon i[data-lucide], .btn-icon svg { width: 16px; height: 16px; }
.btn-icon-danger:hover {
    background: linear-gradient(135deg, #fee2e2, #fecaca);
    border-color: #ef4444;
    color: #b91c1c;
}
.btn-icon-warning:hover {
    background: linear-gradient(135deg, #fef3c7, #fde68a);
    border-color: #f59e0b;
    color: #92400e;
}

/* Live tab — auto-refresh hint */
.tab-pane[data-pane="live"] .card-header {
    position: relative;
}

/* =====================================================================
   Theme system — 4 themes, switchable at runtime
   Activated via <html data-theme="..."> attribute
   ===================================================================== */

/* Theme: light-rainbow (default — vibrant 4-color) */
html[data-theme="light-rainbow"], html:not([data-theme]) {
    --bg:           #fafbff;
    --bg-elev:      #ffffff;
    --surface:      #ffffff;
    --border:       #e2e8f0;
    --text:         #1f2937;
    --text-muted:   #64748b;
    --text-soft:    #94a3b8;
    --primary:      #2563eb;
    --grad-brand:   linear-gradient(90deg, #3b82f6 0%, #10b981 33%, #f59e0b 66%, #ef4444 100%);
    color-scheme: light;
}

/* Theme: light-mono (clean professional) */
html[data-theme="light-mono"] {
    --bg:           #f7f8fa;
    --bg-elev:      #ffffff;
    --surface:      #ffffff;
    --border:       #e5e7eb;
    --text:         #111827;
    --text-muted:   #6b7280;
    --text-soft:    #9ca3af;
    --primary:      #0f172a;
    --grad-brand:   linear-gradient(90deg, #1e293b 0%, #334155 100%);
    color-scheme: light;
}
html[data-theme="light-mono"] body {
    background: #f7f8fa !important;
}
html[data-theme="light-mono"] .stat-card-value,
html[data-theme="light-mono"] .hw-stat-value,
html[data-theme="light-mono"] .sidebar-brand,
html[data-theme="light-mono"] .brand-name,
html[data-theme="light-mono"] .page-title {
    background: linear-gradient(135deg, #0f172a 0%, #475569 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
html[data-theme="light-mono"] .icon-bg-primary,
html[data-theme="light-mono"] .grid-3 .stat-card .stat-card-icon {
    background: linear-gradient(135deg, #1e293b 0%, #475569 100%) !important;
}
html[data-theme="light-mono"] table.data thead {
    background: #f1f5f9 !important;
}
html[data-theme="light-mono"] table.data thead th {
    color: #334155 !important;
    border-bottom: 2px solid #cbd5e1 !important;
    border-image: none !important;
}
html[data-theme="light-mono"] .page-header,
html[data-theme="light-mono"] .sidebar {
    background: #ffffff !important;
}

/* Theme: dark-neon (vibrant dark with neon accents) */
html[data-theme="dark-neon"] {
    --bg:           #0a0e1a;
    --bg-elev:      #131829;
    --surface:      #1a2138;
    --border:       #2a3354;
    --text:         #e2e8f0;
    --text-muted:   #94a3b8;
    --text-soft:    #64748b;
    --primary:      #60a5fa;
    color-scheme: dark;
}
html[data-theme="dark-neon"] body {
    background:
        radial-gradient(circle at 0% 0%,   rgba(96,165,250,0.12)  0%, transparent 30%),
        radial-gradient(circle at 100% 0%, rgba(52,211,153,0.10)  0%, transparent 30%),
        radial-gradient(circle at 0% 100%, rgba(251,191,36,0.10)  0%, transparent 30%),
        radial-gradient(circle at 100% 100%, rgba(248,113,113,0.10) 0%, transparent 30%),
        #0a0e1a !important;
    color: #e2e8f0;
}
html[data-theme="dark-neon"] .sidebar {
    background: linear-gradient(180deg, #0f1424 0%, #131829 50%, #1a1f33 100%) !important;
    border-right: 1px solid #2a3354;
}
html[data-theme="dark-neon"] .nav-item:hover {
    background: rgba(96, 165, 250, 0.08) !important;
    color: #e2e8f0 !important;
}
html[data-theme="dark-neon"] .nav-item.active {
    background: linear-gradient(90deg, rgba(96,165,250,0.18) 0%, rgba(168,85,247,0.10) 100%) !important;
    color: #e2e8f0 !important;
}
html[data-theme="dark-neon"] .card,
html[data-theme="dark-neon"] .stat-card,
html[data-theme="dark-neon"] .hw-stat,
html[data-theme="dark-neon"] .nic-card,
html[data-theme="dark-neon"] .project-card,
html[data-theme="dark-neon"] .wizard-card {
    background: linear-gradient(135deg, #1a2138 0%, #131829 100%) !important;
    border-color: #2a3354 !important;
    color: #e2e8f0;
}
html[data-theme="dark-neon"] .page-header {
    background: linear-gradient(135deg, #131829 0%, #1a1f33 50%, #1f1a2e 100%) !important;
    border-color: #2a3354;
    color: #e2e8f0;
}
html[data-theme="dark-neon"] table.data {
    background: #131829 !important;
}
html[data-theme="dark-neon"] table.data thead {
    background: linear-gradient(90deg, #1e3a5f 0%, #14532d 33%, #5c4513 66%, #5c1717 100%) !important;
}
html[data-theme="dark-neon"] table.data thead th {
    color: #e2e8f0 !important;
}
html[data-theme="dark-neon"] table.data tbody tr:nth-child(even) {
    background: #161c30 !important;
}
html[data-theme="dark-neon"] table.data tbody td {
    color: #cbd5e1 !important;
    border-color: #2a3354 !important;
}
html[data-theme="dark-neon"] .form-input,
html[data-theme="dark-neon"] .form-control,
html[data-theme="dark-neon"] input[type="text"],
html[data-theme="dark-neon"] input[type="email"],
html[data-theme="dark-neon"] input[type="password"],
html[data-theme="dark-neon"] select,
html[data-theme="dark-neon"] textarea {
    background: #131829 !important;
    border-color: #2a3354 !important;
    color: #e2e8f0 !important;
}
html[data-theme="dark-neon"] .inline-code {
    background: rgba(96, 165, 250, 0.1) !important;
    color: #93c5fd !important;
    border-color: #2a3354 !important;
}
html[data-theme="dark-neon"] .text-muted {
    color: #94a3b8 !important;
}
html[data-theme="dark-neon"] .badge-muted {
    background: linear-gradient(135deg, #2a3354, #1a2138) !important;
    color: #94a3b8 !important;
    border-color: #2a3354 !important;
}
html[data-theme="dark-neon"] .code-block,
html[data-theme="dark-neon"] pre.code-block {
    background: #050810 !important;
    color: #93c5fd !important;
}
html[data-theme="dark-neon"] .stat-card-value,
html[data-theme="dark-neon"] .hw-stat-value {
    background: linear-gradient(135deg, #60a5fa 0%, #c084fc 50%, #f472b6 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
html[data-theme="dark-neon"] .pagination-list a,
html[data-theme="dark-neon"] .pagination-list span {
    background: #131829 !important;
    border-color: #2a3354 !important;
    color: #cbd5e1 !important;
}

/* Theme: dark-slate (subdued professional dark) */
html[data-theme="dark-slate"] {
    --bg:           #1e293b;
    --bg-elev:      #273449;
    --surface:      #334155;
    --border:       #475569;
    --text:         #f1f5f9;
    --text-muted:   #cbd5e1;
    --text-soft:    #94a3b8;
    --primary:      #38bdf8;
    color-scheme: dark;
}
html[data-theme="dark-slate"] body {
    background: #1e293b !important;
    color: #f1f5f9;
}
html[data-theme="dark-slate"] .sidebar {
    background: #1a2333 !important;
    border-right: 1px solid #475569;
}
html[data-theme="dark-slate"] .nav-item:hover {
    background: rgba(56, 189, 248, 0.10) !important;
    color: #f1f5f9 !important;
}
html[data-theme="dark-slate"] .nav-item.active {
    background: rgba(56, 189, 248, 0.18) !important;
    color: #f1f5f9 !important;
}
html[data-theme="dark-slate"] .card,
html[data-theme="dark-slate"] .stat-card,
html[data-theme="dark-slate"] .hw-stat,
html[data-theme="dark-slate"] .nic-card,
html[data-theme="dark-slate"] .project-card,
html[data-theme="dark-slate"] .wizard-card {
    background: #273449 !important;
    border-color: #475569 !important;
    color: #f1f5f9;
}
html[data-theme="dark-slate"] .page-header {
    background: #273449 !important;
    border-color: #475569;
    color: #f1f5f9;
}
html[data-theme="dark-slate"] table.data {
    background: #273449 !important;
}
html[data-theme="dark-slate"] table.data thead {
    background: #1a2333 !important;
}
html[data-theme="dark-slate"] table.data thead th {
    color: #cbd5e1 !important;
    border-bottom: 2px solid #475569 !important;
    border-image: none !important;
}
html[data-theme="dark-slate"] table.data tbody tr:nth-child(even) {
    background: #2d3a4f !important;
}
html[data-theme="dark-slate"] table.data tbody td {
    color: #f1f5f9 !important;
    border-color: #475569 !important;
}
html[data-theme="dark-slate"] .form-input,
html[data-theme="dark-slate"] input[type="text"],
html[data-theme="dark-slate"] input[type="email"],
html[data-theme="dark-slate"] input[type="password"],
html[data-theme="dark-slate"] select,
html[data-theme="dark-slate"] textarea {
    background: #1a2333 !important;
    border-color: #475569 !important;
    color: #f1f5f9 !important;
}
html[data-theme="dark-slate"] .text-muted {
    color: #cbd5e1 !important;
}
html[data-theme="dark-slate"] .inline-code {
    background: #1a2333 !important;
    color: #67e8f9 !important;
    border-color: #475569 !important;
}

/* Theme switcher button in header */
.theme-switcher {
    position: relative;
    display: inline-flex;
}
.theme-switcher-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 12px;
    border: 1px solid var(--border, #e2e8f0);
    border-radius: 8px;
    background: var(--bg-elev, white);
    color: var(--text, #1f2937);
    cursor: pointer;
    font-size: 12px;
    font-weight: 600;
}
.theme-switcher-btn:hover {
    border-color: #3b82f6;
}
.theme-switcher-btn i[data-lucide] {
    width: 14px; height: 14px;
}
.theme-switcher-menu {
    position: absolute;
    top: calc(100% + 4px);
    right: 0;
    background: var(--bg-elev, white);
    border: 1px solid var(--border, #e2e8f0);
    border-radius: 10px;
    padding: 6px;
    min-width: 220px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.12);
    display: none;
    z-index: 1000;
}
.theme-switcher-menu.open { display: block; }
.theme-switcher-menu .theme-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 13px;
    color: var(--text);
}
.theme-switcher-menu .theme-item:hover {
    background: rgba(59,130,246,0.08);
}
.theme-switcher-menu .theme-item.active {
    background: linear-gradient(135deg, rgba(59,130,246,0.12), rgba(168,85,247,0.06));
    font-weight: 700;
}
.theme-switcher-menu .theme-swatch {
    width: 24px; height: 24px;
    border-radius: 6px;
    flex-shrink: 0;
    border: 1px solid var(--border);
}
.theme-swatch-light-rainbow { background: linear-gradient(135deg, #3b82f6, #10b981, #f59e0b, #ef4444); }
.theme-swatch-light-mono    { background: linear-gradient(135deg, #ffffff, #94a3b8); }
.theme-swatch-dark-neon     { background: linear-gradient(135deg, #0a0e1a, #60a5fa, #a855f7); }
.theme-swatch-dark-slate    { background: linear-gradient(135deg, #1e293b, #38bdf8); }
.theme-swatch-saas-light   { background: linear-gradient(135deg, #ffffff 40%, #0284c7); border-color:#cbd5e1; }
.theme-swatch-saas-dark    { background: linear-gradient(135deg, #020617 45%, #22d3ee); }
.theme-section-label {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    color: var(--text-muted);
    padding: 6px 10px 4px;
    font-weight: 700;
}

/* Project card enhancements */
.project-card-rich {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.project-health-track {
    display: flex;
    height: 6px;
    border-radius: 4px;
    overflow: hidden;
    background: #e2e8f0;
    margin-bottom: 6px;
}
.ph-seg { height: 100%; }
.ph-online   { background: linear-gradient(90deg, #10b981, #34d399); }
.ph-warning  { background: linear-gradient(90deg, #f59e0b, #fbbf24); }
.ph-critical { background: linear-gradient(90deg, #ef4444, #f87171); }
.ph-offline  { background: #94a3b8; }
.project-health-label {
    font-size: 12px;
    color: var(--text-muted);
}
.project-health-label strong {
    color: var(--text);
    font-size: 13px;
}
.project-stat-label {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.project-stat-label i[data-lucide] {
    width: 12px; height: 12px;
    opacity: 0.65;
}
.project-resources {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}
.resource-pill {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 8px;
    border-radius: 12px;
    background: linear-gradient(135deg, #dbeafe, #d1fae5);
    color: #1e40af;
    font-size: 11px;
    font-weight: 600;
    border: 1px solid rgba(59,130,246,0.2);
}
.resource-pill i[data-lucide] {
    width: 12px; height: 12px;
}
.project-cp-mix {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.cp-tag {
    padding: 3px 9px;
    border-radius: 12px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.3px;
    text-transform: uppercase;
}
.cp-tag-cpanel { background: linear-gradient(135deg, #fed7aa, #fdba74); color: #9a3412; }
.cp-tag-plesk  { background: linear-gradient(135deg, #bae6fd, #7dd3fc); color: #075985; }
.cp-tag-cwp    { background: linear-gradient(135deg, #bbf7d0, #86efac); color: #166534; }
.cp-tag-plain  { background: linear-gradient(135deg, #e2e8f0, #cbd5e1); color: #475569; }

/* Control-panel icon next to server name */
.cp-icon {
    width: 36px; height: 36px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: white;
    box-shadow: 0 4px 10px rgba(37, 99, 235, 0.2);
}
.cp-icon i[data-lucide] { width: 18px; height: 18px; }
.cp-icon-cpanel      { background: linear-gradient(135deg, #f97316, #fb923c); }
.cp-icon-plesk       { background: linear-gradient(135deg, #0ea5e9, #38bdf8); }
.cp-icon-cwp         { background: linear-gradient(135deg, #10b981, #34d399); }
.cp-icon-directadmin { background: linear-gradient(135deg, #a855f7, #c084fc); }
.cp-icon-ispconfig   { background: linear-gradient(135deg, #ec4899, #f472b6); }
.cp-icon-webmin      { background: linear-gradient(135deg, #64748b, #94a3b8); }
.cp-icon-none        { background: linear-gradient(135deg, #475569, #64748b); }

/* =====================================================================
   Add Server wizard — extra colour
   ===================================================================== */

/* Step circles get vivid gradients per stage */
.wizard-steps .wz-step:nth-child(1).active .wz-circle,
.wizard-steps .wz-step:nth-child(1).done   .wz-circle {
    background: linear-gradient(135deg, #3b82f6, #60a5fa);
    border-color: #3b82f6;
}
.wizard-steps .wz-step:nth-child(2).active .wz-circle,
.wizard-steps .wz-step:nth-child(2).done   .wz-circle {
    background: linear-gradient(135deg, #10b981, #34d399);
    border-color: #10b981;
}
.wizard-steps .wz-step:nth-child(3).active .wz-circle,
.wizard-steps .wz-step:nth-child(3).done   .wz-circle {
    background: linear-gradient(135deg, #f59e0b, #fbbf24);
    border-color: #f59e0b;
}
.wizard-steps .wz-step:nth-child(4).active .wz-circle,
.wizard-steps .wz-step:nth-child(4).done   .wz-circle {
    background: linear-gradient(135deg, #ef4444, #f87171);
    border-color: #ef4444;
}
.wizard-steps .wz-step:nth-child(5).active .wz-circle,
.wizard-steps .wz-step:nth-child(5).done   .wz-circle {
    background: linear-gradient(135deg, #a855f7, #c084fc);
    border-color: #a855f7;
}

/* Connector line gradient */
.wizard-steps .wz-step.done::after {
    background: linear-gradient(90deg, #3b82f6, #10b981, #f59e0b, #ef4444, #a855f7);
}

/* Wizard card hero accent — gradient border at top */
.wizard-card {
    border-top: 4px solid;
    border-image: linear-gradient(90deg, #3b82f6, #10b981, #f59e0b, #ef4444, #a855f7) 1;
    background: linear-gradient(135deg, #ffffff 0%, #fafbff 100%);
}

/* Pane title icon — bright gradient pill */
.wz-title i[data-lucide] {
    background: linear-gradient(135deg, #3b82f6, #a855f7);
    color: white !important;
    width: 32px !important; height: 32px !important;
    padding: 6px;
    border-radius: 8px;
    box-shadow: 0 4px 10px rgba(59,130,246,0.3);
}

/* OS picker: huge bright cards */
.os-card-inner {
    background: linear-gradient(135deg, #ffffff 0%, #f5f7fb 100%);
    border-width: 2px;
    transition: all 0.18s;
    position: relative;
    overflow: hidden;
}
.os-card-inner::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, transparent, rgba(168, 85, 247, 0.05));
    opacity: 0;
    transition: opacity 0.18s;
}
.os-card-inner:hover::before { opacity: 1; }
.os-card input:checked + .os-card-inner {
    background: linear-gradient(135deg, #dbeafe 0%, #fef3c7 50%, #fee2e2 100%);
    border-color: #3b82f6;
    box-shadow: 0 8px 24px rgba(59, 130, 246, 0.25);
    transform: translateY(-2px);
}
.os-icon {
    font-size: 48px !important;
    filter: drop-shadow(0 4px 8px rgba(0,0,0,0.1));
}

/* Environment chips — color-rotate by position */
.chip-radio:nth-of-type(1) input:checked + span {
    background: linear-gradient(135deg, #3b82f6, #60a5fa);
    border-color: #3b82f6;
}
.chip-radio:nth-of-type(2) input:checked + span {
    background: linear-gradient(135deg, #f59e0b, #fbbf24);
    border-color: #f59e0b;
}
.chip-radio:nth-of-type(3) input:checked + span {
    background: linear-gradient(135deg, #10b981, #34d399);
    border-color: #10b981;
}
.chip-radio:nth-of-type(4) input:checked + span {
    background: linear-gradient(135deg, #a855f7, #c084fc);
    border-color: #a855f7;
}

/* Provider cards: vivid gradients per provider */
.provider-card:nth-of-type(1) input:checked + .provider-card-inner { background: linear-gradient(135deg, #dbeafe, #bfdbfe); border-color: #3b82f6; color: #1e40af; }
.provider-card:nth-of-type(2) input:checked + .provider-card-inner { background: linear-gradient(135deg, #fef3c7, #fde68a); border-color: #f59e0b; color: #92400e; }
.provider-card:nth-of-type(3) input:checked + .provider-card-inner { background: linear-gradient(135deg, #cffafe, #a5f3fc); border-color: #06b6d4; color: #155e75; }
.provider-card:nth-of-type(4) input:checked + .provider-card-inner { background: linear-gradient(135deg, #fee2e2, #fecaca); border-color: #ef4444; color: #991b1b; }
.provider-card:nth-of-type(5) input:checked + .provider-card-inner { background: linear-gradient(135deg, #ede9fe, #ddd6fe); border-color: #a855f7; color: #6b21a8; }

/* Control panel cards: each gets its own bright signature color when picked */
.cp-card input[value="cpanel"]:checked + .cp-card-inner {
    background: linear-gradient(135deg, #fed7aa 0%, #fdba74 100%);
    border-color: #f97316;
}
.cp-card input[value="plesk"]:checked + .cp-card-inner {
    background: linear-gradient(135deg, #bae6fd 0%, #7dd3fc 100%);
    border-color: #0ea5e9;
}
.cp-card input[value="cwp"]:checked + .cp-card-inner {
    background: linear-gradient(135deg, #bbf7d0 0%, #86efac 100%);
    border-color: #10b981;
}
.cp-card input[value="directadmin"]:checked + .cp-card-inner {
    background: linear-gradient(135deg, #ede9fe 0%, #ddd6fe 100%);
    border-color: #a855f7;
}
.cp-card input[value="ispconfig"]:checked + .cp-card-inner {
    background: linear-gradient(135deg, #fce7f3 0%, #fbcfe8 100%);
    border-color: #ec4899;
}
.cp-card input[value="webmin"]:checked + .cp-card-inner {
    background: linear-gradient(135deg, #f1f5f9 0%, #e2e8f0 100%);
    border-color: #64748b;
}

/* Wizard tip — vivid info banner */
.wz-tip {
    background: linear-gradient(135deg, #ddd6fe 0%, #fbcfe8 50%, #fed7aa 100%) !important;
    border-color: #a855f7 !important;
}
.wz-tip i[data-lucide] {
    background: linear-gradient(135deg, #f59e0b, #ef4444);
    color: white !important;
    border-radius: 50%;
    padding: 4px;
    width: 28px !important; height: 28px !important;
}

/* Review row — alternating bright tints */
.review-row:nth-child(odd)  { background: linear-gradient(90deg, #dbeafe33, transparent); }
.review-row:nth-child(even) { background: linear-gradient(90deg, #d1fae533, transparent); }

/* =====================================================================
   Resource utilisation charts — one chart per card, 2x2 grid
   ===================================================================== */
.charts-grid {
    display: grid;
    /* Exactly 2 columns on desktop, 1 column on narrow screens. */
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    margin-bottom: 20px;
}
@media (max-width: 800px) {
    .charts-grid { grid-template-columns: 1fr; }
}
.chart-card {
    padding: 0;          /* override card default; our header has its own padding */
    overflow: hidden;
}
.chart-card .card-header {
    padding: 14px 18px 10px;
    border-bottom: 1px solid var(--border);
}
.chart-title {
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-muted);
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0;
}
.chart-dot {
    display: inline-block;
    width: 10px; height: 10px;
    border-radius: 50%;
    box-shadow: 0 0 0 3px rgba(255,255,255,0.5),
                0 2px 6px rgba(0,0,0,0.15);
}
.chart-body {
    padding: 14px 14px 18px;
    height: 240px;
}
.chart-body > div {
    width: 100%;
    height: 100%;
}

/* Dark theme — chart cards keep their own color but match dark surface */
html[data-theme="dark-neon"] .chart-card,
html[data-theme="dark-slate"] .chart-card {
    background: var(--surface);
}
html[data-theme="dark-neon"] .chart-card .card-header,
html[data-theme="dark-slate"] .chart-card .card-header {
    border-bottom-color: var(--border);
}

/* =====================================================================
   Agent version chip + upgrade banner
   ===================================================================== */
.agent-ver-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    border-radius: 12px;
    background: linear-gradient(135deg, #ddd6fe, #bfdbfe);
    color: #4338ca;
    font-size: 11px;
    font-weight: 600;
    border: 1px solid rgba(67, 56, 202, 0.2);
}
.agent-ver-chip i[data-lucide] {
    width: 11px; height: 11px;
}
.agent-ver-chip-unknown {
    background: linear-gradient(135deg, #fef3c7, #fde68a);
    color: #92400e;
    border-color: rgba(146, 64, 14, 0.2);
}

.agent-upgrade-banner {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 18px;
    margin-bottom: 20px;
    background: linear-gradient(135deg, #fef3c7 0%, #fed7aa 100%);
    border: 1px solid #f59e0b;
    border-left: 4px solid #f59e0b;
    border-radius: 10px;
}
.agent-upgrade-banner-ok {
    background: linear-gradient(135deg, #d1fae5 0%, #a7f3d0 100%);
    border-color: #10b981;
    border-left-color: #10b981;
}
.agent-upgrade-banner-icon {
    flex-shrink: 0;
    width: 40px; height: 40px;
    border-radius: 50%;
    background: white;
    display: grid;
    place-items: center;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}
.agent-upgrade-banner-icon i[data-lucide] {
    width: 22px; height: 22px;
    color: #b45309;
}
.agent-upgrade-banner-ok .agent-upgrade-banner-icon i[data-lucide] {
    color: #047857;
}
.agent-upgrade-banner-body {
    flex: 1;
    min-width: 0;
}
.agent-upgrade-banner-body strong {
    display: block;
    font-size: 14px;
    color: #78350f;
    margin-bottom: 2px;
}
.agent-upgrade-banner-ok .agent-upgrade-banner-body strong {
    color: #064e3b;
}
.agent-upgrade-banner-body p {
    font-size: 12px;
    color: #92400e;
    margin: 0;
    line-height: 1.5;
}
.agent-upgrade-banner-ok .agent-upgrade-banner-body p {
    color: #065f46;
}

/* Dark theme adjustments */
html[data-theme="dark-neon"] .agent-upgrade-banner,
html[data-theme="dark-slate"] .agent-upgrade-banner {
    background: linear-gradient(135deg, #422006 0%, #5c1f02 100%);
    border-color: #f59e0b;
}
html[data-theme="dark-neon"] .agent-upgrade-banner-ok,
html[data-theme="dark-slate"] .agent-upgrade-banner-ok {
    background: linear-gradient(135deg, #022c22 0%, #064e3b 100%);
    border-color: #10b981;
}
html[data-theme="dark-neon"] .agent-upgrade-banner-body strong,
html[data-theme="dark-slate"] .agent-upgrade-banner-body strong { color: #fde68a; }
html[data-theme="dark-neon"] .agent-upgrade-banner-body p,
html[data-theme="dark-slate"] .agent-upgrade-banner-body p { color: #fcd34d; }
html[data-theme="dark-neon"] .agent-upgrade-banner-ok .agent-upgrade-banner-body strong,
html[data-theme="dark-slate"] .agent-upgrade-banner-ok .agent-upgrade-banner-body strong { color: #a7f3d0; }
html[data-theme="dark-neon"] .agent-upgrade-banner-ok .agent-upgrade-banner-body p,
html[data-theme="dark-slate"] .agent-upgrade-banner-ok .agent-upgrade-banner-body p { color: #6ee7b7; }

/* =====================================================================
   Cloud account sub-navigation tabs
   ===================================================================== */
.cloud-subnav {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
    margin-bottom: 20px;
    padding: 6px;
    background: var(--bg-elev);
    border: 1px solid var(--border);
    border-radius: 12px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.cloud-subnav-item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    border-radius: 8px;
    text-decoration: none;
    font-size: 12.5px;
    font-weight: 500;
    color: var(--text-muted);
    border: 1px solid transparent;
    transition: all 0.15s ease;
}
.cloud-subnav-item:hover {
    color: var(--text);
    background: var(--bg-soft);
}
.cloud-subnav-item.is-active {
    background: var(--bg);
    border: 1px solid currentColor;
    font-weight: 600;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}
.cloud-subnav-item i[data-lucide] { width: 14px; height: 14px; }

@media (max-width: 800px) {
    .cloud-subnav-item span { display: none; }  /* icons-only on narrow screens */
}

/* Recommendation severity pills */
.rec-card {
    border-left: 4px solid #94a3b8;
    background: var(--bg-elev);
    border-radius: 8px;
    padding: 14px 16px;
    margin-bottom: 10px;
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 12px;
    align-items: start;
}
.rec-card.sev-high { border-left-color: #dc2626; background: linear-gradient(135deg, #fef2f2, var(--bg-elev) 30%); }
.rec-card.sev-medium { border-left-color: #f59e0b; background: linear-gradient(135deg, #fefce8, var(--bg-elev) 30%); }
.rec-card.sev-low { border-left-color: #06b6d4; }
.rec-icon {
    width: 40px; height: 40px;
    border-radius: 50%;
    background: white;
    display: grid; place-items: center;
    box-shadow: 0 1px 4px rgba(0,0,0,0.08);
}
.rec-icon i[data-lucide] { width: 22px; height: 22px; }
.rec-card.sev-high   .rec-icon i { color: #dc2626; }
.rec-card.sev-medium .rec-icon i { color: #d97706; }
.rec-card.sev-low    .rec-icon i { color: #0891b2; }
.rec-body strong { display: block; margin-bottom: 4px; font-size: 14px; }
.rec-body p { margin: 0; font-size: 12.5px; color: var(--text-muted); line-height: 1.5; }
.rec-savings {
    background: #dcfce7;
    color: #166534;
    padding: 6px 10px;
    border-radius: 6px;
    font-weight: 700;
    font-size: 12px;
    white-space: nowrap;
    align-self: center;
}

/* MoM trend ribbons */
.mom-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 10px;
    margin-bottom: 20px;
}
.mom-card {
    background: var(--bg-elev);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 12px;
    text-align: center;
}
.mom-card .mom-month { font-size: 11px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em; }
.mom-card .mom-amount { font-size: 18px; font-weight: 700; color: var(--text); margin: 4px 0; }
.mom-card .mom-delta { font-size: 11px; }
.mom-card .mom-delta.up   { color: #dc2626; }
.mom-card .mom-delta.down { color: #16a34a; }
@media (max-width: 800px) {
    .mom-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 480px) {
    .mom-grid { grid-template-columns: repeat(2, 1fr); }
}

/* =====================================================================
   Brand icon alignment in sidebar nav items
   The brand_icon partial returns full-color SVGs, not currentColor icons,
   so we need to suppress the default lucide sizing rules and ensure the
   SVG sits at the same baseline as the text.
   ===================================================================== */
.nav-item .brand-icon-wrap {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    margin-right: 10px;
    flex-shrink: 0;
}
.nav-item .brand-icon-wrap svg {
    width: 18px;
    height: 18px;
    display: block;
}

/* Brand chip — used on cloud account cards / index pages where the logo
   appears with vendor name as a header element */
.brand-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 4px 10px 4px 4px;
    background: var(--bg-soft);
    border: 1px solid var(--border);
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    color: var(--text);
}
.brand-chip svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

/* When the brand icon is the primary visual on a card, larger and centred */
.brand-icon-large {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 10px;
    background: var(--bg-soft);
    border: 1px solid var(--border);
    flex-shrink: 0;
}
.brand-icon-large svg {
    width: 28px;
    height: 28px;
}

/* Server row brand icon — replaces cp-icon */
.server-row-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background: var(--bg-soft);
    border: 1px solid var(--border);
    flex-shrink: 0;
}
.server-row-icon svg { width: 22px; height: 22px; }

/* =====================================================================
   STAT CARDS — Strip-based design (Option B + C) — v4 SCOPED
   Targets ONLY cards that use the .icon-bg pattern (server-detail page,
   cloud dashboards). Cards using the .stat-card-icon + .stat-card-body
   pattern (dashboard, project show) keep their existing flex-row layout
   defined earlier in this file at line ~2582.

   Selector strategy: use `.stat-card:has(> .icon-bg)` to scope every rule
   to the right markup. Browsers without :has() (very old Safari) will see
   the original first-block rules — graceful degradation.

   Markup contract:
     <div class="stat-card primary|accent|warning|success|info|danger">
         <div class="icon-bg"><i data-lucide="cpu"></i></div>     ← strip
         <div class="label">CPU</div>
         <div class="value">9.6<span>%</span></div>
         <div class="delta">Load: ...</div>
         <div class="progress-track"><div class="progress-fill" style="width:9.6%"></div></div>
     </div>
   ===================================================================== */
.stat-card:has(> .icon-bg) {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: stretch !important;
    gap: 4px !important;
    padding: 16px 20px 16px 78px !important;  /* 60px strip + 18px gap */
    min-height: 108px !important;
    background: var(--surface, #ffffff) !important;
    border: 1px solid var(--border, #e2e8f0) !important;
    border-radius: 14px !important;
    overflow: hidden !important;
    transition: transform 0.2s, box-shadow 0.2s;
    position: relative !important;
}
.stat-card:has(> .icon-bg)::before,
.stat-card:has(> .icon-bg)::after { content: none !important; }
.stat-card:has(> .icon-bg):hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 12px 28px -10px rgba(15,23,42,0.12) !important;
}

/* The strip — built from .icon-bg, positioned absolutely so the body
   children center vertically without competing with the strip's height. */
.stat-card:has(> .icon-bg) > .icon-bg {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    bottom: 0 !important;
    width: 60px !important;
    height: auto !important;
    margin: 0 !important;
    flex-shrink: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 0 !important;
    color: #ffffff !important;
    font-size: 24px !important;
    line-height: 1 !important;
    background: linear-gradient(180deg, #94a3b8, #64748b) !important;
}
.stat-card:has(> .icon-bg) > .icon-bg i[data-lucide],
.stat-card:has(> .icon-bg) > .icon-bg svg {
    width: 26px !important;
    height: 26px !important;
    stroke-width: 2.2 !important;
    color: #ffffff !important;
    filter: drop-shadow(0 2px 4px rgba(0,0,0,0.2)) !important;
}

/* Per-color gradient strips */
.stat-card.primary:has(> .icon-bg)  > .icon-bg { background: linear-gradient(180deg, #60a5fa, #2563eb) !important; }
.stat-card.accent:has(> .icon-bg)   > .icon-bg { background: linear-gradient(180deg, #c084fc, #9333ea) !important; }
.stat-card.warning:has(> .icon-bg)  > .icon-bg { background: linear-gradient(180deg, #fbbf24, #d97706) !important; }
.stat-card.success:has(> .icon-bg)  > .icon-bg { background: linear-gradient(180deg, #34d399, #059669) !important; }
.stat-card.info:has(> .icon-bg)     > .icon-bg { background: linear-gradient(180deg, #22d3ee, #0891b2) !important; }
.stat-card.danger:has(> .icon-bg)   > .icon-bg { background: linear-gradient(180deg, #f87171, #dc2626) !important; }

/* Body children */
.stat-card:has(> .icon-bg) > .label {
    font-size: 11px !important;
    color: var(--text-muted, #64748b) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.6px !important;
    font-weight: 600 !important;
    line-height: 1.3 !important;
    margin: 0 !important;
}
.stat-card:has(> .icon-bg) > .value {
    font-size: 24px !important;
    font-weight: 700 !important;
    line-height: 1.15 !important;
    color: var(--text, #0f172a) !important;
    letter-spacing: -0.4px !important;
    margin: 0 !important;
}
.stat-card:has(> .icon-bg) > .value > span {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--text-muted, #94a3b8) !important;
    margin-left: 1px;
}
.stat-card:has(> .icon-bg) > .delta {
    font-size: 11.5px !important;
    color: var(--text-muted, #64748b) !important;
    line-height: 1.4 !important;
    margin: 0 !important;
}

/* Progress bar */
.stat-card:has(> .icon-bg) > .progress-track {
    height: 4px !important;
    background: var(--border, #e2e8f0) !important;
    border-radius: 99px !important;
    margin: 4px 0 0 !important;
    overflow: hidden !important;
}
.stat-card:has(> .icon-bg) > .progress-track > .progress-fill {
    height: 100%;
    border-radius: 99px;
    transition: width 0.4s ease;
    background: linear-gradient(90deg, #34d399, #059669);
}
.stat-card:has(> .icon-bg) > .progress-track > .progress-fill.warn   { background: linear-gradient(90deg, #fbbf24, #d97706); }
.stat-card:has(> .icon-bg) > .progress-track > .progress-fill.danger { background: linear-gradient(90deg, #f87171, #dc2626); }

/* ────────────────────────────────────────────────────────────────
   v2.7.29 — Website observability styles.
   Indexes use the existing .table-wrap + table.data + .badge classes
   from the servers index pattern. Only one addition needed here:
   the .form-hint helper for the create/edit forms.
   ──────────────────────────────────────────────────────────────── */
.form-hint {
    font-size: 11.5px;
    color: var(--text-muted, #94a3b8);
    margin-top: 4px;
    line-height: 1.45;
}

/* week4-config-backup-styles */
/* Config backup card states — subtle distinction from regular cards */
#config-backup-card .card-header h3 .dot {
    width: 8px; height: 8px; border-radius: 50%;
    display: inline-block;
}
#config-backup-card .stat-card {
    background: var(--bg-soft);
}
#config-backup-card form input[type="text"],
#config-backup-card form input[type="password"],
#config-backup-card form input[type="number"],
#config-backup-card form select {
    background: var(--bg, #fff);
}

/* Oxidized card admin override form */
#oxidized-card .hidden { display: none !important; }
#oxidized-card form select { background: #fff; }

/* Diff viewer button-group */
.diff-style-btn.active { color: #fff; }
.diff-style-btn:not(.active) { color: var(--text-muted); }

/* Snapshot list compact row spacing on device detail */
#config-backup-card table.data td { padding: 8px 12px; }
#config-backup-card table.data .ident-code { font-size: 11px; }

/* =====================================================================
   SaaS LIGHT theme — VPW-inspired: white panels, sky/cyan accent, mono data
   ===================================================================== */
html[data-theme="saas-light"] {
    --bg:           #f8fafc;
    --bg-elev:      #ffffff;
    --surface:      #ffffff;
    --bg-soft:      #f1f5f9;
    --border:       #e2e8f0;
    --border-strong:#cbd5e1;
    --text:         #0f172a;
    --text-muted:   #64748b;
    --text-soft:    #94a3b8;
    --primary:      #0284c7;
    --primary-dark: #0369a1;
    --primary-soft: #e0f2fe;
    --accent:       #0891b2;
    --accent-soft:  #cffafe;
    --info:         #0891b2;
    color-scheme: light;
}
/* Mono for data readouts — the VPW signature */
html[data-theme="saas-light"] .stat-card-value,
html[data-theme="saas-light"] .hw-stat-value,
html[data-theme="saas-light"] .finops-kpi .value,
html[data-theme="saas-light"] .hist-kpi .value,
html[data-theme="saas-light"] .kpi-value {
    font-family: var(--font-mono);
    letter-spacing: -0.02em;
}

/* =====================================================================
   SaaS DARK theme — VPW-inspired: slate-950 canvas, cyan accent, SRE-grade
   Mirrors the dark-slate override structure (base CSS hardcodes some light
   colors that need explicit overrides, not just variables).
   ===================================================================== */
html[data-theme="saas-dark"] {
    --bg:           #020617;
    --bg-elev:      #0f172a;
    --surface:      #1e293b;
    --bg-soft:      #0f172a;
    --border:       #1e293b;
    --border-strong:#334155;
    --text:         #e2e8f0;
    --text-muted:   #94a3b8;
    --text-soft:    #64748b;
    --primary:      #22d3ee;
    --primary-dark: #06b6d4;
    --primary-soft: rgba(34,211,238,0.12);
    --accent:       #818cf8;
    --accent-soft:  rgba(129,140,248,0.12);
    --info:         #22d3ee;
    color-scheme: dark;
}
html[data-theme="saas-dark"] body {
    background: #020617 !important;
    color: #e2e8f0;
}
html[data-theme="saas-dark"] .sidebar {
    background: #0b1120 !important;
    border-right: 1px solid #1e293b;
}
html[data-theme="saas-dark"] .nav-item:hover {
    background: rgba(34, 211, 238, 0.08) !important;
    color: #e2e8f0 !important;
}
html[data-theme="saas-dark"] .nav-item.active {
    background: rgba(34, 211, 238, 0.15) !important;
    color: #67e8f9 !important;
    border-left: 2px solid #22d3ee;
}
html[data-theme="saas-dark"] .card,
html[data-theme="saas-dark"] .stat-card,
html[data-theme="saas-dark"] .hw-stat,
html[data-theme="saas-dark"] .nic-card,
html[data-theme="saas-dark"] .project-card,
html[data-theme="saas-dark"] .wizard-card,
html[data-theme="saas-dark"] .finops-kpi,
html[data-theme="saas-dark"] .hist-kpi {
    background: #0f172a !important;
    border-color: #1e293b !important;
    color: #e2e8f0;
}
html[data-theme="saas-dark"] .page-header {
    background: #0f172a !important;
    border-color: #1e293b;
    color: #e2e8f0;
}
html[data-theme="saas-dark"] table.data {
    background: #0f172a !important;
}
html[data-theme="saas-dark"] table.data thead {
    background: #0b1120 !important;
}
html[data-theme="saas-dark"] table.data thead th {
    color: #94a3b8 !important;
    border-bottom: 1px solid #1e293b !important;
    border-image: none !important;
}
html[data-theme="saas-dark"] table.data tbody tr:nth-child(even) {
    background: #131c2e !important;
}
html[data-theme="saas-dark"] table.data tbody td {
    color: #e2e8f0 !important;
    border-color: #1e293b !important;
}
html[data-theme="saas-dark"] .form-input,
html[data-theme="saas-dark"] .form-control,
html[data-theme="saas-dark"] input[type="text"],
html[data-theme="saas-dark"] input[type="email"],
html[data-theme="saas-dark"] input[type="password"],
html[data-theme="saas-dark"] input[type="number"],
html[data-theme="saas-dark"] input[type="month"],
html[data-theme="saas-dark"] select,
html[data-theme="saas-dark"] textarea {
    background: #0b1120 !important;
    border-color: #1e293b !important;
    color: #e2e8f0 !important;
}
html[data-theme="saas-dark"] .text-muted {
    color: #94a3b8 !important;
}
html[data-theme="saas-dark"] .inline-code {
    background: rgba(34, 211, 238, 0.1) !important;
    color: #67e8f9 !important;
    border-color: #1e293b !important;
}
html[data-theme="saas-dark"] .code-block,
html[data-theme="saas-dark"] pre.code-block {
    background: #010207 !important;
    color: #67e8f9 !important;
}
html[data-theme="saas-dark"] .chart-card {
    background: var(--surface);
}
html[data-theme="saas-dark"] .chart-card .card-header {
    border-bottom-color: var(--border);
}
html[data-theme="saas-dark"] .pagination-list a,
html[data-theme="saas-dark"] .pagination-list span {
    background: #0f172a !important;
    border-color: #1e293b !important;
    color: #cbd5e1 !important;
}
html[data-theme="saas-dark"] .agent-upgrade-banner {
    background: linear-gradient(135deg, #422006 0%, #5c1f02 100%);
    border-color: #f59e0b;
}
html[data-theme="saas-dark"] .agent-upgrade-banner-ok {
    background: linear-gradient(135deg, #022c22 0%, #064e3b 100%);
    border-color: #10b981;
}
/* Mono for data readouts — the VPW signature */
html[data-theme="saas-dark"] .stat-card-value,
html[data-theme="saas-dark"] .hw-stat-value,
html[data-theme="saas-dark"] .finops-kpi .value,
html[data-theme="saas-dark"] .hist-kpi .value,
html[data-theme="saas-dark"] .kpi-value {
    font-family: var(--font-mono);
    letter-spacing: -0.02em;
    color: #67e8f9;
}
