/* /Components/Layout/MainLayout.razor.rz.scp.css */
#blazor-error-ui[b-k0r13kysl8] {
    color-scheme: light only;
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    box-sizing: border-box;
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

#blazor-error-ui .dismiss[b-k0r13kysl8] {
    cursor: pointer;
    position: absolute;
    right: 0.75rem;
    top: 0.5rem;
}
/* /Components/Layout/ReconnectModal.razor.rz.scp.css */
.components-reconnect-first-attempt-visible[b-qrf1dauf7m],
.components-reconnect-repeated-attempt-visible[b-qrf1dauf7m],
.components-reconnect-failed-visible[b-qrf1dauf7m],
.components-pause-visible[b-qrf1dauf7m],
.components-resume-failed-visible[b-qrf1dauf7m],
.components-rejoining-animation[b-qrf1dauf7m] {
    display: none;
}

#components-reconnect-modal.components-reconnect-show .components-reconnect-first-attempt-visible[b-qrf1dauf7m],
#components-reconnect-modal.components-reconnect-show .components-rejoining-animation[b-qrf1dauf7m],
#components-reconnect-modal.components-reconnect-paused .components-pause-visible[b-qrf1dauf7m],
#components-reconnect-modal.components-reconnect-resume-failed .components-resume-failed-visible[b-qrf1dauf7m],
#components-reconnect-modal.components-reconnect-retrying[b-qrf1dauf7m],
#components-reconnect-modal.components-reconnect-retrying .components-reconnect-repeated-attempt-visible[b-qrf1dauf7m],
#components-reconnect-modal.components-reconnect-retrying .components-rejoining-animation[b-qrf1dauf7m],
#components-reconnect-modal.components-reconnect-failed[b-qrf1dauf7m],
#components-reconnect-modal.components-reconnect-failed .components-reconnect-failed-visible[b-qrf1dauf7m] {
    display: block;
}


#components-reconnect-modal[b-qrf1dauf7m] {
    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-qrf1dauf7m 0.5s both;
    &[open]

{
    animation: components-reconnect-modal-slideUp-b-qrf1dauf7m 1.5s cubic-bezier(.05, .89, .25, 1.02) 0.3s, components-reconnect-modal-fadeInOpacity-b-qrf1dauf7m 0.5s ease-in-out 0.3s;
    animation-fill-mode: both;
}

}

#components-reconnect-modal[b-qrf1dauf7m]::backdrop {
    background-color: rgba(0, 0, 0, 0.4);
    animation: components-reconnect-modal-fadeInOpacity-b-qrf1dauf7m 0.5s ease-in-out;
    opacity: 1;
}

@keyframes components-reconnect-modal-slideUp-b-qrf1dauf7m {
    0% {
        transform: translateY(30px) scale(0.95);
    }

    100% {
        transform: translateY(0);
    }
}

@keyframes components-reconnect-modal-fadeInOpacity-b-qrf1dauf7m {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

@keyframes components-reconnect-modal-fadeOutOpacity-b-qrf1dauf7m {
    0% {
        opacity: 1;
    }

    100% {
        opacity: 0;
    }
}

.components-reconnect-container[b-qrf1dauf7m] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

#components-reconnect-modal p[b-qrf1dauf7m] {
    margin: 0;
    text-align: center;
}

#components-reconnect-modal button[b-qrf1dauf7m] {
    border: 0;
    background-color: #6b9ed2;
    color: white;
    padding: 4px 24px;
    border-radius: 4px;
}

    #components-reconnect-modal button:hover[b-qrf1dauf7m] {
        background-color: #3b6ea2;
    }

    #components-reconnect-modal button:active[b-qrf1dauf7m] {
        background-color: #6b9ed2;
    }

.components-rejoining-animation[b-qrf1dauf7m] {
    position: relative;
    width: 80px;
    height: 80px;
}

    .components-rejoining-animation div[b-qrf1dauf7m] {
        position: absolute;
        border: 3px solid #0087ff;
        opacity: 1;
        border-radius: 50%;
        animation: components-rejoining-animation-b-qrf1dauf7m 1.5s cubic-bezier(0, 0.2, 0.8, 1) infinite;
    }

        .components-rejoining-animation div:nth-child(2)[b-qrf1dauf7m] {
            animation-delay: -0.5s;
        }

