/* /Components/Atoms/HttpStatusBadge.razor.rz.scp.css */
.http-status-badge[b-3294jj0lks] {
    font-weight: 700;
    font-family: monospace;
    font-size: 0.85rem;
}

.http-status-badge--success[b-3294jj0lks]      { color: #276749; }
.http-status-badge--redirect[b-3294jj0lks]     { color: #744210; }
.http-status-badge--client-error[b-3294jj0lks] { color: #c53030; }
.http-status-badge--server-error[b-3294jj0lks] { color: #742a2a; }
.http-status-badge--unknown[b-3294jj0lks]      { color: #718096; }
/* /Components/Layout/MainLayout.razor.rz.scp.css */
.layout-container[b-4mnc7h4hwp] {
    display: flex;
    flex-direction: column;
    height: 100vh;
    overflow: hidden;
}

.app-bar[b-4mnc7h4hwp] {
    background-color: #3f51b5;
    color: white;
    display: flex;
    align-items: center;
    padding: 0 16px;
    height: 64px;
    min-height: 64px;
    flex-shrink: 0;
    box-shadow: 0 2px 4px -1px rgba(0,0,0,.2), 0 4px 5px 0 rgba(0,0,0,.14), 0 1px 10px 0 rgba(0,0,0,.12);
    z-index: 100;
}

.menu-button[b-4mnc7h4hwp] {
    background: none;
    border: none;
    color: white;
    cursor: pointer;
    padding: 8px;
    margin-right: 8px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    transition: background-color 0.15s;
}

.menu-button:hover[b-4mnc7h4hwp] {
    background-color: rgba(255,255,255,0.15);
}

.menu-button svg[b-4mnc7h4hwp] {
    fill: white;
    width: 24px;
    height: 24px;
}

.app-bar-title[b-4mnc7h4hwp] {
    font-size: 1.25rem;
    font-weight: 500;
    letter-spacing: 0.0125em;
}

.main-content-wrapper[b-4mnc7h4hwp] {
    display: flex;
    flex: 1;
    overflow: hidden;
}

.drawer[b-4mnc7h4hwp] {
    background-color: #ffffff;
    border-right: 1px solid rgba(0,0,0,0.12);
    overflow-y: auto;
    overflow-x: hidden;
    transition: width 0.25s ease;
    flex-shrink: 0;
}

.drawer.open[b-4mnc7h4hwp] {
    width: 240px;
}

.drawer.closed[b-4mnc7h4hwp] {
    width: 0;
}

.main-content[b-4mnc7h4hwp] {
    flex: 1;
    height: calc(100vh - 64px); /* explicit height — required for height:100% to resolve in children */
    overflow: hidden;
    background-color: #f5f5f5;
}

/* container-fluid pa-4 wrapping @Body — fills main-content, own scroll for normal pages */
.main-content > .container-fluid[b-4mnc7h4hwp] {
    height: 100%;
    overflow-y: auto;
    box-sizing: border-box;
}
/* /Components/Layout/NavMenu.razor.rz.scp.css */
#nav-menu[b-azkk0pwrfl] {
    display: flex;
    flex-direction: column;
    width: 240px;
    padding: 8px 0;
}

[b-azkk0pwrfl] .nav-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    color: rgba(0,0,0,0.87);
    text-decoration: none;
    font-size: 0.875rem;
    font-weight: 400;
    transition: background-color 0.15s;
    white-space: nowrap;
}

[b-azkk0pwrfl] .nav-link:hover {
    background-color: rgba(0,0,0,0.04);
    color: rgba(0,0,0,0.87);
    text-decoration: none;
}

[b-azkk0pwrfl] .nav-link.active {
    background-color: rgba(63,81,181,0.12);
    color: #3f51b5;
    font-weight: 600;
}

[b-azkk0pwrfl] .nav-link svg {
    width: 20px;
    height: 20px;
    fill: rgba(0,0,0,0.54);
    flex-shrink: 0;
}

[b-azkk0pwrfl] .nav-link.active svg {
    fill: #3f51b5;
}

.nav-divider[b-azkk0pwrfl] {
    margin: 8px 0;
    border: none;
    border-top: 1px solid rgba(0,0,0,0.12);
}

.text-subtitle2[b-azkk0pwrfl] {
    font-size: 0.75rem;
    font-weight: 600;
    color: rgba(0,0,0,0.54);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 8px 16px 4px;
}
/* /Components/Layout/ReconnectModal.razor.rz.scp.css */
.components-reconnect-first-attempt-visible[b-cyny6iza6x],
.components-reconnect-repeated-attempt-visible[b-cyny6iza6x],
.components-reconnect-failed-visible[b-cyny6iza6x],
.components-pause-visible[b-cyny6iza6x],
.components-resume-failed-visible[b-cyny6iza6x],
.components-rejoining-animation[b-cyny6iza6x] {
    display: none;
}

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


#components-reconnect-modal[b-cyny6iza6x] {
    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-cyny6iza6x 0.5s both;
    &[open]

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

}

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

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

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

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

    100% {
        opacity: 1;
    }
}

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

    100% {
        opacity: 0;
    }
}

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

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

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

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

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

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

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

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

