/* /Components/Layout/MainLayout.razor.rz.scp.css */
/* Blazor Error UI */
#blazor-error-ui[b-1bxl49cgne] {
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    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-1bxl49cgne] {
    cursor: pointer;
    position: absolute;
    right: 0.75rem;
    top: 0.5rem;
}
/* /Components/Layout/PublicAwareLayout.razor.rz.scp.css */
/* ============================================================
   PublicAwareLayout — anonymous branch shell.
   Mirrors PublicLayout's `.public-shell` rule verbatim. Blazor scoped CSS is
   anchored per component (PublicLayout's `.public-shell[b-...]` does not match a
   `.public-shell` authored here), so the rule is duplicated deliberately. A future
   shared `PublicShell` Bit would de-dupe this with PublicLayout.razor.css; until
   then keep the two in sync so the dark-shell tokens don't drift.
   Base dark surface from the adopted design tokens (wwwroot/css/mpl-design-tokens.css).
   ============================================================ */
.public-shell[b-cbgzjsurzy] {
    min-height: 100vh;
    width: 100%;
    background: var(--mpl-bg-0, #0a0a0b);
    color: var(--mpl-fg-2, #d4d4d8);
    overflow-x: hidden;
}
/* /Components/Layout/PublicLayout.razor.rz.scp.css */
/* ============================================================
   PublicLayout — full-viewport shell for public marketing pages.
   No app sidebar/topbar; the page supplies its own nav + footer.
   Base dark surface from the adopted design tokens
   (wwwroot/css/mpl-design-tokens.css).
   ============================================================ */
.public-shell[b-o5rupr0w37] {
    min-height: 100vh;
    width: 100%;
    background: var(--mpl-bg-0, #0a0a0b);
    color: var(--mpl-fg-2, #d4d4d8);
    overflow-x: hidden;
}
/* /Components/Pages/ForgotPassword.razor.rz.scp.css */
/* ForgotPassword.razor.css — scoped styles for WI-158 auth page redesign.
   Tech debt note: Login.razor.css shares the same card/brand/field architecture.
   A shared auth-shared.css import is not available in Blazor scoped CSS; duplication is expected.
   TODO (fast-follow): ResetPassword.razor requires the same dark-card redesign (WI-158 fast-follow) */

/* ── Full-viewport shell ───────────────────────────────────────────────── */

.login-wrap[b-jev4he3o8p] {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: 24px 16px;
    /* Stacked radial-gradient glow — preferred over ::before because no extra DOM element needed */
    background:
        radial-gradient(ellipse 700px 500px at 50% 60%, rgba(204, 0, 0, 0.12) 0%, transparent 70%),
        radial-gradient(ellipse 400px 300px at 50% 40%, rgba(204, 0, 0, 0.07) 0%, transparent 60%),
        var(--mpl-bg-0);
}

/* ── Card ──────────────────────────────────────────────────────────────── */

.login-card[b-jev4he3o8p] {
    width: 100%;
    max-width: 420px;
    border-radius: 20px;
    padding: 32px 28px;
    box-shadow: var(--mpl-shadow-lg);
    border: 1px solid var(--mpl-border-2);
    background: var(--mpl-bg-2);
    position: relative;
}

/* Red gradient top-edge line */
.login-card[b-jev4he3o8p]::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    border-radius: 20px 20px 0 0;
    background: linear-gradient(90deg, transparent 0%, #cc0000 40%, #ff4444 60%, transparent 100%);
}

/* ── Brand block ───────────────────────────────────────────────────────── */

.brand[b-jev4he3o8p] {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: 24px;
    gap: 8px;
}

/* No mpl-float animation on ForgotPassword per comp */
.brand-logo[b-jev4he3o8p] {
    width: 72px;
    height: 72px;
    filter: drop-shadow(0 0 12px rgba(204, 0, 0, 0.5));
}

.brand h1[b-jev4he3o8p] {
    font: 800 22px/1.2 var(--mpl-font-sans);
    color: var(--mpl-fg-1);
    margin: 0;
}

.brand p[b-jev4he3o8p] {
    font-size: 13px;
    color: var(--mpl-fg-3);
    margin: 0;
}

/* ── Form fields ───────────────────────────────────────────────────────── */

.field[b-jev4he3o8p] {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 16px;
}

.field label[b-jev4he3o8p] {
    font-size: 13px;
    font-weight: 500;
    color: var(--mpl-fg-3);
}

/* Descendant selector for sufficient specificity over Bootstrap .form-control */
.login-card .input[b-jev4he3o8p] {
    width: 100%;
    padding: 10px 12px;
    border-radius: 8px;
    border: 1px solid var(--mpl-border-2);
    background: var(--mpl-bg-3);
    color: var(--mpl-fg-1);
    font-size: 14px;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
    /* Do NOT use all:unset — strips focus ring and native keyboard semantics */
}

.login-card .input:focus-visible[b-jev4he3o8p] {
    outline: 2px solid #cc0000;
    outline-offset: 1px;
    border-color: #cc0000;
}

/* ── Buttons (descendant selectors for Bootstrap specificity override) ─── */

.login-card .btn[b-jev4he3o8p] {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border: none;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: opacity 0.15s ease, transform 0.1s ease;
    text-decoration: none;
    /* Do NOT use all:unset — strips focus ring and native keyboard semantics */
}

.login-card .btn:focus-visible[b-jev4he3o8p] {
    outline: 2px solid #cc0000;
    outline-offset: 2px;
}

.login-card .btn-primary[b-jev4he3o8p] {
    background: var(--mpl-grad-brand);
    color: #fff;
}

.login-card .btn-primary:hover:not(:disabled)[b-jev4he3o8p] {
    opacity: 0.9;
    transform: translateY(-1px);
}

.login-card .btn-primary:disabled[b-jev4he3o8p] {
    opacity: 0.55;
    cursor: not-allowed;
    transform: none;
}

.login-card .btn-secondary[b-jev4he3o8p] {
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid var(--mpl-border-2);
    color: var(--mpl-fg-1);
}

.login-card .btn-secondary:hover:not(:disabled)[b-jev4he3o8p] {
    background: rgba(255, 255, 255, 0.12);
}

.login-card .btn-ghost[b-jev4he3o8p] {
    background: transparent;
    border: 1px solid var(--mpl-border-2);
    color: var(--mpl-fg-3);
}

.login-card .btn-ghost:hover:not(:disabled)[b-jev4he3o8p] {
    background: rgba(255, 255, 255, 0.05);
    color: var(--mpl-fg-1);
}

.login-card .btn-lg[b-jev4he3o8p] {
    padding: 12px 20px;
    font-size: 15px;
    border-radius: 10px;
}

.login-card .btn-sm[b-jev4he3o8p] {
    padding: 8px 14px;
    font-size: 13px;
}

.btn-block[b-jev4he3o8p] {
    width: 100%;
    display: flex;
    justify-content: center;
}

.mt-3[b-jev4he3o8p] {
    margin-top: 12px;
}

/* ── Alerts ────────────────────────────────────────────────────────────── */

.auth-error[b-jev4he3o8p] {
    padding: 10px 14px;
    border-radius: 8px;
    background: rgba(204, 0, 0, 0.12);
    border: 1px solid rgba(204, 0, 0, 0.35);
    color: var(--mpl-red-400);
    font-size: 13px;
    margin-bottom: 16px;
}

.alert.a-success[b-jev4he3o8p] {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 14px 16px;
    border-radius: 8px;
    background: rgba(34, 197, 94, 0.1);
    border: 1px solid rgba(34, 197, 94, 0.3);
    color: #86efac;
    font-size: 13px;
    margin-bottom: 20px;
}

.alert.a-success strong[b-jev4he3o8p] {
    display: block;
    font-weight: 600;
    margin-bottom: 4px;
    color: #bbf7d0;
}

.alert.a-success p[b-jev4he3o8p] {
    margin: 0;
    color: #86efac;
}

/* ── Spinner ───────────────────────────────────────────────────────────── */

.mpl-spinner[b-jev4he3o8p] {
    display: inline-block;
    width: 16px;
    height: 16px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: mpl-spin-b-jev4he3o8p 0.7s linear infinite;
    flex-shrink: 0;
}

/* ── Keyframe animations ───────────────────────────────────────────────── */

/* Note: mpl-float is intentionally omitted — no logo animation on ForgotPassword per comp */

@keyframes mpl-spin-b-jev4he3o8p {
    0%   { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* ── Responsive ────────────────────────────────────────────────────────── */

@media (max-width: 767px) {
    .login-card[b-jev4he3o8p] {
        padding: 24px 16px;
        border-radius: 16px;
        max-width: 100%;
    }

    .login-wrap[b-jev4he3o8p] {
        padding: 16px 12px;
        align-items: flex-start;
        padding-top: 32px;
    }
}

@media (max-width: 360px) {
    .login-card[b-jev4he3o8p] {
        padding: 20px 12px;
    }
}
/* /Components/Pages/Home.razor.rz.scp.css */
/* ============================================================
   Home.razor — component-scoped styles (CSS isolation).
   Only the authenticated dashboard's welcome banner lives here;
   the public landing styles moved to PublicLanding.razor.css
   (rendered under PublicLayout, WI-105 / WI-41).
   ============================================================ */
.welcome-banner[b-x20basb2cy] {
    background: linear-gradient(135deg, rgba(26, 0, 0, 0.8) 0%, rgba(42, 0, 0, 0.6) 100%);
    border: 1px solid rgba(204, 0, 0, 0.2);
    box-shadow: var(--shadow-lg);
}
/* /Components/Pages/Leaderboard.razor.rz.scp.css */
/* ============================================================
   Leaderboard.razor — component-scoped styles (CSS isolation), WI-43.
   Dark "after-hours casino" redesign translated from the design comp
   (LeaderboardScreen.jsx + ui.css). Uses the adopted --mpl-* tokens from
   wwwroot/css/mpl-design-tokens.css. Renders under PublicAwareLayout:
   the dark public shell for anonymous visitors, and (transitionally) the
   authenticated AppShell. The shared item primitives (MplMedal, MplAvatar,
   MplEmptyState) bring their own scoped styles; this file owns the PAGE
   containers only — head, filter toolbar, the .medals grid, and the
   standings table. Mirrors the layout conventions in PublicLanding.razor.css.
   ============================================================ */

.lb-page[b-pru7hdzgga] {
    position: relative;
    max-width: 1100px;
    margin: 0 auto;
    padding: 32px 32px 60px;
}

/* ===================== HEAD ===================== */
.lb-head[b-pru7hdzgga] {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 24px;
}

.lb-head-text[b-pru7hdzgga] {
    min-width: 240px;
}

.lb-eyebrow[b-pru7hdzgga] {
    font: 600 var(--mpl-text-xs)/1 var(--mpl-font-sans);
    text-transform: uppercase;
    letter-spacing: var(--mpl-tracking-caps);
    color: var(--mpl-fg-3);
    margin-bottom: 8px;
}

.lb-title[b-pru7hdzgga] {
    font: 800 var(--mpl-text-4xl)/1.12 var(--mpl-font-sans);
    letter-spacing: -0.03em;
    color: var(--mpl-fg-1);
    margin: 0;
}

.lb-sub[b-pru7hdzgga] {
    font: 500 var(--mpl-text-sm)/1.5 var(--mpl-font-sans);
    color: var(--mpl-fg-3);
    margin: 6px 0 0;
}

/* ===================== EXPORT (auth-gated) ===================== */
.lb-head-actions[b-pru7hdzgga] {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.lb-export[b-pru7hdzgga] {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border-radius: var(--mpl-radius-md);
    font: 600 var(--mpl-text-sm)/1 var(--mpl-font-sans);
    color: var(--mpl-fg-1);
    background: var(--mpl-bg-3);
    border: 1px solid var(--mpl-border-2);
    cursor: pointer;
    transition: border-color var(--mpl-dur) var(--mpl-ease),
                background var(--mpl-dur) var(--mpl-ease),
                transform var(--mpl-dur) var(--mpl-ease);
}

.lb-export:hover:not(:disabled)[b-pru7hdzgga] {
    border-color: var(--mpl-red-400);
    background: var(--mpl-bg-4);
    transform: translateY(-1px);
}

.lb-export:disabled[b-pru7hdzgga] {
    opacity: 0.5;
    cursor: not-allowed;
}

.lb-export:focus-visible[b-pru7hdzgga] {
    outline: 2px solid var(--mpl-red-400);
    outline-offset: 2px;
}

/* ===================== TOOLBAR ===================== */
.lb-toolbar[b-pru7hdzgga] {
    background: var(--mpl-grad-card);
    border: 1px solid var(--mpl-border-1);
    border-radius: var(--mpl-radius-lg);
    box-shadow: var(--mpl-shadow-sm);
    padding: 16px 18px;
    margin-bottom: 20px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.lb-toolbar-row[b-pru7hdzgga] {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
}

.lb-label[b-pru7hdzgga] {
    font: 600 var(--mpl-text-sm)/1 var(--mpl-font-sans);
    color: var(--mpl-fg-3);
    white-space: nowrap;
}

/* dates */
.lb-dates[b-pru7hdzgga] {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.lb-dates-icon[b-pru7hdzgga],
.lb-date-sep[b-pru7hdzgga] {
    color: var(--mpl-fg-4);
}

.lb-date[b-pru7hdzgga] {
    background: var(--mpl-bg-3);
    color: var(--mpl-fg-1);
    border: 1px solid var(--mpl-border-2);
    border-radius: var(--mpl-radius-sm);
    padding: 6px 10px;
    font: 500 var(--mpl-text-sm)/1 var(--mpl-font-sans);
    color-scheme: dark; /* native calendar widget in dark */
    max-width: 160px;
}

.lb-date:focus-visible[b-pru7hdzgga] {
    outline: 2px solid var(--mpl-red-400);
    outline-offset: 1px;
}

.lb-date[b-pru7hdzgga]::-webkit-calendar-picker-indicator {
    filter: invert(1);
    opacity: 0.7;
    cursor: pointer;
}

/* reset — pushed to the right of the date row */
.lb-reset[b-pru7hdzgga] {
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: var(--mpl-radius-sm);
    font: 600 var(--mpl-text-sm)/1 var(--mpl-font-sans);
    color: var(--mpl-fg-3);
    background: transparent;
    border: 1px solid var(--mpl-border-2);
    cursor: pointer;
    transition: color var(--mpl-dur) var(--mpl-ease),
                border-color var(--mpl-dur) var(--mpl-ease);
}

.lb-reset:hover[b-pru7hdzgga] {
    color: var(--mpl-fg-1);
    border-color: var(--mpl-border-3);
}

.lb-reset:focus-visible[b-pru7hdzgga] {
    outline: 2px solid var(--mpl-red-400);
    outline-offset: 2px;
}

/* rank-by segmented (single-select radiogroup) */
.lb-rankby[b-pru7hdzgga] {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.lb-seg[b-pru7hdzgga] {
    display: inline-flex;
    background: var(--mpl-bg-1);
    border: 1px solid var(--mpl-border-2);
    border-radius: var(--mpl-radius-md);
    padding: 3px;
    gap: 3px;
    flex-wrap: wrap;
}

.lb-seg-btn[b-pru7hdzgga] {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 14px;
    border: none;
    background: transparent;
    border-radius: var(--mpl-radius-sm);
    font: 600 var(--mpl-text-sm)/1 var(--mpl-font-sans);
    color: var(--mpl-fg-3);
    cursor: pointer;
    transition: color var(--mpl-dur) var(--mpl-ease),
                background var(--mpl-dur) var(--mpl-ease);
}

.lb-seg-btn:hover[b-pru7hdzgga] {
    color: var(--mpl-fg-1);
}

.lb-seg-btn.is-active[b-pru7hdzgga] {
    color: #fff;
    background: var(--mpl-grad-brand);
    box-shadow: var(--mpl-shadow-sm);
}

.lb-seg-btn:focus-visible[b-pru7hdzgga] {
    outline: 2px solid var(--mpl-red-400);
    outline-offset: 2px;
}

/* category chips (spending mode) */
.lb-cats[b-pru7hdzgga] {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    flex-wrap: wrap;
    border-top: 1px solid var(--mpl-border-1);
    padding-top: 14px;
}

.lb-chips[b-pru7hdzgga] {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
}

.lb-chip[b-pru7hdzgga] {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: var(--mpl-radius-pill);
    font: 600 var(--mpl-text-sm)/1.2 var(--mpl-font-sans);
    color: var(--mpl-fg-2);
    background: var(--mpl-bg-3);
    border: 1px solid var(--mpl-border-2);
    cursor: pointer;
    transition: color var(--mpl-dur) var(--mpl-ease),
                border-color var(--mpl-dur) var(--mpl-ease),
                background var(--mpl-dur) var(--mpl-ease);
}

.lb-chip:hover[b-pru7hdzgga] {
    border-color: var(--mpl-border-3);
    color: var(--mpl-fg-1);
}

.lb-chip.is-on[b-pru7hdzgga] {
    color: var(--mpl-red-200);
    background: rgba(204, 0, 0, 0.16);
    border-color: var(--mpl-border-red);
}

.lb-chip-box[b-pru7hdzgga] {
    font-size: 0.95em;
}

.lb-chip:focus-visible[b-pru7hdzgga] {
    outline: 2px solid var(--mpl-red-400);
    outline-offset: 2px;
}

.lb-chip-clear[b-pru7hdzgga] {
    color: var(--mpl-fg-3);
    background: transparent;
}

.lb-cats-hint[b-pru7hdzgga] {
    font: 500 var(--mpl-text-xs)/1.3 var(--mpl-font-sans);
    color: var(--mpl-fg-4);
    align-self: center;
}

/* ===================== MEDALS (podium) ===================== */
/* auto-fit reflow: 3-up on desktop, then 2-up, then 1-up on phones — no media
   query. Also handles the first-place-relaxation case (>3 gold medals): extra
   medals simply wrap onto further rows. */
.medals[b-pru7hdzgga] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
    margin-bottom: 16px;
}

/* Transparent grid cell; carries the per-medal accessible name (role="img").
   The MplMedal root (.medal) stretches to fill the cell. */
.medal-item[b-pru7hdzgga] {
    min-width: 0;
}

/* ===================== STANDINGS TABLE ===================== */
.lb-table-wrap[b-pru7hdzgga] {
    background: var(--mpl-grad-card);
    border: 1px solid var(--mpl-border-1);
    border-radius: var(--mpl-radius-lg);
    box-shadow: var(--mpl-shadow-sm);
    overflow: hidden;
}

.lb-table[b-pru7hdzgga] {
    width: 100%;
    table-layout: fixed;
    border-collapse: collapse;
    font-family: var(--mpl-font-sans);
}

.lb-table thead th[b-pru7hdzgga] {
    text-align: left;
    font: 700 var(--mpl-text-xs)/1 var(--mpl-font-sans);
    text-transform: uppercase;
    letter-spacing: var(--mpl-tracking-wide);
    color: var(--mpl-fg-4);
    padding: 12px 18px;
    border-bottom: 1px solid var(--mpl-border-2);
    background: var(--mpl-bg-1);
}

.lb-table tbody td[b-pru7hdzgga] {
    padding: 12px 18px;
    border-top: 1px solid var(--mpl-border-1);
    vertical-align: middle;
}

.lb-table tbody tr:first-child td[b-pru7hdzgga] {
    border-top: none;
}

.lb-table tbody tr:hover[b-pru7hdzgga] {
    background: var(--mpl-bg-2);
}

.lb-col-rank[b-pru7hdzgga] {
    width: 64px;
}

.lb-col-pts[b-pru7hdzgga] {
    width: 120px;
    text-align: right;
}

.lb-rank-num[b-pru7hdzgga] {
    font: 700 var(--mpl-text-sm)/1 var(--mpl-font-sans);
    color: var(--mpl-fg-4);
    font-variant-numeric: tabular-nums;
}

.lb-player[b-pru7hdzgga] {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
    max-width: 100%;
}

.lb-player-name[b-pru7hdzgga] {
    font: 700 var(--mpl-text-sm)/1.2 var(--mpl-font-sans);
    color: var(--mpl-fg-1);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.lb-pts[b-pru7hdzgga] {
    font: 800 var(--mpl-text-base)/1 var(--mpl-font-sans);
    color: var(--mpl-fg-1);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

.lb-pts small[b-pru7hdzgga] {
    font: 500 var(--mpl-text-xs)/1 var(--mpl-font-sans);
    color: var(--mpl-fg-4);
    margin-left: 4px;
}

/* ===================== EMPTY-STATE CTA ===================== */
/* MplEmptyState's own ::deep CTA rule targets anchors; our Reset is a <button>,
   and the Cta RenderFragment renders in THIS page's CSS scope, so style it here. */
.lb-cta[b-pru7hdzgga] {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border-radius: var(--mpl-radius-md);
    font: 600 var(--mpl-text-sm)/1 var(--mpl-font-sans);
    color: #fff;
    background: var(--mpl-grad-brand);
    border: none;
    box-shadow: var(--mpl-shadow-sm);
    cursor: pointer;
    transition: transform var(--mpl-dur) var(--mpl-ease),
                filter var(--mpl-dur) var(--mpl-ease);
}

.lb-cta:hover[b-pru7hdzgga] {
    transform: translateY(-1px);
    filter: brightness(1.06);
    box-shadow: var(--mpl-glow-red);
}

.lb-cta:focus-visible[b-pru7hdzgga] {
    outline: 2px solid var(--mpl-red-400);
    outline-offset: 2px;
}

/* ===================== RESPONSIVE ===================== */
@media (max-width: 991.98px) {
    .lb-page[b-pru7hdzgga] {
        padding: 24px 18px 48px;
    }

    .lb-title[b-pru7hdzgga] {
        font-size: var(--mpl-text-3xl);
    }
}

@media (max-width: 600px) {
    .lb-head[b-pru7hdzgga] {
        align-items: flex-start;
    }

    .lb-head-actions[b-pru7hdzgga] {
        width: 100%;
    }

    .lb-export[b-pru7hdzgga] {
        width: 100%;
        justify-content: center;
    }

    .lb-reset[b-pru7hdzgga] {
        margin-left: 0;
    }

    .lb-seg[b-pru7hdzgga] {
        width: 100%;
    }

    .lb-seg-btn[b-pru7hdzgga] {
        flex: 1 1 auto;
        justify-content: center;
    }

    .lb-table thead th[b-pru7hdzgga],
    .lb-table tbody td[b-pru7hdzgga] {
        padding: 10px 12px;
    }

    .lb-col-pts[b-pru7hdzgga] {
        width: 92px;
    }
}
/* /Components/Pages/Login.razor.rz.scp.css */
/* Login.razor.css — scoped styles for WI-158 auth page redesign.
   Tech debt note: ForgotPassword.razor.css shares the same card/brand/field architecture.
   A shared auth-shared.css import is not available in Blazor scoped CSS; duplication is expected.
   TODO (fast-follow): ResetPassword.razor requires the same dark-card redesign (WI-158 fast-follow) */

/* ── Full-viewport shell ───────────────────────────────────────────────── */

.login-wrap[b-68lo99poxb] {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: 24px 16px;
    /* Stacked radial-gradient glow — preferred over ::before because no extra DOM element needed */
    background:
        radial-gradient(ellipse 700px 500px at 50% 60%, rgba(204, 0, 0, 0.12) 0%, transparent 70%),
        radial-gradient(ellipse 400px 300px at 50% 40%, rgba(204, 0, 0, 0.07) 0%, transparent 60%),
        var(--mpl-bg-0);
}

/* ── Card ──────────────────────────────────────────────────────────────── */

.login-card[b-68lo99poxb] {
    width: 100%;
    max-width: 420px;
    border-radius: 20px;
    padding: 32px 28px;
    box-shadow: var(--mpl-shadow-lg);
    border: 1px solid var(--mpl-border-2);
    background: var(--mpl-bg-2);
    position: relative;
}

/* Red gradient top-edge line */
.login-card[b-68lo99poxb]::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    border-radius: 20px 20px 0 0;
    background: linear-gradient(90deg, transparent 0%, #cc0000 40%, #ff4444 60%, transparent 100%);
}

/* ── Brand block ───────────────────────────────────────────────────────── */

.brand[b-68lo99poxb] {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: 24px;
    gap: 8px;
}

.brand-logo[b-68lo99poxb] {
    width: 72px;
    height: 72px;
    filter: drop-shadow(0 0 12px rgba(204, 0, 0, 0.5));
    animation: mpl-float-b-68lo99poxb 3s ease-in-out infinite;
}

.brand h1[b-68lo99poxb] {
    font: 800 22px/1.2 var(--mpl-font-sans);
    color: var(--mpl-fg-1);
    margin: 0;
}

.brand p[b-68lo99poxb] {
    font-size: 13px;
    color: var(--mpl-fg-3);
    margin: 0;
}

/* ── Form fields ───────────────────────────────────────────────────────── */

.field[b-68lo99poxb] {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 16px;
}

.field label[b-68lo99poxb] {
    font-size: 13px;
    font-weight: 500;
    color: var(--mpl-fg-3);
}

/* Descendant selector for sufficient specificity over Bootstrap .form-control */
.login-card .input[b-68lo99poxb] {
    width: 100%;
    padding: 10px 12px;
    border-radius: 8px;
    border: 1px solid var(--mpl-border-2);
    background: var(--mpl-bg-3);
    color: var(--mpl-fg-1);
    font-size: 14px;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
    /* Do NOT use all:unset — strips focus ring and native keyboard semantics */
}

.login-card .input:focus-visible[b-68lo99poxb] {
    outline: 2px solid #cc0000;
    outline-offset: 1px;
    border-color: #cc0000;
}

/* ── Remember me / forgot row ──────────────────────────────────────────── */

.inline-row[b-68lo99poxb] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

.remember-label[b-68lo99poxb] {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--mpl-fg-3);
    cursor: pointer;
    user-select: none;
}

input[type="checkbox"][b-68lo99poxb] {
    accent-color: #cc0000;
    width: 14px;
    height: 14px;
    cursor: pointer;
}

.forgot-link[b-68lo99poxb] {
    font-size: 13px;
    color: var(--mpl-fg-4);
    text-decoration: none;
    transition: color 0.15s ease;
}

.forgot-link:hover[b-68lo99poxb] {
    color: var(--mpl-red-400);
}

/* ── Buttons (descendant selectors for Bootstrap specificity override) ─── */

.login-card .btn[b-68lo99poxb] {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border: none;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: opacity 0.15s ease, transform 0.1s ease;
    /* Do NOT use all:unset — strips focus ring and native keyboard semantics */
}

.login-card .btn:focus-visible[b-68lo99poxb] {
    outline: 2px solid #cc0000;
    outline-offset: 2px;
}

.login-card .btn-primary[b-68lo99poxb] {
    background: var(--mpl-grad-brand);
    color: #fff;
}

.login-card .btn-primary:hover:not(:disabled)[b-68lo99poxb] {
    opacity: 0.9;
    transform: translateY(-1px);
}

.login-card .btn-primary:disabled[b-68lo99poxb] {
    opacity: 0.55;
    cursor: not-allowed;
    transform: none;
}

.login-card .btn-ghost[b-68lo99poxb] {
    background: transparent;
    border: 1px solid var(--mpl-border-2);
    color: var(--mpl-fg-3);
}

.login-card .btn-ghost:hover:not(:disabled)[b-68lo99poxb] {
    background: rgba(255, 255, 255, 0.05);
    color: var(--mpl-fg-1);
}

.login-card .btn-lg[b-68lo99poxb] {
    padding: 12px 20px;
    font-size: 15px;
    border-radius: 10px;
}

.btn-block[b-68lo99poxb] {
    width: 100%;
    display: flex;
    justify-content: center;
}

/* ── Alerts ────────────────────────────────────────────────────────────── */

.auth-error[b-68lo99poxb] {
    padding: 10px 14px;
    border-radius: 8px;
    background: rgba(204, 0, 0, 0.12);
    border: 1px solid rgba(204, 0, 0, 0.35);
    color: var(--mpl-red-400);
    font-size: 13px;
    margin-bottom: 16px;
}

.alert.a-info[b-68lo99poxb] {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 14px;
    border-radius: 8px;
    background: rgba(59, 130, 246, 0.1);
    border: 1px solid rgba(59, 130, 246, 0.3);
    color: #93c5fd;
    font-size: 13px;
    margin-bottom: 16px;
}

/* ── Spinner ───────────────────────────────────────────────────────────── */

.mpl-spinner[b-68lo99poxb] {
    display: inline-block;
    width: 16px;
    height: 16px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: mpl-spin-b-68lo99poxb 0.7s linear infinite;
    flex-shrink: 0;
}

/* ── Keyframe animations ───────────────────────────────────────────────── */

@keyframes mpl-float-b-68lo99poxb {
    0%, 100% { transform: translateY(0); }
    50%       { transform: translateY(-8px); }
}

@keyframes mpl-spin-b-68lo99poxb {
    0%   { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* ── Responsive ────────────────────────────────────────────────────────── */

@media (max-width: 767px) {
    .login-card[b-68lo99poxb] {
        padding: 24px 16px;
        border-radius: 16px;
        max-width: 100%;
    }

    .login-wrap[b-68lo99poxb] {
        padding: 16px 12px;
        align-items: flex-start;
        padding-top: 32px;
    }
}

@media (max-width: 360px) {
    .login-card[b-68lo99poxb] {
        padding: 20px 12px;
    }
}
/* /Components/Pages/PublicLanding.razor.rz.scp.css */
/* ============================================================
   PublicLanding.razor — component-scoped styles (CSS isolation).
   Public landing (WI-41) translated from the design comp
   (PublicLandingScreen.jsx + ui.css). Uses the adopted
   --mpl-* tokens from wwwroot/css/mpl-design-tokens.css.
   Rendered under PublicLayout (full viewport, no app chrome).

   WI-90: the public chrome + leaderboard/empty/badge primitives were
   extracted into shared Bits components (Components/Shared/Bits/). What
   remains here is PAGE LAYOUT only: the shell + felt-bloom, hero, section
   scaffolding, the card grid + tournament-card markup (still inline), and
   the leaderboard layout containers (.medals grid, .lb-list). The extracted
   rules now live with their components:
     PublicNav        ← .public-nav* + sign-in button + phone nav
     PublicFooter     ← .public-footer* + phone footer
     MplMedal         ← .medal* (the .medals grid container stays here)
     MplAvatar        ← .lb-avatar
     MplStandingsRow  ← .lb-row* (the .lb-list container stays here)
     MplEmptyState    ← .empty*
     MplStatusBadge   ← .public-badge*
   ============================================================ */

/* ---- Loading state for the public view ---- */
.public-loading[b-65a50dlgpq] {
    min-height: 60vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ===================== PUBLIC LANDING SHELL ===================== */
.public[b-65a50dlgpq] {
    position: relative;
    overflow-x: hidden;
}

.public[b-65a50dlgpq]::before {
    /* radial felt-bloom behind the hero */
    content: '';
    position: absolute;
    top: -80px;
    left: 50%;
    transform: translateX(-50%);
    width: 1200px;
    height: 800px;
    max-width: 100%;
    pointer-events: none;
    background: radial-gradient(ellipse at center, rgba(204, 0, 0, 0.22) 0%, transparent 55%);
}

/* ===================== HERO ===================== */
.public-hero[b-65a50dlgpq] {
    position: relative;
    z-index: 1;
    max-width: 1100px;
    margin: 0 auto;
    padding: 80px 32px 60px;
    text-align: center;
}

.public-hero .logo-row[b-65a50dlgpq] {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 32px;
}

.public-hero img.chip[b-65a50dlgpq] {
    width: 120px;
    height: 120px;
    display: block;
    filter: drop-shadow(0 14px 36px rgba(204, 0, 0, 0.55));
    animation: mpl-float-b-65a50dlgpq 6s ease-in-out infinite;
}

.public-hero h1[b-65a50dlgpq] {
    /* line-height 1.05 + background-clip:text clipped glyph descenders (the "g").
       A slightly looser line-height plus a little bottom padding gives the
       descenders room within the clipped paint box. */
    font: 800 72px/1.12 var(--mpl-font-sans);
    letter-spacing: -0.03em;
    color: var(--mpl-fg-1);
    margin: 0;
    padding-bottom: 0.12em;
    text-wrap: pretty;
    background: linear-gradient(180deg, #ffffff 0%, #d4d4d8 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* ===================== SECTIONS ===================== */
.public-section[b-65a50dlgpq] {
    position: relative;
    z-index: 1;
    max-width: 1100px;
    margin: 0 auto 48px;
    padding: 0 32px;
}

/* A little breathing room between the hero and the first (leaderboard) section. */
#leaderboard[b-65a50dlgpq] {
    margin-top: 24px;
}

.public-section-head[b-65a50dlgpq] {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-bottom: 16px;
    gap: 12px;
}

.public-section-head h2[b-65a50dlgpq] {
    font: 800 24px/1.2 var(--mpl-font-sans);
    letter-spacing: -0.02em;
    color: var(--mpl-fg-1);
    margin: 0;
}

/* Small "View Full Leaderboard" action, top-right of the section head. The flex
   parent (justify-content: space-between) pushes it opposite the heading. */
.public-section-link[b-65a50dlgpq] {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font: 600 13px/1 var(--mpl-font-sans);
    color: var(--mpl-fg-3);
    text-decoration: none;
    white-space: nowrap;
    transition: color var(--mpl-dur) var(--mpl-ease);
}

.public-section-link:hover[b-65a50dlgpq] {
    color: var(--mpl-red-400);
}

.public-section-link i[b-65a50dlgpq] {
    font-size: 0.9em;
    transition: transform var(--mpl-dur) var(--mpl-ease);
}

.public-section-link:hover i[b-65a50dlgpq] {
    transform: translateX(2px);
}

.public-grid[b-65a50dlgpq] {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

/* ===================== PUBLIC CARDS (upcoming / recent) ===================== */
.card.public-card-link[b-65a50dlgpq] {
    display: block;
    text-decoration: none;
    color: inherit;
    background: var(--mpl-grad-card);
    border: 1px solid var(--mpl-border-1);
    border-radius: 16px;
    box-shadow: var(--mpl-shadow-sm);
    overflow: hidden;
}

.public-card-clickable[b-65a50dlgpq] {
    transition: border-color .15s ease, transform .15s ease, box-shadow .15s ease;
}

.public-card-clickable:hover[b-65a50dlgpq] {
    border-color: var(--mpl-red-400);
    transform: translateY(-1px);
    box-shadow: var(--mpl-shadow-md);
}

.public-card-clickable:focus-visible[b-65a50dlgpq] {
    outline: 2px solid var(--mpl-red-400);
    outline-offset: 2px;
}

.public-card-inner[b-65a50dlgpq] {
    padding: 16px 18px;
}

.public-card-head[b-65a50dlgpq] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 8px;
    margin-bottom: 8px;
}

.public-card-title[b-65a50dlgpq] {
    font: 700 16px/1.2 var(--mpl-font-sans);
    color: var(--mpl-fg-1);
}

.public-card-meta[b-65a50dlgpq] {
    font: 500 13px/1.4 var(--mpl-font-sans);
    color: var(--mpl-fg-3);
    display: flex;
    flex-wrap: wrap;
    gap: 4px 12px;
}

.public-card-meta i[b-65a50dlgpq] {
    color: var(--mpl-fg-4);
    margin-right: 2px;
}

/* Tournament type sits on its own line under the venue/date/game-type row. */
.public-card-meta .card-type[b-65a50dlgpq] {
    flex-basis: 100%;
}

.public-card-cta[b-65a50dlgpq] {
    margin-top: 12px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font: 600 12px/1 var(--mpl-font-sans);
    color: var(--mpl-fg-3);
}

/* ===================== TOURNAMENT DIRECTOR CHIPS (WI-156) ===================== */
/* Wrapping row at the bottom of each tournament card: a leading red-tinted
   "TD"/"TDS" label pill followed by one neutral outlined pill per director.
   Rendered as INLINE Razor markup (not RenderTreeBuilder) so CSS isolation
   applies the component's scoped attribute to these elements. */
.public-card-tds[b-65a50dlgpq] {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--mpl-border-1);
}

.tds-label[b-65a50dlgpq] {
    display: inline-flex;
    align-items: center;
    padding: 3px 9px;
    border-radius: 999px;
    font: 700 10px/1 var(--mpl-font-sans);
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--mpl-red-300);
    background: rgba(204, 0, 0, 0.16);
    border: 1px solid var(--mpl-border-red);
    white-space: nowrap;
    flex: none;
}

.tds-chip[b-65a50dlgpq] {
    display: inline-flex;
    align-items: center;
    max-width: 100%;
    padding: 4px 10px;
    border-radius: 999px;
    font: 600 12px/1.2 var(--mpl-font-sans);
    color: var(--mpl-fg-2);
    background: var(--mpl-bg-3);
    border: 1px solid var(--mpl-border-2);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ===================== LEADERBOARD WIDGET (WI-154) ===================== */
/* Layout containers stay here; the medal pill (MplMedal) and standings row
   (MplStandingsRow) primitives were extracted to Bits in WI-90. */

/* auto-fit reflow: 3-up on desktop, 2-up, then 1-up on phones — no media query. */
.medals[b-65a50dlgpq] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
    margin-bottom: 12px;
}

/* Ranked list (places 4..N) container — rows render as direct children. */
.lb-list[b-65a50dlgpq] {
    background: var(--mpl-grad-card);
    border: 1px solid var(--mpl-border-1);
    border-radius: 16px;
    box-shadow: var(--mpl-shadow-sm);
    overflow: hidden;
}

@keyframes mpl-float-b-65a50dlgpq {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-8px); }
}

/* ===================== RESPONSIVE ===================== */
@media (max-width: 991.98px) {
    .public-hero[b-65a50dlgpq] {
        padding: 50px 18px 40px;
    }

    .public-hero img.chip[b-65a50dlgpq] {
        width: 88px;
        height: 88px;
    }

    .public-hero h1[b-65a50dlgpq] {
        font-size: 44px;
    }

    .public-grid[b-65a50dlgpq] {
        grid-template-columns: 1fr;
    }

    .public-section[b-65a50dlgpq] {
        padding: 0 18px;
    }
}

@media (max-width: 600px) {
    /* Keep director chips readable at 360px — cap each pill so long names
       truncate instead of forcing horizontal overflow; row still wraps. */
    .tds-chip[b-65a50dlgpq] {
        max-width: 100%;
    }
}
/* /Components/Pages/Tournaments/PublicTournamentList.razor.rz.scp.css */
/* ============================================================
   PublicTournamentList.razor — component-scoped styles (CSS isolation), WI-157.
   Dark card-rail design for the public tournament list page (comp reconcile plan-v5).
   Uses the adopted --mpl-* tokens from wwwroot/css/mpl-design-tokens.css.
   All structural classes are adapted verbatim from comp/WI-157/ui.css using
   --mpl-* token substitutions. Renders under PublicAwareLayout.
   Class prefix: ptl-  (public-tournament-list) — outer wrapper only.
   All inner classes (list, list-row, seg, etc.) are comp-canonical.
   Note: public-shell, PublicNav, PublicFooter are owned by PublicAwareLayout —
   not part of this component's scoped CSS surface.
   ============================================================ */

/* ===================== PAGE WRAPPER ===================== */
/* Component-owned scoped entry point. Test 8 asserts this class (structural floor).
   Mirrors the tr-page convention from TournamentPublicResults.razor.css line 15. */
.ptl-page[b-zyzvnb8x3t] {
    position: relative;
    max-width: 1200px;
    margin: 0 auto;
    padding: 32px 32px 60px;
}

/* ===================== PAGE HEAD ===================== */
.page-head[b-zyzvnb8x3t] {
    margin-bottom: 22px;
}

.page-head .eyebrow[b-zyzvnb8x3t] {
    font: 600 11px/1.2 var(--mpl-font-sans);
    text-transform: uppercase;
    letter-spacing: .14em;
    color: var(--mpl-fg-4);
}

.page-head h1[b-zyzvnb8x3t] {
    font: 800 30px/1.15 var(--mpl-font-sans);
    letter-spacing: -0.02em;
    color: var(--mpl-fg-1);
    margin: 6px 0 4px;
}

/* ===================== TOOLBAR ===================== */
.toolbar[b-zyzvnb8x3t] {
    background: var(--mpl-bg-2);
    border: 1px solid var(--mpl-border-1);
    border-radius: 14px;
    padding: 12px 16px;
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.toolbar .group[b-zyzvnb8x3t] {
    display: flex;
    align-items: center;
    gap: 8px;
}

.toolbar .spacer[b-zyzvnb8x3t] {
    flex: 1;
}

.ptl-date-input[b-zyzvnb8x3t] {
    background: var(--mpl-bg-3);
    border: 1px solid var(--mpl-border-2);
    border-radius: 8px;
    color: var(--mpl-fg-1);
    font: 400 13px/1 var(--mpl-font-sans);
    padding: 6px 10px;
    transition: border-color var(--mpl-dur) var(--mpl-ease),
                background var(--mpl-dur) var(--mpl-ease);
}

.ptl-date-input:focus[b-zyzvnb8x3t] {
    outline: none;
    border-color: var(--mpl-border-3);
    background: var(--mpl-bg-4);
}

/* ===================== SEGMENTED CONTROL ===================== */
.seg[b-zyzvnb8x3t] {
    display: inline-flex;
    padding: 4px;
    background: var(--mpl-bg-2);
    border: 1px solid var(--mpl-border-1);
    border-radius: 12px;
    gap: 2px;
    flex-wrap: wrap;
}

.seg button[b-zyzvnb8x3t] {
    background: transparent;
    border: none;
    border-radius: 9px;
    color: var(--mpl-fg-3);
    font: 500 13px/1 var(--mpl-font-sans);
    padding: 6px 12px;
    cursor: pointer;
    transition: background var(--mpl-dur) var(--mpl-ease),
                color var(--mpl-dur) var(--mpl-ease);
    white-space: nowrap;
}

.seg button:hover[b-zyzvnb8x3t] {
    background: var(--mpl-bg-3);
    color: var(--mpl-fg-2);
}

.seg button.active[b-zyzvnb8x3t] {
    background: var(--mpl-bg-4);
    color: var(--mpl-fg-1);
    box-shadow: var(--mpl-shadow-xs), inset 0 0 0 1px var(--mpl-border-3);
}

.seg button.active.brand[b-zyzvnb8x3t] {
    background: var(--mpl-grad-brand);
    color: white;
    box-shadow: var(--mpl-shadow-sm);
}

/* ===================== LIST ===================== */
.list[b-zyzvnb8x3t] {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 16px;
}

/* ===================== LIST ROW ===================== */
.list-row[b-zyzvnb8x3t] {
    display: grid;
    grid-template-columns: 1fr auto auto;
    align-items: center;
    gap: 16px;
    background: var(--mpl-bg-2);
    border: 1px solid var(--mpl-border-1);
    border-radius: 14px;
    padding: 14px 18px;
    cursor: pointer;
    transition: all var(--mpl-dur) var(--mpl-ease);
    text-decoration: none;
    color: inherit;
    position: relative;
}

.list-row:hover[b-zyzvnb8x3t] {
    background: var(--mpl-bg-3);
    border-color: var(--mpl-border-2);
    transform: translateY(-1px);
    text-decoration: none;
    color: inherit;
}

.list-row .primary[b-zyzvnb8x3t] {
    font: 700 15px/1.2 var(--mpl-font-sans);
    color: var(--mpl-fg-1);
}

.list-row .secondary[b-zyzvnb8x3t] {
    font: 400 13px/1.35 var(--mpl-font-sans);
    color: var(--mpl-fg-3);
    margin-top: 3px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px 10px;
}

.list-row .secondary .sep[b-zyzvnb8x3t] {
    color: var(--mpl-fg-5);
}

.list-row .secondary i[b-zyzvnb8x3t] {
    color: var(--mpl-fg-4);
    margin-right: 4px;
}

.list-row .when[b-zyzvnb8x3t] {
    text-align: right;
    font: 600 13px/1.3 var(--mpl-font-sans);
    color: var(--mpl-fg-2);
    font-variant-numeric: tabular-nums;
}

.list-row .when small[b-zyzvnb8x3t] {
    display: block;
    color: var(--mpl-fg-4);
    font-size: 11px;
    margin-top: 2px;
    font-weight: 400;
}

.list-row .badge-cell[b-zyzvnb8x3t] {
    display: inline-flex;
    align-items: center;
}

/* ===================== RAIL SYSTEM ===================== */
.list-row.has-rail[b-zyzvnb8x3t] {
    padding-left: 24px;
}

.list-row.has-rail[b-zyzvnb8x3t]::before {
    content: '';
    position: absolute;
    left: 10px;
    top: 14px;
    bottom: 14px;
    width: 3px;
    border-radius: 2px;
    background: var(--mpl-fg-4);
}

.list-row.rail-sched[b-zyzvnb8x3t]::before {
    background: #a1a1aa;
}

.list-row.rail-open[b-zyzvnb8x3t]::before {
    background: #3b82f6;
}

.list-row.rail-closed[b-zyzvnb8x3t]::before {
    background: #f59e0b;
}

.list-row.rail-progress[b-zyzvnb8x3t]::before {
    background: #ff2a2a;
    box-shadow: 0 0 12px #ff2a2a;
}

.list-row.rail-done[b-zyzvnb8x3t]::before {
    background: #10b981;
}

.list-row.rail-cancel[b-zyzvnb8x3t]::before {
    background: #ef4444;
}

/* ===================== EMPTY STATE ===================== */
.empty[b-zyzvnb8x3t] {
    text-align: center;
    padding: 48px 32px;
    background: var(--mpl-bg-1);
    border: 1px dashed var(--mpl-border-2);
    border-radius: 16px;
    background-image: radial-gradient(ellipse at 50% 0%, rgba(204,0,0,0.10) 0%, transparent 60%);
}

.empty i[b-zyzvnb8x3t] {
    font-size: 36px;
    color: var(--mpl-fg-4);
    display: block;
    margin-bottom: 10px;
}

.empty h4[b-zyzvnb8x3t] {
    font: 700 18px/1.2 var(--mpl-font-sans);
    color: var(--mpl-fg-1);
    margin: 0 0 4px;
}

.empty p[b-zyzvnb8x3t] {
    font: 400 14px/1.4 var(--mpl-font-sans);
    color: var(--mpl-fg-3);
    margin: 0 0 18px;
}

/* ===================== BUTTONS ===================== */
/* Minimal button rules so Reset and empty-state Reset work without Bootstrap dependency.
   These mirror ui.css lines 138-161 (comp verbatim) for scoped isolation. */
.btn[b-zyzvnb8x3t] {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border-radius: 10px;
    font: 500 13px/1 var(--mpl-font-sans);
    padding: 8px 14px;
    cursor: pointer;
    border: 1px solid transparent;
    transition: background var(--mpl-dur) var(--mpl-ease),
                border-color var(--mpl-dur) var(--mpl-ease),
                color var(--mpl-dur) var(--mpl-ease);
}

.btn-sm[b-zyzvnb8x3t] {
    padding: 6px 11px;
    font-size: 12px;
    border-radius: 8px;
}

.btn-ghost[b-zyzvnb8x3t] {
    background: transparent;
    border-color: var(--mpl-border-2);
    color: var(--mpl-fg-2);
}

.btn-ghost:hover[b-zyzvnb8x3t] {
    background: var(--mpl-bg-3);
    border-color: var(--mpl-border-3);
    color: var(--mpl-fg-1);
}

.btn-secondary[b-zyzvnb8x3t] {
    background: var(--mpl-bg-3);
    border-color: var(--mpl-border-2);
    color: var(--mpl-fg-2);
}

.btn-secondary:hover[b-zyzvnb8x3t] {
    background: var(--mpl-bg-4);
    border-color: var(--mpl-border-3);
    color: var(--mpl-fg-1);
}

/* ===================== RESPONSIVE ===================== */
@media (max-width: 991.98px) {
    .ptl-page[b-zyzvnb8x3t] {
        padding: 24px 18px 48px;
    }

    .list-row[b-zyzvnb8x3t] {
        grid-template-columns: 1fr auto;
        row-gap: 8px;
    }

    .list-row .when[b-zyzvnb8x3t] {
        grid-column: 2;
    }

    .list-row .badge-cell[b-zyzvnb8x3t] {
        grid-column: 1 / -1;
    }
}
/* /Components/Pages/Tournaments/PublicTournamentReadOnlyView.razor.rz.scp.css */
/* ============================================================
   PublicTournamentReadOnlyView.razor — component-scoped styles (CSS isolation), WI-42.
   Dark "after-hours casino" design for the public tournament detail page.
   Translated from the design comp
   (designs/.../web_app/PublicTournamentDetailScreen.jsx + ui.css): red-gradient
   hero, segmented pill tabs, and the two-card Info layout. Uses the adopted
   --mpl-* tokens from wwwroot/css/mpl-design-tokens.css and mirrors the layout
   conventions in TournamentPublicResults.razor.css and Leaderboard.razor.css.
   Renders under PublicAwareLayout: the dark public shell for anonymous visitors
   and the authenticated AppShell for signed-in users. Shared primitives
   (MplStatusBadge, MplAvatar, MplEmptyState) bring their own scoped styles.
   Class prefix: ptd-  (public tournament detail)
   ============================================================ */

.ptd-page[b-nizybm1c69] {
    position: relative;
    max-width: 1100px;
    margin: 0 auto;
    padding: 32px 32px 60px;
}

/* Ambient red wash across the top of the page (comp parity). Stays within the
   content column to avoid introducing a horizontal scrollbar. */
.ptd-page[b-nizybm1c69]::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 380px;
    pointer-events: none;
    z-index: 0;
    background: radial-gradient(ellipse at 50% 0%, rgba(204, 0, 0, 0.10), transparent 65%);
}

.ptd-page > *[b-nizybm1c69] {
    position: relative;
    z-index: 1;
}

/* ===================== NOT-FOUND ===================== */
.ptd-notfound[b-nizybm1c69] {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 16px 18px;
    border-radius: var(--mpl-radius-lg);
    background: var(--mpl-warning-bg);
    border: 1px solid rgba(245, 158, 11, 0.35);
    color: var(--mpl-fg-1);
    font: 500 var(--mpl-text-base)/1.4 var(--mpl-font-sans);
}

.ptd-notfound i[b-nizybm1c69] {
    color: var(--mpl-warning);
    font-size: 18px;
}

/* ===================== BACK LINK ===================== */
.ptd-back[b-nizybm1c69] {
    margin-bottom: 16px;
}

.ptd-back-link[b-nizybm1c69] {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border-radius: var(--mpl-radius-md);
    font: 600 var(--mpl-text-sm)/1 var(--mpl-font-sans);
    color: var(--mpl-fg-2);
    background: var(--mpl-bg-3);
    border: 1px solid var(--mpl-border-2);
    text-decoration: none;
    transition: color var(--mpl-dur) var(--mpl-ease),
                border-color var(--mpl-dur) var(--mpl-ease),
                background var(--mpl-dur) var(--mpl-ease);
}

.ptd-back-link:hover[b-nizybm1c69] {
    color: var(--mpl-fg-1);
    border-color: var(--mpl-border-3);
    background: var(--mpl-bg-4);
}

.ptd-back-link:focus-visible[b-nizybm1c69] {
    outline: 2px solid var(--mpl-red-400);
    outline-offset: 2px;
}

/* ===================== HERO ===================== */
.ptd-hero[b-nizybm1c69] {
    position: relative;
    background:
        radial-gradient(ellipse at 80% 0%, rgba(204, 0, 0, 0.22), transparent 60%),
        var(--mpl-grad-card);
    border: 1px solid var(--mpl-border-1);
    border-radius: var(--mpl-radius-lg);
    box-shadow: var(--mpl-shadow-sm);
    padding: 24px 28px;
    overflow: hidden;
    margin-bottom: 18px;
}

/* bright red hairline along the very top edge of the hero */
.ptd-hero[b-nizybm1c69]::before {
    content: '';
    position: absolute;
    top: 0;
    left: 28px;
    right: 28px;
    height: 2px;
    background: linear-gradient(90deg, transparent, rgba(204, 0, 0, 0.65), transparent);
}

.ptd-eyebrow[b-nizybm1c69] {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    font: 600 var(--mpl-text-xs)/1 var(--mpl-font-sans);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--mpl-fg-4);
}

.ptd-eyebrow-type[b-nizybm1c69] {
    color: var(--mpl-fg-3);
}

.ptd-hero-title[b-nizybm1c69] {
    font: 800 var(--mpl-text-3xl)/1.15 var(--mpl-font-sans);
    letter-spacing: -0.02em;
    color: var(--mpl-fg-1);
    margin: 10px 0 8px;
    word-break: break-word;
}

.ptd-hero-meta[b-nizybm1c69] {
    color: var(--mpl-fg-3);
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    font: 500 var(--mpl-text-sm)/1.4 var(--mpl-font-sans);
}

.ptd-hero-meta span[b-nizybm1c69] {
    display: inline-flex;
    align-items: center;
}

.ptd-hero-meta i[b-nizybm1c69] {
    color: var(--mpl-fg-4);
    margin-right: 6px;
}

/* ===================== TABS (segmented pill control) ===================== */
.ptd-tabs[b-nizybm1c69] {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px;
    background: var(--mpl-bg-2);
    border: 1px solid var(--mpl-border-1);
    border-radius: 12px;
    margin: 4px 0 16px;
    width: fit-content;
    max-width: 100%;
}

.ptd-tab[b-nizybm1c69] {
    appearance: none;
    background: transparent;
    border: 0;
    padding: 9px 16px;
    border-radius: 8px;
    color: var(--mpl-fg-3);
    cursor: pointer;
    font: 600 var(--mpl-text-sm)/1 var(--mpl-font-sans);
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: color var(--mpl-dur) var(--mpl-ease),
                background var(--mpl-dur) var(--mpl-ease),
                box-shadow var(--mpl-dur) var(--mpl-ease);
    white-space: nowrap;
}

.ptd-tab:hover[b-nizybm1c69] {
    color: var(--mpl-fg-1);
}

.ptd-tab.active[b-nizybm1c69] {
    background: var(--mpl-bg-4);
    color: var(--mpl-fg-1);
    box-shadow: var(--mpl-shadow-xs), inset 0 0 0 1px var(--mpl-border-3);
}

.ptd-tab:focus-visible[b-nizybm1c69] {
    outline: 2px solid var(--mpl-red-400);
    outline-offset: 2px;
}

.ptd-count[b-nizybm1c69] {
    font: 700 10px/1 var(--mpl-font-sans);
    color: var(--mpl-fg-4);
    background: var(--mpl-bg-3);
    padding: 3px 6px;
    border-radius: 999px;
    font-variant-numeric: tabular-nums;
}

.ptd-tab.active .ptd-count[b-nizybm1c69] {
    background: rgba(204, 0, 0, 0.16);
    color: var(--mpl-red-300);
}

.ptd-tab-panel[b-nizybm1c69] {
    margin-top: 0;
}

/* ===================== CARDS ===================== */
.ptd-info-grid[b-nizybm1c69] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 18px;
}

.ptd-card[b-nizybm1c69] {
    background: var(--mpl-grad-card);
    border: 1px solid var(--mpl-border-1);
    border-radius: var(--mpl-radius-lg);
    box-shadow: var(--mpl-shadow-sm);
    overflow: hidden;
    margin-bottom: 22px;
}

.ptd-info-grid .ptd-card[b-nizybm1c69] {
    margin-bottom: 0;
}

.ptd-card-head[b-nizybm1c69] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 8px;
    padding: 16px 20px;
    border-bottom: 1px solid var(--mpl-border-2);
    background: linear-gradient(90deg, rgba(204, 0, 0, 0.12), rgba(204, 0, 0, 0.02));
}

.ptd-card-head-title[b-nizybm1c69] {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font: 700 var(--mpl-text-base)/1 var(--mpl-font-sans);
    color: var(--mpl-fg-1);
}

.ptd-card-head-title i[b-nizybm1c69] {
    color: var(--mpl-fg-3);
    font-size: 18px;
}

.ptd-card-body[b-nizybm1c69] {
    padding: 20px;
    color: var(--mpl-fg-2);
    font: 500 var(--mpl-text-sm)/1.5 var(--mpl-font-sans);
}

.ptd-card-body strong[b-nizybm1c69] {
    color: var(--mpl-fg-1);
}

/* ===================== INFO DEFINITION ROWS ===================== */
.ptd-defs[b-nizybm1c69] {
    display: grid;
    grid-template-columns: auto 1fr;
    row-gap: 12px;
    column-gap: 24px;
    margin: 0;
}

.ptd-defs dt[b-nizybm1c69] {
    font: 600 var(--mpl-text-xs)/1.2 var(--mpl-font-sans);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--mpl-fg-4);
    padding-top: 2px;
}

.ptd-defs dd[b-nizybm1c69] {
    margin: 0;
    font: 500 var(--mpl-text-sm)/1.3 var(--mpl-font-sans);
    color: var(--mpl-fg-1);
}

.ptd-mult[b-nizybm1c69] {
    font: 700 var(--mpl-text-sm)/1 var(--mpl-font-mono);
    color: var(--mpl-fg-2);
}

.ptd-mult-gold[b-nizybm1c69] {
    color: var(--mpl-gold-400);
}

.ptd-mult-note[b-nizybm1c69] {
    margin-left: 8px;
    color: var(--mpl-fg-5);
    font-size: 12px;
}

.ptd-muted[b-nizybm1c69] {
    color: var(--mpl-fg-5);
}

/* ===================== TABLE ===================== */
.ptd-table-wrap[b-nizybm1c69] {
    overflow-x: auto;
}

.ptd-table-wrap:focus-visible[b-nizybm1c69] {
    outline: 2px solid var(--mpl-red-400);
    outline-offset: -2px;
}

.ptd-table[b-nizybm1c69] {
    width: 100%;
    border-collapse: collapse;
    font-family: var(--mpl-font-sans);
    min-width: 480px;
}

.ptd-table thead th[b-nizybm1c69] {
    text-align: left;
    font: 700 var(--mpl-text-xs)/1 var(--mpl-font-sans);
    text-transform: uppercase;
    letter-spacing: var(--mpl-tracking-wide);
    color: var(--mpl-fg-4);
    padding: 12px 18px;
    border-bottom: 1px solid var(--mpl-border-2);
    background: var(--mpl-bg-1);
    white-space: nowrap;
}

.ptd-table thead th.ptd-num-col[b-nizybm1c69] {
    text-align: right;
}

.ptd-table tbody td[b-nizybm1c69] {
    padding: 12px 18px;
    border-top: 1px solid var(--mpl-border-1);
    vertical-align: middle;
    color: var(--mpl-fg-2);
    font: 500 var(--mpl-text-sm)/1.3 var(--mpl-font-sans);
}

.ptd-table tbody tr:first-child td[b-nizybm1c69] {
    border-top: none;
}

.ptd-col-pos[b-nizybm1c69] {
    width: 96px;
}

.ptd-col-num[b-nizybm1c69] {
    width: 80px;
}

.ptd-num-col[b-nizybm1c69] {
    text-align: right;
}

.ptd-num[b-nizybm1c69] {
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

.ptd-total[b-nizybm1c69] {
    font-weight: 800;
    color: var(--mpl-fg-1);
}

/* rows */
.ptd-row[b-nizybm1c69] {
    transition: background var(--mpl-dur-fast) var(--mpl-ease);
}

/* position cell + medal pill */
.ptd-pos-cell[b-nizybm1c69] {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.ptd-pos[b-nizybm1c69] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 30px;
    height: 30px;
    padding: 0 8px;
    border-radius: var(--mpl-radius-pill);
    font: 800 var(--mpl-text-sm)/1 var(--mpl-font-sans);
    font-variant-numeric: tabular-nums;
    color: var(--mpl-fg-2);
    background: var(--mpl-bg-3);
    border: 1px solid var(--mpl-border-2);
}

/* Top-3 minted pills. Near-black ink rides on the bright gradient stops. */
.ptd-pos-gold[b-nizybm1c69],
.ptd-pos-silver[b-nizybm1c69],
.ptd-pos-bronze[b-nizybm1c69] {
    color: #1a1a1a;
    border: none;
    box-shadow:
        inset 0 1px 1px rgba(255, 255, 255, 0.55),
        inset 0 -2px 3px rgba(0, 0, 0, 0.28),
        0 1px 4px rgba(0, 0, 0, 0.4);
}

.ptd-pos-gold[b-nizybm1c69] {
    background: var(--mpl-grad-medal-gold);
}

.ptd-pos-silver[b-nizybm1c69] {
    background: var(--mpl-grad-medal-silver);
}

.ptd-pos-bronze[b-nizybm1c69] {
    background: var(--mpl-grad-medal-bronze);
}

.ptd-pos-empty[b-nizybm1c69] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 30px;
    color: var(--mpl-fg-5);
}

/* player cell */
.ptd-player[b-nizybm1c69] {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
    max-width: 100%;
}

.ptd-player-name[b-nizybm1c69] {
    font: 700 var(--mpl-text-sm)/1.2 var(--mpl-font-sans);
    color: var(--mpl-fg-1);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ptd-partner[b-nizybm1c69] {
    color: var(--mpl-fg-3);
}

/* ===================== EMPTY STATE ===================== */
.ptd-empty-wrap[b-nizybm1c69] {
    padding: 20px;
}

/* ===================== RESPONSIVE ===================== */
@media (max-width: 991.98px) {
    .ptd-page[b-nizybm1c69] {
        padding: 24px 18px 48px;
    }
}

@media (max-width: 600px) {
    .ptd-hero-title[b-nizybm1c69] {
        font-size: var(--mpl-text-2xl);
    }

    .ptd-hero[b-nizybm1c69] {
        padding: 20px 18px;
    }

    .ptd-hero-meta[b-nizybm1c69] {
        gap: 8px 14px;
        font-size: var(--mpl-text-xs);
    }

    .ptd-tabs[b-nizybm1c69] {
        flex-wrap: wrap;
    }

    .ptd-table thead th[b-nizybm1c69],
    .ptd-table tbody td[b-nizybm1c69] {
        padding: 10px 12px;
    }
}
/* /Components/Pages/Tournaments/TournamentPublicResults.razor.rz.scp.css */
/* ============================================================
   TournamentPublicResults.razor — component-scoped styles (CSS isolation), WI-44.
   Dark "after-hours casino" redesign of the PUBLIC tournament results page,
   translated from the design comp (TournamentPublicResultsScreen.jsx + ui.css).
   Uses the adopted --mpl-* tokens from wwwroot/css/mpl-design-tokens.css and
   mirrors the layout conventions in Leaderboard.razor.css. Renders under
   PublicAwareLayout: the dark public shell for anonymous visitors and the
   authenticated AppShell for signed-in users. Shared primitives (MplStatusBadge,
   MplAvatar, MplEmptyState) bring their own scoped styles; this file owns the PAGE
   containers only — back link, header card + fact grid, and the standings table
   (incl. the finish-position medal pills). No hardcoded hex except the near-black
   ink that rides on the bright medal gradients (matches MplMedal's medallion).
   ============================================================ */

.tr-page[b-8xjinpzrce] {
    position: relative;
    max-width: 1100px;
    margin: 0 auto;
    padding: 32px 32px 60px;
}

/* ===================== BACK LINK ===================== */
.tr-back[b-8xjinpzrce] {
    margin-bottom: 20px;
}

.tr-back-link[b-8xjinpzrce] {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border-radius: var(--mpl-radius-md);
    font: 600 var(--mpl-text-sm)/1 var(--mpl-font-sans);
    color: var(--mpl-fg-2);
    background: var(--mpl-bg-3);
    border: 1px solid var(--mpl-border-2);
    text-decoration: none;
    transition: color var(--mpl-dur) var(--mpl-ease),
                border-color var(--mpl-dur) var(--mpl-ease),
                background var(--mpl-dur) var(--mpl-ease);
}

.tr-back-link:hover[b-8xjinpzrce] {
    color: var(--mpl-fg-1);
    border-color: var(--mpl-border-3);
    background: var(--mpl-bg-4);
}

.tr-back-link:focus-visible[b-8xjinpzrce] {
    outline: 2px solid var(--mpl-red-400);
    outline-offset: 2px;
}

/* ===================== NOT-FOUND ===================== */
.tr-notfound[b-8xjinpzrce] {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 16px 18px;
    border-radius: var(--mpl-radius-lg);
    background: var(--mpl-warning-bg);
    border: 1px solid rgba(245, 158, 11, 0.35);
    color: var(--mpl-fg-1);
    font: 500 var(--mpl-text-base)/1.4 var(--mpl-font-sans);
}

.tr-notfound i[b-8xjinpzrce] {
    color: var(--mpl-warning);
    font-size: 18px;
}

/* ===================== HEADER CARD ===================== */
.tr-header[b-8xjinpzrce] {
    background: var(--mpl-grad-card);
    border: 1px solid var(--mpl-border-1);
    border-radius: var(--mpl-radius-lg);
    box-shadow: var(--mpl-shadow-sm);
    overflow: hidden;
    margin-bottom: 22px;
}

.tr-header-bar[b-8xjinpzrce] {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    padding: 22px 24px;
    border-bottom: 1px solid var(--mpl-border-1);
    background: var(--mpl-grad-felt);
}

.tr-trophy[b-8xjinpzrce] {
    flex: none;
    width: 46px;
    height: 46px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--mpl-radius-md);
    background: var(--mpl-grad-brand);
    box-shadow: var(--mpl-shadow-sm);
    color: #fff;
    font-size: 22px;
}

.tr-header-titles[b-8xjinpzrce] {
    min-width: 0;
}

.tr-kicker[b-8xjinpzrce] {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 8px;
}

.tr-kicker-sep[b-8xjinpzrce] {
    color: var(--mpl-fg-5);
}

.tr-type[b-8xjinpzrce] {
    font: 600 var(--mpl-text-xs)/1 var(--mpl-font-sans);
    text-transform: uppercase;
    letter-spacing: var(--mpl-tracking-caps);
    color: var(--mpl-fg-3);
}

.tr-title[b-8xjinpzrce] {
    font: 800 var(--mpl-text-3xl)/1.12 var(--mpl-font-sans);
    letter-spacing: -0.02em;
    color: var(--mpl-fg-1);
    margin: 0;
    word-break: break-word;
}

/* fact grid */
.tr-facts[b-8xjinpzrce] {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    background: var(--mpl-border-1);
}

.tr-fact[b-8xjinpzrce] {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 18px 20px;
    background: var(--mpl-bg-2);
}

.tr-fact-ic[b-8xjinpzrce] {
    flex: none;
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--mpl-radius-sm);
    background: var(--mpl-bg-3);
    border: 1px solid var(--mpl-border-2);
    color: var(--mpl-fg-3);
    font-size: 15px;
}

.tr-fact-body[b-8xjinpzrce] {
    min-width: 0;
}

.tr-fact-label[b-8xjinpzrce] {
    font: 600 var(--mpl-text-xs)/1 var(--mpl-font-sans);
    text-transform: uppercase;
    letter-spacing: var(--mpl-tracking-wide);
    color: var(--mpl-fg-4);
    margin-bottom: 5px;
}

.tr-fact-value[b-8xjinpzrce] {
    font: 700 var(--mpl-text-sm)/1.3 var(--mpl-font-sans);
    color: var(--mpl-fg-1);
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ===================== STANDINGS CARD ===================== */
.tr-card[b-8xjinpzrce] {
    background: var(--mpl-grad-card);
    border: 1px solid var(--mpl-border-1);
    border-radius: var(--mpl-radius-lg);
    box-shadow: var(--mpl-shadow-sm);
    overflow: hidden;
}

.tr-card-head[b-8xjinpzrce] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 8px;
    padding: 16px 20px;
    border-bottom: 1px solid var(--mpl-border-2);
    background: var(--mpl-bg-1);
}

.tr-card-head-title[b-8xjinpzrce] {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font: 700 var(--mpl-text-base)/1 var(--mpl-font-sans);
    color: var(--mpl-fg-1);
}

.tr-card-head-title i[b-8xjinpzrce] {
    color: var(--mpl-fg-3);
    font-size: 18px;
}

.tr-card-head-hint[b-8xjinpzrce] {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font: 500 var(--mpl-text-xs)/1 var(--mpl-font-sans);
    letter-spacing: var(--mpl-tracking-wide);
    color: var(--mpl-fg-4);
}

/* ===================== TABLE ===================== */
.tr-table-wrap[b-8xjinpzrce] {
    overflow-x: auto;
}

.tr-table-wrap:focus-visible[b-8xjinpzrce] {
    outline: 2px solid var(--mpl-red-400);
    outline-offset: -2px;
}

.tr-table[b-8xjinpzrce] {
    width: 100%;
    border-collapse: collapse;
    font-family: var(--mpl-font-sans);
    /* keep the six columns legible while still allowing the wrapper to scroll
       on narrow viewports rather than crushing the cells */
    min-width: 640px;
}

.tr-table thead th[b-8xjinpzrce] {
    text-align: left;
    font: 700 var(--mpl-text-xs)/1 var(--mpl-font-sans);
    text-transform: uppercase;
    letter-spacing: var(--mpl-tracking-wide);
    color: var(--mpl-fg-4);
    padding: 12px 18px;
    border-bottom: 1px solid var(--mpl-border-2);
    background: var(--mpl-bg-1);
    white-space: nowrap;
}

.tr-table thead th.tr-num-col[b-8xjinpzrce] {
    text-align: right;
}

.tr-table tbody td[b-8xjinpzrce] {
    padding: 12px 18px;
    border-top: 1px solid var(--mpl-border-1);
    vertical-align: middle;
    color: var(--mpl-fg-2);
    font: 500 var(--mpl-text-sm)/1.3 var(--mpl-font-sans);
}

.tr-table tbody tr:first-child td[b-8xjinpzrce] {
    border-top: none;
}

.tr-col-pos[b-8xjinpzrce] {
    width: 96px;
}

.tr-num-col[b-8xjinpzrce] {
    text-align: right;
}

.tr-num[b-8xjinpzrce] {
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

.tr-total[b-8xjinpzrce] {
    font-weight: 800;
    color: var(--mpl-fg-1);
}

/* rows */
.tr-row[b-8xjinpzrce] {
    transition: background var(--mpl-dur-fast) var(--mpl-ease);
}

.tr-clickable[b-8xjinpzrce] {
    cursor: pointer;
}

.tr-clickable:hover[b-8xjinpzrce] {
    background: var(--mpl-bg-2);
}

.tr-open[b-8xjinpzrce] {
    background: var(--mpl-bg-2);
}

/* position cell + medal pill */
.tr-pos-cell[b-8xjinpzrce] {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.tr-pos[b-8xjinpzrce] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 30px;
    height: 30px;
    padding: 0 8px;
    border-radius: var(--mpl-radius-pill);
    font: 800 var(--mpl-text-sm)/1 var(--mpl-font-sans);
    font-variant-numeric: tabular-nums;
    color: var(--mpl-fg-2);
    background: var(--mpl-bg-3);
    border: 1px solid var(--mpl-border-2);
}

/* Top-3 minted pills. Near-black ink rides on the bright gradient stops — the
   lightest stop (#ffe98a / #f3f4f6 / #f6c089) against #1a1a1a clears WCAG AA. */
.tr-pos-gold[b-8xjinpzrce],
.tr-pos-silver[b-8xjinpzrce],
.tr-pos-bronze[b-8xjinpzrce] {
    color: #1a1a1a;
    border: none;
    box-shadow:
        inset 0 1px 1px rgba(255, 255, 255, 0.55),
        inset 0 -2px 3px rgba(0, 0, 0, 0.28),
        0 1px 4px rgba(0, 0, 0, 0.4);
}

.tr-pos-gold[b-8xjinpzrce] {
    background: var(--mpl-grad-medal-gold);
}

.tr-pos-silver[b-8xjinpzrce] {
    background: var(--mpl-grad-medal-silver);
}

.tr-pos-bronze[b-8xjinpzrce] {
    background: var(--mpl-grad-medal-bronze);
}

.tr-pos-empty[b-8xjinpzrce] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 30px;
    color: var(--mpl-fg-5);
}

.tr-chev[b-8xjinpzrce] {
    color: var(--mpl-fg-4);
    font-size: 12px;
}

/* player cell */
.tr-player[b-8xjinpzrce] {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
    max-width: 100%;
}

.tr-player-name[b-8xjinpzrce] {
    font: 700 var(--mpl-text-sm)/1.2 var(--mpl-font-sans);
    color: var(--mpl-fg-1);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.tr-partner[b-8xjinpzrce] {
    color: var(--mpl-fg-3);
}

/* ===================== EMPTY STATE ===================== */
/* MplEmptyState renders its own dashed inset panel (darker --mpl-bg-1); give it
   breathing room inside the standings card so it reads as an inset well. */
.tr-empty-wrap[b-8xjinpzrce] {
    padding: 20px;
}

/* ===================== RESPONSIVE ===================== */
@media (max-width: 991.98px) {
    .tr-page[b-8xjinpzrce] {
        padding: 24px 18px 48px;
    }

    .tr-facts[b-8xjinpzrce] {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .tr-title[b-8xjinpzrce] {
        font-size: var(--mpl-text-2xl);
    }

    .tr-facts[b-8xjinpzrce] {
        grid-template-columns: 1fr;
    }

    .tr-header-bar[b-8xjinpzrce] {
        padding: 18px 16px;
    }

    .tr-fact[b-8xjinpzrce] {
        padding: 14px 16px;
    }

    .tr-table thead th[b-8xjinpzrce],
    .tr-table tbody td[b-8xjinpzrce] {
        padding: 10px 12px;
    }
}
/* /Components/Shared/Bits/MplAvatar.razor.rz.scp.css */
/* Avatar bubble — moved verbatim from PublicLanding.razor.css (.lb-avatar, lines
   507-519). Standalone selector; the parent .lb-row grid places this positionally
   (no descendant rule reaches in), so scoping it here is safe. */
.lb-avatar[b-rhud29hfqb] {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--mpl-grad-brand);
    color: #fff;
    font: 700 12px/1 var(--mpl-font-sans);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--mpl-shadow-sm);
    flex: none;
}
/* /Components/Shared/Bits/MplEmptyState.razor.rz.scp.css */
/* Empty state — moved verbatim from PublicLanding.razor.css (.empty family, lines
   348-374) plus the `.empty a.btn*` arm split out of the shared button block
   (546-580). The CTA is consumer-provided ChildContent, so it carries the PAGE's
   scope, not this component's — `::deep` is required for the button rules to reach
   it. No current consumer passes a CTA, so these rules match nothing today. */
.empty[b-lqzccmccae] {
    text-align: center;
    padding: 48px 32px;
    background: var(--mpl-bg-1);
    border: 1px dashed var(--mpl-border-2);
    border-radius: 16px;
    background-image: radial-gradient(ellipse at 50% 0%, rgba(204, 0, 0, 0.10) 0%, transparent 60%);
}

.empty i[b-lqzccmccae] {
    font-size: 36px;
    color: var(--mpl-fg-4);
    display: block;
    margin-bottom: 10px;
}

.empty h4[b-lqzccmccae] {
    font: 700 18px/1.2 var(--mpl-font-sans);
    color: var(--mpl-fg-1);
    margin: 0 0 4px;
}

.empty p[b-lqzccmccae] {
    font: 400 14px/1.4 var(--mpl-font-sans);
    color: var(--mpl-fg-3);
    margin: 0 0 18px;
}

/* Optional CTA button (slotted content) — ::deep crosses into the consumer-scoped
   fragment. Values preserved from the original `.empty a.btn*` rules. */
.empty[b-lqzccmccae]  a.btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border-radius: 12px;
    font: 600 14px/1 var(--mpl-font-sans);
    border: 1px solid transparent;
    text-decoration: none;
    cursor: pointer;
    transition: all var(--mpl-dur) var(--mpl-ease);
    white-space: nowrap;
}

.empty[b-lqzccmccae]  a.btn-primary {
    background: var(--mpl-grad-brand);
    color: #fff;
    box-shadow: var(--mpl-shadow-sm);
}

.empty[b-lqzccmccae]  a.btn-primary:hover {
    transform: translateY(-1px);
    box-shadow: var(--mpl-glow-red);
    filter: brightness(1.06);
}

.empty[b-lqzccmccae]  a.btn-sm {
    padding: 6px 12px;
    font-size: 12px;
    border-radius: 10px;
}
/* /Components/Shared/Bits/MplMedal.razor.rz.scp.css */
/* Medal pill — moved verbatim from PublicLanding.razor.css (.medal family, lines
   388-472, plus the phone overrides at 687-694). The `.medals` grid container
   stays in the page; each <MplMedal/> is placed positionally within it.
   All selectors are rooted on `.medal`, so they stay self-contained under isolation. */
.medal[b-ufefqshmyg] {
    position: relative;
    display: grid;
    grid-template-columns: 36px 1fr auto;
    align-items: center;
    gap: 12px;
    padding: 12px 18px 12px 12px;
    border-radius: 999px;
    background: linear-gradient(145deg, #1f1f25 0%, #15151a 100%);
    border: 1px solid var(--mpl-border-2);
    box-shadow: var(--mpl-shadow-sm);
    overflow: hidden;
    min-width: 0;
}

.medal[b-ufefqshmyg]::before {
    content: '';
    position: absolute;
    left: -18px;
    top: -18px;
    width: 96px;
    height: 96px;
    border-radius: 50%;
    opacity: 0.32;
    filter: blur(16px);
    pointer-events: none;
}

.medal.gold[b-ufefqshmyg] { border-color: rgba(255, 194, 61, 0.45); }
.medal.gold[b-ufefqshmyg]::before { background: radial-gradient(circle, rgba(255,194,61,0.6), transparent 70%); }
.medal.silver[b-ufefqshmyg] { border-color: rgba(203, 213, 225, 0.40); }
.medal.silver[b-ufefqshmyg]::before { background: radial-gradient(circle, rgba(203,213,225,0.45), transparent 70%); }
.medal.bronze[b-ufefqshmyg] { border-color: rgba(205, 127, 50, 0.45); }
.medal.bronze[b-ufefqshmyg]::before { background: radial-gradient(circle, rgba(205,127,50,0.55), transparent 70%); }

.medallion[b-ufefqshmyg] {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 1;
    font: 700 14px/1 var(--mpl-font-sans);
    color: #1a1a1a;
    flex: none;
    box-shadow:
        inset 0 1px 1px rgba(255,255,255,0.55),
        inset 0 -2px 3px rgba(0,0,0,0.32),
        0 2px 6px rgba(0,0,0,0.4);
}

.medal.gold .medallion[b-ufefqshmyg] { background: linear-gradient(135deg, #ffe98a 0%, #ffc23d 45%, #b8860b 100%); }
.medal.silver .medallion[b-ufefqshmyg] { background: linear-gradient(135deg, #f3f4f6 0%, #cbd5e1 45%, #64748b 100%); }
.medal.bronze .medallion[b-ufefqshmyg] { background: linear-gradient(135deg, #f6c089 0%, #cd7f32 45%, #6b3410 100%); }

.medal-meta[b-ufefqshmyg] { position: relative; z-index: 1; min-width: 0; }

.medal-name[b-ufefqshmyg] {
    font: 700 15px/1.2 var(--mpl-font-sans);
    color: var(--mpl-fg-1);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.medal-pts[b-ufefqshmyg] {
    position: relative;
    z-index: 1;
    text-align: right;
    flex: none;
    font: 700 16px/1 var(--mpl-font-sans);
    font-variant-numeric: tabular-nums;
    color: var(--mpl-fg-1);
    white-space: nowrap;
}

.medal-pts small[b-ufefqshmyg] {
    font: 500 9px/1 var(--mpl-font-sans);
    color: var(--mpl-fg-4);
    margin-left: 4px;
    letter-spacing: .08em;
    text-transform: uppercase;
}

/* Phone-width compaction (from PublicLanding.razor.css @media max-width:600px). */
@media (max-width: 600px) {
    .medal[b-ufefqshmyg] {
        padding: 10px 14px 10px 10px;
        gap: 10px;
    }

    .medal-name[b-ufefqshmyg] {
        font-size: 14px;
    }
}
/* /Components/Shared/Bits/MplStandingsRow.razor.rz.scp.css */
/* Standings row — moved verbatim from PublicLanding.razor.css (.lb-row family,
   lines 483-543, plus the phone override at 696-699). The `.lb-list` container
   stays in the page; rows render as direct siblings inside it so `.lb-row + .lb-row`
   keeps matching. `.lb-avatar` lives in MplAvatar. */
.lb-row[b-t9mib2xl9m] {
    display: grid;
    grid-template-columns: auto 32px 1fr auto;
    align-items: center;
    gap: 14px;
    padding: 14px 18px;
    transition: background var(--mpl-dur) var(--mpl-ease);
}

.lb-row + .lb-row[b-t9mib2xl9m] {
    border-top: 1px solid var(--mpl-border-1);
}

.lb-row:hover[b-t9mib2xl9m] {
    background: var(--mpl-bg-2);
}

.lb-rank[b-t9mib2xl9m] {
    font: 700 13px/1 var(--mpl-font-sans);
    color: var(--mpl-fg-4);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

.lb-name[b-t9mib2xl9m] {
    font: 700 14px/1.2 var(--mpl-font-sans);
    color: var(--mpl-fg-1);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
}

.lb-pts[b-t9mib2xl9m] {
    text-align: right;
    font: 800 15px/1 var(--mpl-font-sans);
    color: var(--mpl-fg-1);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

.lb-pts small[b-t9mib2xl9m] {
    font: 500 10px/1 var(--mpl-font-sans);
    color: var(--mpl-fg-4);
    margin-left: 4px;
    text-transform: lowercase;
}

/* Phone-width compaction (from PublicLanding.razor.css @media max-width:600px). */
@media (max-width: 600px) {
    .lb-row[b-t9mib2xl9m] {
        gap: 10px;
        padding: 12px 14px;
    }
}
/* /Components/Shared/Bits/MplStatusBadge.razor.rz.scp.css */
/* Status badge — moved verbatim from PublicLanding.razor.css (lines 315-345).
   Class names and --mpl-* tokens preserved exactly; flat selectors are
   self-contained so CSS isolation scopes them to this component's markup. */
.public-badge[b-jm1c57ztkk] {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 10px;
    border-radius: 999px;
    font: 600 11px/1 var(--mpl-font-sans);
    letter-spacing: .02em;
    border: 1px solid transparent;
    white-space: nowrap;
    flex: none;
}

.public-badge .dot[b-jm1c57ztkk] {
    width: 6px;
    height: 6px;
    border-radius: 50%;
}

.public-badge.badge-sched[b-jm1c57ztkk] { background: rgba(161, 161, 170, 0.14); color: #d4d4d8; border-color: rgba(161, 161, 170, 0.3); }
.public-badge.badge-sched .dot[b-jm1c57ztkk] { background: #a1a1aa; }
.public-badge.badge-open[b-jm1c57ztkk] { background: rgba(59, 130, 246, 0.16); color: #93c5fd; border-color: rgba(59, 130, 246, 0.35); }
.public-badge.badge-open .dot[b-jm1c57ztkk] { background: #3b82f6; }
.public-badge.badge-closed[b-jm1c57ztkk] { background: rgba(245, 158, 11, 0.16); color: #fcd34d; border-color: rgba(245, 158, 11, 0.35); }
.public-badge.badge-closed .dot[b-jm1c57ztkk] { background: #f59e0b; }
.public-badge.badge-progress[b-jm1c57ztkk] { background: rgba(255, 42, 42, 0.16); color: #ff7a7a; border-color: rgba(204, 0, 0, 0.4); }
.public-badge.badge-progress .dot[b-jm1c57ztkk] { background: #ff2a2a; box-shadow: 0 0 8px #ff2a2a; }
.public-badge.badge-done[b-jm1c57ztkk] { background: rgba(16, 185, 129, 0.16); color: #6ee7b7; border-color: rgba(16, 185, 129, 0.35); }
.public-badge.badge-done .dot[b-jm1c57ztkk] { background: #10b981; }
.public-badge.badge-cancel[b-jm1c57ztkk] { background: rgba(239, 68, 68, 0.16); color: #fca5a5; border-color: rgba(239, 68, 68, 0.35); }
.public-badge.badge-cancel .dot[b-jm1c57ztkk] { background: #ef4444; }
/* /Components/Shared/Bits/PublicFooter.razor.rz.scp.css */
/* Public footer — moved verbatim from PublicLanding.razor.css (.public-footer
   family, lines 583-611, plus the phone override at 707-717). All selectors are
   rooted on `.public-footer`, authored by this component, so they self-scope. */
.public-footer[b-n4eno9shsq] {
    position: relative;
    z-index: 1;
    border-top: 1px solid var(--mpl-border-1);
    padding: 24px 32px;
    margin-top: 60px;
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
    max-width: 1100px;
    margin-left: auto;
    margin-right: auto;
    font: 400 12px/1.4 var(--mpl-font-sans);
    color: var(--mpl-fg-4);
}

.public-footer .spacer[b-n4eno9shsq] {
    flex: 1;
}

.public-footer a[b-n4eno9shsq] {
    color: var(--mpl-fg-3);
    text-decoration: none;
}

.public-footer a:hover[b-n4eno9shsq] {
    color: var(--mpl-red-400);
}

/* Phone-width: stack the footer (from @media max-width:600px). */
@media (max-width: 600px) {
    .public-footer[b-n4eno9shsq] {
        padding: 18px;
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: 10px;
    }

    .public-footer .spacer[b-n4eno9shsq] {
        display: none;
    }
}
/* /Components/Shared/Bits/PublicNav.razor.rz.scp.css */
/* Public nav — moved from PublicLanding.razor.css: nav block (38-92), the phone
   override (644-684), and the Sign-in button rules. The button rules originally
   read `.public a.btn` (the page wrapper); rewritten anchored under `.public-nav`
   (this component's root) so they stay specific enough to beat Bootstrap's global
   `.btn`/`.btn-primary` for base AND :hover without relying on the scope attribute
   alone. All --mpl-* tokens and values preserved verbatim. */
.public-nav[b-g2w0x6qbns] {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px 32px;
    background: rgba(10, 10, 11, 0.7);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom: 1px solid var(--mpl-border-1);
}

.public-nav .brand-row[b-g2w0x6qbns] {
    display: flex;
    align-items: center;
    gap: 12px;
}

.public-nav .brand-row img[b-g2w0x6qbns] {
    width: 36px;
    height: 36px;
    filter: drop-shadow(0 4px 8px rgba(204, 0, 0, 0.4));
}

.public-nav .brand-row .name[b-g2w0x6qbns] {
    font: 800 14px/1 var(--mpl-font-sans);
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--mpl-fg-1);
}

.public-nav .spacer[b-g2w0x6qbns] {
    flex: 1;
}

.public-nav .links[b-g2w0x6qbns] {
    display: flex;
    gap: 4px;
}

.public-nav .links a[b-g2w0x6qbns] {
    padding: 8px 14px;
    border-radius: 8px;
    font: 600 13px/1 var(--mpl-font-sans);
    color: var(--mpl-fg-3);
    text-decoration: none;
    cursor: pointer;
    transition: all var(--mpl-dur) var(--mpl-ease);
}

.public-nav .links a:hover[b-g2w0x6qbns] {
    color: var(--mpl-fg-1);
    background: var(--mpl-bg-2);
}

/* Sign-in button (was `.public a.btn*` — re-anchored under `.public-nav`). */
.public-nav a.btn[b-g2w0x6qbns] {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border-radius: 12px;
    font: 600 14px/1 var(--mpl-font-sans);
    border: 1px solid transparent;
    text-decoration: none;
    cursor: pointer;
    transition: all var(--mpl-dur) var(--mpl-ease);
    white-space: nowrap;
}

.public-nav a.btn-primary[b-g2w0x6qbns] {
    background: var(--mpl-grad-brand);
    color: #fff;
    box-shadow: var(--mpl-shadow-sm);
}

.public-nav a.btn-primary:hover[b-g2w0x6qbns] {
    transform: translateY(-1px);
    box-shadow: var(--mpl-glow-red);
    filter: brightness(1.06);
}

.public-nav a.btn-sm[b-g2w0x6qbns] {
    padding: 6px 12px;
    font-size: 12px;
    border-radius: 10px;
}

/* Phone-width: wrap the nav onto two rows (from @media max-width:600px). */
@media (max-width: 600px) {
    .public-nav[b-g2w0x6qbns] {
        padding: 12px 14px;
        gap: 8px;
        flex-wrap: wrap;
        row-gap: 8px;
    }

    .public-nav .brand-row[b-g2w0x6qbns] {
        gap: 8px;
        min-width: 0;
        flex: 1 1 auto;
    }

    .public-nav .brand-row img[b-g2w0x6qbns] {
        width: 28px;
        height: 28px;
    }

    .public-nav .brand-row .name[b-g2w0x6qbns] {
        font-size: 12px;
        letter-spacing: .06em;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        min-width: 0;
    }

    .public-nav .spacer[b-g2w0x6qbns] {
        display: none;
    }

    .public-nav .links[b-g2w0x6qbns] {
        order: 99;
        flex: 1 1 100%;
        justify-content: center;
    }

    .public-nav .links a[b-g2w0x6qbns] {
        padding: 6px 10px;
        font-size: 12px;
    }
}
/* /Components/Shared/Bits/PublicSeoHead.razor.rz.scp.css */
/* intentionally empty — no styling surface; this component emits only <HeadContent>
   markup that is rendered into <head>, so there is no DOM element to scope styles to.
   File retained as a convention placeholder to signal that no scoped styles were
   accidentally omitted (WI-161). */
/* /Components/Shared/PlayerSearchDropdown.razor.rz.scp.css */
.player-search-listbox[b-x25u67pz0t] {
    top: 100%;
    left: 0;
    z-index: 1050;
    max-height: 280px;
    overflow-y: auto;
    border-radius: 0 0 0.375rem 0.375rem;
}

/* Disabled options (already-registered players) */
.player-search-disabled[b-x25u67pz0t] {
    opacity: 0.6;
    cursor: not-allowed;
    pointer-events: none;
}

/* Active keyboard-navigation highlight overrides the Bootstrap .active colour
   so disabled options don't appear selected. */
.list-group-item.active.player-search-disabled[b-x25u67pz0t] {
    background-color: #e9ecef;
    border-color: #dee2e6;
    color: #6c757d;
}
/* /Components/Shared/TournamentResultBreakdownPanel.razor.rz.scp.css */
/* ============================================================
   TournamentResultBreakdownPanel.razor — component-scoped styles (CSS isolation), WI-44.
   Dark "after-hours casino" styling for the per-player points breakdown that expands
   under a standings row. Replaces the previous Bootstrap utility markup; uses the
   adopted --mpl-* tokens from wwwroot/css/mpl-design-tokens.css. Colspan-agnostic —
   shared by the public results page (ColSpan=6) and TournamentDetail (ColSpan 7/8).
   Reproduces the design comp's bp-col / bp-list / bp-row layout.
   ============================================================ */

.bp-cell[b-58p9r50chr] {
    padding: 0;
    background: var(--mpl-bg-1);
}

/* Red accent rail echoes the original border-start, on-theme. */
.bp-panel[b-58p9r50chr] {
    padding: 16px 20px;
    border-left: 3px solid var(--mpl-red-600);
    background: var(--mpl-grad-felt);
}

/* ---- status states (loading / unavailable) ---- */
.bp-status[b-58p9r50chr] {
    display: flex;
    align-items: center;
    gap: 10px;
    font: 500 var(--mpl-text-sm)/1 var(--mpl-font-sans);
    color: var(--mpl-fg-3);
}

.bp-status-muted[b-58p9r50chr] {
    color: var(--mpl-fg-4);
}

.bp-spinner[b-58p9r50chr] {
    width: 16px;
    height: 16px;
    border-radius: 50%;
    border: 2px solid var(--mpl-border-3);
    border-top-color: var(--mpl-red-500);
    animation: bp-spin-b-58p9r50chr 0.7s linear infinite;
    flex: none;
}

@keyframes bp-spin-b-58p9r50chr {
    to {
        transform: rotate(360deg);
    }
}

/* ---- two-column breakdown ---- */
.bp-grid[b-58p9r50chr] {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 28px;
}

.bp-col[b-58p9r50chr] {
    min-width: 0;
}

.bp-col-title[b-58p9r50chr] {
    font: 700 var(--mpl-text-sm)/1 var(--mpl-font-sans);
    color: var(--mpl-fg-1);
    margin: 0 0 10px;
}

.bp-list[b-58p9r50chr] {
    display: flex;
    flex-direction: column;
}

.bp-heading[b-58p9r50chr] {
    font: 600 var(--mpl-text-xs)/1 var(--mpl-font-sans);
    text-transform: uppercase;
    letter-spacing: var(--mpl-tracking-wide);
    color: var(--mpl-fg-4);
    margin: 2px 0 6px;
}

.bp-row[b-58p9r50chr] {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
    padding: 6px 0;
    font: 500 var(--mpl-text-sm)/1.3 var(--mpl-font-sans);
    color: var(--mpl-fg-3);
}

.bp-label[b-58p9r50chr] {
    min-width: 0;
}

.bp-sub[b-58p9r50chr] {
    color: var(--mpl-fg-5);
    font-size: var(--mpl-text-xs);
    margin-left: 4px;
}

.bp-value[b-58p9r50chr] {
    flex: none;
    color: var(--mpl-fg-2);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

.bp-subtotal[b-58p9r50chr] {
    border-top: 1px solid var(--mpl-border-2);
    margin-top: 4px;
    padding-top: 8px;
    color: var(--mpl-fg-2);
}

.bp-total[b-58p9r50chr] {
    border-top: 1px solid var(--mpl-border-2);
    margin-top: 4px;
    padding-top: 8px;
    font-weight: 800;
    color: var(--mpl-fg-1);
}

.bp-total .bp-value[b-58p9r50chr] {
    color: var(--mpl-fg-1);
    font-weight: 800;
}

.bp-empty[b-58p9r50chr] {
    font: 400 var(--mpl-text-sm)/1.4 var(--mpl-font-sans);
    color: var(--mpl-fg-4);
    margin: 0;
}

/* ---- responsive: stack the two columns on narrow viewports ---- */
@media (max-width: 600px) {
    .bp-grid[b-58p9r50chr] {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .bp-panel[b-58p9r50chr] {
        padding: 14px 14px;
    }
}
