/* /Components/Layout/MainLayout.razor.rz.scp.css */
:host[b-fnszu11yml] {
    display: block;
}

/* ── App Bar ─────────────────────────────────────────────── */

[b-fnszu11yml] .mud-appbar {
    height: 64px;
    border-bottom: 1px solid var(--mud-palette-lines-default);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

[b-fnszu11yml] .admin-appbar {
    background: color-mix(in oklab, var(--mud-palette-appbar-background) 85%, transparent) !important;
}

[b-fnszu11yml] .admin-appbar-actions {
    display: flex;
    align-items: center;
}

[b-fnszu11yml] .admin-env-chip {
    font-weight: 600;
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    height: 28px;
    background: color-mix(in oklab, var(--mud-palette-text-secondary) 18%, transparent) !important;
    color: var(--mud-palette-text-secondary) !important;
}

[b-fnszu11yml] .admin-env-chip--production {
    background: color-mix(in oklab, var(--mud-palette-success) 20%, transparent) !important;
    color: var(--mud-palette-success) !important;
}

[b-fnszu11yml] .admin-env-chip--staging {
    background: color-mix(in oklab, var(--mud-palette-info) 22%, transparent) !important;
    color: var(--mud-palette-info) !important;
}

[b-fnszu11yml] .admin-env-chip--development {
    background: color-mix(in oklab, var(--mud-palette-warning) 22%, transparent) !important;
    color: var(--mud-palette-warning) !important;
}

/* ── Drawer ──────────────────────────────────────────────── */

[b-fnszu11yml] .mud-drawer {
    border-right: 1px solid color-mix(in oklab, var(--mud-palette-lines-default) 40%, transparent);
}

[b-fnszu11yml] .mud-drawer-content {
    display: flex;
    flex-direction: column;
    height: 100%;
}

/* ── Drawer Header / Brand ───────────────────────────────── */

[b-fnszu11yml] .admin-drawer-header {
    min-height: 64px;
    padding: 16px 24px;
    border-bottom: 1px solid color-mix(in oklab, var(--mud-palette-lines-default) 40%, transparent);
    display: flex;
    align-items: center;
}

[b-fnszu11yml] .admin-brand {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    gap: 12px;
    width: 100%;
}

[b-fnszu11yml] .admin-brand-mark {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 10px;
    background: color-mix(in oklab, var(--mud-palette-primary) 12%, transparent);
    flex-shrink: 0;
}

[b-fnszu11yml] .admin-brand-mark::after {
    content: '';
    position: absolute;
    inset: -4px;
    border-radius: 14px;
    background: radial-gradient(circle, color-mix(in oklab, var(--mud-palette-primary) 15%, transparent) 0%, transparent 70%);
    pointer-events: none;
    z-index: 0;
}

[b-fnszu11yml] .admin-brand-icon {
    font-size: 22px !important;
    color: var(--mud-palette-primary) !important;
    position: relative;
    z-index: 1;
}

[b-fnszu11yml] .admin-brand-name {
    font-family: 'Manrope', var(--mud-typography-default-family);
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--mud-palette-text-primary);
    line-height: 1;
}

/* ── Drawer Footer ───────────────────────────────────────── */

[b-fnszu11yml] .admin-drawer-footer {
    padding: 12px 16px;
    border-top: 1px solid color-mix(in oklab, var(--mud-palette-lines-default) 40%, transparent);
    display: flex;
    flex-direction: column;
    gap: 6px;
}

[b-fnszu11yml] .admin-user-profile {
    border-radius: 10px !important;
    text-transform: none !important;
    font-weight: 500 !important;
    letter-spacing: 0 !important;
    transition: background-color 0.2s ease !important;
}

[b-fnszu11yml] .admin-user-profile:hover {
    background-color: color-mix(in oklab, var(--mud-palette-primary) 8%, transparent) !important;
}