@keyframes components-rejoining-animation-b-cyny6iza6x {
    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/Molecules/DiagnosticsLogViewer.razor.rz.scp.css */
.diagnostics-log-viewer[b-8ojtmiy9u4] {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    overflow: hidden;
    font-family: monospace;
    font-size: 0.8rem;
}

/* ── Header: title + filter checkboxes ───────────────────────── */
.log-header[b-8ojtmiy9u4] {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 8px;
    flex-shrink: 0;
}

.log-filters[b-8ojtmiy9u4] {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.log-filter-label[b-8ojtmiy9u4] {
    display: flex;
    align-items: center;
    gap: 5px;
    cursor: pointer;
    user-select: none;
    font-family: sans-serif;
    font-size: 0.78rem;
}

.log-filter-label input[type="checkbox"][b-8ojtmiy9u4] {
    cursor: pointer;
    width: 14px;
    height: 14px;
    accent-color: #3f51b5;
    flex-shrink: 0;
}

.log-filter-count[b-8ojtmiy9u4] {
    color: #718096;
    font-size: 0.72rem;
}

/* ── Source badges ───────────────────────────────────────────── */
.log-source-badge[b-8ojtmiy9u4] {
    font-size: 0.72rem;
    font-weight: 700;
    white-space: nowrap;
    flex-shrink: 0;
}

.log-source-badge--teamtime[b-8ojtmiy9u4]  { color: #2b6cb0; }
.log-source-badge--oar[b-8ojtmiy9u4]       { color: #6b46c1; }
.log-source-badge--discovery[b-8ojtmiy9u4] { color: #b7791f; }

/* ── Scrollable log area ─────────────────────────────────────── */
.log-scroll[b-8ojtmiy9u4] {
    flex: 1;
    min-height: 0;
    overflow-y: scroll;
}

/* ── Message span ────────────────────────────────────────────── */
.log-message[b-8ojtmiy9u4] {
    cursor: pointer;
    text-decoration: none;
}

/* ── Raw line popup ──────────────────────────────────────────── */
.raw-line-backdrop[b-8ojtmiy9u4] {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    z-index: 1200;
    display: flex;
    align-items: center;
    justify-content: center;
}

.raw-line-popup[b-8ojtmiy9u4] {
    background: #fff;
    border-radius: 6px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.22);
    width: min(860px, 92vw);
    max-height: 70vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.raw-line-popup-header[b-8ojtmiy9u4] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 16px;
    border-bottom: 1px solid #e2e8f0;
    flex-shrink: 0;
}

.raw-line-close[b-8ojtmiy9u4] {
    background: none;
    border: none;
    font-size: 1rem;
    cursor: pointer;
    color: #718096;
    padding: 2px 6px;
    border-radius: 4px;
}

.raw-line-close:hover[b-8ojtmiy9u4] {
    background: #f7fafc;
    color: #2d3748;
}

.raw-line-content[b-8ojtmiy9u4] {
    margin: 0;
    padding: 14px 16px;
    font-family: monospace;
    font-size: 0.78rem;
    white-space: pre-wrap;
    word-break: break-all;
    overflow-y: auto;
    color: #2d3748;
}
/* /Components/Molecules/Login.razor.rz.scp.css */
.btn-login[b-m3keax7rep] {
	background-color: #594ae2;
	color: #fff;
	padding: 8px 16px;
	border: none;
	border-radius: 4px;
	cursor: pointer;
	font-weight: 500;
	text-transform: uppercase;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
}

.btn-login:hover[b-m3keax7rep] {
	background-color: #4a3ebf;
}
/* /Components/Molecules/Logout.razor.rz.scp.css */
#logout[b-w3pybm7r6a] {
    max-width: 420px;
}

.btn-logout[b-w3pybm7r6a] {
    background-color: #594ae2;
    color: #fff;
    padding: 8px 16px;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    font-weight: 500;
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
}

.btn-logout:hover[b-w3pybm7r6a] {
    background-color: #4a3ebf;
}
/* /Components/Organisms/DiagnosticsPanel.razor.rz.scp.css */
/* ── Session wrapper — fills remaining page height ─────────── */
.diag-session[b-7pwym4lhpf] {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
}

/* ── Toolbar ─────────────────────────────────────────────────── */
.diag-toolbar[b-7pwym4lhpf] {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
    flex-shrink: 0;
}

.diag-toolbar-actions[b-7pwym4lhpf] {
    margin-left: auto;
    display: flex;
    gap: 8px;
}

.diag-url[b-7pwym4lhpf] {
    font-size: 0.76rem;
    word-break: break-all;
    flex: 1 1 0;
    min-width: 0;
}

/* ── Two-column row — stretches to fill diag-session ────────── */
.diag-main-row[b-7pwym4lhpf] {
    flex: 1;
    min-height: 0;
    align-items: stretch !important;
}

/* ── Each column — flex column so paper fills it ────────────── */
.diag-col[b-7pwym4lhpf] {
    display: flex;
    flex-direction: column;
    min-height: 0;
    height: 100%; /* explicit — align-items:stretch alone needs parent with explicit height */
}

/* ── Paper inside column — fills column height ──────────────── */
.diag-paper[b-7pwym4lhpf] {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    overflow: hidden; /* forces children to respect flex bounds */
}

/* ── Metrics row ─────────────────────────────────────────────── */
.req-metrics[b-7pwym4lhpf] {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    flex-shrink: 0;
}

.req-metric[b-7pwym4lhpf] {
    flex: 1 1 60px;
    text-align: center;
    padding: 8px 10px;
    background: #f7fafc;
    border-radius: 8px;
    border: 1px solid #e2e8f0;
    min-width: 54px;
}

.req-metric-value[b-7pwym4lhpf] {
    font-size: 1.4rem;
    font-weight: 700;
    line-height: 1.1;
}

.req-metric-label[b-7pwym4lhpf] {
    font-size: 0.68rem;
    color: #718096;
    margin-top: 3px;
    white-space: nowrap;
}

/* ── Dot chart ───────────────────────────────────────────────── */
.req-chart[b-7pwym4lhpf] {
    display: flex;
    flex-wrap: wrap;
    gap: 3px;
    margin-bottom: 10px;
    flex-shrink: 0;
}

.dot[b-7pwym4lhpf] {
    width: 26px;
    height: 26px;
    border-radius: 5px;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding-left: 2px;
    font-size: 0.6rem;
    font-weight: 600;
    cursor: default;
    flex-shrink: 0;
    transition: transform 0.12s;
    user-select: none;
    position: relative;
}

/* ── OIDC probe badges ───────────────────────────────────────── */
.oidc-badge[b-7pwym4lhpf] {
    position: absolute;
    width: 10px;
    height: 10px;
    font-size: 0.38rem;
    font-weight: 700;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 1px;
    pointer-events: none;
}

.oidc-badge-t[b-7pwym4lhpf] { top: 1px;    right: 1px; }
.oidc-badge-o[b-7pwym4lhpf] { bottom: 1px; right: 1px; }
.oidc-ok[b-7pwym4lhpf]      { background: rgb(51 184 62 / 0.88); color: #1a202c; }
.oidc-fail[b-7pwym4lhpf]    { background: rgb(220 29 29 / 0.7); color: #1a202c; }

.dot:hover[b-7pwym4lhpf] {
    transform: scale(1.3);
    z-index: 10;
    position: relative;
}

.dot-ok[b-7pwym4lhpf]    { background: #c6f6d5; color: #276749; border: 1px solid #9ae6b4; }
.dot-warn[b-7pwym4lhpf]  { background: #fefcbf; color: #744210; border: 1px solid #f6e05e; }
.dot-error[b-7pwym4lhpf] { background: #e2e8f0; color: #4a5568; border: 1px solid #a0aec0; }

/* ── Legend ──────────────────────────────────────────────────── */
.req-legend[b-7pwym4lhpf] {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    font-size: 0.75rem;
    color: #4a5568;
    margin-top: 6px;
    margin-bottom: 8px;
    flex-shrink: 0;
}

.req-legend-group-label[b-7pwym4lhpf] {
    font-weight: 600;
    color: #2d3748;
    font-size: 0.72rem;
}

.req-legend-sep[b-7pwym4lhpf] {
    width: 1px;
    height: 14px;
    background: #cbd5e0;
    flex-shrink: 0;
}

.req-legend-dot[b-7pwym4lhpf] {
    width: 10px;
    height: 10px;
    border-radius: 3px;
    display: inline-block;
    margin-right: 4px;
    vertical-align: middle;
}

.req-legend-oidc[b-7pwym4lhpf] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 11px;
    height: 11px;
    font-size: 0.4rem;
    font-weight: 700;
    border-radius: 1px;
    margin-right: 4px;
    vertical-align: middle;
}

/* ── Detail list rows ────────────────────────────────────────── */
.req-seq[b-7pwym4lhpf] {
    min-width: 3ch;
    text-align: right;
    flex-shrink: 0;
}

/* ── Detail list — fills all remaining space in the paper ───── */
.req-detail-list[b-7pwym4lhpf] {
    flex: 1;
    min-height: 0;
    overflow-y: scroll;
    font-family: monospace;
    font-size: 0.82rem;
}


/* ── Mobile: stack columns ───────────────────────────────────── */
@media (max-width: 767px) {
    .diag-toolbar[b-7pwym4lhpf] {
        gap: 6px;
    }

    .diag-url[b-7pwym4lhpf] {
        flex-basis: 100%;
    }

    .diag-main-row[b-7pwym4lhpf] {
        flex: unset;
    }

    .diag-col[b-7pwym4lhpf] {
        min-height: 300px;
    }
}
/* /Components/Pages/DevelopPage.razor.rz.scp.css */
/* ===== Page wrapper ===== */
.dev-page[b-mssh2d5dcb] {
    padding: 5px;
}

.dev-header[b-mssh2d5dcb] {
    margin-bottom: 16px;
}

.dev-title[b-mssh2d5dcb] {
    font-size: 2.125rem;
    font-weight: 400;
    line-height: 1.235;
    letter-spacing: 0.00735em;
    margin: 0;
}

/* ===== Card ===== */
.dev-card[b-mssh2d5dcb] {
    overflow: hidden;
}

/* ===== Status bar ===== */
.dev-status-bar[b-mssh2d5dcb] {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 20px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    flex-wrap: wrap;
    min-height: 52px;
}

.dev-machine-icon[b-mssh2d5dcb] {
    width: 36px;
    height: 36px;
    border: 1px solid rgba(0, 0, 0, 0.12);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.dev-machine-icon[b-mssh2d5dcb]  svg,
.dev-machine-icon[b-mssh2d5dcb]  img {
    width: 22px;
    height: 22px;
}

/* Pool Refresh Time — single line: label + value side by side */
.dev-status-bar[b-mssh2d5dcb]  #pool-refresh-time {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 0;
}

.dev-status-bar[b-mssh2d5dcb]  .input-label {
    display: inline;
    white-space: nowrap;
    font-size: 0.8rem;
}

.dev-status-bar[b-mssh2d5dcb]  .input-text-readonly {
    display: inline;
    font-size: 0.8rem;
    white-space: nowrap;
}

/* ===== Sections ===== */
.dev-section[b-mssh2d5dcb] {
    padding: 20px 24px;
}

.dev-section + .dev-section[b-mssh2d5dcb] {
    border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.dev-section-title[b-mssh2d5dcb] {
    font-size: 1rem;
    font-weight: 400;
    margin: 0 0 14px 0;
    color: rgba(0, 0, 0, 0.87);
}

/* ===== Desktop: tenant cards — fixed width, no stretching ===== */
.dev-section[b-mssh2d5dcb]  .grid-item {
    flex: 0 1 280px;
    width: 280px;
}

/* ===== Desktop: service cards — compact flex wrap ===== */
.dev-section[b-mssh2d5dcb]  #docker-inspect-card,
.dev-section[b-mssh2d5dcb]  #ping-virtual-machine-card {
    flex: 1 1 190px;
    min-width: 170px;
    max-width: 250px;
}

/* ===== Tablet (600–899px) ===== */
@media (max-width: 899px) {
    .dev-page[b-mssh2d5dcb] {
        padding: 16px;
    }

    .dev-status-bar[b-mssh2d5dcb] {
        padding: 8px 16px;
        gap: 10px;
    }

    .dev-section[b-mssh2d5dcb] {
        padding: 16px;
    }

    .dev-section[b-mssh2d5dcb]  .grid-item {
        flex: 0 1 260px;
        width: 260px;
    }

    .dev-section[b-mssh2d5dcb]  #docker-inspect-card,
    .dev-section[b-mssh2d5dcb]  #ping-virtual-machine-card {
        flex: 1 1 160px;
        min-width: 140px;
        max-width: unset;
    }
}

/* ===== Mobile (< 600px) ===== */
@media (max-width: 599px) {
    .dev-page[b-mssh2d5dcb] {
        padding: 8px;
    }

    .dev-title[b-mssh2d5dcb] {
        font-size: 1.5rem;
    }

    .dev-header[b-mssh2d5dcb] {
        margin-bottom: 8px;
    }

    .dev-status-bar[b-mssh2d5dcb] {
        padding: 8px 12px;
        gap: 8px;
        /* icon + badge on row 1, time wraps to row 2 */
    }

    .dev-machine-icon[b-mssh2d5dcb] {
        width: 30px;
        height: 30px;
    }

    .dev-machine-icon[b-mssh2d5dcb]  svg,
    .dev-machine-icon[b-mssh2d5dcb]  img {
        width: 18px;
        height: 18px;
    }

    /* Pool Refresh Time fills its own row on mobile */
    .dev-status-bar[b-mssh2d5dcb]  #pool-refresh-time {
        flex-basis: 100%;
        padding: 0;
    }

    .dev-section[b-mssh2d5dcb] {
        padding: 12px;
    }

    /* Tenant cards: full width on mobile */
    .dev-section[b-mssh2d5dcb]  .grid-item {
        flex: 1 1 100%;
        min-width: unset;
        max-width: unset;
    }

    /* Service cards: 2 per row on mobile */
    .dev-section[b-mssh2d5dcb]  #docker-inspect-card,
    .dev-section[b-mssh2d5dcb]  #ping-virtual-machine-card {
        flex: 1 1 calc(50% - 4px);
        min-width: 130px;
        max-width: unset;
    }
}

/* ===== Small mobile (< 400px): service cards stack too ===== */
@media (max-width: 399px) {
    .dev-section[b-mssh2d5dcb]  #docker-inspect-card,
    .dev-section[b-mssh2d5dcb]  #ping-virtual-machine-card {
        flex: 1 1 100%;
    }
}
/* /Components/Pages/DiagnosticsPage.razor.rz.scp.css */
/* ── Page wrapper ──────────────────────────────────────────── */
.diag-page[b-5pcyi6sxff] {
    height: 100%;           /* fills container-fluid content area */
    display: flex;
    flex-direction: column;
    padding: 16px 20px 32px;
    box-sizing: border-box;
    /* no overflow:hidden here — inner scroll areas clip themselves,
       and removing it lets CSS tooltips (position:absolute) escape the bounds */
}

.diag-page-header[b-5pcyi6sxff] {
    margin-bottom: 20px;
}

.diag-page-title[b-5pcyi6sxff] {
    font-size: 1.75rem;
    font-weight: 600;
    margin: 0 0 4px 0;
}

.diag-page-subtitle[b-5pcyi6sxff] {
    margin: 0;
    font-size: 0.875rem;
}

/* ── Tablet ────────────────────────────────────────────────── */
@media (max-width: 899px) {
    .diag-page[b-5pcyi6sxff] {
        padding: 12px 16px;
    }
}

/* ── Mobile ────────────────────────────────────────────────── */
@media (max-width: 599px) {
    .diag-page[b-5pcyi6sxff] {
        padding: 8px 12px;
    }

    .diag-page-title[b-5pcyi6sxff] {
        font-size: 1.4rem;
    }
}
/* /Components/Pages/HotfixPage.razor.rz.scp.css */
/* ===== Page wrapper ===== */
.hotfix-page[b-ls8nqkeyrc] {
    padding: 5px;
}

.hotfix-header[b-ls8nqkeyrc] {
    margin-bottom: 16px;
}

.hotfix-title[b-ls8nqkeyrc] {
    font-size: 2.125rem;
    font-weight: 400;
    line-height: 1.235;
    letter-spacing: 0.00735em;
    margin: 0;
}

/* ===== Card ===== */
.hotfix-card[b-ls8nqkeyrc] {
    overflow: hidden;
}

/* ===== Status bar ===== */
.hotfix-status-bar[b-ls8nqkeyrc] {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 20px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    flex-wrap: wrap;
    min-height: 52px;
}

.hotfix-machine-icon[b-ls8nqkeyrc] {
    width: 36px;
    height: 36px;
    border: 1px solid rgba(0, 0, 0, 0.12);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.hotfix-machine-icon[b-ls8nqkeyrc]  svg,
.hotfix-machine-icon[b-ls8nqkeyrc]  img {
    width: 22px;
    height: 22px;
}

/* Pool Refresh Time — single line: label + value side by side */
.hotfix-status-bar[b-ls8nqkeyrc]  #pool-refresh-time {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 0;
}

.hotfix-status-bar[b-ls8nqkeyrc]  .input-label {
    display: inline;
    white-space: nowrap;
    font-size: 0.8rem;
}

.hotfix-status-bar[b-ls8nqkeyrc]  .input-text-readonly {
    display: inline;
    font-size: 0.8rem;
    white-space: nowrap;
}

/* ===== Sections ===== */
.hotfix-section[b-ls8nqkeyrc] {
    padding: 20px 24px;
}

.hotfix-section + .hotfix-section[b-ls8nqkeyrc] {
    border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.hotfix-section-title[b-ls8nqkeyrc] {
    font-size: 1rem;
    font-weight: 400;
    margin: 0 0 14px 0;
    color: rgba(0, 0, 0, 0.87);
}

/* ===== Desktop: tenant cards — fixed width, no stretching ===== */
.hotfix-section[b-ls8nqkeyrc]  .grid-item {
    flex: 0 1 280px;
    width: 280px;
}

/* ===== Desktop: service cards — compact flex wrap ===== */
.hotfix-section[b-ls8nqkeyrc]  #docker-inspect-card,
.hotfix-section[b-ls8nqkeyrc]  #ping-virtual-machine-card {
    flex: 1 1 190px;
    min-width: 170px;
    max-width: 250px;
}

/* ===== Tablet (600–899px) ===== */
@media (max-width: 899px) {
    .hotfix-page[b-ls8nqkeyrc] {
        padding: 16px;
    }

    .hotfix-status-bar[b-ls8nqkeyrc] {
        padding: 8px 16px;
        gap: 10px;
    }

    .hotfix-section[b-ls8nqkeyrc] {
        padding: 16px;
    }

    .hotfix-section[b-ls8nqkeyrc]  .grid-item {
        flex: 0 1 260px;
        width: 260px;
    }

    .hotfix-section[b-ls8nqkeyrc]  #docker-inspect-card,
    .hotfix-section[b-ls8nqkeyrc]  #ping-virtual-machine-card {
        flex: 1 1 160px;
        min-width: 140px;
        max-width: unset;
    }
}

/* ===== Mobile (< 600px) ===== */
@media (max-width: 599px) {
    .hotfix-page[b-ls8nqkeyrc] {
        padding: 8px;
    }

    .hotfix-title[b-ls8nqkeyrc] {
        font-size: 1.5rem;
    }

    .hotfix-header[b-ls8nqkeyrc] {
        margin-bottom: 8px;
    }

    .hotfix-status-bar[b-ls8nqkeyrc] {
        padding: 8px 12px;
        gap: 8px;
        /* icon + badge on row 1, time wraps to row 2 */
    }

    .hotfix-machine-icon[b-ls8nqkeyrc] {
        width: 30px;
        height: 30px;
    }

    .hotfix-machine-icon[b-ls8nqkeyrc]  svg,
    .hotfix-machine-icon[b-ls8nqkeyrc]  img {
        width: 18px;
        height: 18px;
    }

    /* Pool Refresh Time fills its own row on mobile */
    .hotfix-status-bar[b-ls8nqkeyrc]  #pool-refresh-time {
        flex-basis: 100%;
        padding: 0;
    }

    .hotfix-section[b-ls8nqkeyrc] {
        padding: 12px;
    }

    /* Tenant cards: full width on mobile */
    .hotfix-section[b-ls8nqkeyrc]  .grid-item {
        flex: 1 1 100%;
        min-width: unset;
        max-width: unset;
    }

    /* Service cards: 2 per row on mobile */
    .hotfix-section[b-ls8nqkeyrc]  #docker-inspect-card,
    .hotfix-section[b-ls8nqkeyrc]  #ping-virtual-machine-card {
        flex: 1 1 calc(50% - 4px);
        min-width: 130px;
        max-width: unset;
    }
}