@keyframes components-rejoining-animation-b-qrf1dauf7m {
    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/Layout/Theme/ThemeSwitcher.razor.rz.scp.css */
.theme-switcher-wrapper[b-5qclsh01go] {
    position: relative;
    display: inline-flex;
    align-items: center;
}

.theme-switcher-panel[b-5qclsh01go] {
    position: absolute;
    top: calc(100% + 6px);
    right: 0;
    z-index: 1050;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, .12);
    border-radius: .375rem;
    min-width: 210px;
    overflow: hidden;
}

.theme-switcher-header[b-5qclsh01go] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .5rem .75rem;
    background: #f8f9fa;
    border-bottom: 1px solid rgba(0, 0, 0, .08);
}

.theme-switcher-body[b-5qclsh01go] {
    max-height: 420px;
    overflow-y: auto;
    overflow-x: hidden;
}

.theme-group-label[b-5qclsh01go] {
    padding: .45rem .75rem .2rem;
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: #6c757d;
    background: #f8f9fa;
    border-top: 1px solid rgba(0, 0, 0, .06);
    border-bottom: 1px solid rgba(0, 0, 0, .06);
}

.theme-switcher-list[b-5qclsh01go] {
    padding: .25rem 0;
}

.theme-switcher-item[b-5qclsh01go] {
    display: flex;
    align-items: center;
    gap: .6rem;
    width: 100%;
    padding: .45rem .75rem;
    background: transparent;
    border: none;
    cursor: pointer;
    font-size: .875rem;
    color: #212529;
    text-align: left;
    transition: background-color .15s ease;
}

.theme-switcher-item:hover[b-5qclsh01go] {
    background: #e9ecef;
}

.theme-switcher-item.active[b-5qclsh01go] {
    font-weight: 600;
    color: #2774AE;
    background: #edf4fb;
}

.theme-swatch[b-5qclsh01go] {
    display: inline-block;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    border: 1px solid rgba(0, 0, 0, .18);
    flex-shrink: 0;
}

.theme-name[b-5qclsh01go] {
    flex: 1;
}

.btn-close-sm[b-5qclsh01go] {
    width: .75em;
    height: .75em;
}
/* /Components/Layout/TopBar.razor.rz.scp.css */
/* Skip-link: must meet WCAG AA (4.5:1) on white at all times.
   #005587 (Dark Cerulean) gives ~7.0:1 on white.
   Set on the base element so WCAG scanners see a compliant color
   regardless of focus state. */
a.visually-hidden-focusable[b-033de9w2if] {
    color: #005587 !important;
}

a.visually-hidden-focusable:focus[b-033de9w2if],
a.visually-hidden-focusable:focus-visible[b-033de9w2if] {
    color: #005587 !important;
    text-decoration: underline;
}
/* /Components/Pages/Preferences/Components/PreferencesForm.razor.rz.scp.css */
.pref-section[b-3lo2wk16g0] {
    margin-bottom: 2.5rem;
}

.pref-section__heading[b-3lo2wk16g0] {
    font-size: 1.1rem;
    font-weight: 600;
    border-bottom: 2px solid var(--bs-border-color, #dee2e6);
    padding-bottom: .5rem;
    margin-bottom: 1rem;
}

.pref-group-label[b-3lo2wk16g0] {
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--bs-secondary);
    margin-bottom: .5rem;
}

/* ── Theme cards ──────────────────────────────────────────────────────────── */
.pref-theme-grid[b-3lo2wk16g0] {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    margin-bottom: 1rem;
}

