html, body {
    height: 100%;
    margin: 0;
    padding: 0;
}

/* Blazor toggles components-reconnect-* on #components-reconnect-modal — show/hide must be CSS-driven (see MS SignalR doc); JS-only .reconnect-modal--visible missed updates so the overlay stayed display:none. */
#components-reconnect-modal {
    display: none;
}

#components-reconnect-modal.components-reconnect-show,
#components-reconnect-modal.components-reconnect-failed,
#components-reconnect-modal.components-reconnect-rejected,
#components-reconnect-modal.components-reconnect-retrying,
#components-reconnect-modal.components-reconnect-paused {
    display: flex;
    align-items: center;
    justify-content: center;
    position: fixed;
    inset: 0;
    z-index: 10001;
    padding: 1rem;
    background: rgba(15, 18, 28, 0.45);
    box-sizing: border-box;
}

#components-reconnect-modal.components-reconnect-hide {
    display: none !important;
}

.components-reconnect-modal__panel {
    padding: 1.25rem 1.5rem;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.18);
    text-align: center;
    font-family: Inter, system-ui, sans-serif;
    max-width: min(92vw, 22rem);
}

.components-reconnect-modal__title {
    margin: 0 0 0.5rem;
    font-weight: 600;
    font-size: 1.05rem;
}

.components-reconnect-modal__message,
.components-reconnect-modal__attempt,
.components-reconnect-modal__countdown {
    margin: 0.35rem 0;
    font-size: 0.875rem;
    color: var(--text-regular-secondary);
}

#components-reconnect-modal.components-reconnect-modal--offline .components-reconnect-modal__attempt,
#components-reconnect-modal.components-reconnect-modal--offline .components-reconnect-modal__countdown {
    display: none;
}
