/* /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/NavMenu.razor.rz.scp.css */
.navbar-toggler[b-hdjk7amgpg] {
    appearance: none;
    cursor: pointer;
    width: 3.5rem;
    height: 2.5rem;
    color: white;
    position: absolute;
    top: 0.5rem;
    right: 1rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.55%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") no-repeat center/1.75rem rgba(255, 255, 255, 0.1);
}

.navbar-toggler:checked[b-hdjk7amgpg] {
    background-color: rgba(255, 255, 255, 0.5);
}

.top-row[b-hdjk7amgpg] {
    min-height: 3.5rem;
    background-color: rgba(0,0,0,0.4);
}

.navbar-brand[b-hdjk7amgpg] {
    font-size: 1.1rem;
}

.bi[b-hdjk7amgpg] {
    display: inline-block;
    position: relative;
    width: 1.25rem;
    height: 1.25rem;
    margin-right: 0.75rem;
    top: -1px;
    background-size: cover;
}

.bi-house-door-fill-nav-menu[b-hdjk7amgpg] {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-house-door-fill' viewBox='0 0 16 16'%3E%3Cpath d='M6.5 14.5v-3.505c0-.245.25-.495.5-.495h2c.25 0 .5.25.5.5v3.5a.5.5 0 0 0 .5.5h4a.5.5 0 0 0 .5-.5v-7a.5.5 0 0 0-.146-.354L13 5.793V2.5a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5v1.293L8.354 1.146a.5.5 0 0 0-.708 0l-6 6A.5.5 0 0 0 1.5 7.5v7a.5.5 0 0 0 .5.5h4a.5.5 0 0 0 .5-.5Z'/%3E%3C/svg%3E");
}

.bi-plus-square-fill-nav-menu[b-hdjk7amgpg] {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-plus-square-fill' viewBox='0 0 16 16'%3E%3Cpath d='M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm6.5 4.5v3h3a.5.5 0 0 1 0 1h-3v3a.5.5 0 0 1-1 0v-3h-3a.5.5 0 0 1 0-1h3v-3a.5.5 0 0 1 1 0z'/%3E%3C/svg%3E");
}

.bi-list-nested-nav-menu[b-hdjk7amgpg] {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-list-nested' viewBox='0 0 16 16'%3E%3Cpath fill-rule='evenodd' d='M4.5 11.5A.5.5 0 0 1 5 11h10a.5.5 0 0 1 0 1H5a.5.5 0 0 1-.5-.5zm-2-4A.5.5 0 0 1 3 7h10a.5.5 0 0 1 0 1H3a.5.5 0 0 1-.5-.5zm-2-4A.5.5 0 0 1 1 3h10a.5.5 0 0 1 0 1H1a.5.5 0 0 1-.5-.5z'/%3E%3C/svg%3E");
}

.nav-item[b-hdjk7amgpg] {
    font-size: 0.9rem;
    padding-bottom: 0.5rem;
}

    .nav-item:first-of-type[b-hdjk7amgpg] {
        padding-top: 1rem;
    }

    .nav-item:last-of-type[b-hdjk7amgpg] {
        padding-bottom: 1rem;
    }

    .nav-item[b-hdjk7amgpg]  .nav-link {
        color: #d7d7d7;
        background: none;
        border: none;
        border-radius: 4px;
        height: 3rem;
        display: flex;
        align-items: center;
        line-height: 3rem;
        width: 100%;
    }

.nav-item[b-hdjk7amgpg]  a.active {
    background-color: rgba(255,255,255,0.37);
    color: white;
}

.nav-item[b-hdjk7amgpg]  .nav-link:hover {
    background-color: rgba(255,255,255,0.1);
    color: white;
}

.nav-scrollable[b-hdjk7amgpg] {
    display: none;
}

.navbar-toggler:checked ~ .nav-scrollable[b-hdjk7amgpg] {
    display: block;
}

@media (min-width: 641px) {
    .navbar-toggler[b-hdjk7amgpg] {
        display: none;
    }

    .nav-scrollable[b-hdjk7amgpg] {
        /* Never collapse the sidebar for wide screens */
        display: block;

        /* Allow sidebar to scroll for tall menus */
        height: calc(100vh - 3.5rem);
        overflow-y: auto;
    }
}
/* /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: #080f1e;
    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: 10px;
    color: rgba(26,155,196,0.40);
    letter-spacing: .10em;
    text-transform: uppercase;
    text-align: center;
    margin-top: 6px;
}
/* /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; }