/* ===== Small mobile (< 400px): service cards stack too ===== */
@media (max-width: 399px) {
    .hotfix-section[b-ls8nqkeyrc]  #docker-inspect-card,
    .hotfix-section[b-ls8nqkeyrc]  #ping-virtual-machine-card {
        flex: 1 1 100%;
    }
}
/* /Components/Pages/IonosPage.razor.rz.scp.css */
/* ===== Page wrapper ===== */
.ionos-page[b-ssno3986yh] {
    padding: 5px;
}

.ionos-header[b-ssno3986yh] {
    margin-bottom: 16px;
}

.ionos-title[b-ssno3986yh] {
    font-size: 2.125rem;
    font-weight: 400;
    line-height: 1.235;
    letter-spacing: 0.00735em;
    margin: 0;
}

/* ===== Card ===== */
.ionos-card[b-ssno3986yh] {
    overflow: hidden;
}

/* ===== Status bar ===== */
.ionos-status-bar[b-ssno3986yh] {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 20px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    flex-wrap: wrap;
    min-height: 52px;
}

.ionos-machine-icon[b-ssno3986yh] {
    width: 36px;
    height: 36px;
    border: 1px solid rgba(0, 0, 0, 0.12);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.ionos-machine-icon[b-ssno3986yh]  svg,
.ionos-machine-icon[b-ssno3986yh]  img {
    width: 22px;
    height: 22px;
}

/* Pool Refresh Time — single line: label + value side by side */
.ionos-status-bar[b-ssno3986yh]  #pool-refresh-time {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 0;
}

