:root {
    --kb-industrial: var(--mustard);
    --kb-industrial-rgb: 226,153,48;
    --kb-smb: var(--cerulean);
    --kb-smb-rgb: 33,124,163;
    --kb-data: var(--moss);
    --kb-data-rgb: 174,189,56;
    --kb-makers: var(--waterfall);
    --kb-makers-rgb: 104,130,158;
    --kb-knowledge-base: var(--shadow);
    --kb-knowledge-base-rgb: 33,31,48;
}

.kb-page {
    --kb-accent: var(--kb-knowledge-base);
    --kb-accent-rgb: var(--kb-knowledge-base-rgb);
}

.shell-symbol {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: inherit;
    font-family: "Segoe UI Emoji", "Apple Color Emoji", "Noto Color Emoji", var(--font-body);
    font-size: 1rem;
    line-height: 1;
}

.nav-login-icon .shell-symbol {
    font-size: 1.05rem;
}

.kb-docs,
.homelab-docs,
.smb-docs {
    --kb-accent: var(--kb-knowledge-base);
    --kb-accent-rgb: var(--kb-knowledge-base-rgb);
    display: grid;
    grid-template-columns: 240px minmax(0, 1fr) 210px;
    max-width: 1280px;
    margin: 0 auto;
    min-height: calc(100vh - 64px);
    align-items: start;
}

.kb-theme-industrial { --kb-accent: var(--kb-industrial); --kb-accent-rgb: var(--kb-industrial-rgb); }
.kb-theme-smb,
.smb-docs { --kb-accent: var(--kb-smb); --kb-accent-rgb: var(--kb-smb-rgb); }
.kb-theme-data { --kb-accent: var(--kb-data); --kb-accent-rgb: var(--kb-data-rgb); }
.kb-theme-makers,
.homelab-docs { --kb-accent: var(--kb-makers); --kb-accent-rgb: var(--kb-makers-rgb); }
.kb-theme-knowledge-base { --kb-accent: var(--kb-knowledge-base); --kb-accent-rgb: var(--kb-knowledge-base-rgb); }

.kb-page:has(.kb-docs) > .w3-container,
.kb-page:has(.homelab-docs) > .w3-container,
.kb-page:has(.smb-docs) > .w3-container {
    max-width: none;
    padding: 0 !important;
}
.kb-page:has(.kb-docs) > .w3-container > .w3-row,
.kb-page:has(.homelab-docs) > .w3-container > .w3-row,
.kb-page:has(.smb-docs) > .w3-container > .w3-row {
    padding-left: 0 !important;
}
.kb-page:has(.kb-docs) .kb-sidebar,
.kb-page:has(.homelab-docs) .kb-sidebar,
.kb-page:has(.smb-docs) .kb-sidebar {
    display: none;
}
.kb-page:has(.kb-docs) #contentContainer,
.kb-page:has(.homelab-docs) #contentContainer,
.kb-page:has(.smb-docs) #contentContainer {
    display: block;
    width: 100%;
    min-width: 0 !important;
}
.kb-docs a,
.homelab-docs a,
.smb-docs a {
    color: inherit;
}
.kb-sidenav,
.homelab-sidenav,
.smb-sidenav {
    position: sticky;
    top: 64px;
    height: calc(100vh - 64px);
    overflow-y: auto;
    border-right: 1px solid var(--border);
    padding: 1.5rem 0 3rem;
    scrollbar-width: thin;
    scrollbar-color: var(--border) transparent;
}
.kb-sidenav::-webkit-scrollbar,
.homelab-sidenav::-webkit-scrollbar,
.smb-sidenav::-webkit-scrollbar {
    width: 4px;
}
.kb-sidenav::-webkit-scrollbar-thumb,
.homelab-sidenav::-webkit-scrollbar-thumb,
.smb-sidenav::-webkit-scrollbar-thumb {
    background: var(--border);
    border-radius: 2px;
}
.kb-docs .nav-section,
.homelab-docs .nav-section,
.smb-docs .nav-section {
    margin-bottom: 0.25rem;
}
.kb-docs .nav-section-toggle,
.homelab-docs .nav-section-toggle,
.smb-docs .nav-section-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    border: 0;
    background: transparent;
    color: var(--kb-accent);
    cursor: pointer;
    font-family: var(--font-mono);
    font-size: 0.68rem;
    letter-spacing: 0.1em;
    padding: 0.5rem 1.25rem;
    text-align: left;
    text-transform: uppercase;
    transition: color var(--transition);
}
.kb-docs .nav-section-toggle:hover,
.homelab-docs .nav-section-toggle:hover,
.smb-docs .nav-section-toggle:hover {
    color: var(--text-muted);
}
.kb-docs .nav-section-toggle .chev,
.homelab-docs .nav-section-toggle .chev,
.smb-docs .nav-section-toggle .chev {
    font-size: 0.7rem;
    transition: transform var(--transition);
}
.kb-docs .nav-section-toggle.open .chev,
.homelab-docs .nav-section-toggle.open .chev,
.smb-docs .nav-section-toggle.open .chev {
    transform: rotate(90deg);
}
.kb-docs .nav-section-items,
.homelab-docs .nav-section-items,
.smb-docs .nav-section-items {
    display: none;
    flex-direction: column;
    padding-bottom: 0.375rem;
}
.kb-docs .nav-section-items.open,
.homelab-docs .nav-section-items.open,
.smb-docs .nav-section-items.open {
    display: flex;
}
.kb-docs .nav-item,
.homelab-docs .nav-item,
.smb-docs .nav-item {
    display: block;
    margin-left: 0;
    border-left: 2px solid transparent;
    color: var(--text-dim);
    font-size: 0.8125rem;
    line-height: 1.4;
    padding: 0.3rem 1.25rem 0.3rem 1.75rem;
    text-decoration: none;
    transition: color var(--transition), background var(--transition);
}
.kb-docs .nav-item:hover,
.homelab-docs .nav-item:hover,
.smb-docs .nav-item:hover {
    color: var(--text-muted);
    background: rgba(255,255,255,0.02);
}
.kb-docs .nav-item.active,
.homelab-docs .nav-item.active,
.smb-docs .nav-item.active {
    color: var(--kb-accent);
    border-left-color: var(--kb-accent);
    background: rgba(var(--kb-accent-rgb),0.05);
}
.kb-docs .docs-main,
.homelab-docs .docs-main,
.smb-docs .docs-main {
    min-width: 0;
    padding: 2.5rem 2.5rem 4rem;
}
.kb-docs .breadcrumb,
.homelab-docs .breadcrumb,
.smb-docs .breadcrumb {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1.25rem;
    color: var(--text-dim);
    font-family: var(--font-mono);
    font-size: 0.72rem;
}
.kb-docs .breadcrumb a,
.homelab-docs .breadcrumb a,
.smb-docs .breadcrumb a {
    color: var(--text-dim);
    text-decoration: none;
}
.kb-docs .breadcrumb a:hover,
.homelab-docs .breadcrumb a:hover,
.smb-docs .breadcrumb a:hover {
    color: var(--text-muted);
}
.kb-docs .comp-badge,
.homelab-docs .comp-badge,
.smb-docs .comp-badge,
.network-docs .comp-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    margin-bottom: 1.25rem;
    border: 1px solid rgba(var(--kb-accent-rgb),0.28);
    border-radius: 100px;
    background: rgba(var(--kb-accent-rgb),0.12);
    color: var(--kb-accent);
    font-family: var(--font-mono);
    font-size: 0.7rem;
    padding: 0.25rem 0.75rem;
}
.kb-docs .docs-title,
.homelab-docs .docs-title,
.smb-docs .docs-title {
    margin: 0 0 1rem;
    font-family: var(--font-display);
    font-size: clamp(1.625rem, 3vw, 2.25rem);
    font-weight: 800;
    line-height: 1.15;
}
.kb-docs .docs-title span,
.homelab-docs .docs-title span,
.smb-docs .docs-title span {
    color: var(--mustard);
}
.kb-docs .docs-title em,
.homelab-docs .docs-title em,
.smb-docs .docs-title em {
    color: var(--kb-accent);
    font-style: normal;
}
.kb-docs .docs-lead,
.homelab-docs .docs-lead,
.smb-docs .docs-lead {
    max-width: 720px;
    margin-bottom: 2rem;
    border-left: 3px solid var(--kb-accent);
    color: var(--text-muted);
    font-size: 1rem;
    line-height: 1.7;
    padding-left: 1rem;
}
.kb-docs .docs-section,
.homelab-docs .docs-section,
.smb-docs .docs-section {
    margin-bottom: 2.5rem;
}
.kb-docs .docs-section-label,
.homelab-docs .docs-section-label,
.smb-docs .docs-section-label {
    margin-bottom: 0.5rem;
    color: var(--mustard);
    font-family: var(--font-mono);
    font-size: 0.68rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}