[b-fnszu11yml] .admin-user-name {
    font-size: 0.85rem;
    color: var(--mud-palette-text-primary);
}

[b-fnszu11yml] .admin-user-caption {
    font-size: 0.72rem;
    color: var(--mud-palette-text-secondary);
}

[b-fnszu11yml] .admin-theme-section {
    display: flex;
    justify-content: flex-start;
    padding: 0 8px;
}

[b-fnszu11yml] .admin-theme-toggle {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    transition: background-color 0.15s ease;
}

[b-fnszu11yml] .admin-theme-toggle:hover {
    background: color-mix(in oklab, var(--mud-palette-primary) 10%, transparent);
}

/* ── Responsive ──────────────────────────────────────────── */

@media (max-width: 600px) {
    [b-fnszu11yml] .admin-env-chip {
        display: none;
    }
}
/* /Components/Layout/NavMenu.razor.rz.scp.css */
:host[b-w7x6jp4gc4] {
    display: block;
}

/* ── Nav Menu Container ─────────────────────────────────── */

[b-w7x6jp4gc4] .mud-navmenu {
    padding: 12px 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

/* ── Section Color Accent Variables ──────────────────────── */

.nav-group--dailyops[b-w7x6jp4gc4] { --nav-accent: #FFB960; }
.nav-group--content[b-w7x6jp4gc4]  { --nav-accent: #6E8BFF; }
.nav-group--liveops[b-w7x6jp4gc4]  { --nav-accent: #4CAF50; }
.nav-group--players[b-w7x6jp4gc4]  { --nav-accent: #B39DDB; }
.nav-group--system[b-w7x6jp4gc4]   { --nav-accent: #8e909f; }

/* ── Nav Group (collapsible section) ─────────────────────── */

.nav-group[b-w7x6jp4gc4] {
    display: flex;
    flex-direction: column;
}

/* ── Group Header Button ─────────────────────────────────── */

.nav-group-header[b-w7x6jp4gc4] {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 8px 16px 8px 18px;
    margin: 0 16px;
    width: calc(100% - 32px);
    border: none;
    border-radius: 10px;
    background: transparent;
    color: var(--mud-palette-text-secondary);
    cursor: pointer;
    transition: background-color 0.15s ease, color 0.15s ease;
    user-select: none;
    -webkit-user-select: none;
}

.nav-group-header:hover[b-w7x6jp4gc4] {
    background: color-mix(in oklab, var(--nav-accent) 6%, transparent);
    color: var(--mud-palette-text-primary);
}

/* ── Accent Bar (vertical stripe) ────────────────────────── */

.nav-group-accent[b-w7x6jp4gc4] {
    width: 3px;
    /* Reserve the maximum height (was animating 16px→20px on hover, which
       grew the row's intrinsic height and pushed sibling nav buttons by 2px).
       Hover now only animates opacity + transform, neither of which triggers
       layout reflow. */
    height: 20px;
    border-radius: 2px;
    background: var(--nav-accent);
    opacity: 0.5;
    flex-shrink: 0;
    transform: scaleY(0.8);
    transform-origin: center;
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.nav-group-header:hover .nav-group-accent[b-w7x6jp4gc4] {
    opacity: 1;
    transform: scaleY(1);
}

/* ── Section dot (small color marker before label) ──────── */

.nav-group-dot[b-w7x6jp4gc4] {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--nav-accent);
    opacity: 0.85;
    flex-shrink: 0;
    box-shadow: 0 0 0 2px color-mix(in oklab, var(--nav-accent) 25%, transparent);
}

/* ── Group Label (heavier than before for primary structure read) ── */

.nav-group-label[b-w7x6jp4gc4] {
    flex: 1;
    text-align: left;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    line-height: 1;
    color: var(--mud-palette-text-primary);
    opacity: 0.78;
}

.nav-group-header:hover .nav-group-label[b-w7x6jp4gc4] {
    opacity: 1;
}

/* ── Chevron ─────────────────────────────────────────────── */

[b-w7x6jp4gc4] .nav-group-chevron {
    opacity: 0.4;
    transition: opacity 0.15s ease, transform 0.2s ease;
    font-size: 18px !important;
}

.nav-group-header:hover[b-w7x6jp4gc4]  .nav-group-chevron {
    opacity: 0.8;
}

/* ── Group Children Container ────────────────────────────── */

.nav-group-children[b-w7x6jp4gc4] {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding-top: 4px;
    animation: nav-group-expand-b-w7x6jp4gc4 0.2s ease-out;
}

@keyframes nav-group-expand-b-w7x6jp4gc4 {
    from {
        opacity: 0;
        transform: translateY(-6px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ── Individual Nav Links ────────────────────────────────── */

[b-w7x6jp4gc4] .nav-link {
    margin: 0;
    padding: 0;
}

[b-w7x6jp4gc4] .nav-link .mud-nav-link {
    min-height: 44px;
    margin: 1px 16px !important;
    padding: 8px 16px !important;
    border-radius: 10px;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    background-color: transparent !important;
}

[b-w7x6jp4gc4] .nav-link--home .mud-nav-link {
    margin: 1px 16px 4px !important;
}

/* ── Hover ───────────────────────────────────────────────── */

[b-w7x6jp4gc4] .nav-link .mud-nav-link:hover {
    background-color: color-mix(in oklab, var(--mud-palette-primary) 8%, transparent) !important;
}

[b-w7x6jp4gc4] .nav-group--dailyops .nav-link .mud-nav-link:hover {
    background-color: color-mix(in oklab, #FFB960 8%, transparent) !important;
}

[b-w7x6jp4gc4] .nav-group--content .nav-link .mud-nav-link:hover {
    background-color: color-mix(in oklab, #6E8BFF 8%, transparent) !important;
}

[b-w7x6jp4gc4] .nav-group--liveops .nav-link .mud-nav-link:hover {
    background-color: color-mix(in oklab, #4CAF50 8%, transparent) !important;
}

[b-w7x6jp4gc4] .nav-group--players .nav-link .mud-nav-link:hover {
    background-color: color-mix(in oklab, #B39DDB 8%, transparent) !important;
}

[b-w7x6jp4gc4] .nav-group--system .nav-link .mud-nav-link:hover {
    background-color: color-mix(in oklab, #8e909f 8%, transparent) !important;
}

/* ── Active State (route exactly matches link href) ──────── */

[b-w7x6jp4gc4] .nav-link .mud-nav-link.active,
[b-w7x6jp4gc4] .nav-link .mud-nav-link[data-aggregate-active="true"] {
    background-color: color-mix(in oklab, var(--mud-palette-primary) 12%, transparent) !important;
    box-shadow: inset 3px 0 0 0 var(--mud-palette-primary);
}

[b-w7x6jp4gc4] .nav-group--dailyops .nav-link .mud-nav-link.active,
[b-w7x6jp4gc4] .nav-group--dailyops .nav-link .mud-nav-link[data-aggregate-active="true"] {
    background-color: color-mix(in oklab, #FFB960 12%, transparent) !important;
    box-shadow: inset 3px 0 0 0 #FFB960;
}

[b-w7x6jp4gc4] .nav-group--content .nav-link .mud-nav-link.active,
[b-w7x6jp4gc4] .nav-group--content .nav-link .mud-nav-link[data-aggregate-active="true"] {
    background-color: color-mix(in oklab, #6E8BFF 12%, transparent) !important;
    box-shadow: inset 3px 0 0 0 #6E8BFF;
}

[b-w7x6jp4gc4] .nav-group--liveops .nav-link .mud-nav-link.active,
[b-w7x6jp4gc4] .nav-group--liveops .nav-link .mud-nav-link[data-aggregate-active="true"] {
    background-color: color-mix(in oklab, #4CAF50 12%, transparent) !important;
    box-shadow: inset 3px 0 0 0 #4CAF50;
}

[b-w7x6jp4gc4] .nav-group--players .nav-link .mud-nav-link.active,
[b-w7x6jp4gc4] .nav-group--players .nav-link .mud-nav-link[data-aggregate-active="true"] {
    background-color: color-mix(in oklab, #B39DDB 12%, transparent) !important;
    box-shadow: inset 3px 0 0 0 #B39DDB;
}

[b-w7x6jp4gc4] .nav-group--system .nav-link .mud-nav-link.active,
[b-w7x6jp4gc4] .nav-group--system .nav-link .mud-nav-link[data-aggregate-active="true"] {
    background-color: color-mix(in oklab, #8e909f 12%, transparent) !important;
    box-shadow: inset 3px 0 0 0 #8e909f;
}

/* ── Icon Styling ────────────────────────────────────────── */

[b-w7x6jp4gc4] .nav-link .mud-nav-link-icon {
    min-width: 22px;
    width: 22px;
    height: 22px;
    font-size: 20px;
    margin-right: 12px;
    color: var(--mud-palette-text-secondary) !important;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

[b-w7x6jp4gc4] .nav-link .mud-nav-link:hover .mud-nav-link-icon {
    color: var(--mud-palette-text-primary) !important;
    transform: scale(1.08);
}

[b-w7x6jp4gc4] .nav-link .mud-nav-link.active .mud-nav-link-icon,
[b-w7x6jp4gc4] .nav-link .mud-nav-link[data-aggregate-active="true"] .mud-nav-link-icon {
    color: var(--mud-palette-primary) !important;
}

[b-w7x6jp4gc4] .nav-group--dailyops .nav-link .mud-nav-link.active .mud-nav-link-icon,
[b-w7x6jp4gc4] .nav-group--dailyops .nav-link .mud-nav-link[data-aggregate-active="true"] .mud-nav-link-icon {
    color: #FFB960 !important;
}

[b-w7x6jp4gc4] .nav-group--content .nav-link .mud-nav-link.active .mud-nav-link-icon,
[b-w7x6jp4gc4] .nav-group--content .nav-link .mud-nav-link[data-aggregate-active="true"] .mud-nav-link-icon {
    color: #6E8BFF !important;
}

[b-w7x6jp4gc4] .nav-group--liveops .nav-link .mud-nav-link.active .mud-nav-link-icon,
[b-w7x6jp4gc4] .nav-group--liveops .nav-link .mud-nav-link[data-aggregate-active="true"] .mud-nav-link-icon {
    color: #4CAF50 !important;
}

[b-w7x6jp4gc4] .nav-group--players .nav-link .mud-nav-link.active .mud-nav-link-icon,
[b-w7x6jp4gc4] .nav-group--players .nav-link .mud-nav-link[data-aggregate-active="true"] .mud-nav-link-icon {
    color: #B39DDB !important;
}

[b-w7x6jp4gc4] .nav-group--system .nav-link .mud-nav-link.active .mud-nav-link-icon,
[b-w7x6jp4gc4] .nav-group--system .nav-link .mud-nav-link[data-aggregate-active="true"] .mud-nav-link-icon {
    color: #8e909f !important;
}

/* ── Content Layout ──────────────────────────────────────── */

[b-w7x6jp4gc4] .nav-link-content {
    display: flex;
    flex-direction: column;
    gap: 2px;
    justify-content: center;
}

/* ── Title ───────────────────────────────────────────────── */

[b-w7x6jp4gc4] .nav-link-title {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--mud-palette-text-secondary);
    transition: color 0.2s ease;
    line-height: 1.2;
}

[b-w7x6jp4gc4] .nav-link .mud-nav-link:hover .nav-link-title {
    color: var(--mud-palette-text-primary);
}

[b-w7x6jp4gc4] .nav-link .mud-nav-link.active .nav-link-title,
[b-w7x6jp4gc4] .nav-link .mud-nav-link[data-aggregate-active="true"] .nav-link-title {
    color: var(--mud-palette-text-primary);
    font-weight: 600;
}

/* ── Subtitle ────────────────────────────────────────────── */

[b-w7x6jp4gc4] .nav-link-subtitle {
    font-size: 0.65rem;
    font-weight: 400;
    color: var(--mud-palette-text-disabled);
    transition: color 0.2s ease;
    line-height: 1.1;
    letter-spacing: 0.02em;
}

[b-w7x6jp4gc4] .nav-link .mud-nav-link:hover .nav-link-subtitle {
    color: var(--mud-palette-text-secondary);
}

[b-w7x6jp4gc4] .nav-link .mud-nav-link.active .nav-link-subtitle,
[b-w7x6jp4gc4] .nav-link .mud-nav-link[data-aggregate-active="true"] .nav-link-subtitle {
    color: var(--mud-palette-text-secondary);
}
/* /Components/Layout/ReconnectModal.razor.rz.scp.css */
.components-reconnect-first-attempt-visible[b-p6vgaxprdr],
.components-reconnect-repeated-attempt-visible[b-p6vgaxprdr],
.components-reconnect-failed-visible[b-p6vgaxprdr],
.components-pause-visible[b-p6vgaxprdr],
.components-resume-failed-visible[b-p6vgaxprdr],
.components-rejoining-animation[b-p6vgaxprdr] {
    display: none;
}

#components-reconnect-modal.components-reconnect-show .components-reconnect-first-attempt-visible[b-p6vgaxprdr],
#components-reconnect-modal.components-reconnect-show .components-rejoining-animation[b-p6vgaxprdr],
#components-reconnect-modal.components-reconnect-paused .components-pause-visible[b-p6vgaxprdr],
#components-reconnect-modal.components-reconnect-resume-failed .components-resume-failed-visible[b-p6vgaxprdr],
#components-reconnect-modal.components-reconnect-retrying[b-p6vgaxprdr],
#components-reconnect-modal.components-reconnect-retrying .components-reconnect-repeated-attempt-visible[b-p6vgaxprdr],
#components-reconnect-modal.components-reconnect-retrying .components-rejoining-animation[b-p6vgaxprdr],
#components-reconnect-modal.components-reconnect-failed[b-p6vgaxprdr],
#components-reconnect-modal.components-reconnect-failed .components-reconnect-failed-visible[b-p6vgaxprdr] {
    display: block;
}


#components-reconnect-modal[b-p6vgaxprdr] {
    background-color: white;
    width: 20rem;
    margin: 20vh auto;
    padding: 2rem;
    border: 0;
    border-radius: 0.5rem;
    box-shadow: 0 3px 6px 2px rgba(0, 0, 0, 0.3);
    opacity: 0;
    transition: display 0.5s allow-discrete, overlay 0.5s allow-discrete;
    animation: components-reconnect-modal-fadeOutOpacity-b-p6vgaxprdr 0.5s both;
    &[open]

{
    animation: components-reconnect-modal-slideUp-b-p6vgaxprdr 1.5s cubic-bezier(.05, .89, .25, 1.02) 0.3s, components-reconnect-modal-fadeInOpacity-b-p6vgaxprdr 0.5s ease-in-out 0.3s;
    animation-fill-mode: both;
}

}

#components-reconnect-modal[b-p6vgaxprdr]::backdrop {
    background-color: rgba(0, 0, 0, 0.4);
    animation: components-reconnect-modal-fadeInOpacity-b-p6vgaxprdr 0.5s ease-in-out;
    opacity: 1;
}

@keyframes components-reconnect-modal-slideUp-b-p6vgaxprdr {
    0% {
        transform: translateY(30px) scale(0.95);
    }

    100% {
        transform: translateY(0);
    }
}

@keyframes components-reconnect-modal-fadeInOpacity-b-p6vgaxprdr {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

@keyframes components-reconnect-modal-fadeOutOpacity-b-p6vgaxprdr {
    0% {
        opacity: 1;
    }

    100% {
        opacity: 0;
    }
}

.components-reconnect-container[b-p6vgaxprdr] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

#components-reconnect-modal p[b-p6vgaxprdr] {
    margin: 0;
    text-align: center;
}

#components-reconnect-modal button[b-p6vgaxprdr] {
    border: 0;
    background-color: #6b9ed2;
    color: white;
    padding: 4px 24px;
    border-radius: 4px;
}

    #components-reconnect-modal button:hover[b-p6vgaxprdr] {
        background-color: #3b6ea2;
    }

    #components-reconnect-modal button:active[b-p6vgaxprdr] {
        background-color: #6b9ed2;
    }

.components-rejoining-animation[b-p6vgaxprdr] {
    position: relative;
    width: 80px;
    height: 80px;
}

    .components-rejoining-animation div[b-p6vgaxprdr] {
        position: absolute;
        border: 3px solid #0087ff;
        opacity: 1;
        border-radius: 50%;
        animation: components-rejoining-animation-b-p6vgaxprdr 1.5s cubic-bezier(0, 0.2, 0.8, 1) infinite;
    }

        .components-rejoining-animation div:nth-child(2)[b-p6vgaxprdr] {
            animation-delay: -0.5s;
        }

@keyframes components-rejoining-animation-b-p6vgaxprdr {
    0% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 0;
    }

    4.9% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 0;
    }

    5% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 1;
    }

    100% {
        top: 0px;
        left: 0px;
        width: 80px;
        height: 80px;
        opacity: 0;
    }
}
/* /Components/Pages/Infrastructure.razor.rz.scp.css */
/* ── Constellation Graph Container ── */
.infra-graph-container[b-1q93fuuk7i] {
    padding: 0;
    margin-bottom: 24px;
    overflow: hidden;
}

.infra-graph-header[b-1q93fuuk7i] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 24px;
    border-bottom: 1px solid color-mix(in oklab, var(--mud-palette-lines-default) 60%, transparent);
}

.infra-graph-title[b-1q93fuuk7i] {
    font-weight: 600;
    letter-spacing: -0.01em;
}

.infra-svg-wrap[b-1q93fuuk7i] {
    position: relative;
    padding: 16px;
    background: radial-gradient(ellipse at 50% 40%, color-mix(in oklab, var(--mud-palette-primary) 6%, transparent) 0%, transparent 70%);
    overflow: hidden;
}

[b-1q93fuuk7i] .infra-svg {
    width: 100%;
    height: 420px;
    cursor: grab;
    display: block;
    touch-action: none;
    user-select: none;
}

[b-1q93fuuk7i] .infra-svg:active {
    cursor: grabbing;
}

/* ── Zoom Controls ── */
.infra-zoom-controls[b-1q93fuuk7i] {
    position: absolute;
    top: 12px;
    right: 12px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    z-index: 2;
}

[b-1q93fuuk7i] .infra-zoom-btn {
    background: color-mix(in oklab, var(--mud-palette-surface) 85%, var(--mud-palette-lines-default)) !important;
    border: 1px solid color-mix(in oklab, var(--mud-palette-lines-default) 60%, transparent) !important;
    border-radius: var(--admin-radius-sm, 8px) !important;
    width: 32px !important;
    height: 32px !important;
    backdrop-filter: blur(8px);
    transition: background 0.15s ease, border-color 0.15s ease;
}

[b-1q93fuuk7i] .infra-zoom-btn:hover {
    background: color-mix(in oklab, var(--mud-palette-surface) 95%, var(--mud-palette-primary)) !important;
    border-color: color-mix(in oklab, var(--mud-palette-primary) 40%, transparent) !important;
}

/* ── Connection Lines ── */
[b-1q93fuuk7i] .infra-connection {
    stroke: color-mix(in oklab, var(--mud-palette-text-secondary) 25%, transparent);
    stroke-width: 1.5;
    stroke-linecap: round;
    transition: stroke 0.3s ease;
}

[b-1q93fuuk7i] .infra-connection--active {
    stroke: color-mix(in oklab, var(--mud-palette-primary) 40%, transparent);
    stroke-width: 1.5;
    stroke-dasharray: 6 4;
    animation: flow-dash-b-1q93fuuk7i 1.2s linear infinite;
}

@keyframes flow-dash-b-1q93fuuk7i {
    to { stroke-dashoffset: -20; }
}

/* ── Nodes ── */
[b-1q93fuuk7i] .infra-node {
    transition: transform 0.3s ease;
}

[b-1q93fuuk7i] .infra-node-ring {
    fill: none;
    stroke-width: 2;
    transition: all 0.3s ease;
}

[b-1q93fuuk7i] .infra-node-core {
    transition: all 0.3s ease;
}

[b-1q93fuuk7i] .infra-node-label {
    fill: var(--mud-palette-text-secondary);
    font-size: 11px;
    font-weight: 500;
    text-anchor: middle;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    user-select: none;
}

[b-1q93fuuk7i] .infra-node-badge {
    fill: var(--mud-palette-text-primary);
    font-size: 13px;
    font-weight: 700;
    text-anchor: middle;
    user-select: none;
}

/* Healthy */
[b-1q93fuuk7i] .infra-node--healthy .infra-node-ring {
    stroke: color-mix(in oklab, var(--mud-palette-primary) 70%, transparent);
    animation: node-pulse-b-1q93fuuk7i 3s ease-in-out infinite;
}

[b-1q93fuuk7i] .infra-node--healthy .infra-node-core {
    fill: color-mix(in oklab, var(--mud-palette-primary) 15%, var(--mud-palette-surface));
}

@keyframes node-pulse-b-1q93fuuk7i {
    0%, 100% { opacity: 0.7; }
    50% { opacity: 1; }
}

/* Warning */
[b-1q93fuuk7i] .infra-node--warning .infra-node-ring {
    stroke: color-mix(in oklab, var(--mud-palette-warning) 80%, transparent);
    animation: node-pulse-warn-b-1q93fuuk7i 2s ease-in-out infinite;
}

[b-1q93fuuk7i] .infra-node--warning .infra-node-core {
    fill: color-mix(in oklab, var(--mud-palette-warning) 12%, var(--mud-palette-surface));
}

@keyframes node-pulse-warn-b-1q93fuuk7i {
    0%, 100% { opacity: 0.6; }
    50% { opacity: 1; }
}

/* Error */
[b-1q93fuuk7i] .infra-node--error .infra-node-ring {
    stroke: color-mix(in oklab, var(--mud-palette-error) 80%, transparent);
    animation: node-pulse-err-b-1q93fuuk7i 1.5s ease-in-out infinite;
}

[b-1q93fuuk7i] .infra-node--error .infra-node-core {
    fill: color-mix(in oklab, var(--mud-palette-error) 12%, var(--mud-palette-surface));
}

@keyframes node-pulse-err-b-1q93fuuk7i {
    0%, 100% { opacity: 0.5; }
    50% { opacity: 1; }
}

/* Stopped */
[b-1q93fuuk7i] .infra-node--stopped .infra-node-ring {
    stroke: color-mix(in oklab, var(--mud-palette-text-secondary) 30%, transparent);
}

[b-1q93fuuk7i] .infra-node--stopped .infra-node-core {
    fill: color-mix(in oklab, var(--mud-palette-text-secondary) 8%, var(--mud-palette-surface));
}

/* Selected */
[b-1q93fuuk7i] .infra-node--selected .infra-node-ring {
    stroke-width: 3;
    opacity: 1 !important;
}

[b-1q93fuuk7i] .infra-node--selected .infra-node-label {
    fill: var(--mud-palette-text-primary);
    font-weight: 700;
}

/* Hover */
[b-1q93fuuk7i] .infra-node:hover .infra-node-ring {
    stroke-width: 3;
}

[b-1q93fuuk7i] .infra-node:hover .infra-node-label {
    fill: var(--mud-palette-text-primary);
}

/* ── Detail Panel ── */
.infra-detail-panel[b-1q93fuuk7i] {
    margin-top: 24px;
    margin-bottom: 24px;
    overflow: hidden;
}

.infra-detail-header[b-1q93fuuk7i] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 20px;
    border-bottom: 1px solid color-mix(in oklab, var(--mud-palette-lines-default) 60%, transparent);
}

.infra-detail-section[b-1q93fuuk7i] {
    margin-bottom: 14px;
}

.infra-detail-label[b-1q93fuuk7i] {
    display: block;
    font-size: 0.75rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--mud-palette-text-secondary);
    margin-bottom: 4px;
}

.infra-detail-value[b-1q93fuuk7i] {
    display: block;
    font-size: 0.9rem;
    color: var(--mud-palette-text-primary);
    line-height: 1.4;
}

/* ── Scale Events Timeline ── */
.infra-timeline-container[b-1q93fuuk7i] {
    margin-top: 24px;
    margin-bottom: 24px;
    overflow: hidden;
}

.infra-timeline-header[b-1q93fuuk7i] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 24px;
    border-bottom: 1px solid color-mix(in oklab, var(--mud-palette-lines-default) 60%, transparent);
}

.infra-timeline-body[b-1q93fuuk7i] {
    max-height: 320px;
    overflow-y: auto;
    padding: 8px 0;
}

.infra-timeline-empty[b-1q93fuuk7i] {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 48px 24px;
}

.infra-event[b-1q93fuuk7i] {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 24px;
    transition: background 0.15s ease;
    animation: event-slide-in-b-1q93fuuk7i 0.3s ease-out;
}

.infra-event:hover[b-1q93fuuk7i] {
    background: color-mix(in oklab, var(--mud-palette-surface) 60%, var(--mud-palette-lines-default));
}

@keyframes event-slide-in-b-1q93fuuk7i {
    from {
        opacity: 0;
        transform: translateY(-8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.infra-event-time[b-1q93fuuk7i] {
    font-family: monospace;
    font-size: 0.8rem;
    color: var(--mud-palette-text-secondary);
    min-width: 70px;
}

.infra-event-text[b-1q93fuuk7i] {
    font-size: 0.875rem;
    color: var(--mud-palette-text-primary);
}

.infra-event-id[b-1q93fuuk7i] {
    font-family: monospace;
    font-size: 0.8rem;
    color: var(--mud-palette-primary);
    font-weight: 600;
}

/* Event type accent borders */
.infra-event--replica_joined[b-1q93fuuk7i] {
    border-left: 3px solid var(--mud-palette-success);
}

.infra-event--replica_left[b-1q93fuuk7i] {
    border-left: 3px solid var(--mud-palette-warning);
}

.infra-event--replica_expired[b-1q93fuuk7i] {
    border-left: 3px solid var(--mud-palette-error);
}

/* ── Timeline scrollbar ── */
.infra-timeline-body[b-1q93fuuk7i]::-webkit-scrollbar {
    width: 6px;
}

.infra-timeline-body[b-1q93fuuk7i]::-webkit-scrollbar-track {
    background: transparent;
}

.infra-timeline-body[b-1q93fuuk7i]::-webkit-scrollbar-thumb {
    background: color-mix(in oklab, var(--mud-palette-text-secondary) 30%, transparent);
    border-radius: 3px;
}

.infra-timeline-body[b-1q93fuuk7i]::-webkit-scrollbar-thumb:hover {
    background: color-mix(in oklab, var(--mud-palette-text-secondary) 50%, transparent);
}