.ionos-status-bar[b-ssno3986yh]  .input-label {
    display: inline;
    white-space: nowrap;
    font-size: 0.8rem;
}

.ionos-status-bar[b-ssno3986yh]  .input-text-readonly {
    display: inline;
    font-size: 0.8rem;
    white-space: nowrap;
}

/* ===== Sections ===== */
.ionos-section[b-ssno3986yh] {
    padding: 20px 24px;
}

.ionos-section + .ionos-section[b-ssno3986yh] {
    border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.ionos-section-title[b-ssno3986yh] {
    font-size: 1rem;
    font-weight: 400;
    margin: 0 0 14px 0;
    color: rgba(0, 0, 0, 0.87);
}

/* ===== Desktop: tenant cards — fixed width, no stretching ===== */
.ionos-section[b-ssno3986yh]  .grid-item {
    flex: 0 1 280px;
    width: 280px;
}

/* ===== Desktop: service cards — compact flex wrap ===== */
.ionos-section[b-ssno3986yh]  #docker-inspect-card,
.ionos-section[b-ssno3986yh]  #ping-virtual-machine-card {
    flex: 1 1 190px;
    min-width: 170px;
    max-width: 250px;
}

/* ===== Tablet (600–899px) ===== */
@media (max-width: 899px) {
    .ionos-page[b-ssno3986yh] {
        padding: 16px;
    }

    .ionos-status-bar[b-ssno3986yh] {
        padding: 8px 16px;
        gap: 10px;
    }

    .ionos-section[b-ssno3986yh] {
        padding: 16px;
    }

    .ionos-section[b-ssno3986yh]  .grid-item {
        flex: 0 1 260px;
        width: 260px;
    }

    .ionos-section[b-ssno3986yh]  #docker-inspect-card,
    .ionos-section[b-ssno3986yh]  #ping-virtual-machine-card {
        flex: 1 1 160px;
        min-width: 140px;
        max-width: unset;
    }
}