.kb-docs .docs-section h2,
.homelab-docs .docs-section h2,
.smb-docs .docs-section h2 {
    margin: 0 0 0.875rem;
    color: var(--mustard);
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 700;
    line-height: 1.25;
}
.kb-docs .docs-section h2 em,
.homelab-docs .docs-section h2 em,
.smb-docs .docs-section h2 em {
    color: var(--kb-accent);
    font-style: normal;
}
.kb-docs .docs-section p,
.homelab-docs .docs-section p,
.smb-docs .docs-section p {
    margin-bottom: 0.75rem;
    color: var(--text-muted);
    font-size: 0.9375rem;
    line-height: 1.75;
}
.kb-docs .entity-grid,
.homelab-docs .entity-grid,
.smb-docs .entity-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(165px, 1fr));
    gap: 0.75rem;
    margin: 1.25rem 0;
}
.kb-docs .entity-card,
.homelab-docs .entity-card,
.smb-docs .entity-card {
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--bg-card);
    padding: 0.875rem 1rem;
}
.kb-docs .entity-name,
.homelab-docs .entity-name,
.smb-docs .entity-name {
    font-family: var(--font-display);
    font-size: 0.9rem;
    font-weight: 700;
}
.kb-docs .entity-desc,
.homelab-docs .entity-desc,
.smb-docs .entity-desc {
    color: var(--text-muted);
    font-size: 0.8rem;
    line-height: 1.5;
}
.kb-docs .step-list,
.homelab-docs .step-list,
.smb-docs .step-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin: 1.25rem 0;
}
.kb-docs .step-card,
.homelab-docs .step-card,
.smb-docs .step-card {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--bg-card);
    padding: 1rem 1.25rem;
}
.kb-docs .step-num,
.homelab-docs .step-num,
.smb-docs .step-num {
    flex-shrink: 0;
    margin-top: 0.1rem;
    border: 1px solid rgba(var(--kb-accent-rgb),0.2);
    border-radius: 5px;
    background: rgba(var(--kb-accent-rgb),0.1);
    color: var(--kb-accent);
    font-family: var(--font-mono);
    font-size: 0.75rem;
    font-weight: 700;
    padding: 0.2rem 0.55rem;
}
.kb-docs .step-card h4,
.homelab-docs .step-card h4,
.smb-docs .step-card h4 {
    margin: 0 0 0.3rem;
    color: var(--text);
    font-family: var(--font-display);
    font-size: 0.9375rem;
    font-weight: 700;
}
.kb-docs .step-card p,
.homelab-docs .step-card p,
.smb-docs .step-card p {
    margin: 0;
    color: var(--text-muted);
    font-size: 0.875rem;
    line-height: 1.6;
}
.kb-docs .arch-diagram,
.homelab-docs .arch-diagram,
.smb-docs .arch-diagram {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin: 2rem 0;
}
.kb-docs .arch-node-inner,
.homelab-docs .arch-node-inner,
.smb-docs .arch-node-inner {
    display: flex;
    align-items: flex-start;
    gap: 1.125rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background: var(--bg-card);
    padding: 1.375rem 1.5rem;
    transition: border-color var(--transition), background var(--transition);
}
.kb-docs .arch-node-inner:hover,
.homelab-docs .arch-node-inner:hover,
.smb-docs .arch-node-inner:hover {
    background: rgba(255,255,255,0.03);
}
.kb-docs .arch-node-inner.highlight-waterfall,
.homelab-docs .arch-node-inner.highlight-waterfall,
.smb-docs .arch-node-inner.highlight-waterfall {
    border-color: rgba(104,130,158,0.4);
    background: rgba(104,130,158,0.06);
}
.kb-docs .arch-node-inner.highlight-cerulean,
.homelab-docs .arch-node-inner.highlight-cerulean,
.smb-docs .arch-node-inner.highlight-cerulean,
.kb-docs .arch-node-inner.hl-cerulean,
.homelab-docs .arch-node-inner.hl-cerulean,
.smb-docs .arch-node-inner.hl-cerulean {
    border-color: rgba(33,124,163,0.4);
    background: rgba(33,124,163,0.05);
}
.kb-docs .arch-node-inner.highlight-mustard,
.homelab-docs .arch-node-inner.highlight-mustard,
.smb-docs .arch-node-inner.highlight-mustard,
.kb-docs .arch-node-inner.hl-mustard,
.homelab-docs .arch-node-inner.hl-mustard,
.smb-docs .arch-node-inner.hl-mustard {
    border-color: rgba(226,153,48,0.3);
    background: rgba(226,153,48,0.04);
}
.kb-docs .arch-node-inner.highlight-moss,
.homelab-docs .arch-node-inner.highlight-moss,
.smb-docs .arch-node-inner.highlight-moss,
.kb-docs .arch-node-inner.hl-moss,
.homelab-docs .arch-node-inner.hl-moss,
.smb-docs .arch-node-inner.hl-moss {
    border-color: rgba(174,189,56,0.3);
    background: rgba(174,189,56,0.04);
}
.kb-docs .arch-node-inner.highlight-red,
.homelab-docs .arch-node-inner.highlight-red,
.smb-docs .arch-node-inner.highlight-red,
.kb-docs .arch-node-inner.hl-red,
.homelab-docs .arch-node-inner.hl-red,
.smb-docs .arch-node-inner.hl-red {
    border-color: rgba(220,80,80,0.28);
    background: rgba(220,80,80,0.04);
}
.kb-docs .arch-num,
.homelab-docs .arch-num,
.smb-docs .arch-num {
    flex-shrink: 0;
    width: 22px;
    color: var(--text-dim);
    font-family: var(--font-mono);
    font-size: 0.7rem;
    line-height: 1;
    padding-top: 0.2rem;
}
.kb-docs .arch-icon,
.homelab-docs .arch-icon,
.smb-docs .arch-icon {
    display: flex;
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: 10px;
    font-size: 1.25rem;
}
.kb-docs .arch-label,
.homelab-docs .arch-label,
.smb-docs .arch-label {
    margin-bottom: 0.25rem;
    color: var(--text-dim);
    font-family: var(--font-mono);
    font-size: 0.68rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}
