:root {
    --brand-burgundy: #87374f;
    --brand-burgundy-bright: #a54763;
    --brand-blue: #1f6899;
    --brand-blue-bright: #2d88c2;
    --brand-blue-soft: #74b0d5;
    --color-text-on-dark: #f5f7fb;
    --color-text-muted-on-dark: #afbfd4;
    --color-ink: #162236;
    --color-ink-soft: #5f708a;
    --color-surface-light: #f6f8fc;
    --color-surface-dark: #071019;
}

html, body {
    font-family: 'Manrope', sans-serif;
    color: var(--mud-palette-text-primary, #162236);
    background: var(--mud-palette-background, #f3f6fb);
}

html {
    scroll-behavior: smooth;
}

body {
    min-height: 100vh;
    margin: 0;
}

a, .btn-link {
    color: var(--brand-blue-soft);
    transition: transform 120ms ease, opacity 120ms ease, color 120ms ease, background 120ms ease;
}

a:hover, .btn-link:hover {
    opacity: 0.96;
}

button,
input,
textarea,
select {
    font: inherit;
}

.form-control:focus {
    outline: none;
    border-color: rgba(116, 176, 213, 0.8);
    box-shadow: 0 0 0 0.18rem rgba(116, 176, 213, 0.18);
}

h1:focus {
    outline: none;
}

p {
    line-height: 1.6;
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeGxpbmxucz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgb3ZlcmZsb3c9ImhpZGRlbiI+PGRlZnM+PGNsaXBQYXRoIGlkPSJjbGlwMCI+PHJlY3QgeD0iMjM1IiB5PSI1MSIgd2lkdGg9IjU2IiBoZWlnaHQ9IjQ5Ii8+PC9jbGlwUGF0aD48L2RlZnM+PGcgY2xpcC1wYXRoPSJ1cmwoI2NsaXAwKSIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTIzNSAtNTEpIj48cGF0aCBkPSJNMjYzLjUwNiA1MUMyNjQuNzE3IDUxIDI2NS44MTMgNTEuNDgzNyAyNjYuNjA2IDUyLjI2NThMMjY3LjA1MiA1Mi43OTg3IDI2Ny41MzkgNTMuNjI4MyAyOTAuMTg1IDkyLjE4MzEgMjkwLjU0NSA5Mi43OTUgMjkwLjY1NiA5Mi45OTZDMjkwLjg3NyA5My41MTMgMjkxIDk0LjA4MTUgMjkxIDk0LjY3ODIgMjkxIDk3LjA2NTEgMjg5LjAzOCA5OSAyODYuNjE3IDk5TDI0MC4zODMgOTlDMjM3Ljk2MyA5OSAyMzYgOTcuMDY1MSAyMzYgOTQuNjc4MiAyMzYgOTQuMzc5OSAyMzYuMDMxIDk0LjA4ODYgMjM2LjA4OSA5My44MDcyTDIzNi4zMzggOTMuMDE2MiAyMzYuODU4IDkyLjEzMTQgMjU5LjQ3MyA1My42Mjk0IDI1OS45NjEgNTIuNzk4NSAyNjAuNDA3IDUyLjI2NThDMjYxLjIgNTEuNDgzNyAyNjIuMjk2IDUxIDI2My41MDYgNTFaTTI2My41ODYgNjYuMDE4M0MyNjAuNzM3IDY2LjAxODMgMjU5LjMxMyA2Ny4xMjQ1IDI1OS4zMTMgNjkuMzM3IDI1OS4zMTMgNjkuNjEwMiAyNTkuMzMyIDY5Ljg2MDggMjU5LjM3MSA3MC4wODg3TDI2MS43OTUgODQuMDE2MSAyNjUuMzggODQuMDE2MSAyNjcuODIxIDY5Ljc0NzVDMjY3Ljg2IDY5LjczMDkgMjY3Ljg3OSA2OS41ODc3IDI2Ny44NzkgNjkuMzE3OSAyNjcuODc5IDY3LjExODIgMjY2LjQ0OCA2Ni4wMTgzIDI2My41ODYgNjYuMDE4M1pNMjYzLjU3NiA4Ni4wNTQ3QzI2MS4wNDkgODYuMDU0NyAyNTkuNzg2IDg3LjMwMDUgMjU5Ljc4NiA4OS43OTIxIDI1OS43ODYgOTIuMjgzNyAyNjEuMDQ5IDkzLjUyOTUgMjYzLjU3NiA5My41Mjk1IDI2Ni4xMTYgOTMuNTI5NSAyNjcuMzg3IDkyLjI4MzcgMjY3LjM4NyA4OS43OTIxIDI2Ny4zODcgODcuMzAwNSAyNjYuMTE2IDg2LjA1NDcgMjYzLjU3NiA4Ni4wNTQ3WiIgZmlsbD0iI0ZGRTUwMCIgZmlsbC1ydWxlPSJldmVub2RkIi8+PC9nPjwvc3ZnPg==) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

.blazor-error-boundary::after {
    content: "An error has occurred.";
}

.backoffice-theme-host .sf-grid.e-grid {
    border: 1px solid var(--backoffice-syncfusion-border) !important;
    border-radius: 1rem !important;
    background: var(--backoffice-syncfusion-surface) !important;
    color: var(--backoffice-syncfusion-text) !important;
    border-color: var(--backoffice-syncfusion-border) !important;
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden;
    box-shadow: 0 18px 34px rgba(7, 16, 27, 0.12);
}

.backoffice-theme-host .sf-grid.e-grid .e-gridheader,
.backoffice-theme-host .sf-grid.e-grid .e-columnheader,
.backoffice-theme-host .sf-grid.e-grid .e-headercontent,
.backoffice-theme-host .sf-grid.e-grid .e-gridcontent,
.backoffice-theme-host .sf-grid.e-grid .e-content,
.backoffice-theme-host .sf-grid.e-grid .e-table,
.backoffice-theme-host .sf-grid.e-grid .e-gridpager,
.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer,
.backoffice-theme-host .sf-grid.e-grid .e-parentmsgbar,
.backoffice-theme-host .sf-grid.e-grid .e-pagerexternalmsg {
    background: var(--backoffice-syncfusion-surface) !important;
    color: var(--backoffice-syncfusion-text) !important;
}

.backoffice-theme-host .sf-grid.e-grid .e-headercell,
.backoffice-theme-host .sf-grid.e-grid .e-detailheadercell,
.backoffice-theme-host .sf-grid.e-grid .e-filterbarcell {
    background: var(--backoffice-syncfusion-header) !important;
    color: var(--backoffice-syncfusion-text) !important;
    border-color: var(--backoffice-syncfusion-border) !important;
    font-weight: 800;
}

.backoffice-theme-host .sf-grid.e-grid .e-headercell .e-headertext,
.backoffice-theme-host .sf-grid.e-grid .e-filterbarcell,
.backoffice-theme-host .sf-grid.e-grid .e-rowcell,
.backoffice-theme-host .sf-grid.e-grid .e-summarycell,
.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer,
.backoffice-theme-host .sf-grid.e-grid .e-parentmsgbar,
.backoffice-theme-host .sf-grid.e-grid .e-pagerdropdown,
.backoffice-theme-host .sf-grid.e-grid .e-pagerexternalmsg,
.backoffice-theme-host .sf-grid.e-grid .e-icons {
    color: var(--backoffice-syncfusion-text) !important;
}

.backoffice-theme-host .sf-grid.e-grid .e-row,
.backoffice-theme-host .sf-grid.e-grid .e-altrow,
.backoffice-theme-host .sf-grid.e-grid .e-row .e-rowcell,
.backoffice-theme-host .sf-grid.e-grid .e-altrow .e-rowcell,
.backoffice-theme-host .sf-grid.e-grid .e-gridcontent tr,
.backoffice-theme-host .sf-grid.e-grid .e-gridcontent td {
    background: var(--backoffice-syncfusion-surface) !important;
}

.backoffice-theme-host .sf-grid.e-grid .e-rowcell,
.backoffice-theme-host .sf-grid.e-grid .e-gridpager,
.backoffice-theme-host .sf-grid.e-grid .e-summaryrow,
.backoffice-theme-host .sf-grid.e-grid .e-filterbarcell,
.backoffice-theme-host .sf-grid.e-grid .e-headercell {
    border-color: var(--backoffice-syncfusion-border) !important;
}

.backoffice-theme-host .sf-grid.e-grid .e-row:hover .e-rowcell,
.backoffice-theme-host .sf-grid.e-grid .e-altrow:hover .e-rowcell {
    background: var(--backoffice-syncfusion-row-hover) !important;
}

.backoffice-theme-host .sf-grid.e-grid .e-gridpager {
    border-top: 1px solid var(--backoffice-syncfusion-border) !important;
}

.backoffice-theme-host .sf-grid.e-grid .e-gridpager,
.backoffice-theme-host .sf-grid.e-grid .sf-pager.e-pager,
.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer,
.backoffice-theme-host .sf-grid.e-grid .e-parentmsgbar,
.backoffice-theme-host .sf-grid.e-grid .e-numericcontainer {
    background: var(--backoffice-syncfusion-surface) !important;
}

.backoffice-theme-host .sf-grid.e-grid .e-parentmsgbar,
.backoffice-theme-host .sf-grid.e-grid .e-parentmsgbar span,
.backoffice-theme-host .sf-grid.e-grid .e-pagenomsg,
.backoffice-theme-host .sf-grid.e-grid .e-pagecountmsg {
    color: var(--backoffice-syncfusion-muted) !important;
}

.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer .e-link,
.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer .e-first,
.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer .e-prev,
.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer .e-next,
.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer .e-last,
.backoffice-theme-host .sf-grid.e-grid .e-mfirst,
.backoffice-theme-host .sf-grid.e-grid .e-mprev,
.backoffice-theme-host .sf-grid.e-grid .e-mnext,
.backoffice-theme-host .sf-grid.e-grid .e-mlast {
    color: var(--backoffice-syncfusion-muted) !important;
    background: transparent !important;
    border-color: transparent !important;
    box-shadow: none !important;
    border-radius: 0.75rem;
}

.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer .e-link:hover,
.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer .e-first:hover,
.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer .e-prev:hover,
.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer .e-next:hover,
.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer .e-last:hover,
.backoffice-theme-host .sf-grid.e-grid .e-mfirst:hover,
.backoffice-theme-host .sf-grid.e-grid .e-mprev:hover,
.backoffice-theme-host .sf-grid.e-grid .e-mnext:hover,
.backoffice-theme-host .sf-grid.e-grid .e-mlast:hover {
    background: var(--backoffice-syncfusion-accent-soft) !important;
    color: var(--backoffice-syncfusion-accent) !important;
}

.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer .e-link.e-disable,
.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer .e-first.e-disable,
.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer .e-prev.e-disable,
.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer .e-next.e-disable,
.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer .e-last.e-disable,
.backoffice-theme-host .sf-grid.e-grid .e-mfirst.e-disable,
.backoffice-theme-host .sf-grid.e-grid .e-mprev.e-disable,
.backoffice-theme-host .sf-grid.e-grid .e-mnext.e-disable,
.backoffice-theme-host .sf-grid.e-grid .e-mlast.e-disable {
    opacity: 0.5;
    background: transparent !important;
    color: var(--backoffice-syncfusion-muted) !important;
}

.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer .e-currentitem,
.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer .e-currentitem.e-active,
.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer .e-currentitem:hover,
.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer .e-currentitem:focus,
.backoffice-theme-host .sf-grid.e-grid .e-pagercontainer .e-currentitem:focus-visible {
    background: color-mix(in srgb, var(--backoffice-syncfusion-accent) 22%, var(--backoffice-syncfusion-surface)) !important;
    color: var(--backoffice-syncfusion-text) !important;
    border: 1px solid color-mix(in srgb, var(--backoffice-syncfusion-accent) 72%, white 8%) !important;
    border-radius: 0.9rem !important;
    font-weight: 800;
    box-shadow: none !important;
    outline: none !important;
    text-decoration: none !important;
}

.backoffice-theme-host .sf-grid.e-grid .e-filterbarcell {
    background: var(--backoffice-syncfusion-header) !important;
    color: var(--backoffice-syncfusion-text) !important;
    border-color: var(--backoffice-syncfusion-border) !important;
    padding: 0.35rem !important;
}

.backoffice-theme-host .sf-grid.e-grid .e-filterbarcell .e-filterdiv,
.backoffice-theme-host .sf-grid.e-grid .e-filterbarcell .e-fltrinputdiv {
    background: transparent !important;
    padding: 0 !important;
}

.backoffice-theme-host .sf-grid.e-grid .e-filterbarcell .e-input-group,
.backoffice-theme-host .sf-grid.e-grid .e-filterbarcell .e-input-group.e-control-wrapper {
    background: var(--backoffice-syncfusion-input-background) !important;
    border: 1px solid var(--backoffice-syncfusion-input-border) !important;
    border-color: var(--backoffice-syncfusion-input-border) !important;
    border-radius: 0.85rem !important;
    box-shadow: none !important;
}

.backoffice-theme-host .sf-grid.e-grid .e-filterbarcell .e-input-group:focus-within,
.backoffice-theme-host .sf-grid.e-grid .e-filterbarcell .e-input-group.e-control-wrapper:focus-within {
    border-color: var(--backoffice-syncfusion-accent) !important;
    box-shadow: 0 0 0 2px var(--backoffice-syncfusion-accent-soft) !important;
}

.backoffice-theme-host .sf-grid.e-grid .e-filterbarcell input,
.backoffice-theme-host .sf-grid.e-grid .e-filterbarcell input::placeholder {
    color: var(--backoffice-syncfusion-muted) !important;
}

.backoffice-theme-host .sf-grid.e-grid .e-filterbarcell input {
    background: transparent !important;
    color: var(--backoffice-syncfusion-text) !important;
    padding: 0.55rem 0.85rem !important;
    border: none !important;
    box-shadow: none !important;
    border-radius: 0;
}

.backoffice-theme-host .sf-grid.e-grid .e-filterbarcell .e-clear-icon {
    background: transparent !important;
    color: var(--backoffice-syncfusion-muted) !important;
    border-left: 1px solid var(--backoffice-syncfusion-input-border);
}

.dashboard-state,
.dashboard-empty {
    min-height: 18rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    text-align: center;
}

.dashboard-actions-cell {
    width: 13rem;
    text-align: right;
    white-space: nowrap;
}

.dashboard-dialog-shell {
    display: grid;
    gap: 1rem;
    min-width: min(32rem, 80vw);
}

.dashboard-dialog-tab-panel {
    padding: 1rem 0 0;
}

.dashboard-view-shell {
    display: grid;
    gap: 1.25rem;
}

.dashboard-view-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.dashboard-view-kicker {
    display: block;
    color: var(--mud-palette-primary);
    font-size: 0.8rem;
    font-weight: 800;
    text-transform: uppercase;
}

.dashboard-view-header h1 {
    margin: 0.15rem 0 0.25rem;
    font-size: clamp(1.8rem, 3vw, 2.8rem);
}

.dashboard-view-header p {
    margin: 0;
    color: color-mix(in srgb, currentColor 72%, transparent);
}

.dashboard-view-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.5rem;
}

.dashboard-filter-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
}