/* ===== Mobile (< 600px) ===== */
@media (max-width: 599px) {
    .ionos-page[b-ssno3986yh] {
        padding: 8px;
    }

    .ionos-title[b-ssno3986yh] {
        font-size: 1.5rem;
    }

    .ionos-header[b-ssno3986yh] {
        margin-bottom: 8px;
    }

    .ionos-status-bar[b-ssno3986yh] {
        padding: 8px 12px;
        gap: 8px;
        /* icon + badge on row 1, time wraps to row 2 */
    }

    .ionos-machine-icon[b-ssno3986yh] {
        width: 30px;
        height: 30px;
    }

    .ionos-machine-icon[b-ssno3986yh]  svg,
    .ionos-machine-icon[b-ssno3986yh]  img {
        width: 18px;
        height: 18px;
    }

    /* Pool Refresh Time fills its own row on mobile */
    .ionos-status-bar[b-ssno3986yh]  #pool-refresh-time {
        flex-basis: 100%;
        padding: 0;
    }

    .ionos-section[b-ssno3986yh] {
        padding: 12px;
    }

    /* Tenant cards: full width on mobile */
    .ionos-section[b-ssno3986yh]  .grid-item {
        flex: 1 1 100%;
        min-width: unset;
        max-width: unset;
    }

    /* Service cards: 2 per row on mobile */
    .ionos-section[b-ssno3986yh]  #docker-inspect-card,
    .ionos-section[b-ssno3986yh]  #ping-virtual-machine-card {
        flex: 1 1 calc(50% - 4px);
        min-width: 130px;
        max-width: unset;
    }
}

