/* /Components/Layout/MainLayout.razor.rz.scp.css */
.page[b-y8jmtkmzla] {
    position: relative;
    display: flex;
    flex-direction: column;
}

main[b-y8jmtkmzla] {
    flex: 1;
}

.sidebar[b-y8jmtkmzla] {
    background-image: linear-gradient(180deg, rgb(5, 39, 103) 0%, #3a0647 70%);
}

.top-row[b-y8jmtkmzla] {
    background-color: #f7f7f7;
    border-bottom: 1px solid #d6d5d5;
    justify-content: flex-end;
    height: 3.5rem;
    display: flex;
    align-items: center;
}

    .top-row[b-y8jmtkmzla]  a, .top-row[b-y8jmtkmzla]  .btn-link {
        white-space: nowrap;
        margin-left: 1.5rem;
        text-decoration: none;
    }

    .top-row[b-y8jmtkmzla]  a:hover, .top-row[b-y8jmtkmzla]  .btn-link:hover {
        text-decoration: underline;
    }

    .top-row[b-y8jmtkmzla]  a:first-child {
        overflow: hidden;
        text-overflow: ellipsis;
    }

@media (max-width: 640.98px) {
    .top-row[b-y8jmtkmzla] {
        justify-content: space-between;
    }

    .top-row[b-y8jmtkmzla]  a, .top-row[b-y8jmtkmzla]  .btn-link {
        margin-left: 0;
    }
}

@media (min-width: 641px) {
    .page[b-y8jmtkmzla] {
        flex-direction: row;
    }

    .sidebar[b-y8jmtkmzla] {
        width: 250px;
        height: 100vh;
        position: sticky;
        top: 0;
    }

    .top-row[b-y8jmtkmzla] {
        position: sticky;
        top: 0;
        z-index: 1;
    }

    .top-row.auth[b-y8jmtkmzla]  a:first-child {
        flex: 1;
        text-align: right;
        width: 0;
    }

    .top-row[b-y8jmtkmzla], article[b-y8jmtkmzla] {
        padding-left: 2rem !important;
        padding-right: 1.5rem !important;
    }
}

#blazor-error-ui[b-y8jmtkmzla] {
    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-y8jmtkmzla] {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }
/* /Components/Layout/ReconnectModal.razor.rz.scp.css */
.components-reconnect-first-attempt-visible[b-onnuxcaguk],
.components-reconnect-repeated-attempt-visible[b-onnuxcaguk],
.components-reconnect-failed-visible[b-onnuxcaguk],
.components-pause-visible[b-onnuxcaguk],
.components-resume-failed-visible[b-onnuxcaguk],
.components-rejoining-animation[b-onnuxcaguk] {
    display: none;
}

#components-reconnect-modal.components-reconnect-show .components-reconnect-first-attempt-visible[b-onnuxcaguk],
#components-reconnect-modal.components-reconnect-show .components-rejoining-animation[b-onnuxcaguk],
#components-reconnect-modal.components-reconnect-paused .components-pause-visible[b-onnuxcaguk],
#components-reconnect-modal.components-reconnect-resume-failed .components-resume-failed-visible[b-onnuxcaguk],
#components-reconnect-modal.components-reconnect-retrying[b-onnuxcaguk],
#components-reconnect-modal.components-reconnect-retrying .components-reconnect-repeated-attempt-visible[b-onnuxcaguk],
#components-reconnect-modal.components-reconnect-retrying .components-rejoining-animation[b-onnuxcaguk],
#components-reconnect-modal.components-reconnect-failed[b-onnuxcaguk],
#components-reconnect-modal.components-reconnect-failed .components-reconnect-failed-visible[b-onnuxcaguk] {
    display: block;
}


#components-reconnect-modal[b-onnuxcaguk] {
    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-onnuxcaguk 0.5s both;
    &[open]

{
    animation: components-reconnect-modal-slideUp-b-onnuxcaguk 1.5s cubic-bezier(.05, .89, .25, 1.02) 0.3s, components-reconnect-modal-fadeInOpacity-b-onnuxcaguk 0.5s ease-in-out 0.3s;
    animation-fill-mode: both;
}

}

#components-reconnect-modal[b-onnuxcaguk]::backdrop {
    background-color: rgba(0, 0, 0, 0.4);
    animation: components-reconnect-modal-fadeInOpacity-b-onnuxcaguk 0.5s ease-in-out;
    opacity: 1;
}

@keyframes components-reconnect-modal-slideUp-b-onnuxcaguk {
    0% {
        transform: translateY(30px) scale(0.95);
    }

    100% {
        transform: translateY(0);
    }
}

@keyframes components-reconnect-modal-fadeInOpacity-b-onnuxcaguk {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

@keyframes components-reconnect-modal-fadeOutOpacity-b-onnuxcaguk {
    0% {
        opacity: 1;
    }

    100% {
        opacity: 0;
    }
}

.components-reconnect-container[b-onnuxcaguk] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

#components-reconnect-modal p[b-onnuxcaguk] {
    margin: 0;
    text-align: center;
}

#components-reconnect-modal button[b-onnuxcaguk] {
    border: 0;
    background-color: #6b9ed2;
    color: white;
    padding: 4px 24px;
    border-radius: 4px;
}

    #components-reconnect-modal button:hover[b-onnuxcaguk] {
        background-color: #3b6ea2;
    }

    #components-reconnect-modal button:active[b-onnuxcaguk] {
        background-color: #6b9ed2;
    }

.components-rejoining-animation[b-onnuxcaguk] {
    position: relative;
    width: 80px;
    height: 80px;
}

    .components-rejoining-animation div[b-onnuxcaguk] {
        position: absolute;
        border: 3px solid #0087ff;
        opacity: 1;
        border-radius: 50%;
        animation: components-rejoining-animation-b-onnuxcaguk 1.5s cubic-bezier(0, 0.2, 0.8, 1) infinite;
    }

        .components-rejoining-animation div:nth-child(2)[b-onnuxcaguk] {
            animation-delay: -0.5s;
        }