.pref-theme-card[b-3lo2wk16g0] {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .35rem;
    padding: .75rem .9rem;
    border: 2px solid var(--bs-border-color, #dee2e6);
    border-radius: .5rem;
    background: var(--bs-body-bg, #fff);
    cursor: pointer;
    transition: border-color .15s, box-shadow .15s;
    min-width: 90px;
}

    .pref-theme-card:hover[b-3lo2wk16g0] {
        border-color: var(--bs-primary, #0d6efd);
        box-shadow: 0 0 0 3px rgba(var(--bs-primary-rgb, 13,110,253), .15);
    }

    .pref-theme-card--active[b-3lo2wk16g0] {
        border-color: var(--bs-primary, #0d6efd);
        background: var(--bs-primary-bg-subtle, #cfe2ff);
    }

.pref-theme-swatch[b-3lo2wk16g0] {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 2px solid rgba(0, 0, 0, .08);
    display: block;
}

.pref-theme-name[b-3lo2wk16g0] {
    font-size: .78rem;
    font-weight: 500;
}

.pref-theme-check[b-3lo2wk16g0] {
    position: absolute;
    top: 4px;
    right: 5px;
    color: var(--bs-primary, #0d6efd);
    font-size: .8rem;
}

/* ── Width cards ──────────────────────────────────────────────────────────── */
.pref-width-options[b-3lo2wk16g0] {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

.pref-width-card[b-3lo2wk16g0] {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .4rem;
    padding: 1.25rem 2rem;
    border: 2px solid var(--bs-border-color, #dee2e6);
    border-radius: .5rem;
    background: var(--bs-body-bg, #fff);
    cursor: pointer;
    transition: border-color .15s, box-shadow .15s;
    min-width: 160px;
}

    .pref-width-card i.bi:first-child[b-3lo2wk16g0] {
        font-size: 1.75rem;
        color: var(--bs-secondary);
    }

    .pref-width-card:hover[b-3lo2wk16g0] {
        border-color: var(--bs-primary, #0d6efd);
        box-shadow: 0 0 0 3px rgba(var(--bs-primary-rgb, 13,110,253), .15);
    }

    .pref-width-card--active[b-3lo2wk16g0] {
        border-color: var(--bs-primary, #0d6efd);
        background: var(--bs-primary-bg-subtle, #cfe2ff);
    }

.pref-width-label[b-3lo2wk16g0] {
    font-weight: 600;
}

.pref-width-desc[b-3lo2wk16g0] {
    font-size: .78rem;
    color: var(--bs-secondary);
}
/* /Components/Pages/Preferences/Index.razor.rz.scp.css */
.pref-hero[b-5vqzie74al] {
    background: var(--bs-primary, #2774AE);
    color: #fff;
    padding: 2rem 0 1.5rem;
}

.pref-hero h1[b-5vqzie74al] {
    font-size: 1.75rem;
    font-weight: 600;
    margin-bottom: 0.25rem;
}

.pref-hero p[b-5vqzie74al] {
    opacity: .85;
    margin-bottom: 0;
}
/* /Components/Shared/AppTabs.razor.rz.scp.css */
[b-rbdt1qw0z9] .dxbl-tabs-content-panel {
    padding: 0 !important;
}
/* /Components/Shared/VideoPlayer.razor.rz.scp.css */
.video-wrapper[b-7kydb5euc7] {
    position: relative;
    width: 100%;
    max-width: 1296px;
    margin-inline: auto;      /* center when narrower than the column */
    aspect-ratio: 16 / 9;     /* reserve the box up-front — kills the layout jump */
}

.video-wrapper video[b-7kydb5euc7] {
    width: 100%;
    height: 100%;
    object-fit: contain;      /* letterbox non-16:9 videos instead of resizing the box */
    display: block;
    background-color: #000;
    border-radius: 16px;      /* match the overlay's corners */
}

.spinner-overlay[b-7kydb5euc7] {
    position: absolute;
    inset: 0;
    /* Dark navy blue gradient background with a soft center glow */
    background: radial-gradient(circle at 50% 50%, #1f2c41 0%, #111a2e 60%, #0a101d 100%);
    border-radius: 16px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    transition: opacity 0.3s ease;
}

.spinner-overlay.hidden[b-7kydb5euc7] {
    opacity: 0;
    visibility: hidden;
}

.error-message[b-7kydb5euc7] {
    display: none;            /* shown only in the error state */
    flex-direction: column;
    align-items: center;
    text-align: center;
    color: #d1d5db;
    padding: 1rem;
}

.error-message i[b-7kydb5euc7] {
    font-size: 48px;
    color: #f7b48b;
    margin-bottom: 12px;
}

.error-message p[b-7kydb5euc7] {
    font-size: 20px;
    font-weight: 300;
    letter-spacing: 1px;
    margin: 0;
}

/* Error state: hide the spinner, show the message; keep the overlay visible. */
.spinner-overlay.error .spinner-container[b-7kydb5euc7],
.spinner-overlay.error .loading-text[b-7kydb5euc7] {
    display: none;
}

.spinner-overlay.error .error-message[b-7kydb5euc7] {
    display: flex;
}

.spinner-container[b-7kydb5euc7] {
    position: relative;
    width: 100px;
    height: 100px;
    /* Centered slightly above vertical center */
    transform: translateY(-20px);
}

.spinner-segment[b-7kydb5euc7] {
    position: absolute;
    top: 0;
    left: 47%; /* Center the 6px width in the 100px container (50% - 3px) */
    width: 6px;
    height: 20px;
    background-color: #8bb4f7;
    border-radius: 3px;
    transform-origin: 50% 50px;
    opacity: 0.2;
    /* 1.5s seamless loop animation */
    animation: color-chase-b-7kydb5euc7 1.5s linear infinite;
}

/* Positioning and animating the 12 symmetrical segments to create the illusion of clockwise rotation */
.spinner-segment:nth-child(1)[b-7kydb5euc7] { transform: rotate(0deg); animation-delay: -1.5s; }
.spinner-segment:nth-child(2)[b-7kydb5euc7] { transform: rotate(30deg); animation-delay: -1.375s; }
.spinner-segment:nth-child(3)[b-7kydb5euc7] { transform: rotate(60deg); animation-delay: -1.25s; }
.spinner-segment:nth-child(4)[b-7kydb5euc7] { transform: rotate(90deg); animation-delay: -1.125s; }
.spinner-segment:nth-child(5)[b-7kydb5euc7] { transform: rotate(120deg); animation-delay: -1.0s; }
.spinner-segment:nth-child(6)[b-7kydb5euc7] { transform: rotate(150deg); animation-delay: -0.875s; }
.spinner-segment:nth-child(7)[b-7kydb5euc7] { transform: rotate(180deg); animation-delay: -0.75s; }
.spinner-segment:nth-child(8)[b-7kydb5euc7] { transform: rotate(210deg); animation-delay: -0.625s; }
.spinner-segment:nth-child(9)[b-7kydb5euc7] { transform: rotate(240deg); animation-delay: -0.5s; }
.spinner-segment:nth-child(10)[b-7kydb5euc7] { transform: rotate(270deg); animation-delay: -0.375s; }
.spinner-segment:nth-child(11)[b-7kydb5euc7] { transform: rotate(300deg); animation-delay: -0.25s; }
.spinner-segment:nth-child(12)[b-7kydb5euc7] { transform: rotate(330deg); animation-delay: -0.125s; }

/* The animation strictly alters color/brightness, keeping the shapes perfectly still */
@keyframes color-chase-b-7kydb5euc7 {
    0% {
        background-color: #8bb4f7;
        opacity: 1;
        box-shadow: 0 0 10px rgba(139, 180, 247, 0.7);
    }
    25% {
        background-color: #4b6a9e;
        opacity: 0.6;
        box-shadow: none;
    }
    100% {
        background-color: #273d61;
        opacity: 0.2;
        box-shadow: none;
    }
}

.loading-text[b-7kydb5euc7] {
    color: #d1d5db;
    font-size: 24px;
    font-weight: 300;
    letter-spacing: 2px;
    margin-top: 25px;
    /* Adjust for visual balance */
    transform: translateY(-20px);
}