/* ===== Small mobile (< 400px): service cards stack too ===== */
@media (max-width: 399px) {
    .ionos-section[b-ssno3986yh]  #docker-inspect-card,
    .ionos-section[b-ssno3986yh]  #ping-virtual-machine-card {
        flex: 1 1 100%;
    }
}
/* /Components/Pages/ReleasePage.razor.rz.scp.css */
/* ===== Page wrapper ===== */
.release-page[b-macod1unoh] {
    padding: 5px;
}

.release-header[b-macod1unoh] {
    margin-bottom: 16px;
}

.release-title[b-macod1unoh] {
    font-size: 2.125rem;
    font-weight: 400;
    line-height: 1.235;
    letter-spacing: 0.00735em;
    margin: 0;
}

/* ===== Card ===== */
.release-card[b-macod1unoh] {
    overflow: hidden;
}

/* ===== Status bar ===== */
.release-status-bar[b-macod1unoh] {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 20px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    flex-wrap: wrap;
    min-height: 52px;
}

.release-machine-icon[b-macod1unoh] {
    width: 36px;
    height: 36px;
    border: 1px solid rgba(0, 0, 0, 0.12);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.release-machine-icon[b-macod1unoh]  svg,
.release-machine-icon[b-macod1unoh]  img {
    width: 22px;
    height: 22px;
}

/* Pool Refresh Time — single line: label + value side by side */
.release-status-bar[b-macod1unoh]  #pool-refresh-time {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 0;
}