@keyframes components-rejoining-animation-b-onnuxcaguk {
    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/Marketing/DataLayerHero.razor.rz.scp.css */
/* ═══════════════════════════════════════════════════════════════
   BOMSync Data Layer Hero — Scoped CSS
   Pure CSS animation · Zero JavaScript

   ANIMATION CYCLE  19.2s repeating
     0s  – 9.6s    Collect   3 inbound waves from 8 source nodes
     9.6s – 19.2s  Dispatch  outbound teal particles to each node
     Throughout    nucleus absorb-burst flares every 3.2s

   PALETTE
     Navy          #080f1e   stage background
     Navy mid      #0d2033   node card background
     Teal primary  #1a9bc4   spokes, outbound particles, core
     Teal mid      #2ab8d4   secondary nodes, outbound
     Teal bright   #4dd0e8   accent nodes
     Near-white    #a8e8ff   inbound particles, wordmark, bursts
   ═══════════════════════════════════════════════════════════════ */


/* ── Stage shell ─────────────────────────────────────────────── */

.dlh-stage[b-g89cxt4t7i] {
    background: var(--brand-blue, #111b2c);
    border-radius: 16px;
    padding: 32px 24px 24px;
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    overflow: hidden;
    width: 100%;
}


/* ── Ambient starfield ───────────────────────────────────────── */

.dlh-sf[b-g89cxt4t7i] {
    position: absolute;
    inset: 0;
    pointer-events: none;
    border-radius: 16px;
    overflow: hidden;
}

.dlh-sf-dot[b-g89cxt4t7i] {
    position: absolute;
    border-radius: 50%;
    background: #1a9bc4;
    animation: dlh-twinkle-b-g89cxt4t7i 5s ease-in-out infinite;
}

@keyframes dlh-twinkle-b-g89cxt4t7i {
    0%,  100% { opacity: .07; }
    50%        { opacity: .28; }
}


/* ── Scene container ─────────────────────────────────────────── */

.dlh-scene[b-g89cxt4t7i] {
    position: relative;
    width: 100%;
    max-width: 560px;
    height: 420px;
    margin: 0 auto;
}


/* ── SVG connector overlay ───────────────────────────────────── */

.dlh-connectors[b-g89cxt4t7i] {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 8;
    overflow: visible;
}

.dlh-cl[b-g89cxt4t7i] { fill: none; stroke-linecap: round; }

.dlh-cl-p[b-g89cxt4t7i] { stroke: rgba(26,155,196,0.28); stroke-width: 0.8; }
.dlh-cl-s[b-g89cxt4t7i] { stroke: rgba(42,184,212,0.16);  stroke-width: 0.6; }

/* active spoke — pulses bright individually */
.dlh-cl-a[b-g89cxt4t7i]  { stroke: rgba(168,232,255,0.50); stroke-width: 1.0; animation: dlh-cl-flash-b-g89cxt4t7i 4s ease-in-out infinite; }
.dlh-cl-a2[b-g89cxt4t7i] { animation: dlh-cl-flash-b-g89cxt4t7i 4s ease-in-out infinite; animation-delay: 2.0s; stroke: rgba(168,232,255,0.50); stroke-width: 1.0; }
.dlh-cl-a3[b-g89cxt4t7i] { animation: dlh-cl-flash-b-g89cxt4t7i 4s ease-in-out infinite; animation-delay: 1.0s; stroke: rgba(168,232,255,0.50); stroke-width: 1.0; }
.dlh-cl-a4[b-g89cxt4t7i] { animation: dlh-cl-flash-b-g89cxt4t7i 4s ease-in-out infinite; animation-delay: 3.0s; stroke: rgba(168,232,255,0.50); stroke-width: 1.0; }
.dlh-cl-a5[b-g89cxt4t7i] { animation: dlh-cl-flash-b-g89cxt4t7i 4s ease-in-out infinite; animation-delay: 1.5s; stroke: rgba(168,232,255,0.50); stroke-width: 1.0; }
.dlh-cl-a6[b-g89cxt4t7i] { animation: dlh-cl-flash-b-g89cxt4t7i 4s ease-in-out infinite; animation-delay: 2.5s; stroke: rgba(168,232,255,0.50); stroke-width: 1.0; }
.dlh-cl-a7[b-g89cxt4t7i] { animation: dlh-cl-flash-b-g89cxt4t7i 4s ease-in-out infinite; animation-delay: 0.5s; stroke: rgba(168,232,255,0.50); stroke-width: 1.0; }
.dlh-cl-a8[b-g89cxt4t7i] { animation: dlh-cl-flash-b-g89cxt4t7i 4s ease-in-out infinite; animation-delay: 3.5s; stroke: rgba(168,232,255,0.50); stroke-width: 1.0; }

@keyframes dlh-cl-flash-b-g89cxt4t7i {
    0%,  100% { opacity: .25; stroke-width: .7;  }
    40%,  60% { opacity: .90; stroke-width: 1.3; }
}


/* ── Central nucleus ─────────────────────────────────────────── */

.dlh-core[b-g89cxt4t7i] {
    position: absolute;
    left: 50%; top: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    z-index: 20;
}

.dlh-plane[b-g89cxt4t7i] {
    position: absolute;
    border-radius: 50%;
    left: 50%; top: 50%;
    transform: translate(-50%, -50%);
    animation: dlh-plane-spin-b-g89cxt4t7i 10s linear infinite;
}

.dlh-plane-outer[b-g89cxt4t7i] {
    width: 86px; height: 86px;
    border: 1px solid rgba(26,155,196,0.22);
    animation-duration: 16s;
    animation-direction: reverse;
}

.dlh-plane-mid[b-g89cxt4t7i] {
    width: 64px; height: 64px;
    border: 1px dashed rgba(42,184,212,0.35);
    animation-duration: 10s;
}

.dlh-plane-inner[b-g89cxt4t7i] {
    width: 44px; height: 44px;
    border: 1px solid rgba(77,208,232,0.50);
    animation-duration: 7s;
    animation-direction: reverse;
}

@keyframes dlh-plane-spin-b-g89cxt4t7i {
    to { transform: translate(-50%, -50%) rotate(360deg); }
}

/* absorb burst ring — expands outward on each completed collect wave */
.dlh-burst[b-g89cxt4t7i] {
    position: absolute;
    border-radius: 50%;
    width: 28px; height: 28px;
    background: transparent;
    border: 2px solid rgba(168,232,255,0.8);
    left: 50%; top: 50%;
    transform: translate(-50%, -50%);
    animation: dlh-absorb-burst-b-g89cxt4t7i 9.6s ease-out infinite;
    pointer-events: none;
    z-index: 6;
}

.dlh-burst2[b-g89cxt4t7i] { animation-delay: 3.2s; }
.dlh-burst3[b-g89cxt4t7i] { animation-delay: 6.4s; }

@keyframes dlh-absorb-burst-b-g89cxt4t7i {
    0%,  8%  { width: 28px; height: 28px; opacity: 0;  border-color: rgba(168,232,255,0.9); }
    12%       { opacity: 1; }
    40%       { width: 80px; height: 80px; opacity: 0;  border-color: rgba(26,155,196,0); }
    100%      { width: 80px; height: 80px; opacity: 0; }
}

/* nucleus core dot */
.dlh-nucleus[b-g89cxt4t7i] {
    width: 28px; height: 28px;
    border-radius: 50%;
    background: radial-gradient(circle, #d0f8ff 0%, #1a9bc4 45%, rgba(10,80,120,0) 100%);
    box-shadow: 0 0 22px 8px rgba(26,155,196,0.75), 0 0 6px 2px rgba(168,232,255,0.9);
    z-index: 5;
    position: relative;
    animation: dlh-nucleus-pulse-b-g89cxt4t7i 2.6s ease-in-out infinite;
}

@keyframes dlh-nucleus-pulse-b-g89cxt4t7i {
    0%,  100% {
        transform: scale(1);
        box-shadow: 0 0 22px 8px rgba(26,155,196,0.75), 0 0 6px 2px rgba(168,232,255,0.9);
    }
    50% {
        transform: scale(1.3);
        box-shadow: 0 0 38px 16px rgba(26,155,196,0.55), 0 0 10px 4px rgba(168,232,255,0.7);
    }
}

/* BOMSync wordmark below nucleus */
.dlh-wordmark[b-g89cxt4t7i] {
    position: absolute;
    top: calc(50% + 56px);
    left: 50%;
    transform: translateX(-50%);
    font-family: 'Segoe UI', system-ui, sans-serif;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .18em;
    color: rgba(168,232,255,0.75);
    white-space: nowrap;
    z-index: 10;
    text-transform: uppercase;
    animation: dlh-wm-pulse-b-g89cxt4t7i 2.6s ease-in-out infinite;
}

@keyframes dlh-wm-pulse-b-g89cxt4t7i {
    0%,  100% { opacity: .75; }
    50%        { opacity: 1; }
}


/* ── Source node cards ───────────────────────────────────────── */

.dlh-nc[b-g89cxt4t7i] {
    position: absolute;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    z-index: 15;
}

/* layout positions — all relative to scene 560×420, core centre = 280,210 */
.dlh-nc-bim[b-g89cxt4t7i]      { top: 14px;   left: 50%;    transform: translateX(-50%); }
.dlh-nc-erp[b-g89cxt4t7i]      { top: 56px;   left: 3%;     }
.dlh-nc-iot[b-g89cxt4t7i]      { top: 56px;   right: 3%;    }
.dlh-nc-ai[b-g89cxt4t7i]       { top: 158px;  left: 0%;     }
.dlh-nc-teams[b-g89cxt4t7i]    { top: 158px;  right: 0%;    }
.dlh-nc-hist[b-g89cxt4t7i]     { bottom: 56px; left: 3%;    }
.dlh-nc-field[b-g89cxt4t7i]    { bottom: 56px; right: 3%;   }
.dlh-nc-facility[b-g89cxt4t7i] { bottom: 14px; left: 50%;   transform: translateX(-50%); }

.dlh-node-icon[b-g89cxt4t7i] {
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #0d2033;
    border: 1px solid rgba(26,155,196,0.35);
    animation: dlh-node-glow-b-g89cxt4t7i 3s ease-in-out infinite;
}

@keyframes dlh-node-glow-b-g89cxt4t7i {
    0%,  100% { border-color: rgba(26,155,196,0.35); box-shadow: none; }
    50%        { border-color: rgba(42,184,212,0.70); box-shadow: 0 0 10px 2px rgba(26,155,196,0.25); }
}

.dlh-node-lbl[b-g89cxt4t7i] {
    font-family: sans-serif;
    font-size: 8px;
    font-weight: 600;
    letter-spacing: .07em;
    color: rgba(168,232,255,0.55);
    text-transform: uppercase;
    text-align: center;
    white-space: nowrap;
}


/* ── Data particles — shared ─────────────────────────────────── */

.dlh-dp[b-g89cxt4t7i] {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 18;
}

/* inbound — bright white-teal (collecting from source) */
.dlh-dp-in[b-g89cxt4t7i]  { background: #a8e8ff; box-shadow: 0 0 5px 2px rgba(168,232,255,.85); }
/* inbound variant */
.dlh-dp-mid[b-g89cxt4t7i] { background: #4dd0e8; box-shadow: 0 0 4px 2px rgba(77,208,232,.80);  }


/* ═══════════════════════════════════════════════════════════════
   INBOUND COLLECT PARTICLES
   Loop 3.2s — runs continuously giving 3 full waves before the
   outbound particles fire at 9.6s.
   ═══════════════════════════════════════════════════════════════ */

/* BIM → core */
.dlh-p-bim-in[b-g89cxt4t7i] { width:4px; height:4px; animation: dlh-p-bim-in-b-g89cxt4t7i 3.2s linear infinite; animation-delay: 0.0s; }
@keyframes dlh-p-bim-in-b-g89cxt4t7i {
    0%   { left:50%; top:52px;  transform:translate(-50%,0) scale(0);        opacity:0; }
    6%   {                      transform:translate(-50%,0) scale(1);         opacity:1; }
    88%  {                                                                    opacity:.9; }
    100% { left:50%; top:50%;   transform:translate(-50%,-50%) scale(.3);    opacity:0; }
}

/* ERP → core */
.dlh-p-erp-in[b-g89cxt4t7i] { width:3px; height:3px; animation: dlh-p-erp-in-b-g89cxt4t7i 3.2s linear infinite; animation-delay: 0.4s; }
@keyframes dlh-p-erp-in-b-g89cxt4t7i {
    0%   { left:68px;  top:108px; transform:scale(0);                        opacity:0; }
    6%   {                        transform:scale(1);                         opacity:1; }
    88%  {                                                                    opacity:.9; }
    100% { left:50%;   top:50%;   transform:translate(-50%,-50%) scale(.3);  opacity:0; }
}

/* IoT → core */
.dlh-p-iot-in[b-g89cxt4t7i] { width:3px; height:3px; animation: dlh-p-iot-in-b-g89cxt4t7i 3.2s linear infinite; animation-delay: 0.8s; }
@keyframes dlh-p-iot-in-b-g89cxt4t7i {
    0%   { right:68px; top:108px; transform:scale(0);                        opacity:0; }
    6%   {                         transform:scale(1);                        opacity:1; }
    88%  {                                                                    opacity:.9; }
    100% { left:50%;   top:50%;   transform:translate(-50%,-50%) scale(.3);  opacity:0; }
}

/* AI → core */
.dlh-p-ai-in[b-g89cxt4t7i] { width:4px; height:4px; animation: dlh-p-ai-in-b-g89cxt4t7i 3.2s linear infinite; animation-delay: 1.2s; }
@keyframes dlh-p-ai-in-b-g89cxt4t7i {
    0%   { left:28px;  top:192px; transform:scale(0);                        opacity:0; }
    6%   {                        transform:scale(1);                         opacity:1; }
    88%  {                                                                    opacity:.9; }
    100% { left:50%;   top:50%;   transform:translate(-50%,-50%) scale(.4);  opacity:0; }
}

/* Teams → core */
.dlh-p-teams-in[b-g89cxt4t7i] { width:3px; height:3px; animation: dlh-p-teams-in-b-g89cxt4t7i 3.2s linear infinite; animation-delay: 1.6s; }
@keyframes dlh-p-teams-in-b-g89cxt4t7i {
    0%   { right:28px; top:192px; transform:scale(0);                        opacity:0; }
    6%   {                         transform:scale(1);                        opacity:1; }
    88%  {                                                                    opacity:.9; }
    100% { left:50%;   top:50%;   transform:translate(-50%,-50%) scale(.3);  opacity:0; }
}

/* History → core */
.dlh-p-hist-in[b-g89cxt4t7i] { width:3px; height:3px; animation: dlh-p-hist-in-b-g89cxt4t7i 3.2s linear infinite; animation-delay: 2.0s; }
@keyframes dlh-p-hist-in-b-g89cxt4t7i {
    0%   { left:68px;  top:312px; transform:scale(0);                        opacity:0; }
    6%   {                        transform:scale(1);                         opacity:1; }
    88%  {                                                                    opacity:.8; }
    100% { left:50%;   top:50%;   transform:translate(-50%,-50%) scale(.3);  opacity:0; }
}

/* Field → core */
.dlh-p-field-in[b-g89cxt4t7i] { width:3px; height:3px; animation: dlh-p-field-in-b-g89cxt4t7i 3.2s linear infinite; animation-delay: 2.4s; }
@keyframes dlh-p-field-in-b-g89cxt4t7i {
    0%   { right:68px; top:312px; transform:scale(0);                        opacity:0; }
    6%   {                         transform:scale(1);                        opacity:1; }
    88%  {                                                                    opacity:.8; }
    100% { left:50%;   top:50%;   transform:translate(-50%,-50%) scale(.3);  opacity:0; }
}

/* Facility → core */
.dlh-p-fac-in[b-g89cxt4t7i] { width:4px; height:4px; animation: dlh-p-fac-in-b-g89cxt4t7i 3.2s linear infinite; animation-delay: 2.8s; }
@keyframes dlh-p-fac-in-b-g89cxt4t7i {
    0%   { left:50%;   bottom:52px; transform:translate(-50%,0) scale(0);    opacity:0; }
    6%   {                          transform:translate(-50%,0) scale(1);     opacity:1; }
    88%  {                                                                    opacity:.9; }
    100% { left:50%;   top:50%;   transform:translate(-50%,-50%) scale(.3);  opacity:0; }
}


/* ═══════════════════════════════════════════════════════════════
   OUTBOUND DISPATCH PARTICLES
   19.2s cycle — delay 9.6s so they fire only after 3 full
   inbound collect waves. Teal colour distinguishes direction.
   ═══════════════════════════════════════════════════════════════ */

/* BOM → BIM */
.dlh-p-bim-out[b-g89cxt4t7i] { width:4px; height:4px; background:#1a9bc4; box-shadow:0 0 6px 2px rgba(26,155,196,.9); animation: dlh-p-bim-out-b-g89cxt4t7i 9.6s linear infinite; animation-delay: 9.6s; }
@keyframes dlh-p-bim-out-b-g89cxt4t7i {
    0%   { left:50%;   top:50%;  transform:translate(-50%,-50%) scale(.5);   opacity:0; }
    4%   {                       transform:translate(-50%,-50%) scale(1);     opacity:1; }
    88%  {                                                                    opacity:.9; }
    100% { left:50%;   top:52px; transform:translate(-50%,0) scale(0);       opacity:0; }
}

/* BOMSync → ERP */
.dlh-p-erp-out[b-g89cxt4t7i] { width:3px; height:3px; background:#2ab8d4; box-shadow:0 0 5px 2px rgba(42,184,212,.9); animation: dlh-p-erp-out-b-g89cxt4t7i 9.6s linear infinite; animation-delay: 10.0s; }
@keyframes dlh-p-erp-out-b-g89cxt4t7i {
    0%   { left:50%;   top:50%;  transform:translate(-50%,-50%) scale(.4);   opacity:0; }
    4%   {                       transform:scale(1);                          opacity:1; }
    88%  {                                                                    opacity:.9; }
    100% { left:68px;  top:108px; transform:scale(0);                        opacity:0; }
}

/* BOMSync → IoT */
.dlh-p-iot-out[b-g89cxt4t7i] { width:3px; height:3px; background:#4dd0e8; box-shadow:0 0 5px 2px rgba(77,208,232,.9); animation: dlh-p-iot-out-b-g89cxt4t7i 9.6s linear infinite; animation-delay: 10.4s; }
@keyframes dlh-p-iot-out-b-g89cxt4t7i {
    0%   { left:50%;   top:50%;   transform:translate(-50%,-50%) scale(.4);  opacity:0; }
    4%   {                        transform:scale(1);                         opacity:1; }
    88%  {                                                                    opacity:.9; }
    100% { right:68px; top:108px; transform:scale(0);                        opacity:0; }
}

/* BOMSync → AI */
.dlh-p-ai-out[b-g89cxt4t7i] { width:4px; height:4px; background:#1a9bc4; box-shadow:0 0 6px 2px rgba(26,155,196,.9); animation: dlh-p-ai-out-b-g89cxt4t7i 9.6s linear infinite; animation-delay: 10.8s; }
@keyframes dlh-p-ai-out-b-g89cxt4t7i {
    0%   { left:50%;   top:50%;   transform:translate(-50%,-50%) scale(.5);  opacity:0; }
    4%   {                        transform:scale(1);                         opacity:1; }
    88%  {                                                                    opacity:.9; }
    100% { left:28px;  top:192px; transform:scale(0);                        opacity:0; }
}

/* BOMSync → Teams */
.dlh-p-teams-out[b-g89cxt4t7i] { width:3px; height:3px; background:#2ab8d4; box-shadow:0 0 5px 2px rgba(42,184,212,.9); animation: dlh-p-teams-out-b-g89cxt4t7i 9.6s linear infinite; animation-delay: 11.2s; }
@keyframes dlh-p-teams-out-b-g89cxt4t7i {
    0%   { left:50%;   top:50%;   transform:translate(-50%,-50%) scale(.4);  opacity:0; }
    4%   {                        transform:scale(1);                         opacity:1; }
    88%  {                                                                    opacity:.9; }
    100% { right:28px; top:192px; transform:scale(0);                        opacity:0; }
}

/* BOMSync → Facility */
.dlh-p-fac-out[b-g89cxt4t7i] { width:4px; height:4px; background:#1a9bc4; box-shadow:0 0 6px 2px rgba(26,155,196,.9); animation: dlh-p-fac-out-b-g89cxt4t7i 9.6s linear infinite; animation-delay: 11.6s; }
@keyframes dlh-p-fac-out-b-g89cxt4t7i {
    0%   { left:50%;   top:50%;   transform:translate(-50%,-50%) scale(.5);  opacity:0; }
    4%   {                        transform:scale(1);                         opacity:1; }
    88%  {                                                                    opacity:.9; }
    100% { left:50%;   bottom:52px; transform:translate(-50%,0) scale(0);    opacity:0; }
}

/* BOMSync → Field */
.dlh-p-field-out[b-g89cxt4t7i] { width:3px; height:3px; background:#4dd0e8; box-shadow:0 0 5px 2px rgba(77,208,232,.9); animation: dlh-p-field-out-b-g89cxt4t7i 9.6s linear infinite; animation-delay: 12.0s; }
@keyframes dlh-p-field-out-b-g89cxt4t7i {
    0%   { left:50%;   top:50%;   transform:translate(-50%,-50%) scale(.4);  opacity:0; }
    4%   {                        transform:scale(1);                         opacity:1; }
    88%  {                                                                    opacity:.9; }
    100% { right:68px; top:312px; transform:scale(0);                        opacity:0; }
}

/* BOMSync → History */
.dlh-p-hist-out[b-g89cxt4t7i] { width:3px; height:3px; background:#2ab8d4; box-shadow:0 0 5px 2px rgba(42,184,212,.9); animation: dlh-p-hist-out-b-g89cxt4t7i 9.6s linear infinite; animation-delay: 12.4s; }
@keyframes dlh-p-hist-out-b-g89cxt4t7i {
    0%   { left:50%;   top:50%;   transform:translate(-50%,-50%) scale(.4);  opacity:0; }
    4%   {                        transform:scale(1);                         opacity:1; }
    88%  {                                                                    opacity:.9; }
    100% { left:68px;  top:312px; transform:scale(0);                        opacity:0; }
}


/* ── Bottom caption ──────────────────────────────────────────── */

.dlh-caption[b-g89cxt4t7i] {
    font-family: sans-serif;
    font-size: 11px;
    font-weight: 600;
    color: rgb(186 228 255 / 0.95);
    letter-spacing: 0.14em;
    text-transform: uppercase;
    text-align: center;
    margin-top: 10px;
    text-shadow: 0 0 18px rgb(26 155 196 / 0.45), 0 1px 2px rgb(17 27 44 / 0.5);
}

/* Subtle pulse with the 3D stage so the caption reads as part of the motion (Platform). */
.dlh-stage--neural-3d .dlh-caption[b-g89cxt4t7i] {
    animation: dlh-caption-pulse-b-g89cxt4t7i 3.5s ease-in-out infinite;
}

@keyframes dlh-caption-pulse-b-g89cxt4t7i {
    0%, 100% {
        opacity: 0.9;
        filter: brightness(1);
    }
    50% {
        opacity: 1;
        filter: brightness(1.12);
    }
}

/* ── CSS 3D choreography (Platform): perspective + preserve-3d scene + node depth ── */
.dlh-stage--neural-3d[b-g89cxt4t7i] {
    perspective: 1400px;
    perspective-origin: 50% 40%;
}

.dlh-stage--neural-3d .dlh-scene[b-g89cxt4t7i] {
    transform-style: preserve-3d;
    animation: dlh-scene-3d-choreography-b-g89cxt4t7i 18s ease-in-out infinite;
    will-change: transform;
}

/* Combined tilt, gentle Z drift, and micro yaw — “alive” plate (DataLayerHero / Public animation pack) */
@keyframes dlh-scene-3d-choreography-b-g89cxt4t7i {
    0%, 100% {
        transform: rotateX(4deg) rotateY(-5deg) rotateZ(0deg) translateZ(0);
    }
    20% {
        transform: rotateX(2deg) rotateY(2deg) rotateZ(0.4deg) translateZ(14px);
    }
    45% {
        transform: rotateX(-1deg) rotateY(4deg) rotateZ(-0.25deg) translateZ(8px);
    }
    70% {
        transform: rotateX(2.5deg) rotateY(-3deg) rotateZ(0.2deg) translateZ(12px);
    }
}

/* Per-node motion avoided here: several .dlh-nc use translateX(-50%); extra transforms would break alignment. */

/* Reduced motion: disable 3D plate, ring spin, and bursts only (particles/pulses remain). */
@media (prefers-reduced-motion: reduce) {
    .dlh-stage--neural-3d .dlh-scene[b-g89cxt4t7i] {
        animation: none !important;
        transform: none !important;
        will-change: auto;
    }

    .dlh-plane[b-g89cxt4t7i] {
        animation: none !important;
    }

    .dlh-burst[b-g89cxt4t7i] {
        animation: none !important;
    }
}

.dlh-stage--static *[b-g89cxt4t7i],
.dlh-stage--static *[b-g89cxt4t7i]::before,
.dlh-stage--static *[b-g89cxt4t7i]::after {
    animation: none !important;
    transition: none !important;
}

.dlh-stage--static.dlh-stage--neural-3d .dlh-scene[b-g89cxt4t7i] {
    transform: none !important;
}
/* /Components/Marketing/ValueChainDiagram.razor.rz.scp.css */
.vcd-root[b-rhggvs0csl] {
    --vcd-line: rgb(80 120 180 / 0.45);
    --vcd-text: var(--bomsync-on-dark-text, #e8edf5);
    --vcd-text-soft: rgb(232 237 245 / 0.72);
    --vcd-accent: #7eb3f7;
    width: 100%;
    max-width: 960px;
    margin: 0 auto;
    padding: 1.5rem 1rem 2rem;
    position: relative;
    background: var(--brand-blue, #111b2c);
    border-radius: 16px;
    box-shadow: var(--bomsync-shadow-lg, 0 4px 24px rgb(17 27 44 / 0.2));
    color: var(--vcd-text);
}

.vcd-top-header[b-rhggvs0csl] {
    text-align: center;
    margin-bottom: 0.75rem;
}

.vcd-value-chain-wrap[b-rhggvs0csl] {
    text-align: center;
    margin-bottom: 1.35rem;
}

.vcd-vc-eyebrow[b-rhggvs0csl] {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--vcd-accent);
    margin-bottom: 0.5rem;
}

.vcd-main-title[b-rhggvs0csl] {
    font-size: clamp(0.85rem, 1.6vw, 0.95rem);
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--vcd-accent);
    margin-bottom: 0.5rem;
    line-height: 1.35;
}

.vcd-top-arrows[b-rhggvs0csl] {
    display: flex;
    justify-content: center;
    margin: 0.5rem 0 0.75rem;
}

.vcd-value-chain-bar[b-rhggvs0csl] {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.15rem 0;
    max-width: 820px;
    margin: 0 auto;
}

.vcd-vc-item[b-rhggvs0csl] {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 10px;
    color: rgb(154 180 212 / 0.95);
    white-space: nowrap;
}

.vcd-vc-highlight[b-rhggvs0csl] {
    color: rgb(200 216 240 / 0.98);
}

.vcd-dot[b-rhggvs0csl] {
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: #4a7aaa;
    flex-shrink: 0;
}

.vcd-vc-highlight .vcd-dot[b-rhggvs0csl] {
    background: var(--vcd-accent);
}

.vcd-vc-arrow[b-rhggvs0csl] {
    color: #2a4a6a;
    font-size: 13px;
    margin: 0 3px;
    flex-shrink: 0;
}

.vcd-layer[b-rhggvs0csl] {
    position: relative;
    border-radius: 10px 10px 4px 4px;
    padding: 1.15rem 1.1rem 1rem;
    margin-bottom: 3px;
    overflow: visible;
}

.vcd-layer-ai[b-rhggvs0csl] {
    background: linear-gradient(160deg, #111827 0%, #0e1520 100%);
    border: 1px solid #1e3a5f;
    border-bottom: 2px solid #153050;
    min-height: auto;
}

.vcd-layer-ontology[b-rhggvs0csl] {
    background: linear-gradient(160deg, #0f1b2a 0%, #0c1520 100%);
    border: 1px solid #1a3050;
    border-bottom: 2px solid #122540;
    margin-top: -2px;
}

.vcd-layer-security[b-rhggvs0csl] {
    background: linear-gradient(160deg, #0d1520 0%, #0a1018 100%);
    border: 1px solid #162035;
    border-bottom: 2px solid #0e1828;
    margin-top: -2px;
}

.vcd-layer-data[b-rhggvs0csl] {
    background: linear-gradient(160deg, #0b1018 0%, #080c12 100%);
    border: 1px solid #131d2e;
    border-bottom: 2px solid #0a1220;
    margin-top: -2px;
}

.vcd-layer-label[b-rhggvs0csl] {
    display: flex;
    flex-direction: column;
    margin-bottom: 0.85rem;
}

.vcd-l-name[b-rhggvs0csl] {
    font-size: 0.95rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    line-height: 1.25;
    color: var(--vcd-accent);
}

.vcd-layer-ontology .vcd-l-name[b-rhggvs0csl] {
    color: #8fa8d8;
}

.vcd-layer-security .vcd-l-name[b-rhggvs0csl] {
    color: #6e8db8;
}

.vcd-layer-data .vcd-l-name[b-rhggvs0csl] {
    color: #5c7aa0;
}

.vcd-l-sub[b-rhggvs0csl] {
    font-size: 10px;
    letter-spacing: 0.1em;
    opacity: 0.55;
    margin-top: 4px;
    text-transform: uppercase;
    color: var(--vcd-text-soft);
}

.vcd-module-grid[b-rhggvs0csl] {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.vcd-mod-card[b-rhggvs0csl] {
    background: rgb(30 55 90 / 0.35);
    border: 1px solid rgb(80 140 210 / 0.18);
    border-radius: 7px;
    padding: 9px 11px;
    font-size: 10px;
    position: relative;
    flex: 1 1 140px;
    min-width: 120px;
    max-width: 220px;
}

.vcd-mod-card:hover[b-rhggvs0csl] {
    background: rgb(50 90 150 / 0.45);
    border-color: rgb(100 170 255 / 0.35);
}

.vcd-mc-label[b-rhggvs0csl] {
    font-size: 10px;
    font-weight: 600;
    color: #a8c4e8;
    display: block;
    margin-bottom: 4px;
    letter-spacing: 0.03em;
}

.vcd-mc-detail[b-rhggvs0csl] {
    font-size: 9px;
    color: #5a7898;
    line-height: 1.4;
}

.vcd-mc-badge[b-rhggvs0csl] {
    position: absolute;
    top: 5px;
    right: 6px;
    font-size: 8px;
    font-weight: 700;
    color: #3a7abf;
    letter-spacing: 0.05em;
}

.vcd-featured[b-rhggvs0csl] {
    border-color: rgb(120 180 255 / 0.4);
    background: rgb(15 40 80 / 0.55);
    padding: 12px 14px;
}

.vcd-featured .vcd-mc-label[b-rhggvs0csl] {
    font-size: 11px;
    color: #90c8ff;
}

.vcd-accent-cyan[b-rhggvs0csl] {
    border-color: rgb(80 200 200 / 0.22);
    background: rgb(20 60 70 / 0.35);
}

.vcd-accent-cyan .vcd-mc-label[b-rhggvs0csl] {
    color: #70c8c0;
}

.vcd-accent-purple[b-rhggvs0csl] {
    border-color: rgb(140 100 220 / 0.25);
    background: rgb(35 20 65 / 0.35);
}

.vcd-accent-purple .vcd-mc-label[b-rhggvs0csl] {
    color: #b090e8;
}

.vcd-accent-amber[b-rhggvs0csl] {
    border-color: rgb(220 160 50 / 0.22);
    background: rgb(50 35 10 / 0.35);
}

.vcd-accent-amber .vcd-mc-label[b-rhggvs0csl] {
    color: #d4a050;
}

.vcd-entity-row[b-rhggvs0csl] {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.vcd-entity-chip[b-rhggvs0csl] {
    font-size: 10px;
    color: #6a90b8;
    padding: 6px 12px;
    border: 1px solid rgb(60 100 160 / 0.35);
    border-radius: 20px;
    background: rgb(20 40 70 / 0.4);
}

.vcd-entity-chip:hover[b-rhggvs0csl] {
    border-color: rgb(100 160 255 / 0.45);
    color: #9abde0;
}

.vcd-security-grid[b-rhggvs0csl] {
    display: flex;
    gap: 14px 18px;
    flex-wrap: wrap;
    align-items: flex-start;
}

.vcd-sec-item[b-rhggvs0csl] {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: 10px;
    color: #5a7898;
}

.vcd-sec-dot[b-rhggvs0csl] {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    flex-shrink: 0;
}

.vcd-sec-active[b-rhggvs0csl] {
    background: #4a8abf;
    box-shadow: 0 0 4px rgb(74 138 191 / 0.45);
}

.vcd-sec-passive[b-rhggvs0csl] {
    background: #1e3550;
    border: 1px solid #2a4060;
}

.vcd-iso-badges[b-rhggvs0csl] {
    display: flex;
    gap: 6px;
    margin-top: 10px;
    flex-wrap: wrap;
}

.vcd-iso-badge[b-rhggvs0csl] {
    font-size: 8px;
    padding: 2px 7px;
    border-radius: 3px;
    background: rgb(20 40 70 / 0.5);
    border: 1px solid rgb(50 90 150 / 0.35);
    color: #4a7aaa;
    letter-spacing: 0.08em;
    font-weight: 700;
}

.vcd-foundation[b-rhggvs0csl] {
    padding: 0.25rem 0 0.35rem;
}

.vcd-foundation-list[b-rhggvs0csl] {
    margin: 0;
    padding-left: 1.2rem;
    font-size: 0.9rem;
    line-height: 1.55;
    color: var(--vcd-text-soft);
}

.vcd-foundation-list strong[b-rhggvs0csl] {
    color: var(--vcd-text);
    font-weight: 600;
}

.vcd-stack-note[b-rhggvs0csl] {
    margin: 1rem 0 0;
    font-size: 10px;
    letter-spacing: 0.06em;
    color: #3a5878;
    line-height: 1.5;
}

.vcd-layer-edge-line[b-rhggvs0csl] {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgb(50 100 180 / 0.28) 30%, rgb(50 100 180 / 0.28) 70%, transparent);
}

.vcd-layer-sep[b-rhggvs0csl] {
    height: 4px;
    background: linear-gradient(90deg, #0d0f14, rgb(20 50 100 / 0.28), #0d0f14);
    margin: -1px 0;
    position: relative;
    z-index: 2;
}

.vcd-bottom-note[b-rhggvs0csl] {
    text-align: center;
    margin-top: 1.25rem;
    margin-bottom: 0;
    font-size: 9.5px;
    color: #2a4060;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

@keyframes vcd-pulse-dot-b-rhggvs0csl {
    0%, 100% {
        opacity: 0.35;
        transform: scale(1);
    }
    50% {
        opacity: 1;
        transform: scale(1.12);
    }
}

.vcd-pulse[b-rhggvs0csl] {
    animation: vcd-pulse-dot-b-rhggvs0csl 2.5s ease-in-out infinite;
}

.vcd-pulse-delay-1[b-rhggvs0csl] {
    animation-delay: 0.5s;
}

.vcd-pulse-delay-2[b-rhggvs0csl] {
    animation-delay: 1s;
}

.vcd-pulse-delay-3[b-rhggvs0csl] {
    animation-delay: 1.5s;
}

@media (max-width: 600px) {
    .vcd-value-chain-bar[b-rhggvs0csl] {
        justify-content: center;
    }

    .vcd-vc-arrow[b-rhggvs0csl] {
        display: none;
    }

    .vcd-mod-card[b-rhggvs0csl] {
        flex: 1 1 calc(50% - 4px);
    }
}

@media (prefers-reduced-motion: reduce) {
    .vcd-pulse[b-rhggvs0csl],
    .vcd-pulse-delay-1[b-rhggvs0csl],
    .vcd-pulse-delay-2[b-rhggvs0csl],
    .vcd-pulse-delay-3[b-rhggvs0csl] {
        animation: none !important;
    }
}
/* /Components/Pages/Public/BetaNda.razor.rz.scp.css */
/* Visual styles for .legal-doc-page are in wwwroot/css/legal-doc-pages.css (shared with Terms, Privacy, DPA). */
/* /Components/Pages/Public/Invest.razor.rz.scp.css */
.invest-page .metric-card[b-2c0d16n8xt] {
    background: #0b1b2a;
    color: #f3f4f6;
    border-radius: 8px;
    padding: 16px;
    height: 100%;
}

.metric-title[b-2c0d16n8xt] {
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    opacity: 0.8;
}

.metric-value[b-2c0d16n8xt] {
    font-size: 1.4rem;
    font-weight: 700;
    margin-top: 6px;
}

.metric-sub[b-2c0d16n8xt] {
    font-size: 0.85rem;
    opacity: 0.8;
    margin-top: 4px;
}

.invest-top-bar[b-2c0d16n8xt] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.invest-layout[b-2c0d16n8xt] {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 24px;
}

.invest-nav[b-2c0d16n8xt] {
    position: sticky;
    top: 20px;
    align-self: start;
    background: #0b1b2a;
    border-radius: 10px;
    padding: 16px;
    color: #f9fafb;
}

.invest-nav .nav-title[b-2c0d16n8xt] {
    font-weight: 700;
    margin-bottom: 10px;
}

.invest-nav a[b-2c0d16n8xt] {
    display: block;
    color: #e5e7eb;
    text-decoration: none;
    padding: 6px 0;
    font-size: 0.9rem;
}

.invest-nav a:hover[b-2c0d16n8xt] {
    color: #ffffff;
}

.invest-section[b-2c0d16n8xt] {
    padding-bottom: 28px;
    border-bottom: 1px solid #e5e7eb;
    margin-bottom: 28px;
}

.invest-section h3[b-2c0d16n8xt] {
    margin-bottom: 12px;
}

.invest-watermark[b-2c0d16n8xt] {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 1;
    opacity: 0.12;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-auto-rows: 140px;
    transform: rotate(-15deg);
}

.invest-watermark span[b-2c0d16n8xt] {
    font-size: 0.9rem;
    color: #111827;
    white-space: nowrap;
    align-self: center;
    justify-self: center;
}

.invest-content[b-2c0d16n8xt] {
    position: relative;
    z-index: 2;
}

.nda-card[b-2c0d16n8xt] {
    background: #f8fafc;
}

.invest-auth-tabs[b-2c0d16n8xt] {
    background: #ffffff;
    border-radius: 8px;
    padding: 12px;
}

@media (max-width: 992px) {
    .invest-layout[b-2c0d16n8xt] {
        grid-template-columns: 1fr;
    }

    .invest-nav[b-2c0d16n8xt] {
        position: relative;
    }
}
/* /Components/Pages/Public/PreReleaseConfidentiality.razor.rz.scp.css */
/* Visual styles for .legal-doc-page are in wwwroot/css/legal-doc-pages.css (shared with Terms, Privacy, DPA). */
/* /Components/Pages/Public/Testing.razor.rz.scp.css */
.testing-page[b-0pb1nnwejk] {
    min-height: 100vh;
    background: var(--bomsync-page-bg, #0b1220);
    padding: 16px 20px 48px;
}

.testing-banner[b-0pb1nnwejk] {
    background: rgba(26, 155, 196, 0.12);
    border: 1px solid rgba(26, 155, 196, 0.25);
    border-radius: 8px;
    padding: 10px 14px;
    margin-bottom: 24px;
    color: rgba(168, 232, 255, 0.85);
}

.testing-section[b-0pb1nnwejk] {
    margin-bottom: 40px;
}

.testing-section h1[b-0pb1nnwejk] {
    margin-bottom: 6px;
}

.testing-login-mock[b-0pb1nnwejk] {
    position: relative;
    border-radius: 16px;
    overflow: hidden;
    max-width: 720px;
}

.testing-login-card[b-0pb1nnwejk] {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    pointer-events: none;
}

.testing-login-card p[b-0pb1nnwejk] {
    background: rgba(8, 15, 30, 0.88);
    border: 1px solid rgba(26, 155, 196, 0.35);
    border-radius: 12px;
    padding: 24px 32px;
    color: rgba(168, 232, 255, 0.75) !important;
}

.testing-init-stack[b-0pb1nnwejk] {
    position: relative;
    border-radius: 16px;
    overflow: hidden;
    max-width: 900px;
}

.testing-init-overlay[b-0pb1nnwejk] {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    z-index: 50;
    background: rgba(8, 15, 30, 0.55);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
}

.testing-init-caption[b-0pb1nnwejk] {
    font-size: 13px;
    letter-spacing: 0.08em;
    color: rgba(168, 232, 255, 0.7);
}

.empty-layout-root[b-0pb1nnwejk] {
    min-height: 100vh;
}
/* /Components/Templates/BusyIndicator.razor.rz.scp.css */
/* BOMSync neural busy indicator — scoped; pure CSS, no JS. */

.bs-ind[b-ee5mermedq] {
    position: relative;
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
    /* Dark navy disk — uncomment to restore default look */
    /* background: radial-gradient(ellipse at 38% 35%, #0d2540 0%, #080f1e 70%); */
    background: transparent;
}

.bs-ind--sm[b-ee5mermedq] { width: 47px;  height: 47px;  }
.bs-ind--md[b-ee5mermedq] { width: 94px;  height: 94px;  }
.bs-ind--lg[b-ee5mermedq] { width: 141px; height: 141px; }


.bs-core[b-ee5mermedq] {
    position: absolute;
    border-radius: 50%;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    animation: bs-core-pulse-b-ee5mermedq 2.4s ease-in-out infinite;
    pointer-events: none;
}

.bs-ind--sm .bs-core[b-ee5mermedq] {
    width: 10px; height: 10px;
    background: radial-gradient(circle, #a8e8ff 0%, #1a9bc4 40%, rgba(20,130,180,0) 100%);
    box-shadow: 0 0 10px 4px rgba(26,155,196,0.75);
}

.bs-ind--md .bs-core[b-ee5mermedq] {
    width: 14px; height: 14px;
    background: radial-gradient(circle, #c0f0ff 0%, #1a9bc4 40%, rgba(20,130,180,0) 100%);
    box-shadow: 0 0 18px 7px rgba(26,155,196,0.70);
}

.bs-ind--lg .bs-core[b-ee5mermedq] {
    width: 20px; height: 20px;
    background: radial-gradient(circle, #c0f0ff 0%, #1a9bc4 40%, rgba(20,130,180,0) 100%);
    box-shadow: 0 0 28px 10px rgba(26,155,196,0.65);
}

@keyframes bs-core-pulse-b-ee5mermedq {
    0%,  100% { transform: translate(-50%, -50%) scale(1);    opacity: 1;  }
    50%        { transform: translate(-50%, -50%) scale(1.35); opacity: .7; }
}


.bs-halo[b-ee5mermedq] {
    position: absolute;
    border-radius: 50%;
    top: 50%;
    left: 50%;
    transform-origin: center center;
    pointer-events: none;
}

.bs-h1[b-ee5mermedq] {
    width: 68%; height: 68%;
    margin-left: -34%; margin-top: -34%;
    border: 1px solid rgba(26,155,196,0.22);
    animation: bs-spin-cw-b-ee5mermedq 8s linear infinite;
}

.bs-h2[b-ee5mermedq] {
    width: 82%; height: 82%;
    margin-left: -41%; margin-top: -41%;
    border: 1px solid rgba(42,184,212,0.12);
    animation: bs-spin-ccw-b-ee5mermedq 14s linear infinite;
}

.bs-h3[b-ee5mermedq] {
    width: 55%; height: 55%;
    margin-left: -27.5%; margin-top: -27.5%;
    border: 1px dashed rgba(26,155,196,0.15);
    animation: bs-spin-cw-b-ee5mermedq 6s linear infinite;
}

@keyframes bs-spin-cw-b-ee5mermedq  { to { transform: rotate(360deg);  } }
@keyframes bs-spin-ccw-b-ee5mermedq { to { transform: rotate(-360deg); } }


.bs-lines[b-ee5mermedq] {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    overflow: visible;
    pointer-events: none;
}

.bs-ln[b-ee5mermedq] {
    stroke-width: 0.6;
    fill: none;
    stroke-linecap: round;
}

.bs-ln-teal[b-ee5mermedq]   { stroke: rgba(26,155,196,0.38); }
.bs-ln-blue[b-ee5mermedq]   { stroke: rgba(42,184,212,0.25); }

.bs-ln-bright[b-ee5mermedq] {
    stroke: rgba(168,232,255,0.55);
    animation: bs-line-flash-b-ee5mermedq 3s ease-in-out infinite;
}

.bs-ln-bright2[b-ee5mermedq] {
    stroke: rgba(168,232,255,0.55);
    animation: bs-line-flash-b-ee5mermedq 3s ease-in-out infinite;
    animation-delay: 1.5s;
}

@keyframes bs-line-flash-b-ee5mermedq {
    0%,  100% { opacity: .5; stroke-width: .6;  }
    50%        { opacity: 1;  stroke-width: 1.1; }
}


.bs-nd[b-ee5mermedq] {
    position: absolute;
    border-radius: 50%;
    top: 50%;
    left: 50%;
    pointer-events: none;
    animation: bs-nd-breathe-b-ee5mermedq 3s ease-in-out infinite;
}

@keyframes bs-nd-breathe-b-ee5mermedq {
    0%,  100% { opacity: .9; transform: translate(-50%, -50%) var(--tp) scale(1);  }
    50%        { opacity: .3; transform: translate(-50%, -50%) var(--tp) scale(.7); }
}

.bs-nd1[b-ee5mermedq] { --tp: translate(24px,-22px);  width: 6px; height: 6px; background: #1a9bc4; box-shadow: 0 0 7px 3px rgba(26,155,196,.85); animation-delay: 0.0s; }
.bs-nd3[b-ee5mermedq] { --tp: translate(18px, 26px);  width: 7px; height: 7px; background: #1a9bc4; box-shadow: 0 0 8px 3px rgba(26,155,196,.85); animation-delay: 1.2s; }
.bs-nd7[b-ee5mermedq] { --tp: translate(-8px,-34px);  width: 5px; height: 5px; background: #1a9bc4; box-shadow: 0 0 6px 2px rgba(26,155,196,.85); animation-delay: 2.2s; }

.bs-nd2[b-ee5mermedq] { --tp: translate(-26px,-14px); width: 5px; height: 5px; background: #2ab8d4; box-shadow: 0 0 6px 2px rgba(42,184,212,.80); animation-delay: 0.6s; }
.bs-nd4[b-ee5mermedq] { --tp: translate(-20px, 22px); width: 5px; height: 5px; background: #2ab8d4; box-shadow: 0 0 6px 2px rgba(42,184,212,.75); animation-delay: 1.8s; }
.bs-nd8[b-ee5mermedq] { --tp: translate(8px,  35px);  width: 4px; height: 4px; background: #2ab8d4; box-shadow: 0 0 5px 2px rgba(42,184,212,.75); animation-delay: 0.8s; }

.bs-nd5[b-ee5mermedq] { --tp: translate(36px,   4px); width: 4px; height: 4px; background: #4dd0e8; box-shadow: 0 0 5px 2px rgba(77,208,232,.80); animation-delay: 0.4s; }
.bs-nd6[b-ee5mermedq] { --tp: translate(-36px,  6px); width: 4px; height: 4px; background: #4dd0e8; box-shadow: 0 0 5px 2px rgba(77,208,232,.75); animation-delay: 1.0s; }

.bs-nd9[b-ee5mermedq]  { --tp: translate(28px,-30px);  width: 3px; height: 3px; background: #a8e8ff; box-shadow: 0 0 4px 2px rgba(168,232,255,.70); animation-delay: 1.5s; }
.bs-nd10[b-ee5mermedq] { --tp: translate(-30px,-26px); width: 3px; height: 3px; background: #a8e8ff; box-shadow: 0 0 4px 2px rgba(168,232,255,.65); animation-delay: 2.8s; }


.bs-sp[b-ee5mermedq] {
    position: absolute;
    border-radius: 50%;
    background: #a8e8ff;
    box-shadow: 0 0 4px 2px rgba(168,232,255,.85);
    top: 50%;
    left: 50%;
    pointer-events: none;
}

.bs-sp1[b-ee5mermedq] { animation: bs-sp1-b-ee5mermedq 1.8s linear infinite; }
@keyframes bs-sp1-b-ee5mermedq {
    0%   { transform: translate(24px,-22px)         scale(0);  opacity: 0; }
    8%   { opacity: 1; }
    90%  { opacity: .8; }
    100% { transform: translate(-50%,-50%)          scale(.5); opacity: 0; }
}

.bs-sp2[b-ee5mermedq] {
    background: #4dd0e8;
    box-shadow: 0 0 4px 2px rgba(77,208,232,.85);
    animation: bs-sp2-b-ee5mermedq 2.2s linear infinite;
    animation-delay: .7s;
}
@keyframes bs-sp2-b-ee5mermedq {
    0%   { transform: translate(18px,26px)          scale(0);  opacity: 0; }
    8%   { opacity: 1; }
    90%  { opacity: .8; }
    100% { transform: translate(-50%,-50%)          scale(.5); opacity: 0; }
}

.bs-sp3[b-ee5mermedq] {
    background: #2ab8d4;
    box-shadow: 0 0 4px 2px rgba(42,184,212,.85);
    animation: bs-sp3-b-ee5mermedq 1.6s linear infinite;
    animation-delay: 1.2s;
}
@keyframes bs-sp3-b-ee5mermedq {
    0%   { transform: translate(-8px,-34px)         scale(0);  opacity: 0; }
    8%   { opacity: 1; }
    90%  { opacity: .7; }
    100% { transform: translate(-50%,-50%)          scale(.4); opacity: 0; }
}

.bs-sp4[b-ee5mermedq] { animation: bs-sp4-b-ee5mermedq 2.0s linear infinite; animation-delay: .4s; }
@keyframes bs-sp4-b-ee5mermedq {
    0%   { transform: translate(0,0)                scale(.5); opacity: 0; }
    8%   { opacity: 1; }
    90%  { opacity: .7; }
    100% { transform: translate(36px,4px)           scale(0);  opacity: 0; }
}

.bs-sp5[b-ee5mermedq] {
    background: #2ab8d4;
    box-shadow: 0 0 4px 2px rgba(42,184,212,.85);
    animation: bs-sp5-b-ee5mermedq 2.5s linear infinite;
    animation-delay: 1.8s;
}
@keyframes bs-sp5-b-ee5mermedq {
    0%   { transform: translate(-26px,-14px)        scale(0);  opacity: 0; }
    8%   { opacity: 1; }
    90%  { opacity: .7; }
    100% { transform: translate(18px,26px)          scale(0);  opacity: 0; }
}


.bs-ap[b-ee5mermedq] {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    animation: bs-ap-drift-b-ee5mermedq 5s ease-in-out infinite;
}

@keyframes bs-ap-drift-b-ee5mermedq {
    0%,  100% { opacity: .15; transform: var(--ap) scale(1);              }
    50%        { opacity: .45; transform: var(--ap) translateY(-3px) scale(1.3); }
}

.bs-ap1[b-ee5mermedq] { width: 2px; height: 2px; top: 18%; left: 72%; --ap: translate(0,0); animation-delay: 0.0s; background: #4dd0e8; }
.bs-ap2[b-ee5mermedq] { width: 1px; height: 1px; top: 75%; left: 25%; --ap: translate(0,0); animation-delay: 1.0s; background: #2ab8d4; }
.bs-ap3[b-ee5mermedq] { width: 2px; height: 2px; top: 30%; left: 15%; --ap: translate(0,0); animation-delay: 2.0s; background: #1a9bc4; }
.bs-ap4[b-ee5mermedq] { width: 1px; height: 1px; top: 65%; left: 80%; --ap: translate(0,0); animation-delay: 0.5s; background: #4dd0e8; }
.bs-ap5[b-ee5mermedq] { width: 2px; height: 2px; top: 85%; left: 55%; --ap: translate(0,0); animation-delay: 3.0s; background: #2ab8d4; }
.bs-ap6[b-ee5mermedq] { width: 1px; height: 1px; top: 12%; left: 40%; --ap: translate(0,0); animation-delay: 1.5s; background: #a8e8ff; }
.bs-ap7[b-ee5mermedq] { width: 2px; height: 2px; top: 50%; left: 88%; --ap: translate(0,0); animation-delay: 2.5s; background: #1a9bc4; }
.bs-ap8[b-ee5mermedq] { width: 1px; height: 1px; top: 40%; left:  8%; --ap: translate(0,0); animation-delay: 0.8s; background: #4dd0e8; }
