/* /Components/ImportWizard.razor.rz.scp.css */
/* ── Backdrop & Modal ─────────────────────────────────────────────────────── */

.modal-backdrop[b-8qcchijxpq] {
    position: fixed;
    inset: 0;
    background: rgba(10, 10, 20, 0.55);
    backdrop-filter: blur(4px);
    z-index: 1050;
    animation: fadeIn-b-8qcchijxpq 0.15s ease;
}

.wizard-modal[b-8qcchijxpq] {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: min(720px, 96vw);
    max-height: 90vh;
    overflow-y: auto;
    background: var(--fm-surface, #fff);
    border-radius: 16px;
    box-shadow: 0 24px 64px rgba(0,0,0,.18);
    z-index: 1051;
    display: flex;
    flex-direction: column;
    animation: slideUp-b-8qcchijxpq 0.2s ease;
}

@keyframes fadeIn-b-8qcchijxpq { from { opacity: 0 } to { opacity: 1 } }
@keyframes slideUp-b-8qcchijxpq { from { transform: translate(-50%, -48%); opacity: 0 } to { transform: translate(-50%, -50%); opacity: 1 } }

/* ── Header ──────────────────────────────────────────────────────────────── */

.wizard-header[b-8qcchijxpq] {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding: 1.5rem 1.75rem 0;
}

.wizard-title[b-8qcchijxpq] {
    font-size: 1.2rem;
    font-weight: 700;
    margin: 0 0 .2rem;
    color: var(--fm-text, #0d0d1a);
}

.wizard-subtitle[b-8qcchijxpq] {
    font-size: .85rem;
    color: var(--fm-text-muted, #6b7280);
    margin: 0;
}

.wizard-close[b-8qcchijxpq] {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--fm-text-muted, #6b7280);
    padding: .25rem;
    border-radius: 6px;
    line-height: 1;
    transition: background .15s, color .15s;
}
.wizard-close:hover[b-8qcchijxpq] { background: var(--fm-surface-alt, #f4f5f7); color: var(--fm-text, #0d0d1a); }

/* ── Step indicator ──────────────────────────────────────────────────────── */

.wizard-steps[b-8qcchijxpq] {
    display: flex;
    align-items: center;
    padding: 1.25rem 1.75rem;
    gap: .5rem;
}

.wizard-step[b-8qcchijxpq] {
    display: flex;
    align-items: center;
    gap: .4rem;
    color: var(--fm-text-muted, #9ca3af);
    font-size: .78rem;
    font-weight: 500;
    transition: color .2s;
}
.wizard-step.active[b-8qcchijxpq] { color: var(--fm-accent, #1847f5); }

.wizard-step__dot[b-8qcchijxpq] {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    border: 2px solid currentColor;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .7rem;
    font-weight: 700;
    flex-shrink: 0;
    transition: background .2s, border-color .2s;
}
.wizard-step.active .wizard-step__dot[b-8qcchijxpq] {
    background: var(--fm-accent, #1847f5);
    border-color: var(--fm-accent, #1847f5);
    color: #fff;
}

.wizard-step-line[b-8qcchijxpq] {
    flex: 1;
    height: 2px;
    background: var(--fm-border, #e5e7eb);
    border-radius: 1px;
    transition: background .2s;
}
.wizard-step-line.active[b-8qcchijxpq] { background: var(--fm-accent, #1847f5); }

/* ── Body ────────────────────────────────────────────────────────────────── */

.wizard-body[b-8qcchijxpq] {
    padding: 0 1.75rem 1.75rem;
    flex: 1;
}

.wizard-lead[b-8qcchijxpq] {
    font-size: .95rem;
    color: var(--fm-text-muted, #6b7280);
    margin: 0 0 1.25rem;
}

/* ── Broker select cards ─────────────────────────────────────────────────── */

.broker-select-grid[b-8qcchijxpq] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: .75rem;
    margin-bottom: 1rem;
}

.broker-select-card[b-8qcchijxpq] {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .85rem 1rem;
    border: 1.5px solid var(--fm-border, #e5e7eb);
    border-radius: 10px;
    background: var(--fm-surface, #fff);
    cursor: pointer;
    text-align: left;
    transition: border-color .15s, box-shadow .15s, background .15s;
    width: 100%;
    position: relative;
}
.broker-select-card:hover[b-8qcchijxpq] { border-color: var(--fm-accent, #1847f5); box-shadow: 0 0 0 3px rgba(24,71,245,.08); }
.broker-select-card.selected[b-8qcchijxpq] { border-color: var(--fm-accent, #1847f5); background: rgba(24,71,245,.04); }
.broker-select-card--manual[b-8qcchijxpq] { margin-top: .25rem; }

.broker-select-card__icon[b-8qcchijxpq] {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .7rem;
    font-weight: 800;
    letter-spacing: -.5px;
    color: #fff;
    flex-shrink: 0;
}
.broker-select-card__icon--blue[b-8qcchijxpq] { background: #1847f5; }
.broker-select-card__icon--green[b-8qcchijxpq] { background: #00c896; }
.broker-select-card__icon--muted[b-8qcchijxpq] { background: var(--fm-surface-alt, #f4f5f7); color: var(--fm-text-muted, #9ca3af); }

.broker-select-card__info[b-8qcchijxpq] { flex: 1; min-width: 0; }
.broker-select-card__info strong[b-8qcchijxpq] { display: block; font-size: .9rem; color: var(--fm-text, #0d0d1a); }
.broker-select-card__info span[b-8qcchijxpq] { font-size: .75rem; color: var(--fm-text-muted, #9ca3af); }

.broker-select-card__check[b-8qcchijxpq] {
    color: var(--fm-accent, #1847f5);
    font-weight: 700;
    font-size: .9rem;
}

/* ── Divider ─────────────────────────────────────────────────────────────── */

.wizard-divider[b-8qcchijxpq] {
    display: flex;
    align-items: center;
    gap: .75rem;
    margin: .75rem 0;
    color: var(--fm-text-muted, #9ca3af);
    font-size: .8rem;
}
.wizard-divider[b-8qcchijxpq]::before, .wizard-divider[b-8qcchijxpq]::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--fm-border, #e5e7eb);
}

/* ── Method cards ────────────────────────────────────────────────────────── */

.method-cards[b-8qcchijxpq] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.method-card[b-8qcchijxpq] {
    position: relative;
    padding: 1.25rem;
    border: 1.5px solid var(--fm-border, #e5e7eb);
    border-radius: 12px;
    background: var(--fm-surface, #fff);
    cursor: pointer;
    text-align: left;
    transition: border-color .15s, box-shadow .15s, background .15s;
}
.method-card:hover[b-8qcchijxpq] { border-color: var(--fm-accent, #1847f5); box-shadow: 0 0 0 3px rgba(24,71,245,.08); }
.method-card.selected[b-8qcchijxpq] { border-color: var(--fm-accent, #1847f5); background: rgba(24,71,245,.04); }

.method-card__badge[b-8qcchijxpq] {
    position: absolute;
    top: .75rem;
    right: .75rem;
    background: var(--fm-accent, #1847f5);
    color: #fff;
    font-size: .65rem;
    font-weight: 700;
    padding: .15rem .45rem;
    border-radius: 20px;
    letter-spacing: .03em;
}

.method-card__icon[b-8qcchijxpq] {
    color: var(--fm-accent, #1847f5);
    margin-bottom: .75rem;
}

.method-card h3[b-8qcchijxpq] {
    font-size: .95rem;
    font-weight: 600;
    margin: 0 0 .35rem;
    color: var(--fm-text, #0d0d1a);
}
.method-card p[b-8qcchijxpq] {
    font-size: .8rem;
    color: var(--fm-text-muted, #6b7280);
    margin: 0;
    line-height: 1.5;
}

/* ── Export instructions ─────────────────────────────────────────────────── */

.import-instructions[b-8qcchijxpq] {
    background: var(--fm-surface-alt, #f8f9fb);
    border-radius: 10px;
    padding: 1rem 1.25rem;
    margin-bottom: 1.25rem;
}

.import-instructions__title[b-8qcchijxpq] {
    font-size: 0.9375rem;
    font-weight: 600;
    letter-spacing: normal;
    color: var(--fm-text, #0d0d1a);
    margin: 0 0 .6rem;
    display: flex;
    align-items: center;
    gap: .4rem;
}

.import-instructions__note[b-8qcchijxpq] {
    font-size: .8rem;
    color: var(--fm-text-muted, #6b7280);
    margin: 0 0 .6rem;
    padding: .5rem .75rem;
    background: rgba(245, 158, 11, 0.08);
    border-left: 3px solid #f59e0b;
    border-radius: 0 6px 6px 0;
}

.import-instructions__steps[b-8qcchijxpq] {
    margin: 0;
    padding-left: 1.25rem;
    font-size: .82rem;
    color: var(--fm-text-muted, #6b7280);
    line-height: 1.8;
}
.import-instructions__steps strong[b-8qcchijxpq] { color: var(--fm-text, #0d0d1a); }
.import-instructions__steps em[b-8qcchijxpq] { font-style: normal; font-weight: 500; }

/* ── Dropzone ────────────────────────────────────────────────────────────── */

.dropzone[b-8qcchijxpq] {
    border: 2px dashed var(--fm-border, #e5e7eb);
    border-radius: 12px;
    padding: 2.5rem;
    text-align: center;
    cursor: pointer;
    transition: border-color .15s, background .15s;
    margin-bottom: 1rem;
    color: var(--fm-text-muted, #9ca3af);
}
.dropzone:hover[b-8qcchijxpq], .dropzone.dragover[b-8qcchijxpq] {
    border-color: var(--fm-accent, #1847f5);
    background: rgba(24,71,245,.03);
}
.dropzone p[b-8qcchijxpq] { margin: .75rem 0 .5rem; font-size: .9rem; }
.dropzone__hint[b-8qcchijxpq] { font-size: .75rem; display: block; margin-top: .5rem; }

/* ── Preview ─────────────────────────────────────────────────────────────── */

.preview-summary[b-8qcchijxpq] {
    display: flex;
    gap: 1rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}

.preview-stat[b-8qcchijxpq] {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 60px;
    padding: .5rem .75rem;
    border-radius: 8px;
    font-size: .8rem;
    font-weight: 600;
}
.preview-stat--green[b-8qcchijxpq]  { background: rgba(0,200,150,.1); color: #00a97c; }
.preview-stat--muted[b-8qcchijxpq]  { background: var(--fm-surface-alt, #f4f5f7); color: var(--fm-text-muted, #9ca3af); }
.preview-stat--amber[b-8qcchijxpq]  { background: rgba(245,158,11,.1); color: #b45309; }
.preview-stat--red[b-8qcchijxpq]    { background: rgba(239,68,68,.1); color: #dc2626; }

.preview-stat__val[b-8qcchijxpq] { font-size: 1.3rem; line-height: 1; }
.preview-stat__label[b-8qcchijxpq] { font-size: .7rem; font-weight: 400; margin-top: .15rem; }

.preview-table-wrap[b-8qcchijxpq] {
    overflow-x: auto;
    max-height: 280px;
    overflow-y: auto;
    border: 1px solid var(--fm-border, #e5e7eb);
    border-radius: 10px;
    margin-bottom: 1rem;
}

.preview-table[b-8qcchijxpq] {
    width: 100%;
    border-collapse: collapse;
    font-size: .8rem;
}
.preview-table th[b-8qcchijxpq] {
    padding: .5rem .75rem;
    text-align: left;
    font-weight: 600;
    color: var(--fm-text-muted, #6b7280);
    background: var(--fm-surface-alt, #f8f9fb);
    position: sticky;
    top: 0;
    font-size: .73rem;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.preview-table td[b-8qcchijxpq] {
    padding: .45rem .75rem;
    border-top: 1px solid var(--fm-border, #f0f1f3);
    vertical-align: middle;
}

.preview-row--duplicate[b-8qcchijxpq] { opacity: .5; }
.preview-row--parseerror[b-8qcchijxpq] { opacity: .4; }
.preview-row__status[b-8qcchijxpq] { width: 24px; }
.preview-row__detail[b-8qcchijxpq] { color: var(--fm-text-muted, #9ca3af); font-size: .73rem; }

.status-dot[b-8qcchijxpq] {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
}
.status-dot--green[b-8qcchijxpq] { background: #00c896; }
.status-dot--muted[b-8qcchijxpq] { background: #9ca3af; }
.status-dot--amber[b-8qcchijxpq] { background: #f59e0b; }
.status-dot--red[b-8qcchijxpq]   { background: #ef4444; }

.preview-asset[b-8qcchijxpq] { display: block; font-weight: 500; }
.preview-isin[b-8qcchijxpq] { font-size: .7rem; color: var(--fm-text-muted, #9ca3af); font-family: monospace; }
.preview-more[b-8qcchijxpq] { text-align: center; font-size: .78rem; color: var(--fm-text-muted, #9ca3af); margin: .5rem 0 0; }

/* ── Manual import ───────────────────────────────────────────────────────── */

.asset-dropdown[b-8qcchijxpq] {
    list-style: none;
    margin: .25rem 0 0;
    padding: 0;
    border: 1px solid var(--fm-border, #e5e7eb);
    border-radius: 8px;
    background: var(--fm-surface, #fff);
    box-shadow: 0 8px 24px rgba(0,0,0,.1);
    position: absolute;
    z-index: 100;
    width: 100%;
    max-height: 220px;
    overflow-y: auto;
}

.asset-dropdown__item[b-8qcchijxpq] {
    padding: .6rem .85rem;
    cursor: pointer;
    transition: background .1s;
    border-bottom: 1px solid var(--fm-border, #f0f1f3);
}
.asset-dropdown__item:last-child[b-8qcchijxpq] { border-bottom: none; }
.asset-dropdown__item:hover[b-8qcchijxpq] { background: var(--fm-surface-alt, #f4f5f7); }

.asset-dropdown__name[b-8qcchijxpq] { display: block; font-size: .875rem; font-weight: 500; }
.asset-dropdown__meta[b-8qcchijxpq] { font-size: .75rem; color: var(--fm-text-muted, #9ca3af); font-family: monospace; }

.selected-asset-pill[b-8qcchijxpq] {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: rgba(24,71,245,.08);
    color: var(--fm-accent, #1847f5);
    border-radius: 20px;
    padding: .3rem .75rem;
    font-size: .82rem;
    font-weight: 500;
    margin-top: .4rem;
}
.selected-asset-pill button[b-8qcchijxpq] {
    background: none;
    border: none;
    cursor: pointer;
    color: inherit;
    font-size: 1rem;
    line-height: 1;
    padding: 0;
}

.form-row[b-8qcchijxpq] {
    display: grid;
    grid-template-columns: 1fr 1fr auto;
    gap: .75rem;
    align-items: end;
}
.form-group--sm[b-8qcchijxpq] { min-width: 90px; }

.manual-total[b-8qcchijxpq] {
    font-size: .9rem;
    color: var(--fm-text-muted, #6b7280);
    margin: -.25rem 0 1rem;
}
.manual-total strong[b-8qcchijxpq] { color: var(--fm-text, #0d0d1a); }

/* ── Result screen ───────────────────────────────────────────────────────── */

.result-screen[b-8qcchijxpq] {
    text-align: center;
    padding: 1rem 0 .5rem;
}

.result-icon[b-8qcchijxpq] {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1rem;
}
.result-icon--success[b-8qcchijxpq] { background: rgba(0,200,150,.12); color: #00a97c; }

.result-title[b-8qcchijxpq] {
    font-size: 1.15rem;
    font-weight: 700;
    margin: 0 0 .4rem;
    color: var(--fm-text, #0d0d1a);
}
.result-desc[b-8qcchijxpq] {
    font-size: .9rem;
    color: var(--fm-text-muted, #6b7280);
    margin: 0 0 1.25rem;
}

.result-errors[b-8qcchijxpq] {
    text-align: left;
    font-size: .8rem;
    margin-bottom: 1rem;
    color: #dc2626;
}
.result-errors summary[b-8qcchijxpq] { cursor: pointer; font-weight: 600; margin-bottom: .35rem; }
.result-errors ul[b-8qcchijxpq] { margin: 0; padding-left: 1.25rem; }

.result-actions[b-8qcchijxpq] {
    display: flex;
    justify-content: center;
    gap: .75rem;
}

/* ── Loading spinner ─────────────────────────────────────────────────────── */

.wizard-loading[b-8qcchijxpq] {
    text-align: center;
    padding: 2rem;
    color: var(--fm-text-muted, #9ca3af);
}
.wizard-loading p[b-8qcchijxpq] { margin: .75rem 0 0; font-size: .88rem; }

.spinner[b-8qcchijxpq] {
    display: inline-block;
    width: 28px;
    height: 28px;
    border: 3px solid var(--fm-border, #e5e7eb);
    border-top-color: var(--fm-accent, #1847f5);
    border-radius: 50%;
    animation: spin-b-8qcchijxpq .7s linear infinite;
}
.spinner--sm[b-8qcchijxpq] {
    width: 14px;
    height: 14px;
    border-width: 2px;
    vertical-align: middle;
    margin-right: .35rem;
}
@keyframes spin-b-8qcchijxpq { to { transform: rotate(360deg) } }

/* ── Alerts ──────────────────────────────────────────────────────────────── */

.alert[b-8qcchijxpq] {
    padding: .75rem 1rem;
    border-radius: 8px;
    font-size: .83rem;
    margin-bottom: 1rem;
    display: flex;
    align-items: flex-start;
    gap: .5rem;
    line-height: 1.5;
}
.alert-danger[b-8qcchijxpq] { background: rgba(239,68,68,.08); color: #b91c1c; }
.alert-warning[b-8qcchijxpq] { background: rgba(245,158,11,.08); color: #92400e; }
.alert-info[b-8qcchijxpq] { background: rgba(24,71,245,.06); color: #1e40af; }
.alert svg[b-8qcchijxpq] { flex-shrink: 0; margin-top: .1rem; }

/* ── Footer ──────────────────────────────────────────────────────────────── */

.wizard-footer[b-8qcchijxpq] {
    display: flex;
    justify-content: flex-end;
    gap: .75rem;
    margin-top: 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid var(--fm-border, #f0f1f3);
}

/* ── Shared form helpers ─────────────────────────────────────────────────── */

.form-group[b-8qcchijxpq] { position: relative; margin-bottom: .85rem; }
.form-label[b-8qcchijxpq] { display: block; font-size: .8rem; font-weight: 600; color: var(--fm-text-muted, #6b7280); margin-bottom: .35rem; }
.form-label--optional[b-8qcchijxpq] { font-weight: 400; }

.btn-sm[b-8qcchijxpq] { padding: .3rem .75rem; font-size: .8rem; }

/* ── Responsive ──────────────────────────────────────────────────────────── */

@media (max-width: 540px) {
    .wizard-modal[b-8qcchijxpq] { border-radius: 12px 12px 0 0; top: auto; bottom: 0; transform: translateX(-50%); max-height: 95vh; }
    @keyframes slideUp-b-8qcchijxpq { from { transform: translateX(-50%) translateY(4%); opacity: 0 } to { transform: translateX(-50%) translateY(0); opacity: 1 } }
    .method-cards[b-8qcchijxpq] { grid-template-columns: 1fr; }
    .form-row[b-8qcchijxpq] { grid-template-columns: 1fr 1fr; }
    .form-group--sm[b-8qcchijxpq] { grid-column: span 2; }
}

/* ── Asset lookup panel ──────────────────────────────────────────────────── */

.asset-lookup-panel[b-8qcchijxpq] {
    border: 1px solid rgba(245,158,11,.3);
    border-radius: 12px;
    background: rgba(245,158,11,.04);
    margin-bottom: 1rem;
    overflow: hidden;
}

.asset-lookup-panel__header[b-8qcchijxpq] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .75rem 1rem;
    border-bottom: 1px solid rgba(245,158,11,.2);
    background: rgba(245,158,11,.06);
}

.asset-lookup-panel__title[b-8qcchijxpq] {
    display: block;
    font-size: .875rem;
    font-weight: 600;
    color: #92400e;
}

.asset-lookup-panel__subtitle[b-8qcchijxpq] {
    display: block;
    font-size: .75rem;
    color: #b45309;
    margin-top: .1rem;
}

.asset-lookup-list[b-8qcchijxpq] {
    max-height: 240px;
    overflow-y: auto;
}

.asset-lookup-row[b-8qcchijxpq] {
    display: grid;
    grid-template-columns: 180px 1fr 80px 60px 60px;
    align-items: center;
    gap: .5rem;
    padding: .5rem 1rem;
    border-bottom: 1px solid rgba(245,158,11,.1);
    font-size: .8rem;
}
.asset-lookup-row:last-child[b-8qcchijxpq] { border-bottom: none; }
.asset-lookup-row--found[b-8qcchijxpq] { background: transparent; }
.asset-lookup-row--manual[b-8qcchijxpq] { background: rgba(245,158,11,.03); }

.asset-lookup-row__isin[b-8qcchijxpq] {
    display: flex;
    align-items: center;
    gap: .4rem;
}
.asset-lookup-row__isin-val[b-8qcchijxpq] {
    font-family: monospace;
    font-size: .75rem;
    color: var(--fm-text-muted, #6b7280);
}

.asset-lookup-row__name[b-8qcchijxpq] { font-weight: 500; color: var(--fm-text, #0d0d1a); }
.asset-lookup-row__ticker[b-8qcchijxpq] { font-family: monospace; font-size: .75rem; color: var(--fm-text-muted, #6b7280); }
.asset-lookup-row__type[b-8qcchijxpq] { font-size: .73rem; color: var(--fm-text-muted, #9ca3af); }
.asset-lookup-row__currency[b-8qcchijxpq] { font-size: .75rem; font-family: monospace; color: var(--fm-text-muted, #9ca3af); }

.fm-input--sm[b-8qcchijxpq] {
    padding: .25rem .45rem;
    font-size: .78rem;
    border-radius: 6px;
}

.asset-lookup-panel__footer[b-8qcchijxpq] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: .75rem 1rem;
    border-top: 1px solid rgba(245,158,11,.2);
    background: rgba(245,158,11,.04);
}

.asset-lookup-panel__note[b-8qcchijxpq] {
    font-size: .75rem;
    color: #b45309;
    flex: 1;
}
/* /Pages/Assets.razor.rz.scp.css */
.asset-search[b-ajfbqfl7il] {
    position: relative;
    max-width: 480px;
    margin-bottom: 1.75rem;
}
.asset-search__icon[b-ajfbqfl7il] {
    position: absolute;
    left: 1rem;
    top: 50%;
    transform: translateY(-50%);
    color: #8892aa;
    font-size: 0.875rem;
    pointer-events: none;
}
.asset-search__input[b-ajfbqfl7il] {
    padding-left: 2.5rem;
}
.asset-search__input:disabled[b-ajfbqfl7il] {
    cursor: not-allowed;
    opacity: 0.5;
}

.asset-types[b-ajfbqfl7il] {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.5rem;
    margin: 0 0 0;
}
.asset-type-badge[b-ajfbqfl7il] {
    font-size: 10px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 2px;
    padding: 0.25rem 0.75rem;
    border-radius: 6px;
    background: #e8edff;
    color: #1847f5;
    border: none;
}
.asset-type-badge--green[b-ajfbqfl7il] {
    background: rgba(0, 200, 150, 0.1);
    color: #00c896;
}

.coming-soon-note[b-ajfbqfl7il] {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8125rem;
    color: #8892aa;
    margin: 1.125rem 0 0;
    font-weight: 300;
}
/* /Pages/Brokers.razor.rz.scp.css */
.broker-grid[b-fwme5ywzz9] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
    gap: 1rem;
    margin-bottom: 1.75rem;
    list-style: none;
    padding: 0;
}

/* ============================================================
   BROKER CARD
   ============================================================ */
.broker-card[b-fwme5ywzz9] {
    background: #ffffff;
    border: 1px solid rgba(24, 71, 245, 0.1);
    border-radius: 16px;
    padding: 1.5rem;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}
.broker-card:not(.broker-card--coming):hover[b-fwme5ywzz9] {
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(24, 71, 245, 0.12);
    border-color: rgba(24, 71, 245, 0.2);
}
.broker-card--coming[b-fwme5ywzz9] {
    opacity: 0.55;
    background: #f7f8fc;
}

.broker-card__header[b-fwme5ywzz9] {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    margin-bottom: 0.875rem;
}

.broker-card__icon[b-fwme5ywzz9] {
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Syne', sans-serif;
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: -0.5px;
    flex-shrink: 0;
}
.broker-card__icon--blue[b-fwme5ywzz9]  { background: #e8edff; color: #1847f5; }
.broker-card__icon--green[b-fwme5ywzz9] { background: rgba(0, 200, 150, 0.1); color: #00c896; }
.broker-card__icon--muted[b-fwme5ywzz9] {
    background: #f7f8fc;
    color: #8892aa;
    border: 1.5px dashed rgba(24, 71, 245, 0.2);
}

.broker-card__meta[b-fwme5ywzz9] { flex: 1; min-width: 0; }
.broker-card__name[b-fwme5ywzz9] {
    font-family: 'Syne', sans-serif;
    font-size: 0.9375rem;
    font-weight: 700;
    letter-spacing: -0.5px;
    margin: 0 0 0.125rem;
    color: #0a0f1e;
}
.broker-card__country[b-fwme5ywzz9] {
    font-size: 0.75rem;
    color: #8892aa;
    margin: 0;
    font-weight: 300;
}

.broker-card__desc[b-fwme5ywzz9] {
    font-size: 0.8125rem;
    color: #8892aa;
    line-height: 1.6;
    margin: 0 0 1rem;
    font-weight: 300;
}
.broker-card--coming .broker-card__desc[b-fwme5ywzz9] { margin-bottom: 0; }

.broker-card__tags[b-fwme5ywzz9] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.375rem;
}

.broker-tag[b-fwme5ywzz9] {
    font-size: 10px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 2px;
    padding: 0.2rem 0.625rem;
    border-radius: 6px;
    background: #e8edff;
    color: #1847f5;
}
.broker-tag--green[b-fwme5ywzz9] {
    background: rgba(0, 200, 150, 0.1);
    color: #00c896;
}
.broker-tag--muted[b-fwme5ywzz9] {
    background: #f0f2f8;
    color: #8892aa;
}

/* ============================================================
   CARD BOTTOM ACTIONS  (import + disconnect row)
   ============================================================ */
.broker-card__bottom-actions[b-fwme5ywzz9] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.875rem;
    flex-wrap: wrap;
}

.broker-card__confirm-label[b-fwme5ywzz9] {
    font-size: 0.8125rem;
    color: #8892aa;
    font-weight: 500;
}

/* ============================================================
   PORTFOLIO PICKER  (inline select before opening wizard)
   ============================================================ */
.broker-card__picker[b-fwme5ywzz9] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.875rem;
    flex-wrap: wrap;
}

.broker-card__picker select[b-fwme5ywzz9] {
    flex: 1;
    min-width: 0;
}

/* ============================================================
   BINANCE INLINE CONNECT FORM
   ============================================================ */
.broker-card__inline-form[b-fwme5ywzz9] {
    margin-top: 0.875rem;
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
}

.broker-card__form-row[b-fwme5ywzz9] {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.broker-card__form-label[b-fwme5ywzz9] {
    font-size: 0.75rem;
    font-weight: 500;
    color: #3d4966;
    letter-spacing: 0.01em;
}

.broker-card__input-wrap[b-fwme5ywzz9] {
    position: relative;
    display: flex;
    align-items: center;
}

.broker-card__input-wrap .fm-input[b-fwme5ywzz9] {
    flex: 1;
    padding-right: 2.5rem;
}

.broker-card__toggle-vis[b-fwme5ywzz9] {
    position: absolute;
    right: 0.625rem;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    color: #8892aa;
    display: flex;
    align-items: center;
    line-height: 1;
}

.broker-card__toggle-vis:hover[b-fwme5ywzz9] { color: #1847f5; }

.broker-card__form-actions[b-fwme5ywzz9] {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.5rem;
    margin-top: 0.25rem;
}

/* ============================================================
   FOOTER NOTE
   ============================================================ */
.brokers-note[b-fwme5ywzz9] {
    font-size: 0.8125rem;
    color: #8892aa;
    margin: 0;
    font-weight: 300;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 640px) {
    .broker-grid[b-fwme5ywzz9] { grid-template-columns: 1fr; }
}
/* /Pages/Connections.razor.rz.scp.css */
.connections-grid[b-31ayi4qo64] {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    max-width: 640px;
}

.connection-card[b-31ayi4qo64] {
    background: var(--fm-surface, #fff);
    border: 1px solid var(--fm-border, #e5e7eb);
    border-radius: 12px;
    padding: 1.25rem;
}

.connection-card__header[b-31ayi4qo64] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: .75rem;
}

.connection-card__broker[b-31ayi4qo64] {
    display: flex;
    align-items: center;
    gap: .5rem;
}

.connection-card__name[b-31ayi4qo64] {
    font-weight: 600;
    font-size: .95rem;
    color: var(--fm-text, #0d0d1a);
}

.connection-badge[b-31ayi4qo64] {
    font-size: .68rem;
    font-weight: 600;
    padding: .15rem .45rem;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.connection-badge--apikey[b-31ayi4qo64] { background: rgba(24,71,245,.1); color: var(--fm-accent, #1847f5); }
.connection-badge--csv[b-31ayi4qo64] { background: var(--fm-surface-alt, #f4f5f7); color: var(--fm-text-muted, #6b7280); }

.connection-card__count[b-31ayi4qo64] {
    font-size: .8rem;
    color: var(--fm-text-muted, #9ca3af);
}

.connection-card__meta[b-31ayi4qo64] {
    font-size: .82rem;
    color: var(--fm-text-muted, #6b7280);
    margin: 0;
}

.connection-sync[b-31ayi4qo64] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.sync-status[b-31ayi4qo64] {
    font-size: .82rem;
    display: flex;
    align-items: center;
    gap: .4rem;
}
.sync-status--running[b-31ayi4qo64] { color: var(--fm-accent, #1847f5); }
.sync-status--done[b-31ayi4qo64] { color: #00a97c; }
.sync-status--error[b-31ayi4qo64] { color: #dc2626; }
.sync-status--none[b-31ayi4qo64] { color: var(--fm-text-muted, #9ca3af); }

.sync-actions[b-31ayi4qo64] {
    display: flex;
    align-items: center;
    gap: .5rem;
}

.btn-sm[b-31ayi4qo64] {
    padding: .35rem .75rem;
    font-size: .8rem;
}
/* /Pages/Holdings.razor.rz.scp.css */
/* ── Holdings summary strip ────────────────────────────────────────────── */
.holdings-summary[b-5trtl4suaz] {
    display: flex;
    gap: 2rem;
    padding: 1rem 1.25rem;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    margin-bottom: 1.25rem;
    flex-wrap: wrap;
}

.holdings-stat[b-5trtl4suaz] {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
}

.holdings-stat__val[b-5trtl4suaz] {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--text-primary);
    letter-spacing: -0.02em;
}

.holdings-stat__label[b-5trtl4suaz] {
    font-size: 0.72rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

/* ── Holdings table overrides ──────────────────────────────────────────── */
.holdings-table td[b-5trtl4suaz] {
    vertical-align: middle;
}

.holdings-asset[b-5trtl4suaz] {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.holdings-asset__name[b-5trtl4suaz] {
    font-weight: 500;
    color: var(--text-primary);
}

.holdings-asset__meta[b-5trtl4suaz] {
    display: flex;
    gap: 0.4rem;
    align-items: center;
}

.holdings-ticker[b-5trtl4suaz] {
    font-size: 0.72rem;
    font-weight: 600;
    color: #1847f5;
    background: rgba(24, 71, 245, 0.08);
    padding: 0.1rem 0.4rem;
    border-radius: 4px;
    letter-spacing: 0.02em;
}

.holdings-isin[b-5trtl4suaz] {
    font-size: 0.72rem;
    color: var(--text-muted);
    font-family: var(--font-mono, monospace);
}

.holdings-exchange[b-5trtl4suaz] {
    font-size: 0.8rem;
    color: var(--text-muted);
}

.holdings-type[b-5trtl4suaz] {
    display: inline-block;
    font-size: 0.72rem;
    font-weight: 500;
    padding: 0.15rem 0.55rem;
    border-radius: 20px;
    text-transform: capitalize;
    background: var(--surface-alt, #f5f5f5);
    color: var(--text-secondary);
}

.holdings-type--etf[b-5trtl4suaz] {
    background: rgba(0, 200, 150, 0.1);
    color: #007a5a;
}

.holdings-type--stock[b-5trtl4suaz] {
    background: rgba(24, 71, 245, 0.08);
    color: #1847f5;
}

.holdings-type--crypto[b-5trtl4suaz] {
    background: rgba(245, 158, 11, 0.1);
    color: #b45309;
}

.holdings-cost[b-5trtl4suaz] {
    font-weight: 600;
    color: var(--text-primary);
}
/* /Pages/Index.razor.rz.scp.css */
/* ============================================================
   SECTION SPACING
   ============================================================ */
.dashboard__section-header[b-krvxttn9ki] {
    margin-bottom: 0.5rem;
}

/* ============================================================
   STATS GRID
   ============================================================ */
.stats-grid[b-krvxttn9ki] {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    margin-bottom: 2.25rem;
    list-style: none;
    padding: 0;
}

.stat-card[b-krvxttn9ki] {
    background: #ffffff;
    border: 1px solid rgba(24, 71, 245, 0.1);
    border-radius: 16px;
    padding: 1.375rem 1.25rem;
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.stat-card:hover[b-krvxttn9ki] {
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(24, 71, 245, 0.12);
}

.stat-card__icon[b-krvxttn9ki] {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 1rem;
}
.stat-card__icon--blue[b-krvxttn9ki]  { background: #e8edff; color: #1847f5; }
.stat-card__icon--green[b-krvxttn9ki] { background: rgba(0, 200, 150, 0.1); color: #00c896; }

.stat-card__label[b-krvxttn9ki] {
    font-family: 'DM Sans', sans-serif;
    font-size: 10px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: #8892aa;
    margin: 0 0 0.25rem;
}
.stat-card__value[b-krvxttn9ki] {
    font-family: 'Syne', sans-serif;
    font-size: 1.625rem;
    font-weight: 800;
    letter-spacing: -1.5px;
    color: #0a0f1e;
    margin: 0 0 0.25rem;
    line-height: 1;
}
.stat-card__note[b-krvxttn9ki] {
    font-size: 0.75rem;
    color: #8892aa;
    margin: 0;
    font-weight: 300;
}

/* ============================================================
   FEATURE GRID
   ============================================================ */
.feature-grid[b-krvxttn9ki] {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    margin-bottom: 2.25rem;
}

.feature-card[b-krvxttn9ki] {
    background: #ffffff;
    border: 1px solid rgba(24, 71, 245, 0.1);
    border-radius: 16px;
    padding: 1.375rem 1.25rem;
    display: flex;
    align-items: center;
    gap: 1rem;
    color: #0a0f1e;
    text-decoration: none !important;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}
.feature-card:hover[b-krvxttn9ki] {
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(24, 71, 245, 0.15);
    border-color: rgba(24, 71, 245, 0.2);
    color: #0a0f1e;
}
.feature-card--disabled[b-krvxttn9ki] {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

.feature-card__icon[b-krvxttn9ki] {
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 1.125rem;
}
.feature-card__icon--blue[b-krvxttn9ki]  { background: #e8edff; color: #1847f5; }
.feature-card__icon--green[b-krvxttn9ki] { background: rgba(0, 200, 150, 0.1); color: #00c896; }

.feature-card__body[b-krvxttn9ki]  { flex: 1; min-width: 0; }
.feature-card__title[b-krvxttn9ki] {
    font-family: 'Syne', sans-serif;
    font-size: 0.9375rem;
    font-weight: 700;
    letter-spacing: -0.5px;
    margin: 0 0 0.25rem;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.375rem;
    color: #0a0f1e;
}
.feature-card__desc[b-krvxttn9ki] {
    font-size: 0.8125rem;
    color: #8892aa;
    margin: 0;
    line-height: 1.6;
    font-weight: 300;
}
.feature-card__arrow[b-krvxttn9ki] {
    color: #8892aa;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    transition: transform 0.2s, color 0.2s;
}
.feature-card:hover .feature-card__arrow[b-krvxttn9ki] {
    transform: translateX(3px);
    color: #1847f5;
}
.feature-card__arrow--lock[b-krvxttn9ki] {
    color: #8892aa;
    opacity: 0.5;
}

/* Ensure SVGs inside icon containers scale properly */
.stat-card__icon svg[b-krvxttn9ki],
.feature-card__icon svg[b-krvxttn9ki] {
    width: 100%;
    height: 100%;
    display: block;
}

/* ============================================================
   GETTING STARTED
   ============================================================ */
.getting-started[b-krvxttn9ki] {
    background: #ffffff;
    border: 1px solid rgba(24, 71, 245, 0.1);
    border-radius: 20px;
    padding: 2rem;
}

.getting-started__title[b-krvxttn9ki] {
    font-family: 'Syne', sans-serif;
    font-size: 1.125rem;
    font-weight: 800;
    letter-spacing: -0.75px;
    color: #0a0f1e;
    margin: 0 0 0.25rem;
}
.getting-started__subtitle[b-krvxttn9ki] {
    font-size: 0.875rem;
    color: #8892aa;
    margin: 0 0 1.75rem;
    font-weight: 300;
}

.checklist[b-krvxttn9ki] {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
}
.checklist__item[b-krvxttn9ki] {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.0625rem 0;
    border-bottom: 1px solid rgba(24, 71, 245, 0.08);
}
.checklist__item:first-child[b-krvxttn9ki] { padding-top: 0; }
.checklist__item:last-child[b-krvxttn9ki]  { border-bottom: none; padding-bottom: 0; }

.checklist__step[b-krvxttn9ki] {
    width: 2rem;
    height: 2rem;
    border-radius: 9999px;
    background: #e8edff;
    color: #1847f5;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    font-weight: 700;
    font-family: 'Syne', sans-serif;
    flex-shrink: 0;
}

.checklist__body[b-krvxttn9ki] { flex: 1; min-width: 0; }
.checklist__name[b-krvxttn9ki] {
    font-size: 0.875rem;
    font-weight: 500;
    color: #0a0f1e;
    margin: 0 0 0.125rem;
}
.checklist__desc[b-krvxttn9ki] {
    font-size: 0.8125rem;
    color: #8892aa;
    margin: 0;
    font-weight: 300;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px) {
    .stats-grid[b-krvxttn9ki]   { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 860px) {
    .feature-grid[b-krvxttn9ki] { grid-template-columns: 1fr; }
}
@media (max-width: 580px) {
    .stats-grid[b-krvxttn9ki]          { grid-template-columns: 1fr; }
    .checklist__item[b-krvxttn9ki]     { flex-wrap: wrap; }
    .checklist__item .btn[b-krvxttn9ki] { margin-left: 3rem; }
}
/* /Pages/Portfolios.razor.rz.scp.css */
.coming-soon-note[b-puc5xem1ck] {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8125rem;
    color: #8892aa;
    margin: 1.125rem 0 0;
    font-weight: 300;
}

/* Portfolios */

/* Needed so .portfolio-card__actions can be positioned absolute */
.portfolio-card[b-puc5xem1ck] { position: relative; }

/* Reserve space on the right so the portfolio name never slides under the action buttons */
.portfolio-card__header[b-puc5xem1ck] { padding-right: 5rem; justify-content: flex-start; }

/* The clickable card body — resets anchor appearance */
.portfolio-card__link[b-puc5xem1ck] {
    display: block;
    text-decoration: none;
    color: inherit;
}
.portfolio-card__link:hover[b-puc5xem1ck] { color: inherit; }

/* Edit + delete button cluster, absolutely placed top-right */
.portfolio-card__actions[b-puc5xem1ck] {
    position: absolute;
    top: 1rem;
    right: 1rem;
    display: flex;
    align-items: center;
    gap: .375rem;
    opacity: 0;
    pointer-events: none;
    transition: opacity .15s;
}

.portfolio-card:hover .portfolio-card__actions[b-puc5xem1ck],
.portfolio-card--confirming .portfolio-card__actions[b-puc5xem1ck] {
    opacity: 1;
    pointer-events: auto;
}

/* Override the global opacity:0 on the delete button — visibility is now
   controlled at the .portfolio-card__actions level */
.portfolio-card__delete[b-puc5xem1ck] { opacity: 1; }

.portfolio-card__edit[b-puc5xem1ck] {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--fm-ink-muted);
    padding: .2rem;
    border-radius: 4px;
    transition: color .15s;
}
.portfolio-card__edit:hover[b-puc5xem1ck] { color: var(--fm-primary); }

.portfolio-card__confirm-label[b-puc5xem1ck] {
    font-size: .8rem;
    font-weight: 600;
    color: var(--fm-ink-muted);
    white-space: nowrap;
    margin-right: .125rem;
}
/* /Pages/Transactions.razor.rz.scp.css */
.broker-chips[b-96u6hbcq69] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1.75rem;
}

.broker-chip[b-96u6hbcq69] {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.375rem 0.875rem;
    border: 1.5px solid rgba(24, 71, 245, 0.15);
    border-radius: 100px;
    font-size: 0.8125rem;
    font-weight: 500;
    color: #3d4663;
    background: #ffffff;
}
.broker-chip--muted[b-96u6hbcq69] {
    color: #8892aa;
    background: transparent;
    border-style: dashed;
    font-weight: 300;
}

.coming-soon-note[b-96u6hbcq69] {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8125rem;
    color: #8892aa;
    margin: 1.125rem 0 0;
    font-weight: 300;
}
/* /Shared/MainLayout.razor.rz.scp.css */
.fm-layout[b-6cppbbfhc2] {
    display: flex;
    min-height: 100vh;
}

.fm-sidebar[b-6cppbbfhc2] {
    width: 260px;
    flex-shrink: 0;
    background: #0a0f1e;
    position: sticky;
    top: 0;
    height: 100vh;
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-width: none;
    z-index: 10;
}
.fm-sidebar[b-6cppbbfhc2]::-webkit-scrollbar { display: none; }

.fm-main[b-6cppbbfhc2] {
    flex: 1;
    min-width: 0;
    background: #f7f8fc;
    overflow-x: hidden;
}

@media (max-width: 768px) {
    .fm-layout[b-6cppbbfhc2]       { flex-direction: column; }
    .fm-sidebar[b-6cppbbfhc2]      { width: 100%; height: auto; position: relative; }
}
/* /Shared/NavMenu.razor.rz.scp.css */
/* ================================================================
   SHELL
   ================================================================ */
.fm-nav[b-co27ej0mon] {
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: 100vh;
    background: #0a0f1e;
}

/* ================================================================
   BRAND HEADER
   ================================================================ */
.fm-nav__header[b-co27ej0mon] {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.375rem 1.125rem 1.25rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    flex-shrink: 0;
    overflow: hidden;
}

/* Subtle radial glow behind the logo — premium fintech feel */
.fm-nav__header[b-co27ej0mon]::before {
    content: '';
    position: absolute;
    top: -48px;
    left: -24px;
    width: 180px;
    height: 180px;
    background: radial-gradient(circle, rgba(24, 71, 245, 0.14) 0%, transparent 68%);
    pointer-events: none;
}

.fm-nav__brand[b-co27ej0mon] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    text-decoration: none !important;
    position: relative;   /* above the glow pseudo */
    z-index: 1;
}
.fm-nav__brand:hover[b-co27ej0mon] { text-decoration: none; }

/* Logo mark — blue ring container */
.fm-nav__logomark[b-co27ej0mon] {
    width: 38px;
    height: 38px;
    flex-shrink: 0;
    border-radius: 10px;
    background: rgba(24, 71, 245, 0.12);
    border: 1px solid rgba(24, 71, 245, 0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s, border-color 0.2s;
}
.fm-nav__brand:hover .fm-nav__logomark[b-co27ej0mon] {
    background: rgba(24, 71, 245, 0.2);
    border-color: rgba(24, 71, 245, 0.45);
}

.fm-nav__brandtext[b-co27ej0mon] {
    display: flex;
    flex-direction: column;
    gap: 1px;
}

.fm-nav__brand-name[b-co27ej0mon] {
    font-family: 'Syne', sans-serif;
    font-size: 1rem;
    font-weight: 800;
    letter-spacing: -0.5px;
    color: #ffffff;
    line-height: 1;
}

.fm-nav__brand-tag[b-co27ej0mon] {
    font-family: 'DM Sans', sans-serif;
    font-size: 10px;
    font-weight: 400;
    color: rgba(255, 255, 255, 0.3);
    letter-spacing: 0.2px;
    line-height: 1;
}

/* Mobile toggle */
.fm-nav__toggle[b-co27ej0mon] {
    display: none;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: rgba(255, 255, 255, 0.4);
    cursor: pointer;
    padding: 0.4375rem;
    line-height: 0;
    transition: background 0.2s, color 0.2s;
    position: relative;
    z-index: 1;
    flex-shrink: 0;
}
.fm-nav__toggle:hover[b-co27ej0mon] {
    background: rgba(255, 255, 255, 0.1);
    color: rgba(255, 255, 255, 0.85);
    border-color: rgba(255, 255, 255, 0.18);
}

/* ================================================================
   COLLAPSIBLE BODY
   ================================================================ */
.fm-nav__body[b-co27ej0mon] {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-width: none;
}
.fm-nav__body[b-co27ej0mon]::-webkit-scrollbar { display: none; }

/* ================================================================
   NAV GROUPS + SECTION LABELS
   ================================================================ */
.fm-nav__links[b-co27ej0mon] {
    flex: 1;
    padding: 1.125rem 0.875rem 0.5rem;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.fm-nav__group[b-co27ej0mon] {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.fm-nav__group + .fm-nav__group[b-co27ej0mon] {
    margin-top: 1.25rem;
    padding-top: 1.125rem;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.fm-nav__section-label[b-co27ej0mon] {
    display: block;
    font-family: 'DM Sans', sans-serif;
    font-size: 9.5px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: rgba(255, 255, 255, 0.22);
    padding: 0 0.375rem;
    margin-bottom: 0.25rem;
    user-select: none;
}

/* ================================================================
   NAV LINKS
   NavLink is a Blazor child component — it renders its own <a> tag,
   which does NOT receive this component's scoped CSS attribute.
   ::deep pierces that boundary so display:flex actually applies.
   ================================================================ */
.fm-nav__links[b-co27ej0mon]  .fm-nav__link {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 0.75rem;
    padding: 0.3125rem 0.625rem 0.3125rem 0.3125rem;
    border-radius: 9px;
    text-decoration: none !important;
    font-family: 'DM Sans', sans-serif;
    font-size: 0.9375rem;
    font-weight: 400;
    line-height: 1;
    cursor: pointer;
    transition: background 0.18s ease, box-shadow 0.18s ease;
}
.fm-nav__links[b-co27ej0mon]  .fm-nav__link:hover {
    background: rgba(255, 255, 255, 0.05);
    text-decoration: none;
}
.fm-nav__links[b-co27ej0mon]  .fm-nav__link.active {
    background: rgba(0, 200, 150, 0.07);
    box-shadow: inset 3px 0 0 #00c896;
}

/* ── Label — scoped normally (NavMenu renders the <span>) ── */
.fm-nav__label[b-co27ej0mon] {
    flex: 1;
    color: rgba(255, 255, 255, 0.72);
    font-family: 'DM Sans', sans-serif;
    font-size: 0.9375rem;
    font-weight: 400;
    line-height: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: color 0.18s ease;
}
.fm-nav__links[b-co27ej0mon]  .fm-nav__link:hover  .fm-nav__label { color: #ffffff; }
.fm-nav__links[b-co27ej0mon]  .fm-nav__link.active .fm-nav__label { color: #00c896; font-weight: 500; }

/* ================================================================
   ICON BOX — scoped normally (NavMenu renders the <span>)
   ================================================================ */
.fm-nav__icon[b-co27ej0mon] {
    width: 32px;
    height: 32px;
    flex-shrink: 0;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
    transition: background 0.18s ease, border-color 0.18s ease;
}
.fm-nav__icon svg[b-co27ej0mon] {
    width: 15px;
    height: 15px;
    display: block;
    color: rgba(255, 255, 255, 0.4);
    transition: color 0.18s ease;
    flex-shrink: 0;
}
.fm-nav__links[b-co27ej0mon]  .fm-nav__link:hover  .fm-nav__icon         { background: rgba(255,255,255,0.09); border-color: rgba(255,255,255,0.11); }
.fm-nav__links[b-co27ej0mon]  .fm-nav__link:hover  .fm-nav__icon svg     { color: rgba(255,255,255,0.88); }
.fm-nav__links[b-co27ej0mon]  .fm-nav__link.active .fm-nav__icon         { background: rgba(0,200,150,0.14); border-color: rgba(0,200,150,0.26); }
.fm-nav__links[b-co27ej0mon]  .fm-nav__link.active .fm-nav__icon svg     { color: #00c896; }

/* ================================================================
   USER FOOTER
   ================================================================ */
.fm-nav__footer[b-co27ej0mon] {
    padding: 0.875rem;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    flex-shrink: 0;
}

.fm-nav__user[b-co27ej0mon] {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    padding: 0.5625rem 0.5rem;
    border-radius: 10px;
    border: 1px solid transparent;
    cursor: pointer;
    transition: background 0.18s, border-color 0.18s;
}
.fm-nav__user:hover[b-co27ej0mon] {
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(255, 255, 255, 0.07);
}

/* Avatar — monogram with blue ring */
.fm-nav__avatar[b-co27ej0mon] {
    width: 34px;
    height: 34px;
    border-radius: 9999px;
    background: linear-gradient(135deg, rgba(24,71,245,0.35) 0%, rgba(24,71,245,0.15) 100%);
    border: 1.5px solid rgba(24, 71, 245, 0.4);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.fm-nav__avatar span[b-co27ej0mon] {
    font-family: 'Syne', sans-serif;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.5px;
    color: rgba(100, 140, 255, 0.9);
    user-select: none;
}

.fm-nav__user-info[b-co27ej0mon] {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
    overflow: hidden;
}

.fm-nav__user-name[b-co27ej0mon] {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.8125rem;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.78);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.2;
}

.fm-nav__user-role[b-co27ej0mon] {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    font-weight: 300;
    color: rgba(255, 255, 255, 0.28);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.2;
}

.fm-nav__user-action[b-co27ej0mon] {
    color: rgba(255, 255, 255, 0.2);
    flex-shrink: 0;
    line-height: 0;
    transition: color 0.18s;
}
.fm-nav__user:hover .fm-nav__user-action[b-co27ej0mon] {
    color: rgba(255, 255, 255, 0.5);
}

/* ================================================================
   MOBILE  —  frosted glass sticky bar
   ================================================================ */
@media (max-width: 768px) {
    .fm-nav[b-co27ej0mon] {
        min-height: auto;
        background: rgba(10, 15, 30, 0.95);
        backdrop-filter: blur(20px);
        -webkit-backdrop-filter: blur(20px);
        position: sticky;
        top: 0;
        z-index: 100;
    }

    .fm-nav__toggle[b-co27ej0mon] {
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .fm-nav__body--collapsed[b-co27ej0mon] { display: none; }
    .fm-nav__body[b-co27ej0mon] { border-bottom: 1px solid rgba(255,255,255,0.06); }

    /* On mobile there's no sidebar wall, so drop the inset bar */
    .fm-nav__link.active[b-co27ej0mon] { box-shadow: none; }

    .fm-nav__links[b-co27ej0mon] { padding: 0.75rem; }
    .fm-nav__group + .fm-nav__group[b-co27ej0mon] { margin-top: 0.75rem; padding-top: 0.75rem; }
}

/* ================================================================
   DESKTOP  —  always expanded
   ================================================================ */
@media (min-width: 769px) {
    .fm-nav[b-co27ej0mon] { height: 100vh; }
    .fm-nav__body--collapsed[b-co27ej0mon] { display: flex !important; }
}
