/* /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;
    /* Cap apparent size — random JS can otherwise stack into a bright “orb” */
    max-width: 2px;
    max-height: 2px;
}

@keyframes dlh-twinkle-b-g89cxt4t7i {
    0%,  100% { opacity: .05; }
    50%        { opacity: .18; }
}


/* ── Scene container ─────────────────────────────────────────── */

.dlh-scene[b-g89cxt4t7i] {
    position: relative;
    width: 100%;
    max-width: 560px;
    height: 420px;
    margin: 0 auto;
    isolation: isolate;
}


/* ── 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: none;
    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: 50%;    left: 0%;     transform: translateY(-50%); }
.dlh-nc-teams[b-g89cxt4t7i]    { top: 50%;    right: 0%;    transform: translateY(-50%); }
.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: none;
    text-align: center;
    white-space: nowrap;
}


/* ── Data particles — shared ─────────────────────────────────── */

.dlh-dp[b-g89cxt4t7i] {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 18;
}

/* During animation-delay, apply 0% keyframes so dots are not left at auto/0,0 (glow reads as a top-left “orb”). */
.dlh-scene > .dlh-dp[b-g89cxt4t7i] {
    animation-fill-mode: both;
}

/* inbound — bright white-teal (collecting from source) — tighter glow so scale(0) frames never bloom */
.dlh-dp-in[b-g89cxt4t7i]  { background: #a8e8ff; box-shadow: 0 0 3px 1px rgba(168,232,255,.55); }
/* inbound variant */
.dlh-dp-mid[b-g89cxt4t7i] { background: #4dd0e8; box-shadow: 0 0 2px 1px rgba(77,208,232,.55);  }


/* ═══════════════════════════════════════════════════════════════
   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 (same spoke as SVG a3; use left/top only — mixing right→left caused stray flashes top-left) */
.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%   { left:84.286%; top:27.619%; transform:translate(-50%,-50%) scale(0);   opacity:0; }
    6%   {                        transform:translate(-50%,-50%) scale(1);    opacity:1; }
    88%  {                                                                   opacity:.9; }
    100% { left:50%;     top:50%;   transform:translate(-50%,-50%) scale(.3); opacity:0; }
}

/* AI → core (outer end of horizontal spoke a4, y=210) */
.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:210px; 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 (SVG a5 outer end; left/top only) */
.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%   { left:90.714%; top:50%;   transform:translate(-50%,-50%) scale(0); opacity:0; }
    6%   {                        transform:translate(-50%,-50%) 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 (SVG a7 lower-right; left/top only) */
.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%   { left:84.286%; top:72.381%; transform:translate(-50%,-50%) scale(0); opacity:0; }
    6%   {                          transform:translate(-50%,-50%) scale(1); opacity:1; }
    88%  {                                                                   opacity:.8; }
    100% { left:50%;     top:50%;    transform:translate(-50%,-50%) scale(.3); opacity:0; }
}

/* Facility → core (SVG a8 vertical; left/top only — avoid bottom↔top mix so path tracks the spoke) */
.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; }
.dlh-p-fac-in.dlh-p-fac-in--alt[b-g89cxt4t7i] { animation-delay: 1.05s; }
.dlh-p-fac-in.dlh-p-fac-in--alt2[b-g89cxt4t7i] { animation-delay: 2.35s; }
@keyframes dlh-p-fac-in-b-g89cxt4t7i {
    0%   { left:50%;   top:83.81%; transform:translate(-50%,-50%) scale(0);   opacity:0; }
    6%   {                        transform:translate(-50%,-50%) 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:translate(-50%,-50%) scale(1);  opacity:1; }
    88%  {                                                                   opacity:.9; }
    100% { left:84.286%; top:27.619%; transform:translate(-50%,-50%) 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:210px; 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:translate(-50%,-50%) scale(1);    opacity:1; }
    88%  {                                                                   opacity:.9; }
    100% { left:90.714%; top:50%; transform:translate(-50%,-50%) scale(0);   opacity:0; }
}