.kb-docs .arch-title,
.homelab-docs .arch-title,
.smb-docs .arch-title {
    margin-bottom: 0.35rem;
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 700;
}
.kb-docs .arch-desc,
.homelab-docs .arch-desc,
.smb-docs .arch-desc {
    color: var(--text-muted);
    font-size: 0.8625rem;
    line-height: 1.6;
}
.kb-docs .arch-connector,
.homelab-docs .arch-connector,
.smb-docs .arch-connector {
    color: var(--cerulean);
    font-family: var(--font-mono);
    font-size: 0.75rem;
    line-height: 1.4;
    padding: 0.55rem 0 0.55rem 4.4rem;
}
.kb-docs .conn-arrow,
.homelab-docs .conn-arrow,
.smb-docs .conn-arrow {
    flex-shrink: 0;
    color: var(--text-dim);
    font-size: 0.7rem;
}
.kb-docs .conn-label,
.homelab-docs .conn-label,
.smb-docs .conn-label {
    border: 1px solid var(--border);
    border-radius: 100px;
    background: rgba(255,255,255,0.92);
    color: var(--kb-accent);
    font-family: var(--font-mono);
    font-size: 0.68rem;
    font-weight: 600;
    line-height: 1.4;
    padding: 0.15rem 0.625rem;
    white-space: nowrap;
    box-shadow: 0 6px 18px rgba(33,31,48,0.06);
}
.kb-docs .scenario-box,
.homelab-docs .scenario-box,
.smb-docs .scenario-box {
    overflow: hidden;
    margin: 1.5rem 0;
    border: 1px solid rgba(var(--kb-accent-rgb),0.3);
    border-radius: var(--radius-lg);
    background: var(--bg-card);
}
.kb-docs .scenario-header,
.homelab-docs .scenario-header,
.smb-docs .scenario-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    border-bottom: 1px solid rgba(var(--kb-accent-rgb),0.2);
    background: rgba(var(--kb-accent-rgb),0.1);
    padding: 1rem 1.375rem;
}
.kb-docs .scenario-header .page-symbol,
.homelab-docs .scenario-header .page-symbol,
.smb-docs .scenario-header .page-symbol,
.kb-docs .scenario-mark,
.homelab-docs .scenario-mark,
.smb-docs .scenario-mark {
    color: var(--kb-accent);
    font-size: 1rem;
}
.kb-docs .scenario-header h3,
.homelab-docs .scenario-header h3,
.smb-docs .scenario-header h3 {
    margin: 0;
    color: var(--text);
    font-family: var(--font-display);
    font-size: 0.9375rem;
    font-weight: 700;
}
.kb-docs .scenario-header p,
.homelab-docs .scenario-header p,
.smb-docs .scenario-header p {
    margin: 0;
    color: var(--text-muted);
    font-size: 0.825rem;
}
.kb-docs .scenario-flow,
.homelab-docs .scenario-flow,
.smb-docs .scenario-flow {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    padding: 1.25rem 1.375rem;
}
.kb-docs .sc-step,
.homelab-docs .sc-step,
.smb-docs .sc-step {
    display: flex;
    align-items: flex-start;
    gap: 0.875rem;
    color: var(--text-muted);
    font-size: 0.875rem;
    line-height: 1.55;
}
.kb-docs .sc-tag,
.homelab-docs .sc-tag,
.smb-docs .sc-tag {
    flex-shrink: 0;
    margin-top: 0.1rem;
    border-radius: 4px;
    font-family: var(--font-mono);
    font-size: 0.68rem;
    padding: 0.15rem 0.5rem;
    white-space: nowrap;
}
.kb-docs .sc-tag.server,
.homelab-docs .sc-tag.server,
.smb-docs .sc-tag.server,
.kb-docs .sc-tag.alert,
.homelab-docs .sc-tag.alert,
.smb-docs .sc-tag.alert { border: 1px solid rgba(104,130,158,0.2); background: rgba(104,130,158,0.12); color: var(--waterfall); }
.kb-docs .sc-tag.component,
.homelab-docs .sc-tag.component,
.smb-docs .sc-tag.component,
.kb-docs .sc-tag.camera,
.homelab-docs .sc-tag.camera,
.smb-docs .sc-tag.camera { border: 1px solid rgba(33,124,163,0.2); background: rgba(33,124,163,0.12); color: var(--cerulean); }
.kb-docs .sc-tag.task,
.homelab-docs .sc-tag.task,
.smb-docs .sc-tag.task { border: 1px solid rgba(226,153,48,0.2); background: rgba(226,153,48,0.1); color: var(--mustard); }
.kb-docs .sc-tag.event,
.homelab-docs .sc-tag.event,
.smb-docs .sc-tag.event { border: 1px solid rgba(174,189,56,0.2); background: rgba(174,189,56,0.1); color: var(--moss); }
.kb-docs .sc-tag.manager,
.homelab-docs .sc-tag.manager,
.smb-docs .sc-tag.manager { border: 1px solid rgba(80,81,96,0.3); background: rgba(80,81,96,0.2); color: var(--thunder); }
.kb-docs .sc-tag.action,
.homelab-docs .sc-tag.action,
.smb-docs .sc-tag.action { border: 1px solid rgba(220,80,80,0.2); background: rgba(220,80,80,0.1); color: #e05555; }
.kb-docs .sc-arrow,
.homelab-docs .sc-arrow,
.smb-docs .sc-arrow {
    flex-shrink: 0;
    margin-top: 0.25rem;
    color: var(--text-dim);
    font-size: 0.7rem;
}
.kb-docs .scenario-flow code,
.homelab-docs .scenario-flow code,
.smb-docs .scenario-flow code {
    background: rgba(255,255,255,0.92);
    border: 1px solid rgba(33,124,163,0.28);
    color: var(--cerulean);
    font-weight: 700;
    box-shadow: 0 4px 12px rgba(0,0,0,0.12);
}
.kb-docs .code-block,
.homelab-docs .code-block,
.smb-docs .code-block,
.network-docs .code-block {
    overflow-x: auto;
    margin: 1.25rem 0;
    border: 1px solid var(--border);
    border-left: 3px solid var(--cerulean);
    border-radius: 0 var(--radius) var(--radius) 0;
    background: var(--shadow);
    font-family: var(--font-mono);
    font-size: 0.8125rem;
    line-height: 1.75;
    padding: 1rem 1.25rem;
}
.network-docs .code-block code {
    background: transparent;
    color: inherit;
    font-size: inherit;
    padding: 0;
}
.kb-docs .code-comment,
.homelab-docs .code-comment,
.smb-docs .code-comment { color: var(--text-dim); }
.kb-docs .code-topic,
.homelab-docs .code-topic,
.smb-docs .code-topic { color: var(--cerulean); }
.kb-docs .code-key,
.homelab-docs .code-key,
.smb-docs .code-key { color: var(--mustard); }
.kb-docs .code-val,
.homelab-docs .code-val,
.smb-docs .code-val { color: var(--moss); }
.kb-docs .code-str,
.homelab-docs .code-str,
.smb-docs .code-str { color: var(--waterfall); }
.kb-docs .callout,
.homelab-docs .callout,
.smb-docs .callout {
    margin: 1.25rem 0;
    border-radius: 0 var(--radius) var(--radius) 0;
    color: var(--text-muted);
    font-size: 0.9rem;
    line-height: 1.6;
    padding: 1rem 1.25rem;
}
.kb-docs .callout.waterfall,
.homelab-docs .callout.waterfall,
.smb-docs .callout.waterfall { border: 1px solid rgba(104,130,158,0.22); border-left: 3px solid var(--waterfall); background: rgba(104,130,158,0.06); }
.kb-docs .callout.waterfall strong,
.homelab-docs .callout.waterfall strong,
.smb-docs .callout.waterfall strong { color: var(--waterfall); }
.kb-docs .callout.mustard,
.homelab-docs .callout.mustard,
.smb-docs .callout.mustard { border: 1px solid rgba(226,153,48,0.2); border-left: 3px solid var(--mustard); background: rgba(226,153,48,0.06); }
.kb-docs .callout.mustard strong,
.homelab-docs .callout.mustard strong,
.smb-docs .callout.mustard strong { color: var(--mustard); }
.kb-docs .callout.moss,
.homelab-docs .callout.moss,
.smb-docs .callout.moss { border: 1px solid rgba(174,189,56,0.2); border-left: 3px solid var(--moss); background: rgba(174,189,56,0.06); }
.kb-docs .callout.moss strong,
.homelab-docs .callout.moss strong,
.smb-docs .callout.moss strong { color: var(--moss); }
.kb-docs .callout.cerulean,
.homelab-docs .callout.cerulean,
.smb-docs .callout.cerulean { border: 1px solid rgba(33,124,163,0.2); border-left: 3px solid var(--cerulean); background: rgba(33,124,163,0.06); }
.kb-docs .callout.cerulean strong,
.homelab-docs .callout.cerulean strong,
.smb-docs .callout.cerulean strong { color: var(--cerulean); }
.kb-docs .callout a,
.homelab-docs .callout a,
.smb-docs .callout a {
    font-weight: 600;
}
.kb-docs .site-grid,
.homelab-docs .site-grid,
.smb-docs .site-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 0.875rem;
    margin: 1.25rem 0;
}
.kb-docs .site-card,
.homelab-docs .site-card,
.smb-docs .site-card {
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background: var(--bg-card);
    padding: 1rem 1.125rem;
}
.kb-docs .site-card.highlight,
.homelab-docs .site-card.highlight,
.smb-docs .site-card.highlight {
    border-color: rgba(var(--kb-accent-rgb),0.3);
    background: rgba(var(--kb-accent-rgb),0.06);
}
.kb-docs .site-icon,
.homelab-docs .site-icon,
.smb-docs .site-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    margin-bottom: 0.75rem;
    border-radius: 8px;
    background: rgba(33,124,163,0.13);
}
.kb-docs .site-card.highlight .site-icon,
.homelab-docs .site-card.highlight .site-icon,
.smb-docs .site-card.highlight .site-icon {
    background: rgba(var(--kb-accent-rgb),0.16);
}
.kb-docs .site-title,
.homelab-docs .site-title,
.smb-docs .site-title,
.kb-docs .site-card h4,
.homelab-docs .site-card h4,
.smb-docs .site-card h4 {
    margin-bottom: 0.25rem;
    color: var(--text);
    font-family: var(--font-display);
    font-size: 0.9rem;
    font-weight: 700;
}
.kb-docs .site-card:not(.highlight) .site-title,
.homelab-docs .site-card:not(.highlight) .site-title,
.smb-docs .site-card:not(.highlight) .site-title,
.kb-docs .site-card:not(.highlight) h4,
.homelab-docs .site-card:not(.highlight) h4,
.smb-docs .site-card:not(.highlight) h4 {
    color: #ffffff;
}
.kb-docs .site-desc,
.homelab-docs .site-desc,
.smb-docs .site-desc,
.kb-docs .site-card p,
.homelab-docs .site-card p,
.smb-docs .site-card p {
    color: var(--text-muted);
    font-size: 0.8rem;
    line-height: 1.5;
}
.kb-docs .docs-figure,
.homelab-docs .docs-figure,
.smb-docs .docs-figure,
.kb-docs figure,
.homelab-docs figure,
.smb-docs figure {
    margin: 1.75rem 0;
}
.kb-docs .docs-figure img,
.homelab-docs .docs-figure img,
.smb-docs .docs-figure img,
.kb-docs figure img,
.homelab-docs figure img,
.smb-docs figure img {
    display: block;
    width: 100%;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
}
.kb-docs .docs-figure figcaption,
.homelab-docs .docs-figure figcaption,
.smb-docs .docs-figure figcaption,
.kb-docs figcaption,
.homelab-docs figcaption,
.smb-docs figcaption {
    margin-top: 0.625rem;
    color: var(--text-dim);
    font-family: var(--font-mono);
    font-size: 0.72rem;
    padding-left: 0.25rem;
}
.kb-docs .usecase-grid,
.homelab-docs .usecase-grid,
.smb-docs .usecase-grid,
.kb-docs .related-kb-grid,
.homelab-docs .related-kb-grid,
.smb-docs .related-kb-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 0.75rem;
    margin-top: 0.875rem;
}
.kb-docs .usecase-card,
.homelab-docs .usecase-card,
.smb-docs .usecase-card,
.kb-docs .related-kb-card,
.homelab-docs .related-kb-card,
.smb-docs .related-kb-card {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    border: 1px solid rgba(33,31,48,0.14);
    border-radius: var(--radius);
    background: rgba(255,255,255,0.82);
    box-shadow: 0 12px 32px rgba(33,31,48,0.05);
    color: var(--shadow);
    font-size: 0.8375rem;
    font-weight: 600;
    line-height: 1.4;
    padding: 0.875rem 1rem;
    text-decoration: none;
    transition: border-color var(--transition), color var(--transition), background var(--transition), transform var(--transition);
}
.kb-docs .usecase-card:hover,
.homelab-docs .usecase-card:hover,
.smb-docs .usecase-card:hover,
.kb-docs .related-kb-card:hover,
.homelab-docs .related-kb-card:hover,
.smb-docs .related-kb-card:hover {
    color: var(--kb-accent);
    border-color: rgba(var(--kb-accent-rgb),0.35);
    background: #ffffff;
    transform: translateY(-2px);
}
.kb-docs .uc-icon,
.homelab-docs .uc-icon,
.smb-docs .uc-icon {
    display: flex;
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 8px;
    font-family: var(--font-mono);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    margin-bottom: 0.75rem;
}
.kb-docs .uc-text h4,
.homelab-docs .uc-text h4,
.smb-docs .uc-text h4 {
    color: var(--text);
    font-family: var(--font-display);
    font-size: 0.9rem;
    font-weight: 700;
    margin: 0 0 0.25rem;
}
.kb-docs .uc-text p,
.homelab-docs .uc-text p,
.smb-docs .uc-text p {
    color: var(--text-muted);
    font-size: 0.8rem;
    line-height: 1.5;
    margin: 0;
}
.kb-docs .related-kb-grid a.related-kb-card,
.kb-docs .related-kb-grid a.related-kb-card:link,
.kb-docs .related-kb-grid a.related-kb-card:visited,
.homelab-docs .related-kb-grid a.related-kb-card,
.homelab-docs .related-kb-grid a.related-kb-card:link,
.homelab-docs .related-kb-grid a.related-kb-card:visited,
.smb-docs .related-kb-grid a.related-kb-card,
.smb-docs .related-kb-grid a.related-kb-card:link,
.smb-docs .related-kb-grid a.related-kb-card:visited {
    color: var(--shadow) !important;
    -webkit-text-fill-color: var(--shadow) !important;
    text-shadow: none;
}
.kb-docs .related-kb-grid a.related-kb-card:hover,
.homelab-docs .related-kb-grid a.related-kb-card:hover,
.smb-docs .related-kb-grid a.related-kb-card:hover {
    color: var(--kb-accent) !important;
    -webkit-text-fill-color: var(--kb-accent) !important;
}
.kb-docs .related-kb-card .page-symbol,
.homelab-docs .related-kb-card .page-symbol,
.smb-docs .related-kb-card .page-symbol,
.kb-docs .related-kb-card .mini-icon,
.homelab-docs .related-kb-card .mini-icon,
.smb-docs .related-kb-card .mini-icon {
    flex-shrink: 0;
    margin-top: 0.1rem;
    color: var(--kb-accent);
    font-size: 0.875rem;
    transition: color var(--transition);
}
.kb-docs .related-kb-title,
.homelab-docs .related-kb-title,
.smb-docs .related-kb-title {
    color: var(--shadow) !important;
    opacity: 1 !important;
}
.kb-docs .related-kb-card:hover .related-kb-title,
.homelab-docs .related-kb-card:hover .related-kb-title,
.smb-docs .related-kb-card:hover .related-kb-title {
    color: var(--kb-accent) !important;
}
.kb-docs .docs-toc,
.homelab-docs .docs-toc,
.smb-docs .docs-toc {
    position: sticky;
    top: 80px;
    border-left: 1px solid var(--border);
    padding: 1.5rem 1.25rem 1.5rem 0.5rem;
}
.kb-docs .toc-label,
.homelab-docs .toc-label,
.smb-docs .toc-label {
    margin-bottom: 0.75rem;
    color: var(--mustard);
    font-family: var(--font-mono);
    font-size: 0.63rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}
