/* ================================================================
   App Scaffold — Tabler Overrides
   Replicated from CFM 4 Linux layout style
   ================================================================ */

/* ── Table Text ───────────────────────────────────────────────── */
.table td, .table th { font-weight: 600; }

/* ── Responsive tables ────────────────────────────────────────── */
@media (max-width: 991.98px) {
    .table-responsive { overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .table-responsive > .table { min-width: 600px; }
    .page, .page-wrapper, .page-body, .container-xl { overflow-x: hidden; max-width: 100vw; }
}

/* ── Toggle switch colors ─────────────────────────────────────── */
.form-switch .form-check-input { background-color: #d63939; border-color: #d63939; }
.form-switch .form-check-input:checked { background-color: #008710; border-color: #008710; }
.form-check-input:focus { box-shadow: 0 0 0 0.25rem rgba(0, 135, 16, 0.25); border-color: #008710; }

/* ── Global Topbar ────────────────────────────────────────────── */
.app-topbar {
    position: fixed; top: 0; left: 0; right: 0;
    height: 3.5rem;
    background: linear-gradient(90deg, #003e17, #008710);
    z-index: 1040;
    box-shadow: 0 1px 4px rgba(0,0,0,0.15);
}
.app-topbar-inner {
    display: flex; align-items: center; justify-content: space-between;
    height: 100%; padding: 0 1rem;
}
.app-topbar-brand {
    display: flex; align-items: center; gap: 0.5rem;
    color: #fff; text-decoration: none; font-size: 1.25rem; font-weight: 700; letter-spacing: 0.5px;
}
.app-topbar-brand:hover { color: #fff; text-decoration: none; }
.app-topbar-brand svg { flex-shrink: 0; }
.app-topbar-hamburger {
    background: none; border: none; color: #fff; font-size: 1.5rem;
    padding: 0.25rem; cursor: pointer; margin-left: 0.75rem; line-height: 1;
}
.app-topbar-hamburger:hover { opacity: 0.8; }
.navbar-vertical { --tblr-navbar-active-border-color: #008710; }
.navbar-expand-lg .nav-item.active::after { border-color: #008710 !important; }
.app-topbar-icon { color: rgba(255,255,255,0.7); text-decoration: none; line-height: 1; }
.app-topbar-icon:hover { color: #fff; text-decoration: none; }
.app-topbar-add { color: #fff; font-size: 16px; font-weight: 500; padding: 5px 13px; text-decoration: none; display: inline-flex; align-items: center; line-height: 1; cursor: pointer; }
.app-topbar-add:hover { color: rgba(255,255,255,0.8); background: #027c11; border-radius: 5px; text-decoration: none; }
.app-topbar-user {
    display: flex; align-items: center; gap: 0.75rem;
}
.app-topbar-user-link {
    display: flex; align-items: center; color: #fff !important; text-decoration: none; padding: 0; cursor: pointer;
}
.app-topbar-user-link:hover { color: rgba(255,255,255,0.9) !important; text-decoration: none; }
.app-topbar-avatar { background: rgba(255,255,255,0.2) !important; color: #fff !important; font-weight: 600; }
.app-topbar-username { font-weight: 500; font-size: 0.875rem; line-height: 1.2; }
.app-topbar-role { font-size: 0.75rem; opacity: 0.75; line-height: 1.2; }
.app-topbar .dropdown-item { display: flex; align-items: center; }

/* ── Search bar placeholder ───────────────────────────────────── */
.app-topbar input::placeholder { color: #fff !important; opacity: 0.6; }
.app-topbar input {
    background: rgba(255,255,255,0.12) !important;
    border: 1px solid rgba(255,255,255,0.15) !important;
    color: #fff !important; font-size: 0.82rem; height: 32px;
}

/* ── Footer ───────────────────────────────────────────────────── */
.app-footer {
    position: fixed; bottom: 0; left: 0; right: 0;
    z-index: 1040; padding: 0.75rem 1rem;
    text-align: center; font-size: 0.8125rem;
    color: var(--tblr-secondary);
    background: var(--tblr-body-bg, #fff);
    border-top: 1px solid var(--tblr-border-color);
}
@media (max-width: 991.98px) {
    .app-footer { position: static; }
    .page-wrapper { padding-bottom: 0; }
}
.app-footer a { color: var(--tblr-primary); text-decoration: none; font-weight: 500; }
.app-footer a:hover { text-decoration: underline; }

/* ── Sidebar top offset + filter ──────────────────────────────── */
@media (min-width: 992px) {
    .navbar-vertical { top: 3.5rem !important; height: calc(100vh - 3.5rem) !important; padding-top: 0 !important; }
    .sidebar-filter input::placeholder { color: rgba(255,255,255,0.4) !important; }
    body.sidebar-collapsed .sidebar-filter { display: none !important; }
}

/* ── Sidebar scrollbar ────────────────────────────────────────── */
@media (min-width: 992px) {
    .navbar-vertical .navbar-collapse {
        overflow-y: auto;
        max-height: calc(100vh - 3.5rem - 3rem);
        scrollbar-width: thin;
        scrollbar-color: rgba(255,255,255,0.2) transparent;
    }
    .navbar-vertical .navbar-collapse::-webkit-scrollbar { width: 3px; }
    .navbar-vertical .navbar-collapse::-webkit-scrollbar-thumb {
        background: rgba(255,255,255,0.2); border-radius: 2px;
    }

    /* Sidebar transitions */
    .navbar-vertical { transition: width 0.25s ease; overflow: hidden !important; overflow-y: auto !important; }
    html.topbar-scroll { overflow: hidden !important; }
    html.topbar-scroll body { height: 100vh !important; overflow: hidden !important; }
    html.topbar-scroll .page { height: 100vh !important; min-height: 0 !important; overflow: hidden !important; }
    html.topbar-scroll .app-topbar { position: relative !important; flex-shrink: 0 !important; }
    html.topbar-scroll #impersonate-banner { position: relative !important; top: auto !important; flex-shrink: 0 !important; }
    html.topbar-scroll .page-wrapper { flex: 1 !important; overflow-y: auto !important; min-height: 0 !important; padding-top: 0.75rem !important; }
    html.topbar-scroll .page-body { min-height: 0 !important; }
    html.topbar-scroll .page-body .container-xl { padding-bottom: 5rem !important; }
    .page-wrapper { transition: margin-left 0.25s ease; padding-top: 4rem !important; padding-bottom: 3.5rem !important; }

    /* Collapsed sidebar */
    body.sidebar-collapsed .navbar-vertical { width: 70px !important; min-width: 70px !important; }
    body.sidebar-collapsed .navbar-vertical ~ .page-wrapper { margin-left: 70px !important; }
    body.sidebar-collapsed .navbar-vertical .nav-link-title,
    body.sidebar-collapsed .navbar-vertical .navbar-nav > .nav-item > span { display: none !important; }
    body.sidebar-collapsed .navbar-vertical .nav-item.mt-2 {
        margin-top: 0.25rem !important; border-top: 1px solid rgba(255,255,255,0.1); padding-top: 0.25rem;
    }
    body.sidebar-collapsed .navbar-vertical .nav-link { justify-content: center; padding-left: 0; padding-right: 0; }
    body.sidebar-collapsed .navbar-vertical .nav-link-icon { margin: 0; font-size: 1.35rem; }

    /* Tooltip on hover when collapsed */
    body.sidebar-collapsed .navbar-vertical .nav-link { position: relative; }
    body.sidebar-collapsed .navbar-vertical .nav-item > .nav-link::after {
        content: attr(data-sidebar-title);
        position: absolute; left: 100%; top: 50%; transform: translateY(-50%);
        background: #1e293b; color: #fff; padding: 4px 10px; border-radius: 4px;
        font-size: 0.8125rem; white-space: nowrap; opacity: 0; pointer-events: none;
        transition: opacity 0.15s; margin-left: 8px; z-index: 1100;
    }
    body.sidebar-collapsed .navbar-vertical .nav-item > .nav-link:hover::after { opacity: 1; }
}

/* ── Sidebar collapse toggle ──────────────────────────────────── */
@media (min-width: 992px) {
    .sidebar-toggle {
        position: fixed;
        left: 15rem;
        top: 50%;
        transform: translateY(-50%);
        width: 10px;
        height: 144px;
        background: var(--tblr-navbar-bg, #1b2434);
        border-radius: 0 10px 10px 0;
        display: flex;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        z-index: 1041;
        opacity: 0.6;
        transition: left 0.25s ease, opacity 0.2s ease;
    }
    .sidebar-toggle:hover { opacity: 1; }
    .sidebar-toggle i {
        color: rgba(255,255,255,0.8);
        font-size: 0.7rem;
        transition: transform 0.25s ease;
    }
    body.sidebar-collapsed .sidebar-toggle { left: 70px; }
    body.sidebar-collapsed .sidebar-toggle i { transform: rotate(180deg); }
}

/* ── Chart responsive height ─────────────────────────────────── */
.chart-container { position: relative; height: 450px; }
@media (max-width: 767.98px) {
    .chart-container { height: 220px; }
}

/* ── Lock screen shake ───────────────────────────────────────── */
@keyframes lockShake {
    0%, 100% { transform: translateX(0); }
    10%, 30%, 50%, 70%, 90% { transform: translateX(-6px); }
    20%, 40%, 60%, 80% { transform: translateX(6px); }
}

/* ── Demo Mode ───────────────────────────────────────────────── */
.demo-blur {
    filter: blur(5px);
    user-select: none;
    pointer-events: none;
    display: inline;
    transition: filter 0.2s ease;
}
/* Statically marked sensitive fields (admin keys, usernames, emails):
   no effect normally, blurred only while demo mode is active. */
body.demo-active .demo-secret {
    filter: blur(5px);
    user-select: none;
    pointer-events: none;
}

/* ── Notifications rDNS column (shown only when the toggle is on) ── */
.rdns-col { display: none; }
#alerts-table.rdns-on .rdns-col { display: table-cell; }

/* ── Command Palette (Ctrl+K) ────────────────────────────────── */
.cmdp-trigger {
    align-items: center;
    gap: 6px;
    background: var(--tblr-bg-surface-secondary, #f1f5f9);
    border: 1px solid var(--tblr-border-color, #dadcde);
    border-radius: 6px;
    color: var(--tblr-secondary, #667382);
    font-size: 0.8rem;
    padding: 4px 10px;
    margin-right: 8px;
    cursor: pointer;
    transition: border-color 0.15s ease;
}
.cmdp-trigger:hover { border-color: var(--tblr-primary, #066fd1); }
.cmdp-trigger kbd {
    background: var(--tblr-bg-surface, #fff);
    border: 1px solid var(--tblr-border-color, #dadcde);
    border-radius: 4px;
    font-size: 0.65rem;
    padding: 1px 5px;
    color: inherit;
}
#cmdp-overlay {
    position: fixed;
    inset: 0;
    z-index: 1100;
    background: rgba(15, 23, 42, 0.45);
    backdrop-filter: blur(2px);
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding-top: 14vh;
}
#cmdp-box {
    width: 100%;
    max-width: 560px;
    background: var(--tblr-bg-surface, #fff);
    border: 1px solid var(--tblr-border-color, #dadcde);
    border-radius: 10px;
    box-shadow: 0 18px 50px rgba(0, 0, 0, 0.35);
    overflow: hidden;
}
#cmdp-input-wrap {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    border-bottom: 1px solid var(--tblr-border-color, #dadcde);
    color: var(--tblr-secondary, #667382);
}
#cmdp-input {
    flex: 1;
    border: none;
    outline: none;
    background: transparent;
    font-size: 1rem;
    color: var(--tblr-body-color, #1d273b);
}
#cmdp-input-wrap kbd {
    background: var(--tblr-bg-surface-secondary, #f1f5f9);
    border: 1px solid var(--tblr-border-color, #dadcde);
    border-radius: 4px;
    font-size: 0.65rem;
    padding: 2px 6px;
    color: var(--tblr-secondary, #667382);
}
#cmdp-list { max-height: 50vh; overflow-y: auto; padding: 6px; }
.cmdp-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 12px;
    border-radius: 6px;
    cursor: pointer;
    color: var(--tblr-body-color, #1d273b);
    text-decoration: none;
}
.cmdp-item:hover { text-decoration: none; }
.cmdp-item i { color: var(--tblr-secondary, #667382); font-size: 1rem; }
.cmdp-item.active { background: var(--tblr-primary, #066fd1); color: #fff; }
.cmdp-item.active i, .cmdp-item.active .cmdp-hint { color: rgba(255, 255, 255, 0.8); }
.cmdp-label { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cmdp-hint { font-size: 0.7rem; color: var(--tblr-secondary, #667382); text-transform: uppercase; letter-spacing: 0.4px; }
.cmdp-empty { padding: 24px; text-align: center; color: var(--tblr-secondary, #667382); }
.demo-badge {
    display: inline-flex;
    align-items: center;
    background: #e74c3c;
    color: #fff;
    font-size: 0.6rem;
    font-weight: 700;
    padding: 2px 7px;
    border-radius: 3px;
    letter-spacing: 0.5px;
    margin-left: 8px;
    vertical-align: middle;
    animation: demoPulse 2s ease-in-out infinite;
}
@keyframes demoPulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.6; }
}

/* ── Toast container ──────────────────────────────────────────── */
#toast-container { z-index: 1090 !important; }

/* ══════════════════════════════════════════════════════════════════
   MATRIX THEME — CRT Green Phosphor
   ══════════════════════════════════════════════════════════════════ */
[data-cfm-theme="matrix"] {
    --tblr-body-bg: #0a0a0a !important;
    --tblr-body-color: #33ff33 !important;
    --tblr-card-bg: #0d1a0d !important;
    --tblr-card-border-color: #1a3a1a !important;
    --tblr-border-color: #1a3a1a !important;
    --tblr-bg-surface: #0d1a0d !important;
    --tblr-bg-surface-secondary: #0a140a !important;
    --tblr-primary: #00cc00 !important;
    --tblr-link-color: #33ff33 !important;
    --tblr-link-hover-color: #66ff66 !important;
    --tblr-secondary: #2a8a2a !important;
    --tblr-muted: #2a8a2a !important;
    --tblr-code-color: #66ff66 !important;
    --tblr-active-bg: rgba(0,255,0,0.08) !important;
}
[data-cfm-theme="matrix"] body { background: #0a0a0a !important; color: #33ff33 !important; }
[data-cfm-theme="matrix"] .page-title { color: #00ff00 !important; }
[data-cfm-theme="matrix"] .text-secondary { color: #2a8a2a !important; }
[data-cfm-theme="matrix"] .card { background: #0d1a0d !important; border-color: #1a3a1a !important; box-shadow: 0 0 8px rgba(0,255,0,0.05) !important; position: relative; }
[data-cfm-theme="matrix"] .card::before { content:''; position:absolute; inset:0; border-radius:inherit; pointer-events:none; z-index:1; background:repeating-linear-gradient(0deg,transparent 0px,transparent 2px,rgba(0,0,0,0.04) 2px,rgba(0,0,0,0.04) 4px); }
[data-cfm-theme="matrix"] .card-header { border-color: #1a3a1a !important; }
[data-cfm-theme="matrix"] .card-footer { border-color: #1a3a1a !important; }
[data-cfm-theme="matrix"] .card-title { color: #00ff00 !important; }
[data-cfm-theme="matrix"] .table { --tblr-table-bg: transparent !important; --tblr-table-border-color: #1a3a1a !important; color: #33ff33 !important; }
[data-cfm-theme="matrix"] .table thead th { color: #00cc00 !important; border-color: #1a3a1a !important; }
[data-cfm-theme="matrix"] .table-striped > tbody > tr:nth-of-type(odd) { --tblr-table-striped-bg: rgba(0,255,0,0.03) !important; }
[data-cfm-theme="matrix"] .form-control, [data-cfm-theme="matrix"] .form-select { background: #0a140a !important; border-color: #1a3a1a !important; color: #33ff33 !important; }
[data-cfm-theme="matrix"] .form-control:focus, [data-cfm-theme="matrix"] .form-select:focus { border-color: #00cc00 !important; box-shadow: 0 0 0 0.25rem rgba(0,204,0,0.15) !important; }
[data-cfm-theme="matrix"] .form-control::placeholder { color: #1a6a1a !important; }
[data-cfm-theme="matrix"] .btn-primary { background: #00aa00 !important; border-color: #00aa00 !important; color: #000 !important; }
[data-cfm-theme="matrix"] .btn-primary:hover { background: #00cc00 !important; border-color: #00cc00 !important; }
[data-cfm-theme="matrix"] .btn-outline-secondary { border-color: #2a5a2a !important; color: #33ff33 !important; }
[data-cfm-theme="matrix"] .btn-outline-secondary:hover { background: rgba(0,255,0,0.1) !important; }
[data-cfm-theme="matrix"] .btn-outline-primary { border-color: #00aa00 !important; color: #00cc00 !important; }
[data-cfm-theme="matrix"] .btn-outline-primary:hover, [data-cfm-theme="matrix"] .btn-outline-primary.active { background: #00aa00 !important; color: #000 !important; }
[data-cfm-theme="matrix"] .navbar-vertical { background: #050a05 !important; border-right: 1px solid #1a3a1a !important; }
[data-cfm-theme="matrix"] .navbar-vertical .nav-link { color: #2a8a2a !important; }
[data-cfm-theme="matrix"] .navbar-vertical .nav-link:hover, [data-cfm-theme="matrix"] .navbar-vertical .nav-item.active .nav-link { color: #33ff33 !important; background: rgba(0,255,0,0.08) !important; }
[data-cfm-theme="matrix"] .app-topbar { background: linear-gradient(90deg, #001a00, #003a00) !important; box-shadow: 0 1px 4px rgba(0,255,0,0.1) !important; }
[data-cfm-theme="matrix"] .dropdown-menu { background: #0d1a0d !important; border-color: #1a3a1a !important; }
[data-cfm-theme="matrix"] .dropdown-item { color: #33ff33 !important; }
[data-cfm-theme="matrix"] .dropdown-item:hover { background: rgba(0,255,0,0.1) !important; }
[data-cfm-theme="matrix"] .badge.bg-blue-lt, [data-cfm-theme="matrix"] .badge.bg-primary-lt { background: rgba(0,204,0,0.15) !important; color: #00ff00 !important; }
[data-cfm-theme="matrix"] .badge.bg-secondary-lt { background: rgba(0,255,0,0.08) !important; color: #2a8a2a !important; }
[data-cfm-theme="matrix"] .badge.bg-red-lt { background: rgba(255,50,50,0.2) !important; }
[data-cfm-theme="matrix"] .badge.bg-yellow-lt { background: rgba(200,200,0,0.2) !important; }
[data-cfm-theme="matrix"] .badge.bg-green-lt { background: rgba(0,255,0,0.15) !important; color: #00ff00 !important; }
[data-cfm-theme="matrix"] .modal-content { background: #0d1a0d !important; border-color: #1a3a1a !important; }
[data-cfm-theme="matrix"] .avatar { background: rgba(0,204,0,0.15) !important; color: #00ff00 !important; }
[data-cfm-theme="matrix"] code { color: #66ff66 !important; }
[data-cfm-theme="matrix"] pre { background: #050a05 !important; border: 1px solid #1a3a1a !important; }
[data-cfm-theme="matrix"] a:not(.btn):not(.nav-link):not(.dropdown-item) { color: #33ff33 !important; }
[data-cfm-theme="matrix"] a:not(.btn):not(.nav-link):not(.dropdown-item):hover { color: #66ff66 !important; }
[data-cfm-theme="matrix"] .nav-tabs .nav-link { color: #2a8a2a !important; }
[data-cfm-theme="matrix"] .nav-tabs .nav-link.active { color: #33ff33 !important; background: #0d1a0d !important; border-color: #1a3a1a !important; }
[data-cfm-theme="matrix"] .app-footer { border-color: #1a3a1a !important; background: #0a0a0a !important; color: #2a8a2a !important; }
[data-cfm-theme="matrix"] .offcanvas { background: #050a05 !important; }
[data-cfm-theme="matrix"] .accordion-button { background: #0a140a !important; color: #33ff33 !important; }
[data-cfm-theme="matrix"] .accordion-button.collapsed { color: #2a8a2a !important; }
[data-cfm-theme="matrix"] .accordion-body { background: #0d1a0d !important; }
[data-cfm-theme="matrix"] .chart-container { filter: hue-rotate(90deg) saturate(1.5); }
[data-cfm-theme="matrix"] ::selection { background: #00aa00 !important; color: #000 !important; }
[data-cfm-theme="matrix"] ::-webkit-scrollbar { width: 8px; }
[data-cfm-theme="matrix"] ::-webkit-scrollbar-track { background: #0a0a0a; }
[data-cfm-theme="matrix"] ::-webkit-scrollbar-thumb { background: #1a3a1a; border-radius: 4px; }
[data-cfm-theme="matrix"] ::-webkit-scrollbar-thumb:hover { background: #2a5a2a; }
[data-cfm-theme="matrix"] .h1,[data-cfm-theme="matrix"] .h2,[data-cfm-theme="matrix"] .h3,[data-cfm-theme="matrix"] h1,[data-cfm-theme="matrix"] h2,[data-cfm-theme="matrix"] h3 { color: #00ff00 !important; }