/* BOMSync → Facility + staggered return for higher OPERATIONS traffic */
.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; }
.dlh-p-fac-out.dlh-p-fac-out--alt[b-g89cxt4t7i] { animation-delay: 12.85s; }
@keyframes dlh-p-fac-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:83.81%; transform:translate(-50%,-50%) 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:translate(-50%,-50%) scale(1);    opacity:1; }
    88%  {                                                                   opacity:.9; }
    100% { left:84.286%; top:72.381%; transform:translate(-50%,-50%) 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/SolutionsBimHero.razor.rz.scp.css */
.bim-hero[b-0clmm15s5e] {
    position: relative;
    width: 100%;
    margin: 2.5rem auto 0;
    border-radius: 1rem;
    background: var(--brand-blue);
    overflow: hidden;
    box-shadow: var(--bomsync-shadow-lg);
}

.hero-stage[b-0clmm15s5e] {
    position: relative;
    width: 100%;
    min-height: 320px;
    height: clamp(320px, 58vw, 560px);
    background: var(--brand-blue);
    overflow: hidden;
}

canvas[b-0clmm15s5e] {
    display: block;
    width: 100%;
    height: 100%;
}

.brand-reveal[b-0clmm15s5e] {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    transform: translateY(clamp(-54px, -6.8vw, -16px));
    pointer-events: none;
    opacity: 0;
    gap: 0;
}

.brand-word[b-0clmm15s5e] {
    margin-bottom: 0.55vw;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    font-family: "Vipnagorgialla", "Rajdhani", "Segoe UI", sans-serif;
    font-size: clamp(2.5rem, 7.2vw, 7rem);
    letter-spacing: 0.01em;
}

.brand-tagline[b-0clmm15s5e] {
    margin-top: 0.55vw;
    font-family: "Inter", "Segoe UI", Arial, sans-serif;
    font-size: clamp(0.85rem, 1.5vw, 1.35rem);
    font-weight: 500;
    color: var(--bomsync-on-dark-text);
    letter-spacing: 0.02em;
}

.brand-bom[b-0clmm15s5e] {
    color: var(--bomsync-on-dark-text);
}

.brand-sync[b-0clmm15s5e] {
    color: var(--bs-cyan);
}

.brand-icon-wrap[b-0clmm15s5e] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    width: 0.7em;
    height: 0.7em;
    top: -0.03em;
}

.brand-icon-wrap svg[b-0clmm15s5e] {
    width: 100%;
    height: 100%;
    overflow: visible;
}

.brand-tagline .pipe[b-0clmm15s5e] {
    color: var(--bomsync-freshness-10);
    margin: 0 0.38em;
}

.brand-tagline .for-bim[b-0clmm15s5e] {
    color: var(--bs-cyan);
    font-weight: 600;
}

@media (max-width: 768px) {
    .brand-reveal[b-0clmm15s5e] {
        transform: translateY(-30px);
    }

    .brand-word[b-0clmm15s5e] {
        font-size: clamp(2.2rem, 10.2vw, 4.6rem);
    }

    .brand-tagline[b-0clmm15s5e] {
        font-size: clamp(0.8rem, 2.9vw, 1rem);
    }
}
/* /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/PageHero.razor.rz.scp.css */
/* Richer, brighter secondary line for short-attention public readers */
.page-hero-public-lead[b-8m6karjgse] {
    font-size: 1.02rem;
    line-height: 1.55;
    letter-spacing: 0.015em;
    color: rgba(252 253 255 / 0.93);
}

.page-hero-subcontent[b-8m6karjgse] {
    font-size: 1rem;
    line-height: 1.55;
    letter-spacing: 0.015em;
    color: rgba(252 253 255 / 0.9);
}