.kb-docs .docs-toc ul,
.homelab-docs .docs-toc ul,
.smb-docs .docs-toc ul {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    margin: 0;
    padding: 0;
    list-style: none;
}
.kb-docs .docs-toc a,
.homelab-docs .docs-toc a,
.smb-docs .docs-toc a {
    display: block;
    border-left: 2px solid transparent;
    color: var(--text-dim);
    font-size: 0.8rem;
    line-height: 1.4;
    padding: 0.2rem 0.5rem;
    text-decoration: none;
    transition: color var(--transition), border-color var(--transition);
}
.kb-docs .docs-toc a:hover,
.kb-docs .docs-toc a.active,
.homelab-docs .docs-toc a:hover,
.homelab-docs .docs-toc a.active,
.smb-docs .docs-toc a:hover,
.smb-docs .docs-toc a.active {
    color: var(--kb-accent);
    border-left-color: var(--kb-accent);
}
.kb-docs .docs-main code,
.homelab-docs .docs-main code,
.smb-docs .docs-main code {
    border-radius: 4px;
    background: rgba(33,31,48,0.07);
    color: var(--shadow);
    font-family: var(--font-mono);
    font-size: 0.8rem;
    padding: 0.12rem 0.35rem;
}
.kb-docs .docs-main .entity-card .entity-name {
    color: white;
}
.kb-docs .docs-main .step-num {
    color: white;
}
.kb-docs .docs-main .step-card code {
    color: var(--waterfall);
}
.kb-docs .page-symbol,
.homelab-docs .page-symbol,
.smb-docs .page-symbol {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: inherit;
    font-family: "Segoe UI Emoji", "Apple Color Emoji", "Noto Color Emoji", var(--font-body);
    font-size: 1rem;
    line-height: 1;
}
.kb-docs .badge-symbol,
.homelab-docs .badge-symbol,
.smb-docs .badge-symbol {
    font-size: 0.82rem;
}
@media (max-width: 1100px) {
    .kb-docs,
    .homelab-docs,
    .smb-docs {
        grid-template-columns: 220px minmax(0, 1fr);
    }
    .kb-docs .docs-toc,
    .homelab-docs .docs-toc,
    .smb-docs .docs-toc {
        display: none;
    }
}
@media (max-width: 740px) {
    .kb-docs,
    .homelab-docs,
    .smb-docs {
        grid-template-columns: minmax(0, 1fr);
    }
    .kb-sidenav,
    .homelab-sidenav,
    .smb-sidenav {
        display: none;
    }
    .kb-docs .docs-main,
    .homelab-docs .docs-main,
    .smb-docs .docs-main {
        padding: 2rem 1.25rem 3rem;
    }
    .kb-docs .arch-node-inner,
    .homelab-docs .arch-node-inner,
    .smb-docs .arch-node-inner {
        flex-direction: column;
    }
    .kb-docs .arch-connector,
    .homelab-docs .arch-connector,
    .smb-docs .arch-connector {
        padding-left: 1rem;
    }
    .kb-docs .conn-label,
    .homelab-docs .conn-label,
    .smb-docs .conn-label {
        white-space: normal;
    }
    .kb-docs .sc-step,
    .homelab-docs .sc-step,
    .smb-docs .sc-step {
        flex-wrap: wrap;
    }
}
/* Network Camera KB page */
.kb-page:has(.network-docs) > .w3-container {
    max-width: none;
    padding: 0 !important;
}
.kb-page:has(.network-docs) > .w3-container > .w3-row {
    padding-left: 0 !important;
}
.kb-page:has(.network-docs) #contentContainer {
    display: block;
    width: 100%;
    min-width: 0 !important;
}
.network-docs {
    --kb-accent: var(--kb-knowledge-base);
    --kb-accent-rgb: var(--kb-knowledge-base-rgb);
    display: grid;
    grid-template-columns: 240px minmax(0, 1fr) 210px;
    max-width: 1280px;
    margin: 0 auto;
    min-height: calc(100vh - 64px);
    align-items: start;
}
.network-docs a {
    color: inherit;
}
.network-docs .network-icon {
    flex-shrink: 0;
    color: inherit;
    font-family: var(--font-mono);
    font-size: 0.68rem;
    line-height: 1;
}
.network-docs .network-sidenav {
    position: sticky;
    top: 64px;
    height: calc(100vh - 64px);
    overflow-y: auto;
    border-right: 1px solid var(--border);
    padding: 1.5rem 0 3rem;
    scrollbar-width: thin;
    scrollbar-color: var(--border) transparent;
}
.network-docs .network-sidenav::-webkit-scrollbar {
    width: 4px;
}
.network-docs .network-sidenav::-webkit-scrollbar-thumb {
    background: var(--border);
    border-radius: 2px;
}
.network-docs .nav-section {
    margin-bottom: 0.25rem;
}
.network-docs .nav-section-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    border: 0;
    background: transparent;
    color: var(--kb-accent);
    cursor: pointer;
    font-family: var(--font-mono);
    font-size: 0.68rem;
    letter-spacing: 0.1em;
    padding: 0.5rem 1.25rem;
    text-align: left;
    text-transform: uppercase;
    transition: color var(--transition);
}
.network-docs .nav-section-toggle:hover {
    color: var(--text-muted);
}
.network-docs .nav-section-toggle .chev {
    font-size: 0.7rem;
    transition: transform var(--transition);
}
.network-docs .nav-section-toggle.open .chev {
    transform: rotate(90deg);
}
.network-docs .nav-section-items {
    display: none;
    flex-direction: column;
    padding-bottom: 0.375rem;
}
.network-docs .nav-section-items.open {
    display: flex;
}
.network-docs .nav-item {
    display: block;
    border-left: 2px solid transparent;
    color: var(--text);
    font-size: 0.8125rem;
    line-height: 1.4;
    padding: 0.32rem 1.25rem 0.32rem 1.75rem;
    text-decoration: none;
    transition: color var(--transition), background var(--transition), border-color var(--transition);
}
.network-docs .nav-item:hover {
    background: rgba(var(--kb-accent-rgb),0.05);
    color: var(--kb-accent);
}
.network-docs .nav-item.active {
    background: rgba(var(--kb-accent-rgb),0.08);
    border-left-color: var(--kb-accent);
    color: var(--kb-accent);
}
.network-docs .network-main {
    min-width: 0;
    padding: 2.5rem 2.5rem 4rem;
}
.network-docs .network-breadcrumb {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.5rem;
    color: #344054;
    font-family: var(--font-mono);
    font-size: 0.72rem;
    margin-bottom: 1.25rem;
}
.network-docs .network-breadcrumb a {
    color: #344054;
    text-decoration: none;
}
.network-docs .network-breadcrumb a:hover {
    color: var(--kb-accent);
}
.network-docs .network-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: rgba(var(--kb-accent-rgb),0.12);
    border: 1px solid rgba(var(--kb-accent-rgb),0.28);
    border-radius: 100px;
    color: var(--kb-accent);
    font-family: var(--font-mono);
    font-size: 0.7rem;
    margin-bottom: 1.25rem;
    padding: 0.25rem 0.75rem;
}
.network-docs .network-title {
    color: var(--mustard);
    font-family: var(--font-display);
    font-size: clamp(1.75rem, 3vw, 2.6rem);
    font-weight: 800;
    line-height: 1.12;
    margin: 0 0 1rem;
}
.network-docs .network-title em {
    color: var(--kb-accent);
    font-style: normal;
}
.network-docs .network-lead {
    border-left: 3px solid var(--kb-accent);
    color: #5f6b85;
    font-size: 1rem;
    line-height: 1.72;
    margin: 0 0 2rem;
    max-width: 720px;
    padding-left: 1rem;
}
.network-docs .video-wrap {
    position: relative;
    height: 0;
    overflow: hidden;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    margin: 1.5rem 0;
    padding-bottom: 56.25%;
}
.network-docs .video-wrap iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
}
.network-docs .docs-img {
    display: block;
    width: 100%;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    margin: 1.25rem 0 1rem;
}
.network-docs .network-section {
    margin-bottom: 2.5rem;
}
.network-docs .network-section-label,
.network-docs .related-label {
    color: var(--mustard);
    font-family: var(--font-mono);
    font-size: 0.68rem;
    letter-spacing: 0.12em;
    margin-bottom: 0.5rem;
    text-transform: uppercase;
}
.network-docs .network-section h2 {
    color: var(--mustard);
    font-family: var(--font-display);
    font-size: 1.32rem;
    font-weight: 700;
    line-height: 1.25;
    margin: 0 0 0.875rem;
}
.network-docs .network-section h2 em {
    color: var(--kb-accent);
    font-style: normal;
}
.network-docs .network-section h3 {
    color: #1b2438;
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 700;
    margin: 1.25rem 0 0.5rem;
}
.network-docs .network-section p {
    color: #5f6b85;
    font-size: 0.9375rem;
    line-height: 1.75;
    margin: 0 0 0.75rem;
}
.network-docs .concept-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 1rem;
    margin: 1.5rem 0;
}
.network-docs .concept-card,
.network-docs .format-card,
.network-docs .step-card,
.network-docs .related-kb-card {
    background: rgba(255,255,255,0.94);
    border: 1px solid rgba(var(--kb-accent-rgb),0.16);
    box-shadow: 0 8px 28px rgba(20,31,54,0.04);
}
.network-docs .concept-card {
    border-radius: var(--radius-lg);
    padding: 1.125rem 1.25rem;
    transition: border-color var(--transition), transform var(--transition);
}
.network-docs .concept-card:hover,
.network-docs .format-card:hover {
    border-color: rgba(var(--kb-accent-rgb),0.35);
    transform: translateY(-2px);
}
.network-docs .concept-card.highlight {
    background: rgba(var(--kb-accent-rgb),0.06);
    border-color: rgba(var(--kb-accent-rgb),0.35);
}
.network-docs .concept-card .cc-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 8px;
    margin-bottom: 0.875rem;
    background: rgba(var(--kb-accent-rgb),0.12);
    color: var(--kb-accent);
    font-family: var(--font-mono);
    font-size: 0.8rem;
    font-weight: 700;
}
.network-docs .concept-card h3 {
    color: #1b2438;
    font-family: var(--font-display);
    font-size: 0.9375rem;
    font-weight: 700;
    margin: 0 0 0.4rem;
}
.network-docs .concept-card p {
    font-size: 0.8375rem;
    line-height: 1.55;
    margin: 0;
}
.network-docs .protocol-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin: 0.875rem 0;
}
.network-docs .proto-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 6px;
    font-family: var(--font-mono);
    font-size: 0.78rem;
    font-weight: 600;
    padding: 0.3rem 0.75rem;
}
.network-docs .proto-pill.preferred {
    background: rgba(var(--kb-accent-rgb),0.14);
    border: 1px solid rgba(var(--kb-accent-rgb),0.3);
    color: var(--kb-accent);
}
.network-docs .proto-pill.standard {
    background: rgba(255,255,255,0.75);
    border: 1px solid rgba(var(--kb-accent-rgb),0.18);
    color: #5f6b85;
}
.network-docs .format-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    gap: 0.625rem;
    margin: 0.875rem 0;
}
.network-docs .format-card {
    border-radius: var(--radius);
    padding: 0.75rem 0.875rem;
    text-align: center;
    transition: border-color var(--transition), transform var(--transition);
}
.network-docs .format-name {
    color: var(--kb-accent);
    font-family: var(--font-mono);
    font-size: 0.85rem;
    font-weight: 700;
    margin-bottom: 0.25rem;
}
.network-docs .format-desc {
    color: #5f6b85;
    font-size: 0.75rem;
    line-height: 1.4;
}
.network-docs .step-list {
    display: flex;
    flex-direction: column;
    gap: 0.875rem;
    margin: 1.25rem 0;
}
.network-docs .step-card {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    border-radius: var(--radius);
    padding: 1rem 1.25rem;
}
.network-docs .step-num {
    flex-shrink: 0;
    background: rgba(var(--kb-accent-rgb),0.1);
    border: 1px solid rgba(var(--kb-accent-rgb),0.22);
    border-radius: 5px;
    color: var(--kb-accent);
    font-family: var(--font-mono);
    font-size: 0.75rem;
    font-weight: 700;
    margin-top: 0.1rem;
    padding: 0.2rem 0.55rem;
}
.network-docs .step-card h4 {
    color: #1b2438;
    font-family: var(--font-display);
    font-size: 0.9375rem;
    font-weight: 700;
    margin: 0 0 0.3rem;
}
.network-docs .step-card p {
    font-size: 0.875rem;
    line-height: 1.6;
    margin: 0;
}
.network-docs .param-table-wrap {
    overflow-x: auto;
    margin: 1.25rem 0;
    border: 1px solid rgba(33,31,48,0.12);
    border-radius: var(--radius-lg);
    background: #fff;
    box-shadow: 0 12px 32px rgba(33,31,48,0.07);
}
.network-docs .param-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    font-size: 0.8375rem;
}
.network-docs .param-table th,
.network-docs .param-table td {
    padding: 0.95rem 1rem;
    border-bottom: 1px solid rgba(33,31,48,0.12);
    line-height: 1.5;
    text-align: left;
    vertical-align: top;
}
.network-docs .param-table th {
    background: rgba(174,189,56,0.1);
    color: var(--moss);
    font-family: var(--font-display);
    font-size: 0.82rem;
    font-weight: 700;
    white-space: nowrap;
}
.network-docs .param-table td {
    color: var(--thunder);
}
.network-docs .param-table tr:nth-child(even) {
    background: rgba(174,189,56,0.035);
}
.network-docs .param-table tr:last-child td {
    border-bottom: 0;
}
.network-docs .param-table tr:hover td {
    background: rgba(174,189,56,0.055);
}
.network-docs .param-name {
    color: var(--kb-accent);
    font-family: var(--font-mono);
    font-size: 0.8rem;
    font-weight: 700;
    white-space: nowrap;
}
.network-docs .req-badge {
    display: inline-block;
    border-radius: 3px;
    font-family: var(--font-mono);
    font-size: 0.62rem;
    padding: 0.1rem 0.45rem;
}
.network-docs .req-badge.yes {
    background: rgba(174,189,56,0.12);
    border: 1px solid rgba(174,189,56,0.2);
    color: var(--moss);
}
.network-docs .req-badge.no {
    background: rgba(var(--kb-accent-rgb),0.1);
    border: 1px solid rgba(var(--kb-accent-rgb),0.18);
    color: var(--kb-accent);
}
.network-docs .param-desc ul {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    list-style: none;
    margin: 0.4rem 0 0;
    padding: 0;
}
.network-docs .param-desc li {
    color: var(--thunder);
    font-size: 0.8125rem;
}
.network-docs .param-desc .docs-img {
    max-width: min(100%, 520px);
    margin: 0.85rem 0 0;
}
.network-docs .param-default {
    color: var(--thunder);
    font-family: var(--font-mono);
    font-size: 0.775rem;
    white-space: nowrap;
}
.network-docs code {
    background: rgba(var(--kb-accent-rgb),0.1);
    border-radius: 4px;
    color: var(--kb-accent);
    font-family: var(--font-mono);
    font-size: 0.825rem;
    padding: 0.15rem 0.4rem;
}
.network-docs .callout {
    border-radius: 0 var(--radius) var(--radius) 0;
    color: #5f6b85;
    font-size: 0.9rem;
    line-height: 1.65;
    margin: 1.25rem 0;
    padding: 1rem 1.25rem;
}
.network-docs .callout.waterfall {
    background: rgba(var(--kb-accent-rgb),0.07);
    border: 1px solid rgba(var(--kb-accent-rgb),0.22);
    border-left: 3px solid var(--kb-accent);
}
.network-docs .callout.waterfall strong {
    color: var(--kb-accent);
}
.network-docs .callout.mustard {
    background: rgba(226,153,48,0.07);
    border: 1px solid rgba(226,153,48,0.24);
    border-left: 3px solid var(--mustard);
}
.network-docs .callout.mustard strong {
    color: var(--mustard);
}
.network-docs .related-label {
    display: block;
    margin: 2.5rem 0 0.875rem;
}
.network-docs .related-kb-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 0.75rem;
}
.network-docs .related-kb-card {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    border-radius: var(--radius);
    color: #1b2438;
    font-size: 0.8375rem;
    line-height: 1.4;
    padding: 0.875rem 1rem;
    text-decoration: none;
    transition: border-color var(--transition), color var(--transition), transform var(--transition);
}
.network-docs .related-kb-card:hover {
    border-color: rgba(var(--kb-accent-rgb),0.35);
    color: var(--kb-accent);
    transform: translateY(-2px);
}
.network-docs .related-kb-card .network-icon {
    color: var(--kb-accent);
    font-weight: 700;
    min-width: 3rem;
}
.network-docs .network-toc {
    position: sticky;
    top: 80px;
    border-left: 1px solid var(--border);
    padding: 1.5rem 1.25rem 1.5rem 0.5rem;
}
.network-docs .toc-label {
    color: var(--mustard);
    font-family: var(--font-mono);
    font-size: 0.63rem;
    letter-spacing: 0.12em;
    margin-bottom: 0.75rem;
    text-transform: uppercase;
}
.network-docs .network-toc ul {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    list-style: none;
    margin: 0;
    padding: 0;
}
.network-docs .network-toc a {
    display: block;
    border-left: 2px solid transparent;
    color: #344054;
    font-size: 0.8rem;
    line-height: 1.4;
    padding: 0.2rem 0.5rem;
    text-decoration: none;
    transition: color var(--transition), border-color var(--transition);
}
.network-docs .network-toc a:hover,
.network-docs .network-toc a.active {
    border-left-color: var(--kb-accent);
    color: var(--kb-accent);
}
@media (max-width: 1100px) {
    .network-docs {
        grid-template-columns: 220px minmax(0, 1fr);
    }
    .network-docs .network-toc {
        display: none;
    }
}
@media (max-width: 740px) {
    .network-docs {
        grid-template-columns: 1fr;
    }
    .network-docs .network-sidenav {
        display: none;
    }
    .network-docs .network-main {
        padding: 2rem 1.25rem 3rem;
    }
}
/* Shared shell KB menu */
.kb-shell-layout {
    display: grid;
    grid-template-columns: 240px minmax(0, 1fr);
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 2rem 4rem;
    align-items: start;
}
.kb-shell-layout .kb-sidebar {
    position: sticky;
    top: 64px;
    display: block !important;
    float: none !important;
    width: 240px !important;
    max-width: 240px;
    height: calc(100vh - 64px);
    overflow-y: auto;
    border-right: 1px solid var(--border);
    padding: 1.5rem 0 3rem;
    scrollbar-width: thin;
    scrollbar-color: var(--border) transparent;
}
.kb-shell-layout .kb-sidebar::-webkit-scrollbar { width: 4px; }
.kb-shell-layout .kb-sidebar::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }
.kb-shell-layout .kb-sidebar > a[href^="#"] {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    border: 0;
    background: transparent !important;
    color: var(--waterfall) !important;
    cursor: pointer;
    font-family: var(--font-mono);
    font-size: 0.68rem;
    letter-spacing: 0.1em;
    padding: 0.5rem 1.25rem !important;
    text-align: left;
    text-transform: uppercase;
    transition: color var(--transition);
}
.kb-shell-layout .kb-sidebar > a[href^="#"]:hover { color: var(--text-muted) !important; }
.kb-shell-layout .kb-sidebar > a[href^="#"]::after { content: '\203A'; font-size: 0.7rem; transition: transform var(--transition); }
.kb-shell-layout .kb-sidebar > a[href^="#"].kb-active-section::after,
.kb-shell-layout .kb-sidebar > a[href^="#"].kb-open-section::after { transform: rotate(90deg); }
.kb-shell-layout .kb-sidebar > a[href^="#"] b { font-weight: 400; }
.kb-shell-layout .kb-sidebar .kb-submenu {
    display: none;
    margin: 0 0 0.25rem !important;
    padding: 0 0 0.375rem !important;
    border-left: 0 !important;
}
.kb-shell-layout .kb-sidebar .kb-submenu.kb-expanded { display: block; }
.kb-shell-layout .kb-sidebar .kb-submenu .tablink {
    display: block;
    width: 100% !important;
    margin-left: 0;
    border-left: 2px solid transparent;
    border-radius: 0;
    background: transparent !important;
    color: var(--text-dim) !important;
    font-size: 0.8125rem;
    line-height: 1.4;
    padding: 0.3rem 1.25rem 0.3rem 1.75rem !important;
    text-decoration: none;
    white-space: normal !important;
    transition: color var(--transition), background var(--transition);
}
.kb-shell-layout .kb-sidebar .kb-submenu .tablink:hover {
    color: var(--text-muted) !important;
    background: rgba(255,255,255,0.02) !important;
}
.kb-shell-layout .kb-sidebar .kb-submenu .kb-active-link {
    color: var(--waterfall) !important;
    border-left-color: var(--waterfall);
    background: rgba(104,130,158,0.05) !important;
    font-weight: 400;
}
.kb-shell-content {
    min-width: 0 !important;
    width: auto !important;
    overflow: visible !important;
    padding: 2.5rem 2.5rem 4rem;
}
.kb-shell-breadcrumb {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.5rem;
    color: var(--text-dim);
    font-family: var(--font-mono);
    font-size: 0.72rem;
    line-height: 1.5;
    margin-bottom: 1.25rem;
}
.kb-shell-breadcrumb a {
    color: var(--text-dim);
    text-decoration: none;
}
.kb-shell-breadcrumb a:hover {
    color: var(--text-muted);
}
.kb-shell-breadcrumb span:last-child {
    color: var(--text);
}
.kb-shell-content > .w3-container {
    max-width: none !important;
    padding: 0 !important;
}
.kb-shell-content > .w3-container > .w3-content {
    max-width: none !important;
}
.kb-shell-content .homelab-sidenav,
.kb-shell-content .smb-sidenav,
.kb-shell-content .network-sidenav,
.kb-shell-content .onvif-sidenav,
.kb-shell-content .capture-sidenav,
.kb-shell-content .motion-sidenav,
.kb-shell-content .docs-sidenav,
.kb-shell-content .article-sidebar,
.kb-shell-content .network-toc,
.kb-shell-content .docs-toc,
.kb-shell-content .capture-toc,
.kb-shell-content .kb-toc,
.kb-shell-content .breadcrumb,
.kb-shell-content .network-breadcrumb,
.kb-shell-content .capture-breadcrumb,
.kb-shell-content .kb-breadcrumb,
.kb-shell-content > .kb-layout > .kb-sidenav {
    display: none !important;
}
.kb-shell-content .homelab-docs,
.kb-shell-content .kb-docs,
.kb-shell-content .smb-docs,
.kb-shell-content .network-docs,
.kb-shell-content .onvif-docs,
.kb-shell-content .capture-onvif-docs,
.kb-shell-content .motion-onvif-docs,
.kb-shell-content .docs-layout {
    grid-template-columns: minmax(0, 1fr) !important;
    max-width: none !important;
    margin: 0 !important;
    min-height: 0 !important;
}
.kb-shell-content .homelab-docs .docs-main,
.kb-shell-content .kb-docs .docs-main,
.kb-shell-content .smb-docs .docs-main,
.kb-shell-content .network-docs .network-main,
.kb-shell-content .onvif-docs .docs-main,
.kb-shell-content .motion-onvif-docs .docs-main,
.kb-shell-content .capture-onvif-docs .capture-main,
.kb-shell-content .docs-layout .docs-main,
.kb-shell-content > .kb-layout > .kb-main {
    padding-top: 0 !important;
}