.release-status-bar[b-macod1unoh]  .input-label {
    display: inline;
    white-space: nowrap;
    font-size: 0.8rem;
}

.release-status-bar[b-macod1unoh]  .input-text-readonly {
    display: inline;
    font-size: 0.8rem;
    white-space: nowrap;
}

/* ===== Sections ===== */
.release-section[b-macod1unoh] {
    padding: 20px 24px;
}

.release-section + .release-section[b-macod1unoh] {
    border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.release-section-title[b-macod1unoh] {
    font-size: 1rem;
    font-weight: 400;
    margin: 0 0 14px 0;
    color: rgba(0, 0, 0, 0.87);
}

/* ===== Desktop: tenant cards — fixed width, no stretching ===== */
.release-section[b-macod1unoh]  .grid-item {
    flex: 0 1 280px;
    width: 280px;
}

/* ===== Desktop: service cards — compact flex wrap ===== */
.release-section[b-macod1unoh]  #docker-inspect-card,
.release-section[b-macod1unoh]  #ping-virtual-machine-card {
    flex: 1 1 190px;
    min-width: 170px;
    max-width: 250px;
}

/* ===== Tablet (600–899px) ===== */
@media (max-width: 899px) {
    .release-page[b-macod1unoh] {
        padding: 16px;
    }

    .release-status-bar[b-macod1unoh] {
        padding: 8px 16px;
        gap: 10px;
    }

    .release-section[b-macod1unoh] {
        padding: 16px;
    }

    .release-section[b-macod1unoh]  .grid-item {
        flex: 0 1 260px;
        width: 260px;
    }

    .release-section[b-macod1unoh]  #docker-inspect-card,
    .release-section[b-macod1unoh]  #ping-virtual-machine-card {
        flex: 1 1 160px;
        min-width: 140px;
        max-width: unset;
    }
}