.page-hero-subcontent a[b-8m6karjgse] {
    color: rgba(224 242 254 / 0.98);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.page-hero-subcontent a:hover[b-8m6karjgse] {
    color: #fff;
}
/* /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/Security.razor.rz.scp.css */
/* ============================================================
   BOMSync.Public — Security & Trust page scoped styles  v2.0
   File:  Security.razor.css  (Blazor scoped CSS)
   Tone:  Warm, confident, professional. No alarm colours.
          Maps abstract tokens to BOMSync canonical theme vars.
   Updated: 2026-05-11 — infra grid expanded for 12 items;
            pillars support 9; hero badges flex-wrap for 6.
   ============================================================ */

/* ── Page shell — bridge design tokens to bomsync-theme ───── */
.bsp-page[b-pmxaw3gba1] {
    --font-sans: system-ui, -apple-system, "Segoe UI", sans-serif;
    --color-text-primary: var(--bomsync-text);
    --color-text-secondary: var(--bomsync-text-secondary);
    --color-text-tertiary: var(--bomsync-text-muted);
    --color-background-primary: var(--bomsync-elevated-surface);
    --color-background-secondary: var(--bomsync-brand-subtle);
    --color-border-tertiary: var(--bomsync-border);
    --color-border-secondary: var(--bomsync-border-strong);
    --color-text-success: #0f6e56;
    --color-background-success: #e1f5ee;
    --color-border-success: #b8e0d4;
    --color-text-info: #185fa5;
    --color-text-warning: #ba7517;
    --border-radius-lg: 12px;
    --border-radius-md: 8px;

    font-family: var(--font-sans, system-ui, sans-serif);
    color: var(--color-text-primary);
}

/* ── Hero ────────────────────────────────────────────────── */
.bsp-hero[b-pmxaw3gba1] {
    padding: 5rem 2rem 4rem;
    border-bottom: 0.5px solid var(--color-border-tertiary);
    background: var(--color-background-primary);
}

.bsp-hero-inner[b-pmxaw3gba1] {
    max-width: 760px;
    margin: 0 auto;
}

.bsp-eyebrow[b-pmxaw3gba1] {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    color: var(--color-text-success);
    margin-bottom: 1.25rem;
}

.bsp-hero h1[b-pmxaw3gba1] {
    font-size: clamp(26px, 4vw, 38px);
    font-weight: 500;
    color: var(--color-text-primary);
    line-height: 1.2;
    margin-bottom: 1.25rem;
    max-width: 580px;
}

.bsp-hero-lead[b-pmxaw3gba1] {
    font-size: 17px;
    color: var(--color-text-secondary);
    line-height: 1.75;
    max-width: 600px;
    margin-bottom: 2rem;
}

.bsp-hero-badges[b-pmxaw3gba1] {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.bsp-badge[b-pmxaw3gba1] {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: 500;
    padding: 6px 14px;
    border-radius: 20px;
    background: var(--color-background-success);
    color: var(--color-text-success);
    border: 0.5px solid var(--color-border-success);
}

.bsp-badge i[b-pmxaw3gba1] { font-size: 14px; }

/* ── Section wrapper ─────────────────────────────────────── */
.bsp-section[b-pmxaw3gba1] {
    padding: 4rem 2rem;
    border-bottom: 0.5px solid var(--color-border-tertiary);
}

.bsp-section-alt[b-pmxaw3gba1] {
    background: var(--color-background-secondary);
}

.bsp-section-inner[b-pmxaw3gba1] {
    max-width: 900px;
    margin: 0 auto;
}

.bsp-section-label[b-pmxaw3gba1] {
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-text-tertiary);
    margin-bottom: 0.5rem;
}

.bsp-section-title[b-pmxaw3gba1] {
    font-size: clamp(20px, 3vw, 26px);
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: 1.25rem;
    max-width: 580px;
    line-height: 1.3;
}

.bsp-body-text[b-pmxaw3gba1] {
    font-size: 15px;
    color: var(--color-text-secondary);
    line-height: 1.75;
    margin-bottom: 1rem;
}

.bsp-body-max[b-pmxaw3gba1] { max-width: 640px; }

/* ── Pillar grid ─────────────────────────────────────────── */
.bsp-pillars[b-pmxaw3gba1] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1rem;
    margin-top: 2rem;
}