/* Banalytics Modules page */
.modules-docs .docs-lead {
    margin-bottom: 2rem !important;
}
.modules-docs .docs-lead + .docs-section {
    margin-top: 0 !important;
    padding-top: 0 !important;
}
.modules-docs .docs-section {
    margin-bottom: 2.5rem !important;
    padding: 0 !important;
}
.modules-docs .docs-section + .docs-section {
    margin-top: 0 !important;
    padding-top: 0 !important;
}
.modules-docs figure {
    margin: 1.25rem 0 0.75rem !important;
}
.modules-docs figcaption {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}
.modules-docs .modules-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 0.82fr);
    gap: 1.25rem;
    align-items: stretch;
    margin: 1.5rem 0 2.5rem;
}
.modules-docs .modules-hero-copy {
    border: 1px solid rgba(var(--kb-accent-rgb),0.16);
    border-radius: var(--radius-lg);
    background: rgba(var(--kb-accent-rgb),0.035);
    padding: 1.25rem 1.375rem;
}
.modules-docs .modules-hero-copy h2 {
    margin: 0 0 0.875rem;
    color: var(--mustard);
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 700;
    line-height: 1.25;
}
.modules-docs .modules-hero-copy h2 em {
    color: var(--kb-accent);
    font-style: normal;
}
.modules-docs .modules-video {
    position: relative;
    min-height: 260px;
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background: var(--shadow);
}
.modules-docs .modules-video iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
}
.modules-docs .module-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1rem;
    margin: 1.25rem 0;
}
.modules-docs .module-card {
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background: var(--bg-card);
    box-shadow: 0 18px 45px rgba(33,31,48,0.05);
}
.modules-docs .module-card-header {
    border-bottom: 1px solid var(--border);
    padding: 1rem 1.125rem;
}
.modules-docs .module-kicker {
    display: inline-flex;
    margin-bottom: 0.55rem;
    border: 1px solid rgba(33,124,163,0.22);
    border-radius: 100px;
    background: rgba(33,124,163,0.08);
    color: var(--cerulean);
    font-family: var(--font-mono);
    font-size: 0.64rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    padding: 0.16rem 0.55rem;
}
.modules-docs .module-card h3 {
    margin: 0 0 0.4rem;
    color: var(--text);
    font-family: var(--font-display);
    font-size: 1rem;
    line-height: 1.25;
}
.modules-docs .module-card p {
    margin: 0;
    color: var(--text-muted);
    font-size: 0.84rem;
    line-height: 1.55;
}
.modules-docs .module-body {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding: 1rem 1.125rem 1.125rem;
}
.modules-docs .module-group-title {
    margin-bottom: 0.5rem;
    color: var(--mustard);
    font-family: var(--font-mono);
    font-size: 0.66rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}