/* ===== Mobile (< 600px) ===== */
@media (max-width: 599px) {
    .release-page[b-macod1unoh] {
        padding: 8px;
    }

    .release-title[b-macod1unoh] {
        font-size: 1.5rem;
    }

    .release-header[b-macod1unoh] {
        margin-bottom: 8px;
    }

    .release-status-bar[b-macod1unoh] {
        padding: 8px 12px;
        gap: 8px;
        /* icon + badge on row 1, time wraps to row 2 */
    }

    .release-machine-icon[b-macod1unoh] {
        width: 30px;
        height: 30px;
    }

    .release-machine-icon[b-macod1unoh]  svg,
    .release-machine-icon[b-macod1unoh]  img {
        width: 18px;
        height: 18px;
    }

    /* Pool Refresh Time fills its own row on mobile */
    .release-status-bar[b-macod1unoh]  #pool-refresh-time {
        flex-basis: 100%;
        padding: 0;
    }

    .release-section[b-macod1unoh] {
        padding: 12px;
    }

    /* Tenant cards: full width on mobile */
    .release-section[b-macod1unoh]  .grid-item {
        flex: 1 1 100%;
        min-width: unset;
        max-width: unset;
    }

    /* Service cards: 2 per row on mobile */
    .release-section[b-macod1unoh]  #docker-inspect-card,
    .release-section[b-macod1unoh]  #ping-virtual-machine-card {
        flex: 1 1 calc(50% - 4px);
        min-width: 130px;
        max-width: unset;
    }
}

/* ===== Small mobile (< 400px): service cards stack too ===== */
@media (max-width: 399px) {
    .release-section[b-macod1unoh]  #docker-inspect-card,
    .release-section[b-macod1unoh]  #ping-virtual-machine-card {
        flex: 1 1 100%;
    }
}