.bsp-pillar[b-pmxaw3gba1] {
    background: var(--color-background-primary);
    border: 0.5px solid var(--color-border-tertiary);
    border-radius: var(--border-radius-lg);
    padding: 1.5rem;
    transition: border-color 0.2s;
}

.bsp-pillar:hover[b-pmxaw3gba1] {
    border-color: var(--color-border-secondary);
}

.bsp-pillar-icon[b-pmxaw3gba1] {
    width: 44px;
    height: 44px;
    border-radius: var(--border-radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    margin-bottom: 1rem;
}

.bsp-icon-teal[b-pmxaw3gba1]   { background: #E1F5EE; color: #0F6E56; }
.bsp-icon-blue[b-pmxaw3gba1]   { background: #E6F1FB; color: #185FA5; }
.bsp-icon-amber[b-pmxaw3gba1]  { background: #FAEEDA; color: #BA7517; }
.bsp-icon-purple[b-pmxaw3gba1] { background: #EEEDFE; color: #534AB7; }
.bsp-icon-green[b-pmxaw3gba1]  { background: #EAF3DE; color: #3B6D11; }
.bsp-icon-coral[b-pmxaw3gba1]  { background: #E1F5EE; color: #0F6E56; }

.bsp-pillar-title[b-pmxaw3gba1] {
    font-size: 15px;
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: 0.5rem;
    line-height: 1.35;
}

.bsp-pillar-body[b-pmxaw3gba1] {
    font-size: 13.5px;
    color: var(--color-text-secondary);
    line-height: 1.65;
}

/* ── Split layout (isolation section) ───────────────────── */
.bsp-split[b-pmxaw3gba1] {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
}

@media (max-width: 700px) {
    .bsp-split[b-pmxaw3gba1] { grid-template-columns: 1fr; gap: 2rem; }
}

.bsp-split-text .bsp-section-title[b-pmxaw3gba1] { max-width: 100%; }

/* ── Isolation diagram ───────────────────────────────────── */
.bsp-isolation-diagram[b-pmxaw3gba1] {
    background: var(--color-background-primary);
    border: 0.5px solid var(--color-border-tertiary);
    border-radius: var(--border-radius-lg);
    padding: 1.5rem;
}

.bsp-iso-row[b-pmxaw3gba1] {
    display: flex;
    gap: 8px;
    justify-content: center;
}

.bsp-iso-tenants[b-pmxaw3gba1] { margin-top: 0; }

.bsp-iso-box[b-pmxaw3gba1] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 14px 16px;
    border-radius: var(--border-radius-md);
    border: 0.5px solid var(--color-border-tertiary);
    font-size: 12px;
    font-weight: 500;
    color: var(--color-text-primary);
    text-align: center;
    flex: 1;
}

.bsp-iso-box i[b-pmxaw3gba1] { font-size: 20px; margin-bottom: 2px; }

.bsp-iso-global[b-pmxaw3gba1] {
    background: #E6F1FB;
    border-color: #B5D4F4;
    color: #0C447C;
    width: 100%;
    max-width: 220px;
    margin: 0 auto;
}

.bsp-iso-tenant[b-pmxaw3gba1] {
    background: #EAF3DE;
    border-color: #C0DD97;
    color: #27500A;
}

.bsp-iso-other[b-pmxaw3gba1] {
    opacity: 0.45;
}

.bsp-iso-sub[b-pmxaw3gba1] {
    font-size: 10px;
    font-weight: 400;
    opacity: 0.8;
}

.bsp-iso-divider[b-pmxaw3gba1] {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 10px 0;
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: var(--color-text-tertiary);
}

.bsp-iso-divider[b-pmxaw3gba1]::before,
.bsp-iso-divider[b-pmxaw3gba1]::after {
    content: "";
    flex: 1;
    height: 1px;
    background: var(--color-border-secondary);
}

/* ── Signature cards ─────────────────────────────────────── */
.bsp-sig-cards[b-pmxaw3gba1] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
    margin-top: 2rem;
}

.bsp-sig-card[b-pmxaw3gba1] {
    background: var(--color-background-primary);
    border: 0.5px solid var(--color-border-tertiary);
    border-radius: var(--border-radius-lg);
    padding: 1.25rem 1.5rem;
}

.bsp-sig-icon[b-pmxaw3gba1] {
    font-size: 22px;
    color: var(--color-text-success);
    margin-bottom: 0.75rem;
}

.bsp-sig-card h3[b-pmxaw3gba1] {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: 0.5rem;
}

.bsp-sig-card p[b-pmxaw3gba1] {
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.6;
}

/* ── Jurisdiction grid ───────────────────────────────────── */
.bsp-jurisdiction-grid[b-pmxaw3gba1] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1rem;
    margin: 1.5rem 0;
}

.bsp-jurisdiction[b-pmxaw3gba1] {
    display: flex;
    align-items: center;
    gap: 14px;
    background: var(--color-background-primary);
    border: 0.5px solid var(--color-border-tertiary);
    border-radius: var(--border-radius-md);
    padding: 1rem 1.25rem;
}

.bsp-juri-flag[b-pmxaw3gba1] {
    font-size: 26px;
    flex-shrink: 0;
}

.bsp-juri-name[b-pmxaw3gba1] {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: 2px;
}

.bsp-juri-law[b-pmxaw3gba1] {
    font-size: 12px;
    color: var(--color-text-secondary);
    line-height: 1.45;
}

.bsp-compliance-note[b-pmxaw3gba1] {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    background: #FAEEDA;
    border: 0.5px solid #FAC775;
    border-radius: var(--border-radius-md);
    padding: 1rem 1.25rem;
    margin-top: 1.5rem;
}

.bsp-compliance-note i[b-pmxaw3gba1] {
    font-size: 18px;
    color: #BA7517;
    flex-shrink: 0;
    margin-top: 1px;
}

.bsp-compliance-note p[b-pmxaw3gba1] {
    font-size: 13.5px;
    color: #633806;
    line-height: 1.65;
}

/* ── Infrastructure grid ─────────────────────────────────── */
.bsp-infra-grid[b-pmxaw3gba1] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
    margin-top: 2rem;
}

.bsp-infra-item[b-pmxaw3gba1] {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    background: var(--color-background-primary);
    border: 0.5px solid var(--color-border-tertiary);
    border-radius: var(--border-radius-lg);
    padding: 1.25rem;
}

.bsp-infra-item > i[b-pmxaw3gba1] {
    font-size: 22px;
    color: var(--color-text-info);
    flex-shrink: 0;
    margin-top: 2px;
}

.bsp-infra-title[b-pmxaw3gba1] {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: 4px;
}

.bsp-infra-body[b-pmxaw3gba1] {
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.6;
}

/* ── Steps ───────────────────────────────────────────────── */
.bsp-steps[b-pmxaw3gba1] {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 2rem;
    max-width: 680px;
}

.bsp-step[b-pmxaw3gba1] {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    background: var(--color-background-primary);
    border: 0.5px solid var(--color-border-tertiary);
    border-radius: var(--border-radius-lg);
    padding: 1.25rem 1.5rem;
}

.bsp-step-num[b-pmxaw3gba1] {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: #E1F5EE;
    color: #0F6E56;
    font-size: 14px;
    font-weight: 500;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin-top: 2px;
}

.bsp-step-title[b-pmxaw3gba1] {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: 4px;
}

.bsp-step-body[b-pmxaw3gba1] {
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.65;
}

/* ── Standards grid ──────────────────────────────────────── */
.bsp-standards-grid[b-pmxaw3gba1] {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-top: 2rem;
}

@media (max-width: 640px) {
    .bsp-standards-grid[b-pmxaw3gba1] { grid-template-columns: 1fr; }
}

.bsp-standard[b-pmxaw3gba1] {
    background: var(--color-background-primary);
    border: 0.5px solid var(--color-border-tertiary);
    border-radius: var(--border-radius-lg);
    overflow: hidden;
}

.bsp-std-tag[b-pmxaw3gba1] {
    padding: 10px 16px;
    font-size: 12px;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 6px;
}

.bsp-std-live[b-pmxaw3gba1] { background: #EAF3DE; color: #27500A; }
.bsp-std-road[b-pmxaw3gba1] { background: #EEEDFE; color: #3C3489; }

.bsp-std-list[b-pmxaw3gba1] {
    list-style: none;
    padding: 12px 16px 16px;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.bsp-std-list li[b-pmxaw3gba1] {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.5;
}

.bsp-std-list li i[b-pmxaw3gba1] { font-size: 15px; flex-shrink: 0; margin-top: 1px; }
.bsp-std-live + .bsp-std-list i[b-pmxaw3gba1] { color: var(--color-text-success); }
.bsp-std-road + .bsp-std-list i[b-pmxaw3gba1] { color: var(--color-text-warning); }

/* ── CTA section ─────────────────────────────────────────── */
.bsp-section-cta[b-pmxaw3gba1] {
    background: #042C53;
    border-bottom: none;
}

.bsp-cta-inner[b-pmxaw3gba1] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 2rem;
}

.bsp-cta-title[b-pmxaw3gba1] {
    font-size: 22px;
    font-weight: 500;
    color: #ffffff;
    margin-bottom: 0.5rem;
    max-width: 500px;
}

.bsp-cta-sub[b-pmxaw3gba1] {
    font-size: 14px;
    color: #85B7EB;
    line-height: 1.7;
    max-width: 500px;
}

.bsp-cta-actions[b-pmxaw3gba1] {
    display: flex;
    gap: 10px;
    flex-shrink: 0;
    flex-wrap: wrap;
}

.bsp-btn[b-pmxaw3gba1] {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: 14px;
    font-weight: 500;
    padding: 11px 22px;
    border-radius: var(--border-radius-md);
    text-decoration: none;
    transition: opacity 0.15s, transform 0.1s;
    white-space: nowrap;
}

.bsp-btn:hover[b-pmxaw3gba1] { opacity: 0.88; transform: translateY(-1px); }
.bsp-btn:active[b-pmxaw3gba1] { transform: translateY(0); }

.bsp-btn-primary[b-pmxaw3gba1] {
    background: #0F6E56;
    color: #ffffff;
}

.bsp-btn-secondary[b-pmxaw3gba1] {
    background: rgba(255,255,255,0.08);
    color: #ffffff;
    border: 0.5px solid rgba(255,255,255,0.25);
}

/* ── Footer meta (review date only; legal links live in layout footer) ── */
.bsp-footer-meta[b-pmxaw3gba1] {
    display: flex;
    justify-content: center;
    padding: 1rem 2rem 2.5rem;
    max-width: 900px;
    margin: 0 auto;
}

.bsp-footer-meta .bsp-reviewed[b-pmxaw3gba1] {
    margin-left: 0;
}

.bsp-reviewed[b-pmxaw3gba1] {
    font-size: 12px;
    color: var(--color-text-tertiary);
    margin-left: auto;
}

/* ── Responsive tweaks ───────────────────────────────────── */
@media (max-width: 500px) {
    .bsp-hero[b-pmxaw3gba1] { padding: 3rem 1.25rem 2.5rem; }
    .bsp-section[b-pmxaw3gba1] { padding: 3rem 1.25rem; }
    .bsp-pillars[b-pmxaw3gba1] { grid-template-columns: 1fr; }
    .bsp-cta-inner[b-pmxaw3gba1] { flex-direction: column; }
    .bsp-reviewed[b-pmxaw3gba1] { margin-left: 0; }
}
/* /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/Shared/SecurityBadges.razor.rz.scp.css */
/* BOMSync.Public — SecurityBadges (scoped); maps to bomsync-theme tokens */

.bsb-section[b-76wu1f34cn] {
    padding: 3.5rem 2rem;
    border-top: 0.5px solid var(--bomsync-border);
}

.bsb-inner[b-76wu1f34cn] { max-width: 900px; margin: 0 auto; }

.bsb-section-label[b-76wu1f34cn] {
    font-size: 11px; font-weight: 500; letter-spacing: .1em;
    text-transform: uppercase; color: var(--bomsync-text-muted); margin-bottom: .4rem;
}

.bsb-section-title[b-76wu1f34cn] {
    font-size: 22px; font-weight: 500; color: var(--bomsync-text);
    margin-bottom: .4rem; line-height: 1.3;
}

.bsb-section-desc[b-76wu1f34cn] {
    font-size: 14px; color: var(--bomsync-text-secondary); line-height: 1.65;
    max-width: 640px; margin-bottom: 0;
}

.bsb-group[b-76wu1f34cn] { margin-top: 2rem; }

.bsb-group-roadmap[b-76wu1f34cn] {
    padding-top: 1.25rem;
    border-top: 0.5px solid var(--bomsync-border);
}

.bsb-group-label[b-76wu1f34cn] {
    font-size: 11px; font-weight: 500; letter-spacing: .09em;
    text-transform: uppercase; color: var(--bomsync-text-muted); margin-bottom: .75rem;
    display: flex; align-items: center; gap: 6px;
}

.bsb-group-label-qualifier[b-76wu1f34cn] {
    font-weight: 400; text-transform: none; letter-spacing: 0;
    font-size: 11px; color: var(--bomsync-text-muted); font-style: italic;
}

.bsb-group-note[b-76wu1f34cn] {
    font-size: 11.5px; color: var(--bomsync-text-muted); line-height: 1.6;
    margin-top: .75rem; max-width: 640px;
    padding: 8px 12px;
    background: var(--bomsync-surface-2);
    border-left: 3px solid var(--bomsync-border-strong);
    border-radius: 0 6px 6px 0;
}

.bsb-badges[b-76wu1f34cn] {
    display: flex; flex-wrap: wrap; gap: 10px;
    list-style: none; padding: 0; margin: 0;
}

.bsb-badge[b-76wu1f34cn] {
    display: flex; flex-direction: column; align-items: center;
    background: var(--bomsync-elevated-surface);
    border: 0.5px solid var(--bomsync-border);
    border-radius: 10px;
    padding: 14px 14px 12px;
    min-width: 104px; max-width: 130px;
    transition: border-color .15s, transform .1s;
    cursor: default;
}

.bsb-badge:hover[b-76wu1f34cn] {
    border-color: var(--bomsync-border-strong);
    transform: translateY(-1px);
}

.bsb-badge-infra[b-76wu1f34cn] {
    border-left: 3px solid var(--btn-primary-bg);
    padding-left: 11px;
}

.bsb-badge-road[b-76wu1f34cn] {
    opacity: .6;
}

.bsb-badge-road:hover[b-76wu1f34cn] {
    opacity: .8;
    transform: none;
}

.bsb-icon[b-76wu1f34cn] {
    width: 56px; height: 56px; border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 8px; overflow: hidden;
}

.bsb-icon svg[b-76wu1f34cn] { width: 44px; height: 44px; display: block; }

.bsb-bg-blue[b-76wu1f34cn]   { background: #E6F1FB; }
.bsb-bg-teal[b-76wu1f34cn]   { background: #E1F5EE; }
.bsb-bg-green[b-76wu1f34cn]  { background: #EAF3DE; }
.bsb-bg-amber[b-76wu1f34cn]  { background: #FAEEDA; }
.bsb-bg-purple[b-76wu1f34cn] { background: #EEEDFE; }
.bsb-bg-gray[b-76wu1f34cn]   { background: #F1EFE8; }

.bsb-label[b-76wu1f34cn] {
    font-size: 11.5px; font-weight: 500;
    color: var(--bomsync-text);
    text-align: center; line-height: 1.3;
}

.bsb-sub[b-76wu1f34cn] {
    font-size: 10px; color: var(--bomsync-text-muted);
    text-align: center; margin-top: 2px; line-height: 1.3;
}

.bsb-badge-status[b-76wu1f34cn] {
    font-size: 10px; font-weight: 500;
    color: #b45309;
    text-align: center; margin-top: 2px; line-height: 1.3;
}

.bsb-footnote[b-76wu1f34cn] {
    display: flex; align-items: flex-start; gap: 8px;
    margin-top: 1.75rem; font-size: 12px;
    color: var(--bomsync-text-muted); line-height: 1.6;
    max-width: 700px; padding: 10px 14px;
    background: var(--bomsync-surface-2);
    border-radius: 8px;
}

.bsb-footnote-icon[b-76wu1f34cn] {
    font-size: 15px;
    flex-shrink: 0;
    margin-top: 1px;
    color: var(--btn-primary-bg);
}

@media (max-width: 500px) {
    .bsb-section[b-76wu1f34cn] { padding: 2.5rem 1.25rem; }
    .bsb-badge[b-76wu1f34cn] { min-width: 88px; max-width: 108px; padding: 10px 10px 8px; }
    .bsb-icon[b-76wu1f34cn] { width: 48px; height: 48px; }
    .bsb-icon svg[b-76wu1f34cn] { width: 36px; height: 36px; }
}
/* /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; }
/* /Components/Templates/PortalTradeWorkbenchShell.razor.rz.scp.css */
.portal-wb-sidebar-inner[b-6p48a7gnh2] {
    background: var(--brand-blue, #1b2537);
    min-height: 100%;
}

.portal-wb-brand[b-6p48a7gnh2] {
    padding: 0.65rem 0.6rem 0.55rem;
    flex-shrink: 0;
}

.portal-wb-brand-title[b-6p48a7gnh2] {
    color: var(--bomsync-on-dark-text, #fff);
    font-size: 0.8125rem;
    font-weight: 600;
}

.portal-wb-brand-sub[b-6p48a7gnh2] {
    color: rgba(255, 255, 255, 0.42);
    font-size: 0.68rem;
    margin-top: 0.15rem;
}

.portal-wb-section[b-6p48a7gnh2] {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    opacity: 0.48;
    padding: 0.5rem 0.55rem 0.2rem;
    margin-top: 0.35rem;
    color: var(--bomsync-on-dark-text, #fff);
}

.portal-wb-link[b-6p48a7gnh2] {
    display: block;
    padding: 0.4rem 0.55rem;
    border-radius: 4px;
    color: var(--bomsync-on-dark-text, rgba(255, 255, 255, 0.78));
    text-decoration: none;
    font-size: 0.8125rem;
    border-left: 2px solid transparent;
}

.portal-wb-link:hover[b-6p48a7gnh2] {
    background: rgba(255, 255, 255, 0.08);
    color: var(--bomsync-on-dark-text, #fff);
}

.portal-wb-push[b-6p48a7gnh2] {
    background: var(--bomsync-page-bg, var(--bs-body-bg));
}

.portal-wb-topbar[b-6p48a7gnh2] {
    background: var(--bs-body-bg);
    border-color: var(--bomsync-border-strong, var(--bs-border-color)) !important;
}

.portal-wb-main[b-6p48a7gnh2] {
    background: var(--bomsync-page-bg, var(--bs-body-bg));
}