.modules-docs .module-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}
.modules-docs .module-links a,
.modules-docs .module-links span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    border: 1px solid rgba(104,130,158,0.2);
    border-radius: 6px;
    background: rgba(255,255,255,0.68);
    color: var(--text-muted);
    font-size: 0.78rem;
    line-height: 1.35;
    padding: 0.28rem 0.55rem;
    text-decoration: none;
}
.modules-docs .module-links a {
    color: var(--cerulean);
}
.modules-docs .module-links a:hover {
    border-color: rgba(33,124,163,0.34);
    color: var(--cerulean);
    background: rgba(33,124,163,0.06);
}
.modules-docs .module-links span {
    opacity: 0.68;
}
.modules-docs .version-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 0.875rem;
    margin: 1.25rem 0;
}
.modules-docs .version-card {
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background: var(--bg-card);
    padding: 1rem 1.125rem;
}
.modules-docs .version-card span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    margin-bottom: 0.75rem;
    border: 1px solid rgba(var(--kb-accent-rgb),0.22);
    border-radius: 8px;
    background: rgba(var(--kb-accent-rgb),0.08);
    color: var(--kb-accent);
    font-family: var(--font-mono);
    font-weight: 800;
}
.modules-docs .version-card h3 {
    margin: 0 0 0.35rem;
    font-family: var(--font-display);
    font-size: 0.95rem;
}
.modules-docs .version-card p {
    margin: 0;
    color: var(--text-muted);
    font-size: 0.83rem;
    line-height: 1.55;
}
@media (max-width: 900px) {
    .modules-docs .modules-hero {
        grid-template-columns: minmax(0, 1fr);
    }
    .modules-docs .modules-video {
        min-height: auto;
        aspect-ratio: 16 / 9;
    }
}
.kb-shell-content .article-layout {
    padding: 0 !important;
}
.kb-shell-content .article-shell-grid {
    display: block !important;
    max-width: none !important;
}
.kb-shell-content .article-content {
    width: 100% !important;
    min-width: 0 !important;
}

