html, body {
    font-family: 'Open Sans', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
}

.sidebar {
    color: #FFFFFF;
}

a, .btn-link {
    color: #006bb7;
}

.cb-paper-content {
    padding: 20px;
}

.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 {
    box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #2C5F2D;
}

.content {
    padding-top: 1.1rem;
}

h1:focus {
    outline: none;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.form-control:focus {
    border-color: #2C5F2D !important;
}

.mud-paper > :not(:last-child),
.mud-form > :not(:last-child) {
    margin-bottom: 8px;
}

.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;
}

.balance-report-header-style:has(.balance-report-header-group) {
    background-color: var(--mud-palette-background-gray);
}

.chip-with-progress {
    position: absolute;
    top: 3px;
    left: calc(50% - 50px);
}

.mud-nav-item {
    width: auto !important;
}

.mud-navmenu-secondary {
    gap: 3px;
}

.mud-nav-link-text {
    margin-left: 0px !important;
    margin-inline-start: 0px !important;
}

.invoice-items-toolbar-hack .mud-table-toolbar {
    height: auto;
}

/* ==========================================
   QUBOO DESIGN SYSTEM - Gradient Styles
   ========================================== */

/* ACCESSIBILITY - KEYBOARD FOCUS STATES
   All buttons have clear focus indicators for keyboard navigation.
   Uses :focus-visible to show focus only on keyboard interaction.
   WCAG 2.2 compliant:
   - 4px underline in matching color (e.g., green for primary buttons)
   - Minimum 3:1 contrast ratio against background
   - Works in both light and dark mode
   - Subtle and elegant - focus indicator doesn't overwhelm the design
*/

/* Icon sizing */
.mud-nav-link svg,
.mud-icon-button svg,
.mud-button svg {
    width: 24px;
    height: 24px;
    max-width: 24px;
    max-height: 24px;
}