.dashboard-filter-dialog {
    height: min(70vh, 42rem);
    width: 100%;
    display: flex;
    overflow: hidden;
    background: var(--mud-palette-background-grey);
}

.dashboard-filter-dialog-nav {
    width: 14rem;
    flex: 0 0 14rem;
    border-right: 1px solid var(--mud-palette-divider);
    overflow-y: auto;
    background: var(--mud-palette-background);
    padding: 0.5rem 0;
}

.dashboard-filter-dialog-content {
    flex: 1 1 auto;
    min-width: 0;
    overflow-y: auto;
    background: var(--mud-palette-background);
    padding: 1rem;
}

.dashboard-visual-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.dashboard-visual-layout {
    min-height: 28rem;
}

.dashboard-visual-layout .e-panel-container {
    height: 100%;
}

.dashboard-visual-layout .e-panel {
    border: 0;
    background: transparent;
    box-shadow: none;
}

.dashboard-visual-layout-editable .e-panel {
    outline: 1px dashed color-mix(in srgb, var(--mud-palette-primary) 30%, transparent);
    outline-offset: -2px;
}

.dashboard-visual {
    min-height: 18rem;
    height: 100%;
    display: flex;
    flex-direction: column;
    border: 1px solid color-mix(in srgb, var(--dashboard-accent) 24%, transparent);
    border-radius: 8px;
    padding: 1rem;
    background: color-mix(in srgb, var(--dashboard-accent) 7%, var(--mud-palette-surface));
    overflow: hidden;
}