.kb-docs .param-table-wrap {
    overflow-x: auto;
    margin: 1.25rem 0;
    border: 1px solid rgba(33,31,48,0.12);
    border-radius: var(--radius-lg);
    background: #fff;
    box-shadow: 0 12px 32px rgba(33,31,48,0.07);
}
.kb-docs .param-table {
    width: 100%;
    overflow: hidden;
    border-collapse: separate;
    border-spacing: 0;
    font-size: 0.8375rem;
}
.kb-docs .param-table th {
    padding: 0.95rem 1rem;
    border-bottom: 1px solid rgba(33,31,48,0.12);
    background: rgba(var(--kb-accent-rgb),0.08);
    color: var(--mustard);
    font-family: var(--font-display);
    font-size: 0.82rem;
    font-weight: 700;
    text-align: left;
    white-space: nowrap;
    line-height: 1.5;
}
.kb-docs .param-table td {
    padding: 0.95rem 1rem;
    border-bottom: 1px solid rgba(33,31,48,0.12);
    color: var(--thunder);
    text-align: left;
    vertical-align: top;
    line-height: 1.5;
}
.kb-docs .param-table tr:nth-child(even) {
    background: rgba(var(--kb-accent-rgb),0.035);
}
.kb-docs .param-table tr:last-child td {
    border-bottom: 0;
}
.kb-docs .param-table tr:hover td {
    background: rgba(var(--kb-accent-rgb),0.055);
}
.kb-docs .param-name {
    color: var(--kb-accent);
    font-family: var(--font-mono);
    font-size: 0.8rem;
    font-weight: 700;
    white-space: nowrap;
}
.kb-docs .req-badge {
    display: inline-block;
    border-radius: 3px;
    font-family: var(--font-mono);
    font-size: 0.62rem;
    padding: 0.1rem 0.45rem;
}
.kb-docs .req-badge.yes {
    border: 1px solid rgba(174,189,56,0.2);
    background: rgba(174,189,56,0.12);
    color: var(--moss);
}
.kb-docs .req-badge.no {
    border: 1px solid var(--border);
    background: rgba(255,255,255,0.05);
    color: var(--text-dim);
}
.kb-docs .param-desc {
    color: var(--thunder);
    font-size: 0.8375rem;
}
.kb-docs .param-desc ul {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    margin: 0.4rem 0 0;
    padding: 0;
    list-style: none;
}
.kb-docs .param-desc li {
    display: flex;
    gap: 0.5rem;
    color: var(--thunder);
    font-size: 0.8125rem;
}
.kb-docs .param-desc li::before {
    content: "-";
    flex-shrink: 0;
    color: var(--waterfall);
}
.kb-docs .param-default {
    color: var(--thunder);
    font-family: var(--font-mono);
    font-size: 0.775rem;
    white-space: nowrap;
}
@media (max-width: 1100px) {
    .kb-shell-layout { grid-template-columns: 220px minmax(0, 1fr); padding: 0 1.25rem 3rem; }
    .kb-shell-layout .kb-sidebar { width: 220px !important; max-width: 220px; }
    .kb-shell-content .homelab-docs,
    .kb-shell-content .smb-docs,
    .kb-shell-content .network-docs,
    .kb-shell-content .docs-layout { grid-template-columns: minmax(0, 1fr) !important; }
}
@media (max-width: 740px) {
    .kb-shell-layout { grid-template-columns: minmax(0, 1fr); padding: 0; }
    .kb-shell-layout .kb-sidebar { display: none; }
    .kb-shell-content { padding: 2rem 1.25rem 3rem; }
}
