* {
    box-sizing: border-box;
}

html {
    min-width: 320px;
    scroll-behavior: smooth;
}

html, body {
    background: #f8fafc;
    color: #18212f;
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
    line-height: 1.5;
}

body {
    margin: 0;
}

img {
    display: block;
    height: auto;
    max-width: 100%;
}

h1,
h2,
h3,
p {
    overflow-wrap: anywhere;
}

h1 {
    font-size: clamp(2rem, 4vw, 3.25rem);
    line-height: 1.05;
    margin: 0 0 0.75rem;
}

h2 {
    line-height: 1.25;
}

.skip-link {
    background: #101827;
    border-radius: 0 0 8px 0;
    color: #fff;
    font-weight: 800;
    left: 0;
    padding: 0.75rem 1rem;
    position: fixed;
    top: 0;
    transform: translateY(-120%);
    transition: transform 120ms ease;
    z-index: 2000;
}

.skip-link:focus {
    transform: translateY(0);
}

a, .btn-link {
    color: #006bb7;
}

.btn-primary {
    color: #fff;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

.btn:focus,
.btn:active:focus,
.btn-link.nav-link:focus,
.form-control:focus,
.form-check-input:focus,
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible {
    outline: 3px solid #f3b43f;
    outline-offset: 3px;
    box-shadow: none;
}

.content {
    padding-top: 1.1rem;
}

.not-found-shell {
    margin: 0 auto;
    max-width: 74rem;
    padding: 2rem 1rem;
}

.project-shell,
.status-header {
    align-items: flex-start;
    display: flex;
    gap: 2rem;
    justify-content: space-between;
    margin: 0 0 2rem;
}

.eyebrow {
    color: #58677b;
    font-size: 0.78rem;
    font-weight: 700;
    margin: 0 0 0.35rem;
    text-transform: uppercase;
}

.lead {
    color: #415064;
    max-width: 52rem;
}

.quick-actions,
.work-grid,
.status-grid,
.summary-strip,
.doc-list,
.dashboard-grid,
.visual-dashboard,
.player-flow,
.section-progress-grid,
.priority-list,
.architecture-grid,
.recruitment-grid,
.job-detail-grid,
.message-thread {
    display: grid;
    gap: 1rem;
}

.quick-actions {
    min-width: 14rem;
}

.game-hero {
    background:
        linear-gradient(135deg, rgba(16, 24, 39, 0.96), rgba(22, 61, 97, 0.84)),
        linear-gradient(90deg, #101827, #253449);
    border: 1px solid #27374b;
    border-radius: 8px;
    color: #f8fafc;
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(18rem, 0.95fr);
    padding: 1.5rem;
}

.game-hero .eyebrow,
.game-hero .lead {
    color: #d8e3f3;
}

.hero-copy {
    max-width: 48rem;
}

.hero-media {
    align-self: stretch;
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 8px;
    margin: 0;
    min-height: 18rem;
    overflow: hidden;
}

.hero-media picture,
.hero-media img {
    height: 100%;
    width: 100%;
}

.hero-media img {
    object-fit: cover;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1.25rem;
}

.element-showcase {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: repeat(4, minmax(7rem, 1fr));
    margin-bottom: 1.5rem;
}

.element-card {
    background: #fff;
    border: 1px solid #d8dee8;
    border-radius: 8px;
    min-height: 5.5rem;
    padding: 0.85rem;
}

.element-card span,
.element-card strong {
    display: block;
}

.element-card span {
    color: #172033;
    font-size: 1.05rem;
    font-weight: 900;
}

.element-card strong {
    color: #5f6f84;
    font-size: 0.82rem;
    margin-top: 0.35rem;
}

.element-card.fire {
    border-left: 5px solid #ef4444;
}

.element-card.water {
    border-left: 5px solid #38bdf8;
}

.element-card.earth {
    border-left: 5px solid #22c55e;
}

.element-card.air {
    border-left: 5px solid #facc15;
}

.action-link,
.refresh-button {
    background: #1f6feb;
    border: 1px solid #1f6feb;
    border-radius: 6px;
    color: #fff;
    align-items: center;
    display: inline-flex;
    justify-content: center;
    font-weight: 700;
    padding: 0.65rem 0.9rem;
    text-align: center;
    text-decoration: none;
    white-space: nowrap;
}

.action-link.secondary {
    background: #ffffff;
    color: #1f6feb;
}

.action-link:hover,
.refresh-button:hover,
.text-link:hover {
    filter: brightness(0.96);
}

.button-row,
.editor-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.work-grid,
.status-grid,
.game-pillars,
.dashboard-grid,
.visual-dashboard,
.architecture-grid,
.recruitment-grid,
.job-detail-grid {
    grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
}

.work-grid article,
.game-pillars article,
.status-panel,
.auth-panel,
.summary-strip article,
.doc-row,
.dashboard-panel,
.chart-panel,
.player-flow article,
.section-progress,
.architecture-panel,
.job-card,
.message-bubble {
    background: #fff;
    border: 1px solid #d8dee8;
    border-radius: 8px;
    padding: 1rem;
}

.work-grid h2,
.game-pillars h2,
.status-panel h2,
.dashboard-panel h2,
.chart-panel h2,
.player-flow h2,
.section-progress h2,
.job-card h2,
.architecture-section h2 {
    font-size: 1rem;
    margin: 0 0 0.5rem;
}

.game-pillars {
    grid-template-columns: repeat(auto-fit, minmax(17rem, 1fr));
    margin-bottom: 1.5rem;
}

.game-pillars p {
    color: #5f6f84;
}

.visual-dashboard {
    grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
    margin-bottom: 1.5rem;
}

.chart-panel {
    align-content: start;
    display: grid;
    gap: 1rem;
}

.chart-panel.wide {
    grid-column: span 2;
}

.donut-chart {
    align-items: center;
    aspect-ratio: 1;
    border-radius: 50%;
    display: grid;
    justify-self: center;
    max-width: 13rem;
    min-width: 10rem;
    padding: 1rem;
    place-items: center;
    width: 68%;
}

.donut-chart > div {
    align-items: center;
    background: #fff;
    border-radius: 50%;
    display: grid;
    height: 72%;
    justify-items: center;
    width: 72%;
}

.donut-chart strong {
    color: #172033;
    font-size: 1.45rem;
}

.donut-chart span {
    color: #66758a;
    font-size: 0.82rem;
    margin-top: -0.4rem;
}

.chart-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem 0.85rem;
}

.chart-legend span {
    align-items: center;
    color: #415064;
    display: inline-flex;
    font-size: 0.9rem;
    gap: 0.35rem;
}

.chart-legend i {
    border-radius: 999px;
    display: inline-block;
    height: 0.65rem;
    width: 0.65rem;
}

.legend-done {
    background: #1f6feb;
}

.legend-open {
    background: #dc2626;
}

.legend-reference {
    background: #94a3b8;
}

.bar-chart {
    display: grid;
    gap: 0.75rem;
}

.bar-row {
    align-items: center;
    display: grid;
    gap: 0.75rem;
    grid-template-columns: 8rem minmax(8rem, 1fr) 2rem;
}

.bar-row span {
    color: #415064;
    font-weight: 700;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.bar-row strong {
    color: #172033;
    text-align: right;
}

.bar-track {
    background: #e5eaf1;
    border-radius: 999px;
    height: 0.72rem;
    overflow: hidden;
}

.bar-track i {
    background: #dc2626;
    display: block;
    height: 100%;
}

.launcher-hero {
    background: #101827;
    border: 1px solid #27374b;
    border-radius: 8px;
    color: #f8fafc;
    padding: 1.25rem;
}

.launcher-hero .eyebrow,
.launcher-hero .lead {
    color: #b8c5d8;
}

.primary-download {
    align-self: center;
    background: #f3b43f;
    border-color: #f3b43f;
    color: #151008;
    min-width: 13rem;
}

.player-flow {
    grid-template-columns: repeat(auto-fit, minmax(13rem, 1fr));
    margin-bottom: 1.5rem;
}

.player-flow span {
    align-items: center;
    background: #172033;
    border-radius: 999px;
    color: #f8fafc;
    display: inline-flex;
    font-weight: 800;
    height: 2rem;
    justify-content: center;
    margin-bottom: 0.75rem;
    width: 2rem;
}

.dashboard-grid {
    margin-bottom: 1.5rem;
}

.dashboard-panel.wide {
    grid-column: span 2;
}

.panel-title-row,
.section-progress-title {
    align-items: center;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
}

.muted,
.dashboard-panel p,
.player-flow p,
.section-progress p {
    color: #5f6f84;
}

.priority-row {
    align-items: center;
    border: 1px solid #d8dee8;
    border-radius: 6px;
    color: #1f2937;
    display: grid;
    gap: 0.5rem;
    grid-template-columns: minmax(0, 1fr) max-content max-content;
    padding: 0.75rem;
    text-decoration: none;
}

.priority-row:hover {
    border-color: #1f6feb;
}

.priority-row small {
    color: #6b7a90;
}

.compact-steps {
    color: #415064;
    margin: 0 0 1rem;
    padding-left: 1.25rem;
}

.compact-dl {
    display: grid;
    gap: 0.5rem 1rem;
    grid-template-columns: 6rem minmax(0, 1fr);
    margin: 0;
}

.compact-dl dt {
    color: #5f6f84;
    font-weight: 700;
}

.compact-dl dd {
    margin: 0;
    overflow-wrap: anywhere;
}

.text-link {
    align-items: center;
    color: #1f6feb;
    display: inline-flex;
    font-weight: 700;
    min-height: 2.5rem;
    text-decoration: none;
}

.section-progress {
    margin-bottom: 1.5rem;
}

.architecture-section {
    margin-bottom: 1.5rem;
}

.architecture-grid {
    grid-template-columns: repeat(auto-fit, minmax(22rem, 1fr));
    margin-top: 1rem;
}

.architecture-panel {
    align-content: start;
    display: grid;
    gap: 1rem;
}

.architecture-heading {
    align-items: baseline;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
}

.architecture-heading h3 {
    font-size: 1rem;
    margin: 0;
}

.architecture-heading span {
    color: #66758a;
    font-size: 0.86rem;
}

.architecture-map {
    display: grid;
    gap: 0.9rem;
}

.arch-lane {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    display: grid;
    gap: 0.55rem;
    padding: 0.85rem;
}

.arch-lane.arch-grid {
    grid-template-columns: repeat(auto-fit, minmax(9rem, 1fr));
}

.arch-lane.arch-flow {
    grid-template-columns: 1fr;
}

.arch-lane p {
    color: #58677b;
    font-size: 0.78rem;
    font-weight: 800;
    grid-column: 1 / -1;
    letter-spacing: 0.04em;
    margin: 0;
    text-transform: uppercase;
}

.arch-node {
    background: #fff;
    border: 1px solid #cbd5e1;
    border-left: 5px solid #1f6feb;
    border-radius: 7px;
    color: #172033;
    font-weight: 800;
    min-height: 4.3rem;
    padding: 0.65rem;
}

.arch-node small {
    color: #66758a;
    display: block;
    font-weight: 600;
    margin-top: 0.2rem;
}

.arch-node.primary {
    border-left-color: #f3b43f;
}

.arch-node.proxy {
    border-left-color: #7c3aed;
}

.arch-node.store {
    border-left-color: #166534;
}

.arch-node.file {
    border-left-color: #0f766e;
}

.arch-arrow {
    align-items: center;
    color: #58677b;
    display: flex;
    font-size: 0.82rem;
    font-weight: 800;
    justify-content: flex-start;
    min-height: 1.2rem;
    padding-left: 0.75rem;
    text-align: center;
}

.arch-arrow::after {
    content: "v";
    font-size: 0.78rem;
    margin-left: 0.45rem;
}

.arch-relations {
    display: grid;
    gap: 0.45rem;
}

.arch-relations span {
    background: #eef4ff;
    border: 1px solid #d8e5ff;
    border-radius: 6px;
    color: #314158;
    font-size: 0.9rem;
    padding: 0.55rem 0.65rem;
}

.section-progress-grid {
    grid-template-columns: repeat(auto-fit, minmax(13rem, 1fr));
    margin-top: 1rem;
}

.section-progress-grid article {
    border: 1px solid #e2e8f0;
    border-radius: 6px;
    padding: 0.75rem;
}

.section-progress-title span {
    color: #6b7a90;
    font-size: 0.85rem;
}

.progress-track {
    background: #e5eaf1;
    border-radius: 999px;
    height: 0.55rem;
    margin: 0.75rem 0 0.45rem;
    overflow: hidden;
}

.progress-track span {
    background: #1f6feb;
    display: block;
    height: 100%;
}

.doc-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.doc-tabs button {
    background: #fff;
    border: 1px solid #c9d4e4;
    border-radius: 999px;
    color: #314158;
    font-weight: 700;
    padding: 0.45rem 0.85rem;
}

.doc-tabs button.active {
    background: #1f6feb;
    border-color: #1f6feb;
    color: #fff;
}

.doc-row.needs-work {
    border-left: 5px solid #dc2626;
}

.doc-row.tracking {
    border-left: 5px solid #1f6feb;
}

.doc-row.reference {
    border-left: 5px solid #94a3b8;
}

.status-title {
    align-items: center;
    display: flex;
    justify-content: space-between;
}

.status-badge {
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 700;
    padding: 0.25rem 0.55rem;
}

.status-badge.online {
    background: #dcfce7;
    color: #166534;
}

.status-badge.offline {
    background: #fee2e2;
    color: #991b1b;
}

.status-panel dl {
    display: grid;
    gap: 0.45rem 1rem;
    grid-template-columns: 7rem 1fr;
    margin: 1rem 0 0;
}

.status-panel dt {
    color: #5f6f84;
    font-weight: 700;
}

.status-panel dd {
    margin: 0;
    overflow-wrap: anywhere;
}

.status-error {
    color: #991b1b;
    margin: 1rem 0 0;
}

.status-ok {
    color: #166534;
    font-weight: 700;
    margin: 1rem 0;
}

.summary-strip {
    grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
    margin-bottom: 1.5rem;
}

.summary-strip span {
    color: #1f2937;
    display: block;
    font-size: 1.4rem;
    font-weight: 800;
}

.summary-strip p,
.doc-row p {
    color: #5f6f84;
    margin: 0;
}

.doc-row {
    align-items: start;
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(0, 1fr) auto;
}

.doc-row h2 {
    font-size: 1rem;
    margin: 0 0 0.35rem;
}

.doc-row dl {
    display: grid;
    gap: 0.35rem 0.75rem;
    grid-template-columns: max-content max-content;
    margin: 0;
    white-space: nowrap;
}

.doc-row dt {
    color: #5f6f84;
}

.doc-row dd {
    font-weight: 700;
    margin: 0;
}

.auth-panel {
    max-width: 34rem;
}

.auth-panel form {
    display: grid;
    gap: 0.85rem;
}

.auth-panel label {
    color: #415064;
    display: grid;
    font-weight: 700;
    gap: 0.35rem;
}

.auth-panel input {
    border: 1px solid #b8c3d3;
    border-radius: 6px;
    min-height: 2.5rem;
    padding: 0.45rem 0.6rem;
}

.auth-panel .check-row {
    align-items: center;
    display: flex;
}

.recruitment-grid {
    grid-template-columns: repeat(auto-fit, minmax(20rem, 1fr));
}

.job-card {
    align-content: start;
    display: grid;
    gap: 0.75rem;
}

.job-card.full {
    background: #f8fafc;
}

.job-card-head {
    align-items: flex-start;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    min-width: 0;
}

.job-card-head h2 {
    line-height: 1.35;
}

.job-card p,
.message-bubble p {
    color: #415064;
    margin: 0;
}

.application-status {
    color: #166534;
    font-weight: 800;
}

.job-meta {
    background: #eef4ff;
    border: 1px solid #d8e5ff;
    border-radius: 6px;
    color: #314158;
    font-size: 0.9rem;
    font-weight: 700;
    padding: 0.5rem 0.65rem;
}

.job-detail-grid {
    margin-bottom: 1.5rem;
}

.auth-panel.wide-form {
    max-width: 54rem;
}

.auth-panel textarea,
.wide-form textarea {
    border: 1px solid #b8c3d3;
    border-radius: 6px;
    min-height: 9rem;
    padding: 0.6rem;
    resize: vertical;
    width: 100%;
}

.auth-panel input,
.auth-panel textarea,
.wide-form textarea {
    width: 100%;
}

.auth-panel .check-row input {
    width: auto;
}

.message-thread {
    margin-bottom: 1rem;
    max-width: 58rem;
}

.message-bubble {
    display: grid;
    gap: 0.5rem;
}

.message-bubble.admin {
    border-left: 5px solid #1f6feb;
}

.message-bubble.candidate {
    border-left: 5px solid #f3b43f;
}

.message-bubble div {
    align-items: baseline;
    display: flex;
    gap: 0.75rem;
    justify-content: space-between;
    min-width: 0;
}

.message-bubble span {
    color: #6b7a90;
    font-size: 0.85rem;
}

.admin-table-wrap {
    background: #fff;
    border: 1px solid #d8dee8;
    border-radius: 8px;
    overflow-x: auto;
}

.admin-table {
    border-collapse: collapse;
    min-width: 58rem;
    width: 100%;
}

.admin-table caption {
    color: #415064;
    font-weight: 800;
    padding: 0.85rem;
    text-align: left;
}

.admin-table th,
.admin-table td {
    border-bottom: 1px solid #e2e8f0;
    padding: 0.85rem;
    text-align: left;
    vertical-align: top;
}

.admin-table th {
    background: #f8fafc;
    color: #415064;
    font-size: 0.78rem;
    text-transform: uppercase;
}

.admin-table td small {
    color: #6b7a90;
    display: block;
    font-size: 0.78rem;
    margin-top: 0.25rem;
    overflow-wrap: anywhere;
}

.role-chip {
    background: #eef4ff;
    border: 1px solid #d8e5ff;
    border-radius: 999px;
    color: #314158;
    display: inline-flex;
    font-size: 0.78rem;
    font-weight: 800;
    margin: 0 0.35rem 0.35rem 0;
    padding: 0.25rem 0.55rem;
}

.role-chip.neutral {
    background: #f1f5f9;
    border-color: #e2e8f0;
    color: #64748b;
}

.role-toggle {
    align-items: center;
    color: #314158;
    display: flex;
    font-weight: 700;
    gap: 0.45rem;
    margin-bottom: 0.45rem;
}

.role-toggle input {
    height: 1rem;
    width: 1rem;
}

.recruitment-actions {
    margin-bottom: 1rem;
}

.action-link.danger {
    border-color: #991b1b;
    color: #991b1b;
}

.markdown-document {
    background: #fff;
    border: 1px solid #d8dee8;
    border-radius: 8px;
    color: #1f2937;
    overflow: auto;
    padding: 1rem;
    white-space: pre-wrap;
}

.editor-panel {
    display: grid;
    gap: 1rem;
}

.editor-panel textarea {
    border: 1px solid #b8c3d3;
    border-radius: 8px;
    font-family: Consolas, "Liberation Mono", monospace;
    min-height: 58vh;
    padding: 1rem;
    resize: vertical;
    width: 100%;
}

@media (max-width: 900px) {
    .game-hero {
        grid-template-columns: 1fr;
    }

    .hero-media {
        min-height: 13rem;
    }

    .element-showcase {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 720px) {
    .project-shell,
    .status-header,
    .doc-row,
    .priority-row {
        display: block;
    }

    .quick-actions,
    .hero-actions,
    .status-header .refresh-button {
        margin-top: 1rem;
    }

    .element-showcase {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        margin-top: 1.25rem;
    }

    .dashboard-panel.wide {
        grid-column: span 1;
    }

    .chart-panel.wide {
        grid-column: span 1;
    }

    .bar-row {
        grid-template-columns: 1fr;
    }

    .bar-row strong {
        text-align: left;
    }

    .architecture-grid {
        grid-template-columns: 1fr;
    }

    .architecture-heading {
        display: block;
    }

    .button-row,
    .editor-actions,
    .hero-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .action-link,
    .refresh-button,
    .text-link {
        justify-content: center;
        width: 100%;
    }
}

@media (max-width: 420px) {
    .element-showcase,
    .summary-strip,
    .work-grid,
    .status-grid,
    .dashboard-grid,
    .visual-dashboard,
    .player-flow,
    .section-progress-grid,
    .architecture-grid,
    .recruitment-grid,
    .job-detail-grid {
        grid-template-columns: 1fr;
    }
}

h1:focus {
    outline: none;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.validation-message {
    color: #e50000;
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
    color: var(--bs-secondary-color);
    text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
    text-align: start;
}