.dashboard-chart-host {
    min-width: 0;
    width: 100%;
    flex: 1 1 auto;
}

.dashboard-visual-card {
    grid-column: span 1;
}

.dashboard-visual-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.dashboard-visual-header span {
    color: var(--dashboard-accent);
    font-size: 0.75rem;
    font-weight: 800;
    text-transform: uppercase;
}

.dashboard-visual-header h2 {
    margin: 0.15rem 0 0;
    font-size: 1.05rem;
}

.dashboard-visual-header strong {
    color: var(--dashboard-accent);
    font-size: 1.6rem;
}

.dashboard-visual-actions {
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.dashboard-visual-loading {
    min-height: 11rem;
    display: grid;
    place-items: center;
}

.dashboard-card-figure {
    height: 11rem;
    display: grid;
    align-content: center;
    justify-items: center;
    gap: 0.35rem;
}

.dashboard-card-figure span {
    color: var(--dashboard-accent);
    font-size: 3rem;
    font-weight: 800;
}

.dashboard-card-figure small,
.dashboard-bar-column small {
    color: color-mix(in srgb, currentColor 62%, transparent);
}

.dashboard-bar-chart {
    height: 12rem;
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 1fr;
    align-items: end;
    gap: 0.75rem;
    padding-top: 1rem;
}

.dashboard-bar-column {
    height: 100%;
    display: grid;
    grid-template-rows: 1fr auto;
    gap: 0.5rem;
    align-items: end;
    text-align: center;
}

.dashboard-bar-column span {
    display: block;
    min-height: 0.5rem;
    border-radius: 0.45rem 0.45rem 0 0;
    background: var(--dashboard-accent);
}

.dashboard-line-chart {
    width: 100%;
    height: 12rem;
    margin-top: 1rem;
}

.dashboard-line-chart polyline {
    fill: none;
    stroke: var(--dashboard-accent);
    stroke-width: 6;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.dashboard-pie-chart {
    width: min(12rem, 80%);
    aspect-ratio: 1;
    border-radius: 50%;
    margin: 1.25rem auto 0;
    box-shadow: inset 0 0 0 1rem color-mix(in srgb, var(--mud-palette-surface) 96%, transparent);
}

.dashboard-pie-legend {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.45rem 0.75rem;
    margin-top: 1rem;
    color: color-mix(in srgb, currentColor 65%, transparent);
    font-size: 0.8rem;
}

@media (max-width: 900px) {
    .dashboard-filter-bar,
    .dashboard-visual-grid {
        grid-template-columns: 1fr;
    }

    .dashboard-view-header {
        flex-direction: column;
    }

    .dashboard-view-actions {
        justify-content: flex-start;
    }
}