/* Gradient Buttons - Primary */
.mud-button-filled.mud-button-filled-primary {
    background: linear-gradient(135deg, #3D7A3E 0%, #2C5F2D 50%, #234A24 100%) !important;
    box-shadow: 0 2px 8px rgba(44, 95, 45, 0.3), inset 0 1px 0 rgba(255,255,255,0.15);
    transition: all 0.2s ease;
}
.mud-button-filled.mud-button-filled-primary:hover {
    background: linear-gradient(135deg, #4A8F4B 0%, #3D7A3E 50%, #2C5F2D 100%) !important;
    box-shadow: 0 4px 12px rgba(44, 95, 45, 0.4), inset 0 1px 0 rgba(255,255,255,0.2);
    transform: translateY(-1px);
}
.mud-button-filled.mud-button-filled-primary:active {
    background: linear-gradient(135deg, #234A24 0%, #2C5F2D 100%) !important;
    transform: translateY(0);
}
.mud-button-filled.mud-button-filled-primary:focus-visible {
    outline: none;
    box-shadow: 0 2px 8px rgba(44, 95, 45, 0.3),
                inset 0 1px 0 rgba(255,255,255,0.15),
                0 4px 0 0 #4ADE80 !important;
}

/* Gradient Buttons - Secondary */
.mud-button-filled.mud-button-filled-secondary {
    background: linear-gradient(135deg, #5A6B7A 0%, #475569 50%, #374151 100%) !important;
    box-shadow: 0 2px 8px rgba(71, 85, 105, 0.3), inset 0 1px 0 rgba(255,255,255,0.1);
    transition: all 0.2s ease;
}
.mud-button-filled.mud-button-filled-secondary:hover {
    background: linear-gradient(135deg, #6B7D8E 0%, #5A6B7A 50%, #475569 100%) !important;
    box-shadow: 0 4px 12px rgba(71, 85, 105, 0.4), inset 0 1px 0 rgba(255,255,255,0.15);
    transform: translateY(-1px);
}
.mud-button-filled.mud-button-filled-secondary:focus-visible {
    outline: none;
    box-shadow: 0 2px 8px rgba(71, 85, 105, 0.3),
                inset 0 1px 0 rgba(255,255,255,0.1),
                0 4px 0 0 #94A3B8 !important;
}

/* Gradient Buttons - Error/Danger */
.mud-button-filled.mud-button-filled-error {
    background: linear-gradient(135deg, #EF4444 0%, #DC2626 50%, #B91C1C 100%) !important;
    box-shadow: 0 2px 8px rgba(220, 38, 38, 0.3), inset 0 1px 0 rgba(255,255,255,0.15);
    transition: all 0.2s ease;
}
.mud-button-filled.mud-button-filled-error:hover {
    background: linear-gradient(135deg, #F87171 0%, #EF4444 50%, #DC2626 100%) !important;
    box-shadow: 0 4px 12px rgba(220, 38, 38, 0.4), inset 0 1px 0 rgba(255,255,255,0.2);
    transform: translateY(-1px);
}
.mud-button-filled.mud-button-filled-error:focus-visible {
    outline: none;
    box-shadow: 0 2px 8px rgba(220, 38, 38, 0.3),
                inset 0 1px 0 rgba(255,255,255,0.15),
                0 4px 0 0 #FCA5A5 !important;
}

/* Gradient Cards & Papers */
.mud-paper {
    transition: all 0.2s ease;
}
.mud-paper.mud-elevation-2 {
    background: linear-gradient(145deg, #FFFFFF 0%, #FAFAF9 100%);
    box-shadow: 0 2px 8px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
}
.mud-paper.mud-elevation-2:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,0.08), 0 2px 4px rgba(0,0,0,0.04);
}

/* Gradient Table Headers */
.mud-table-head {
    background: linear-gradient(180deg, #F5F5F4 0%, #E7E5E4 100%);
}
.mud-table-head th {
    font-weight: 600 !important;
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 0.05em;
}

/* Outlined Buttons with Gradient Border */
.mud-button-outlined.mud-button-outlined-primary {
    border: 2px solid transparent;
    background: linear-gradient(white, white) padding-box,
                linear-gradient(135deg, #3D7A3E, #2C5F2D) border-box;
    transition: all 0.2s ease;
}
.mud-button-outlined.mud-button-outlined-primary:hover {
    background: linear-gradient(#F0FDF4, #DCFCE7) padding-box,
                linear-gradient(135deg, #4A8F4B, #3D7A3E) border-box;
}
.mud-button-outlined.mud-button-outlined-primary:focus-visible {
    outline: none;
    box-shadow: 0 4px 0 0 #2C5F2D !important;
}

/* Gradient Tooltips */
.mud-tooltip {
    background: linear-gradient(135deg, #1C1917 0%, #292524 100%) !important;
}

/* Theme Background */
.mud-theme-background {
    background: linear-gradient(180deg, #FAFAF9 0%, #F5F5F4 100%);
}

/* ==========================================
   DARK MODE STYLES
   ========================================== */

/* Dark mode body background */
body.dark-mode {
    background: #0C0A09 !important;
}

/* Dark mode page container */
body.dark-mode .page {
    background-color: #0C0A09;
}

/* Dark mode sidebar */
body.dark-mode .sidebar {
    background-color: #1A3D1B;
    background-image: linear-gradient(180deg, #1A3D1B 0%, #0F2810 100%);
}

/* Dark mode main content */
body.dark-mode main {
    background: linear-gradient(180deg, #0C0A09 0%, #141211 100%);
}

/* Dark mode top-row */
body.dark-mode .top-row {
    background-color: #1C1917;
    border-bottom-color: #292524;
}

/* Dark mode cards and papers */
body.dark-mode .mud-paper,
body.dark-mode .mud-paper.mud-elevation-0,
body.dark-mode .mud-paper.mud-elevation-1,
body.dark-mode .mud-paper.mud-elevation-2,
body.dark-mode .mud-paper.mud-elevation-3,
body.dark-mode .mud-paper.mud-elevation-4 {
    background: linear-gradient(145deg, #1C1917 0%, #141211 100%) !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.03) !important;
    color: #FAFAF9 !important;
}

/* Dark mode tables */
body.dark-mode .mud-table,
body.dark-mode .mud-table-container,
body.dark-mode .mud-table-root {
    background: linear-gradient(145deg, #1C1917 0%, #141211 100%) !important;
}
body.dark-mode .mud-table-body .mud-table-row {
    background: transparent !important;
}
body.dark-mode .mud-table-body .mud-table-row:hover {
    background: rgba(74, 222, 128, 0.1) !important;
}
body.dark-mode .mud-table-cell {
    border-bottom-color: #292524 !important;
    color: #FAFAF9 !important;
}
body.dark-mode .mud-table-head {
    background: linear-gradient(180deg, #292524 0%, #1C1917 100%) !important;
}
body.dark-mode .mud-table-head th {
    color: #A8A29E !important;
}

/* Dark mode inputs */
body.dark-mode .mud-input-slot,
body.dark-mode .mud-input-control-input-container,
body.dark-mode .mud-input {
    background: #1C1917 !important;
    color: #FAFAF9 !important;
}
body.dark-mode .mud-input-outlined .mud-input-outlined-border {
    border-color: #292524 !important;
}

/* Dark mode toolbar */
body.dark-mode .mud-toolbar {
    background: linear-gradient(180deg, #1C1917 0%, #141211 100%) !important;
    color: #FAFAF9 !important;
}

/* Dark mode text */
body.dark-mode .mud-typography {
    color: #FAFAF9 !important;
}
body.dark-mode .mud-text-secondary {
    color: #A8A29E !important;
}

/* Dark mode dividers */
body.dark-mode .mud-divider {
    border-color: #292524 !important;
}

/* Dark mode filled buttons - focus states */
body.dark-mode .mud-button-filled.mud-button-filled-primary:focus-visible {
    outline: none;
    box-shadow: 0 2px 8px rgba(74, 222, 128, 0.4),
                inset 0 1px 0 rgba(255,255,255,0.15),
                0 4px 0 0 #86EFAC !important;
}
body.dark-mode .mud-button-filled.mud-button-filled-secondary:focus-visible {
    outline: none;
    box-shadow: 0 2px 8px rgba(148, 163, 184, 0.3),
                inset 0 1px 0 rgba(255,255,255,0.1),
                0 4px 0 0 #CBD5E1 !important;
}
body.dark-mode .mud-button-filled.mud-button-filled-error:focus-visible {
    outline: none;
    box-shadow: 0 2px 8px rgba(248, 113, 113, 0.3),
                inset 0 1px 0 rgba(255,255,255,0.15),
                0 4px 0 0 #FCA5A5 !important;
}

/* Dark mode outlined buttons */
body.dark-mode .mud-button-outlined.mud-button-outlined-primary {
    background: #1C1917 !important;
    border: 2px solid #4ADE80 !important;
}
body.dark-mode .mud-button-outlined.mud-button-outlined-primary:hover {
    background: #1A3D1B !important;
    border: 2px solid #86EFAC !important;
}
body.dark-mode .mud-button-outlined.mud-button-outlined-primary:focus-visible {
    outline: none;
    box-shadow: 0 4px 0 0 #86EFAC !important;
}
body.dark-mode .mud-button-outlined.mud-button-outlined-secondary {
    background: #1C1917 !important;
    border: 2px solid #64748B !important;
}
body.dark-mode .mud-button-outlined.mud-button-outlined-secondary:hover {
    background: #292524 !important;
    border: 2px solid #94A3B8 !important;
}
body.dark-mode .mud-button-outlined.mud-button-outlined-secondary:focus-visible {
    outline: none;
    box-shadow: 0 4px 0 0 #CBD5E1 !important;
}

/* Dark mode theme background */
body.dark-mode .mud-theme-background {
    background: linear-gradient(180deg, #0C0A09 0%, #171412 100%) !important;
}

/* ==========================================
   FIGURE STYLES - For illustrations/icons
   ========================================== */

/* Report page figures */
.report-figure {
    width: 100px;
    height: 100px;
    opacity: 0.9;
    margin: 16px 0;
}

/* Empty state figures in tables */
.empty-state-figure {
    width: 80px;
    height: 80px;
    opacity: 0.8;
}