@font-face {
    font-family: "Inter";
    src: url("/fonts/Inter/Inter-VariableFont_opsz_wght.ttf") format("truetype");
    font-weight: 100 900;
    font-stretch: 75% 125%;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("/fonts/Inter/Inter-Italic-VariableFont_opsz_wght.ttf") format("truetype");
    font-weight: 100 900;
    font-stretch: 75% 125%;
    font-style: italic;
    font-display: swap;
}

:root {
    --rz-text-font-family: "Inter", system-ui, sans-serif;
    --rz-primary-light: color-mix(in srgb, var(--rz-primary) 85%, white);
    --rz-primary-lighter: color-mix(in srgb, var(--rz-primary) 70%, white);
    --rz-primary-dark: color-mix(in srgb, var(--rz-primary) 85%, black);
    --rz-primary-darker: color-mix(in srgb, var(--rz-primary) 70%, black);
    --rz-on-primary-lighter: var(--rz-on-primary);
    --rz-on-primary-light: var(--rz-on-primary);
    --rz-secondary-light: color-mix(in srgb, var(--rz-secondary) 85%, white);
    --rz-secondary-lighter: color-mix(in srgb, var(--rz-secondary) 70%, white);
    --rz-secondary-dark: color-mix(in srgb, var(--rz-secondary) 85%, black);
    --rz-secondary-darker: color-mix(in srgb, var(--rz-secondary) 70%, black);
    --rz-primary-darker: color-mix(in srgb, var(--rz-primary) 70%, black);
    --rz-on-secondary-lighter: var(--rz-on-primary);
    --rz-on-secondary-light: var(--rz-on-primary);
    --rz-selectbar-selected-background-color: var(--rz-primary);
    --rz-selectbar-selected-color: var(--rz-on-primary);
    --rz-tabs-tab-hover-background-color: #dbd7d752;
    --rz-dialog-zindex: 100020;
    --rz-dialog-mask-zindex: 100000;
    --rz-dropdown-item-selected-color: var(--rz-primary);
    --rz-dropdown-item-selected-hover-color: var(--rz-dropdown-item-selected-color);
    --rz-dropdown-item-selected-background-color: color-mix(in srgb, var(--rz-primary), transparent 75%);
    --rz-dropdown-item-selected-hover-background-color: var(--rz-dropdown-item-selected-background-color);
    --rz-pager-numeric-button-selected-color: var(--rz-primary);
    --rz-pager-numeric-button-selected-background-color: color-mix(in srgb, var(--rz-primary), transparent 75%);
    --rz-switch-checked-circle-background-color: var(--rz-primary);
    --rz-switch-checked-background-color: color-mix(in srgb, var(--rz-primary), transparent 75%);
    --rz-checkbox-checked-hover-background-color: var(--rz-primary);
    --rz-border-radius: 1rem;
    --bs-card-border-radius: 1rem;
    --rz-tabs-padding: 0.5rem;
    --rz-tabs-tab-text-transform: none;
    --rz-input-min-height: 40px;
    --rz-grid-stripe-background-color: color-mix(in srgb, var(--rz-grid-stripe-odd-background-color) 60%, rgb(240, 242, 245));
    --rz-grid-hover-background-color: color-mix(in srgb, var(--rz-grid-stripe-odd-background-color) 60%, rgb(215, 215, 215));
    --rz-form-field-helper-padding: 0;
    --rz-card-shadow: 0 1px 6px -1px rgba(0, 0, 0, 0.1), 0 1px 4px -1px rgba(0, 0, 0, 0.06) !important;
    --rz-button-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06) !important;
    --rz-button-hover-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.14), 0 2px 4px -1px rgba(0, 0, 0, 0.1);
    --rz-button-active-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.18), 0 2px 4px -1px rgba(0, 0, 0, 0.12);
    --rz-pager-summary-color: var(--rz-text-color);
    --rz-dropdown-item-hover-background-color: #f5f5f573;
    --rz-dropdown-item-hover-color: var(--rz-text-color);
    --rz-border-normal: var(--rz-border-width) solid var(--rz-border-color);
    --rz-grid-detail-template-background-color: transparent;
    --rz-pager-numeric-button-hover-background-color: #f5f5f521;
    --rz-grid-cell-font-size: 0.825rem;
    --rz-grid-header-font-size: 0.825rem;
    --rz-grid-filter-font-size: 0.825rem;
    --embedpdf-accent-primary: var(--rz-primary);
    --embedpdf-accent-primary-hover: color-mix(in srgb, var(--rz-primary) 85%, black);
    --embedpdf-accent-primary-active: color-mix(in srgb, var(--rz-primary) 70%, black);
    --embedpdf-accent-primary-light: color-mix(in srgb, var(--rz-primary) 18%, white);
    --embedpdf-accent-primary-foreground: var(--rz-on-primary);
    --embedpdf-background-app: var(--rz-layout-body-background-color);
    --embedpdf-background-surface: var(--rz-base-background-color);
    --embedpdf-background-surface-alt: var(--rz-base-100);
    --embedpdf-background-elevated: var(--rz-card-background-color);
    --embedpdf-background-overlay: rgba(0, 0, 0, 0.45);
    --embedpdf-background-input: var(--rz-base-background-color);
    --embedpdf-foreground-primary: var(--rz-text-color);
    --embedpdf-foreground-secondary: var(--rz-text-secondary-color);
    --embedpdf-foreground-muted: var(--rz-text-tertiary-color);
    --embedpdf-foreground-disabled: color-mix(in srgb, var(--rz-text-color) 45%, transparent);
    --embedpdf-foreground-on-accent: var(--rz-on-primary);
    --embedpdf-interactive-hover: color-mix(in srgb, var(--rz-primary) 10%, transparent);
    --embedpdf-interactive-active: color-mix(in srgb, var(--rz-primary) 16%, transparent);
    --embedpdf-interactive-selected: color-mix(in srgb, var(--rz-primary) 20%, white);
    --embedpdf-interactive-focus: var(--rz-primary);
    --embedpdf-border-default: var(--rz-border-color);
    --embedpdf-border-subtle: color-mix(in srgb, var(--rz-border-color) 55%, transparent);
    --embedpdf-border-strong: color-mix(in srgb, var(--rz-border-color) 70%, black);
    --embedpdf-state-error: var(--rz-danger);
    --embedpdf-state-error-light: color-mix(in srgb, var(--rz-danger) 15%, white);
    --embedpdf-state-warning: var(--rz-warning);
    --embedpdf-state-warning-light: color-mix(in srgb, var(--rz-warning) 18%, white);
    --embedpdf-state-success: var(--rz-success);
    --embedpdf-state-success-light: color-mix(in srgb, var(--rz-success) 16%, white);
    --embedpdf-state-info: var(--rz-info);
    --embedpdf-state-info-light: color-mix(in srgb, var(--rz-info) 16%, white);
    --light-gray: #f9f9f9;
    --app-surface-raised: var(--rz-base-background-color);
    --app-surface-soft: color-mix(in srgb, var(--rz-base-background-color) 94%, var(--rz-layout-body-background-color));
    --app-surface-muted: color-mix(in srgb, var(--rz-base-background-color) 88%, var(--rz-layout-body-background-color));
    --app-surface-accent-soft: color-mix(in srgb, var(--rz-primary) 8%, var(--rz-base-background-color));
    --app-surface-accent-hover: color-mix(in srgb, var(--rz-primary) 12%, var(--rz-base-background-color));
    --app-surface-info-soft: color-mix(in srgb, var(--rz-info) 12%, var(--rz-base-background-color));
    --app-border-soft: color-mix(in srgb, var(--rz-border-color) 70%, white);
    --app-border-muted: color-mix(in srgb, var(--rz-border-color) 45%, white);
    --app-border-strong: color-mix(in srgb, var(--rz-border-color) 90%, var(--rz-text-color));
    --app-text-soft: color-mix(in srgb, var(--rz-text-color) 82%, white);
    --app-text-muted: var(--rz-text-secondary-color);
    --app-text-faint: color-mix(in srgb, var(--rz-text-secondary-color) 70%, white);
    --app-shadow-soft: 0 1px 2px rgba(0, 0, 0, 0.05);
    --app-shadow-subtle: 0 2px 4px rgba(0, 0, 0, 0.02);
    --app-shadow-card-hover: 0 8px 16px rgba(0, 0, 0, 0.05);
    --app-shadow-info: 0 2px 4px color-mix(in srgb, var(--rz-info) 24%, transparent);
    --app-shadow-info-hover: 0 4px 6px color-mix(in srgb, var(--rz-info) 32%, transparent);
}

.rz-dialog-wrapper {
    z-index: calc(var(--rz-dialog-zindex) + 1) !important;
}

.rz-popup,
.rz-overlaypanel {
    z-index: calc(var(--rz-dialog-zindex) + 2) !important;
}

img {
    user-select: none;
}

html,
body,
#app,
.main-content {
    height: 100%;
    overflow: hidden;
    font-family: var(--rz-text-font-family);
    color: var(--rz-text-color);
    background: var(--rz-layout-body-background-color);
    font-weight: 300;
}

.sidenav {
    display: flex !important;
    flex-direction: column;
    justify-content: start;
    align-items: center;
    flex-wrap: nowrap;
    box-shadow: var(--rz-card-shadow) !important;
}

#StartDate,
#EndDate {
    border: 1px solid white;
    background-color: #f7f7f7;
}


.navbar-collapse {
    margin-bottom: 2rem !important;
    flex: 1;
    padding: 0 1rem !important;
    width: 100% !important;
}

.nav-link {
    width: 100%;
    margin: 0rem !important;
}

.user-item {
    background-color: transparent !important;
}

#iconNavbarLogout {
    margin-left: auto !important;
    width: fit-content !important;
    border-radius: 0.2rem !important;
    transition: background-color 0.2s ease-in;
}

#iconNavbarLogout:hover {
    background-color: rgba(199, 199, 199, 0.2);
}

.outline-nav-item a {
    border: 1px solid #dfdfdf;
}

.outline-nav-item a.active {
    border: 0px !important;
}

.navbar-collapse {
    margin-bottom: 0rem !important;
}

.folder-img {
    filter: drop-shadow(0px 4px 6px rgba(0, 0, 0, 0.1));
    width: 150px;
    margin-top: 100px;
}

#navbar {
    padding-inline: 0rem !important;
    width: auto !important;
}

.logout-icon {
    color: black !important;
    font-size: 1rem !important;
}

.loading-center {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    background: transparent;
    z-index: calc(var(--rz-dialog-zindex) * 4) !important;
}

.loading-progress {
    position: relative;
    width: 8rem;
    height: 8rem;
}

.loading-progress circle {
    fill: none;
    stroke: #e0e0e0;
    stroke-width: 0.6rem;
    transform-origin: 50% 50%;
    transform: rotate(-90deg);
}

.loading-progress circle:last-child {
    stroke: var(--rz-primary);
    stroke-dasharray:
        calc(3.141 * var(--blazor-load-percentage, 0%) * 0.8), 500%;
    transition: stroke-dasharray 0.05s ease-in-out;
}

.loading-progress.indeterminate circle:last-child {
    stroke-dasharray:
        calc(1 * var(--blazor-load-percentage, 0%) * 0.8), 500% !important;
    animation: rotation 1s linear infinite;
}

.rz-form-field:not(:has(.rz-state-disabled, .rz-disabled, input:disabled, textarea:disabled, select:disabled)) .rz-form-field-label {
    color: var(--rz-primary) !important;
    font-weight: 500;
}

.rz-form-field:not(:has(.rz-state-disabled, .rz-disabled, input:disabled, textarea:disabled, select:disabled)) .rz-form-field-content {
    border-color: color-mix(in srgb, var(--rz-primary) 55%, var(--rz-border-color)) !important;
}

.rz-form-field:has(.rz-state-disabled) .rz-inputtext,
.rz-form-field:has(.rz-state-disabled) .rz-inputtext:disabled,
.rz-form-field:has(.rz-state-disabled) .rz-numeric-input,
.rz-form-field:has(.rz-state-disabled) .rz-dropdown,
.rz-form-field:has(.rz-state-disabled) .rz-datepicker,
.rz-form-field:has(.rz-disabled) .rz-inputtext,
.rz-form-field:has(.rz-disabled) .rz-inputtext:disabled,
.rz-form-field:has(.rz-disabled) .rz-numeric-input,
.rz-form-field:has(.rz-disabled) .rz-dropdown,
.rz-form-field:has(.rz-disabled) .rz-datepicker,
.rz-form-field:has(input:disabled) .rz-inputtext,
.rz-form-field:has(input:disabled) .rz-inputtext:disabled,
.rz-form-field:has(input:disabled) .rz-numeric-input,
.rz-form-field:has(input:disabled) .rz-dropdown,
.rz-form-field:has(input:disabled) .rz-datepicker,
.rz-form-field:has(textarea:disabled) .rz-inputtext,
.rz-form-field:has(select:disabled) .rz-dropdown {
    background-color: var(--rz-base-background-color);
    border-color: var(--rz-border-color);
    color: color-mix(in srgb, var(--rz-text-color) 78%, white);
    opacity: 1;
}

.rz-form-field:has(.rz-state-disabled) .rz-inputtext::placeholder,
.rz-form-field:has(.rz-state-disabled) .rz-numeric-input::placeholder,
.rz-form-field:has(.rz-disabled) .rz-inputtext::placeholder,
.rz-form-field:has(.rz-disabled) .rz-numeric-input::placeholder,
.rz-form-field:has(input:disabled) .rz-inputtext::placeholder,
.rz-form-field:has(textarea:disabled) .rz-inputtext::placeholder {
    color: color-mix(in srgb, var(--rz-text-secondary-color) 80%, white);
}

.rz-form-field:has(.rz-state-disabled) .rz-chkbox-box,
.rz-form-field:has(.rz-state-disabled) .rz-radiobutton-box,
.rz-form-field:has(.rz-disabled) .rz-chkbox-box,
.rz-form-field:has(.rz-disabled) .rz-radiobutton-box,
.rz-form-field:has(input:disabled) .rz-chkbox-box,
.rz-form-field:has(input:disabled) .rz-radiobutton-box {
    background-color: var(--rz-base-background-color);
    border-color: var(--rz-border-color);
    opacity: 1;
}

.loading-progress-text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    justify-content: center;
    align-items: center;
    width: 4rem;
    height: 4rem;
}

.loading-progress-text img {
    width: 100%;
    height: 100%;
}

#blazor-error-ui {
    color-scheme: light only;
    background: linear-gradient(135deg, #d32f2f, #b71c1c);
    bottom: 2rem;
    left: 50%;
    transform: translateX(-50%);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.25);
    border-radius: 0.75rem;
    box-sizing: border-box;
    display: none;
    padding: 1rem 1.5rem;
    position: fixed;
    width: auto;
    min-width: 400px;
    z-index: 100000;
}

#blazor-error-ui[style*="display: block"] {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
}

#blazor-error-ui .dismiss {
    transition: opacity 0.2s ease-in-out;
}

#blazor-error-ui .dismiss:hover {
    opacity: 1 !important;
}

.blazor-error-boundary {
    background:
        url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDg2IDY2LjA1NDMgMjYzLjU3NiA2Ni4wNTQ3IDI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem,
        #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

.blazor-error-boundary::after {
    content: "An error has occurred.";
}

.loading-screen {
    width: 100vw;
    height: 100vh;
    backdrop-filter: blur(5px);
    position: fixed;
    top: 0;
    left: 0;
    z-index: calc(var(--rz-dialog-zindex) * 4) !important;
    display: flex;
    justify-content: center;
    align-items: center;
}

body:has(.loading-screen) {
    height: 100vh;
    overflow: hidden;
}

body:has(.components-reconnect-show) .loading-screen {
    visibility: hidden;
}

/* Override creative-tim list-check rule that hides text inputs inside <ul><li>.
   DataFilter editors use list items and need visible inputs (ex: numeric day offset). */
.rz-datafilter ul li input[type="text"] {
    display: block !important;
}

.rz-datafilter .current-day-filter {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.rz-datafilter .current-day-filter-field {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    flex: 1 1 260px;
    min-width: 240px;
}

.rz-datafilter .current-day-filter-label {
    font-size: 0.75rem;
    color: var(--rz-text-tertiary-color);
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.rz-datafilter .current-day-filter-offset {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    white-space: nowrap;
}

.rz-datafilter .current-day-filter-sign {
    font-size: 0.75rem;
    color: var(--rz-text-tertiary-color);
    min-width: 24px;
    text-align: center;
    padding: 0 0.25rem;
    border-radius: 0.25rem;
    background: var(--rz-base-200, #f2f2f2);
}

.rz-datafilter .current-day-filter-suffix {
    font-size: 0.85rem;
    color: var(--rz-text-secondary-color);
    min-width: 32px;
}

.rz-datafilter .current-day-filter-business {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-left: 0;
    padding: 0.2rem 0.5rem;
    border-radius: 0.4rem;
    background: var(--rz-base-50, #fafafa);
    border: 1px solid var(--rz-base-300, #e5e5e5);
    white-space: nowrap;
}

.rz-datafilter .current-day-filter-business-label {
    font-size: 0.8rem;
    color: var(--rz-text-secondary-color);
    white-space: nowrap;
}

.spinner-container {
    display: flex;
    justify-content: center;
    align-items: center;
    filter: drop-shadow(2px 4px 6px #393939);
}

.loading-logo {
    position: absolute;
    width: 50px;
    height: 50px;
    opacity: 0.8;
    object-fit: contain;
}

.loader {
    width: 88px;
    height: 88px;
    border: 3px solid var(--rz-primary);
    border-radius: 50%;
    display: inline-block;
    position: relative;
    box-sizing: border-box;
    animation: rotation 1s linear infinite;
}

.username-container {
    min-width: 0;
    flex: 1 1 auto;
}

.username-container .rounded-circle {
    min-width: 25px;
}

.buttons-container {
    flex: 0 0 auto;
}

.username-text {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.loader::after {
    content: "";
    box-sizing: border-box;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 100px;
    height: 100px;
    border-radius: 50%;
    border: 3px solid transparent;
    border-bottom-color: var(--rz-primary);
}

.rounded-input {
    border-radius: var(--rz-input-border-radius) !important;
}

@keyframes rotation {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

.kanban-board {
    padding: 1rem;
    overflow: hidden;
}

.kanban-row {
    height: 100%;
    display: flex;
}

.rz-datatable-loading {
    background-color: transparent !important;
}

.notification-badge {
    height: 20px;
    min-width: 20px;
    position: absolute;
    top: -4px;
    right: 20px;
    font-size: 10px;
}

.tab-title-with-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    white-space: nowrap;
}

.tab-count-badge {
    min-width: 1.25rem;
    height: 1.25rem;
    padding: 0 0.38rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: var(--rz-danger);
    color: #fff;
    font-size: 0.68rem;
    font-weight: 700;
    line-height: 1;
}

.rz-badge-round {
    display: flex !important;
    align-items: center;
    justify-content: center;
    min-width: 1.25rem;
    height: 1.25rem;
    padding: 0 !important;
    border-radius: 50% !important;
    font-size: 0.65rem;
    line-height: 1;
    aspect-ratio: 1/1;
}

.notification-popup {
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.18);
    background: linear-gradient(180deg, #ffffff 0%, #fcfcfd 100%);
}

.popup-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    font-weight: 600;
    border-bottom: 1px solid #ececec;
    background: linear-gradient(180deg, #ffffff 0%, #fafafa 100%);
    letter-spacing: 0.01em;
}

.notification-count {
    min-width: 1.75rem;
    height: 1.75rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 0 0.5rem;
    font-size: 0.8rem;
    background: color-mix(in srgb, var(--rz-primary) 14%, white);
    color: var(--rz-primary-darker);
}

.popup-footer {
    border-top: 1px solid #ececec;
    padding: 12px 16px 16px;
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    background: #fff;
}

.notifications-dialog-container {
    width: 90% !important;
    height: fit-content;
    min-height: 680px;
}

.label-offset {
    margin-left: 0rem !important;
    padding-left: var(--rz-input-padding-inline);
}

.notification-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 0.9rem 1rem !important;
    margin-inline: 0.1rem;
    margin-block: 0.25rem;
    border-radius: 16px;
    background: #fff;
    border: 1px solid #f1f1f1;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.03);
    transition:
        transform 0.15s ease,
        opacity 0.22s ease,
        box-shadow 0.15s ease,
        border-color 0.15s ease,
        background-color 0.15s ease;
    will-change: transform, opacity, background-color;
}

.notification-item:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.05);
    border-color: color-mix(in srgb, var(--rz-primary) 18%, #f1f1f1);
}

.notification-item.unread {
    background-color: color-mix(in srgb, var(--rz-primary) 8%, white);
    border-color: color-mix(in srgb, var(--rz-primary) 18%, #f1f1f1);
}

.notification-item.read {
    opacity: 0.75;
}

.notification-item.is-ack-warning {
    background-color: color-mix(in srgb, #14b8a6 12%, white);
    border-color: color-mix(in srgb, #14b8a6 22%, #f1f1f1);
    box-shadow: 0 6px 16px color-mix(in srgb, #14b8a6 10%, transparent);
}

.notification-item.is-delete-warning {
    background-color: color-mix(in srgb, var(--rz-danger) 12%, white);
    border-color: color-mix(in srgb, var(--rz-danger) 22%, #f1f1f1);
    box-shadow: 0 6px 16px color-mix(in srgb, var(--rz-danger) 10%, transparent);
}

.notification-content {
    min-width: 0;
    flex: 1 1 auto;
}

.notification-actions {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.notification-actions .compact-button {
    width: 2.6rem;
    min-width: 2.6rem;
    height: 2.6rem;
    min-height: 2.6rem;
    padding: 0 !important;
    border-radius: 999px !important;
    justify-content: center;
}

.notification-actions .compact-button i {
    margin-right: 0;
    font-size: 0.9rem;
}

.notification-seen-icon {
    width: 2.6rem;
    min-width: 2.6rem;
    height: 2.6rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: color-mix(in srgb, #14b8a6 12%, white);
    border: 1px solid color-mix(in srgb, #14b8a6 18%, white);
    color: #0f766e;
    font-size: 0.9rem;
}

.notification-seen-icon i {
    font-size: 0.85rem;
}

.notification-title {
    font-weight: 600;
    font-size: 13px;
}

.notification-text {
    font-size: 0.9rem;
    color: var(--app-text-soft);
    font-weight: 500;
    line-height: 1.35;
    word-break: break-word;
}

.notification-date {
    font-size: 0.78rem;
    color: var(--app-text-muted);
    margin-top: 0.35rem;
}

.notification-popup .rz-datalist-data,
.notifications-dialog .rz-datalist-data {
    border-bottom: 1px solid #f1f1f1;
    box-shadow: none !important;
    padding-block: 0.35rem !important;
    background: transparent;
}

.notification-popup .rz-datalist-data li,
.notifications-dialog .rz-datalist-data li {
    padding-block: 0.1rem;
    box-shadow: none;
    background: transparent;
}

.notification-seen-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 0.4rem 0.75rem;
    font-size: 0.8rem;
    font-weight: 600;
    color: #0f766e;
    background: color-mix(in srgb, #14b8a6 12%, white);
    border: 1px solid color-mix(in srgb, #14b8a6 18%, white);
}

.notification-seen-at {
    color: var(--app-text-faint);
    font-size: 0.78rem;
}

.kanban-column {
    padding-inline: 0.5rem;
    overflow-x: visible;
    position: relative;
    background: var(--kanban-background-color);
    color: var(--kanban-text-color);
    border-radius: 12px;
    padding-block: 0.85rem;
    /* Dynamic width: container / configured desktop columns, accounting for row gap */
    flex: 0 0 calc(100% / var(--kc-desktop, 4) - 0.5rem + 0.5rem / var(--kc-desktop, 4));
    max-width: calc(100% / var(--kc-desktop, 4) - 0.5rem + 0.5rem / var(--kc-desktop, 4));
    min-width: min(260px, calc(100% / var(--kc-desktop, 4) - 0.5rem + 0.5rem / var(--kc-desktop, 4)));
    height: 100%;
    display: flex;
    flex-direction: column;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

/* Tablet (< 1200px) */
@media (max-width: 1199px) {
    .kanban-column {
        flex: 0 0 calc(100% / var(--kc-tablet, 3) - 0.5rem + 0.5rem / var(--kc-tablet, 3));
        max-width: calc(100% / var(--kc-tablet, 3) - 0.5rem + 0.5rem / var(--kc-tablet, 3));
        min-width: min(220px, calc(100% / var(--kc-tablet, 3) - 0.5rem + 0.5rem / var(--kc-tablet, 3)));
        padding-inline: 0.4rem;
    }
}

/* Mobile (< 768px) */
@media (max-width: 767px) {
    .kanban-column {
        flex: 0 0 calc(100% / var(--kc-mobile, 2) - 0.35rem + 0.35rem / var(--kc-mobile, 2));
        max-width: calc(100% / var(--kc-mobile, 2) - 0.35rem + 0.35rem / var(--kc-mobile, 2));
        min-width: min(200px, calc(100% / var(--kc-mobile, 2) - 0.35rem + 0.35rem / var(--kc-mobile, 2)));
        padding-inline: 0.3rem;
        border-radius: 8px;
    }
}

.filters-popup {
    min-width: 400px;
}

.filters-popup .rz-panel {
    box-shadow: none !important;
}

.rz-dialog-content {
    height: 100%;
}

.no-workflow-container {
    box-shadow: var(--rz-card-shadow);
    width: 100%;
    height: 100%;
    background-color: white;
    border-radius: 0.5rem;
    text-align: center;
    padding-inline: 2rem;
}

.kanban-column-header {
    font-weight: 700;
    color: #333;
    padding-bottom: 0.6rem;
    padding-inline: 0.4rem;
    font-size: 0.72rem;
    letter-spacing: 0.04em;
    border-bottom: 2px solid rgba(0, 0, 0, 0.06);
    margin-bottom: 0.4rem;
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

.kanban-status-container {
    font-size: 0.62rem !important;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    border-radius: 0.4rem;
    color: white;
    padding-inline: 0.45rem;
    padding-block: 0.18rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}

.rz-datalist-data li {
    padding-inline: 0.65rem;
    padding-block: 0.6rem;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.08), 0 0 0 1px rgba(0, 0, 0, 0.04);
    border: 0;
    border-radius: 0.6rem !important;
    transition: box-shadow 0.15s ease, transform 0.1s ease;
    background: #fff;
}

.kanban-column-content {
    padding-inline: 3px;
    overflow-y: auto;
    overflow-x: hidden;
    padding-top: 0.3rem;
    scrollbar-width: thin;
    scrollbar-color: rgba(0, 0, 0, 0.15) transparent;
}

.kanban-column-content::-webkit-scrollbar {
    width: 8px;
}

.kanban-column-content::-webkit-scrollbar-thumb {
    background-color: #ccc;
    border-radius: 4px;
}

.kanban-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    display: inline-block;
    flex-shrink: 0;
}

.rz-data-grid {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.rz-datalist-content {
    padding-inline: 3px;
}

.rz-data-grid .rz-data-grid-data {
    flex-grow: 1;
}

.rz-notification {
    z-index: calc(var(--rz-dialog-zindex) * 5) !important;
    top: 0 !important;
}

.rz-notification-item-wrapper {
    border-radius: var(--rz-notification-border-radius);
}

.rz-table-drag-drop-item > td {
    border-top: 1px solid var(--rz-primary) !important;
    border-bottom: 1px solid var(--rz-primary) !important;
    background-image: linear-gradient(
        0deg,
        color-mix(in srgb, var(--rz-primary) 7%, transparent),
        color-mix(in srgb, var(--rz-primary) 7%, transparent)
    ) !important;
}

.workflow-fields-grid .rz-data-row.rz-table-drag-drop-item > td {
    border-top: 2px solid var(--rz-primary) !important;
    border-bottom: 2px solid var(--rz-primary) !important;
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--rz-primary) 28%, transparent);
    background-image: linear-gradient(
        0deg,
        color-mix(in srgb, var(--rz-primary) 10%, transparent),
        color-mix(in srgb, var(--rz-primary) 10%, transparent)
    ) !important;
}

.rz-colorpicker-value {
    max-width: 30px;
}

.rz-form-field-helper {
    padding-bottom: 5px;
}

button {
    text-transform: none !important;
}

.border-nav-bar {
    border-radius: var(--bs-card-border-radius);
}

.rz-dialog-side {
    border-radius: 0 !important;
}

.blocked-column {
    white-space: normal !important;
}

.dialog-lg {
    min-width: 50% !important;
}

.side-bar-content-height .rz-dialog-side-content {
    height: calc(100% - var(--titlebar-height, 50px));
}

.card-divider {
    height: 1px !important;
    background-color: #3d3c3c !important;
    margin-left: 1rem !important;
    margin-right: 1rem !important;
}

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

input[type="number"] {
    -moz-appearance: textfield;
    appearance: textfield;
}

.rz-tabview {
    padding-right: 0.25rem !important;
    padding-top: 0.5rem;
    white-space: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.rz-colorpicker-popup {
    user-select: none !important;
}

.rz-tabview-panels {
    overflow: hidden;
}

.rz-tabview {
    overflow-y: hidden;
}

.tabs-layout-shell {
    min-height: fit-content;
}

.tabs-layout-right {
    display: flex;
    align-items: center;
    min-height: 48px;
    padding-top: 0.25rem;
    padding-bottom: 0.25rem;
}

.tabs-layout-right-inner {
    align-items: center;
    flex-wrap: wrap;
}

.report-tabs-toolbar {
    min-height: 48px;
}

.report-tabs-toolbar-item {
    min-height: 40px;
}

.rz-dropdown {
    padding-block: 0.3rem !important;
    min-height: var(--rz-input-min-height);
}

.rz-dropdown-label,
.rz-multiselect-label {
    padding-right: 4.5rem !important;
    display: flex !important;
    align-items: center !important;
    min-width: 0 !important;
    max-width: 100% !important;
    text-overflow: ellipsis !important;
    overflow: hidden !important;
    white-space: nowrap !important;
}

.rz-dropdown-label>*,
.rz-multiselect-label>* {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.rz-dropdown-clear-icon,
.rz-multiselect-clear-icon {
    right: 2.5rem !important;
    z-index: 1 !important;
}

.process-item-color-tag {
    height: 100%;
    position: absolute;
    left: 0px;
    top: 0px;
    width: 8px;
}

.rz-datalist-data li {
    position: relative;
    overflow: hidden;
}

.rz-datalist-data li:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12), 0 0 0 1px rgba(0, 0, 0, 0.06) !important;
    transform: translateY(-1px);
}

.kanban-row {
    padding-bottom: 1rem !important;
    gap: 0.5rem;
    align-items: stretch;
}

@media (max-width: 767px) {
    .kanban-row {
        gap: 0.35rem;
    }
}

.rz-datalist-data {
    padding-inline: 0rem !important;
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}

.rz-datalist-data li {
    margin-inline: 0rem !important;
    margin-block: 0 !important;
}

.kanban-board {
    padding: 0rem !important;
}

/* ── Kanban card inner layout ── */
.kanban-card-inner {
    display: flex;
    flex-direction: column;
    min-width: 0;
    position: relative;
}

.kanban-card-action {
    cursor: pointer;
    color: var(--rz-text-secondary);
    font-size: 0.875rem;
    padding: 4px 6px;
    border-radius: 4px;
    transition: background 0.12s;
}

.kanban-card-action:hover {
    background: rgba(0, 0, 0, 0.07);
}

.kanban-card-header {
    min-width: 0;
    padding-right: 2rem;
}

.kanban-card-header.has-edit-action {
    padding-right: 3.7rem;
}

.kanban-card-field {
    font-size: 0.75rem;
    line-height: 1.35;
}

.kanban-card-field-label {
    font-weight: 600;
    color: #555;
    margin-right: 2px;
}

.kanban-card-field-value {
    font-weight: 400;
    color: #777;
}

.kanban-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 0.7rem;
    color: #999;
    margin-top: 0.3rem;
    padding-top: 0.3rem;
    border-top: 1px solid rgba(0, 0, 0, 0.05);
}

.kanban-card-date {
    color: #aaa;
}

.kanban-card-id {
    font-weight: 700;
    color: #777;
    font-size: 0.72rem;
}

.kanban-count-badge {
    background: rgba(0, 0, 0, 0.07);
    color: #777;
    font-size: 0.65rem;
    font-weight: 700;
    border-radius: 999px;
    padding: 1px 7px;
    margin-left: auto;
}

/* ── */
.process-item-expand-container {
    position: absolute;
    top: 2px;
    right: 2px;
    gap: 0.15rem;
}

.process-item-expand-container .kanban-card-action,
.process-item-expand-container .compact-button,
.process-item-expand-container .rz-button {
    padding: 2px 4px;
    min-width: 1.5rem;
    min-height: 1.5rem;
    font-size: 0.78rem;
}

.process-item-expand-container .compact-button i,
.process-item-expand-container .kanban-card-action i,
.process-item-expand-container .rz-button i {
    font-size: 0.78rem;
}

.case-actions-menu-anchor {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
}

.case-actions-menu-anchor-list {
    width: 2.2rem;
    height: 2.2rem;
}

.case-actions-menu-anchor-kanban {
    width: 1.5rem;
    height: 1.5rem;
}

.rz-popup,
.rz-overlaypanel {
    border-radius: 0.3rem;
    box-shadow: 0px 2px 6px 0px #e3e3e3;
    background-color: white;
    position: absolute;
    padding-block: 0.5rem;
}

.case-actions-popup {
    position: fixed !important;
    max-width: calc(100vw - 1rem);
    max-height: calc(100vh - 1rem);
    overflow: auto;
}

.popup-button {
    cursor: pointer;
    padding-block: 0.8rem;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: start;
    gap: 0.8rem;
    padding-inline: 0.8rem;
    min-width: 200px;
}

.popup-button-icon {
    color: var(--rz-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 1.2rem;
}

.popup-button:hover {
    background-color: #f5f5f5;
}

.form-warning-text {
    font-size: 8px;
    color: yellow;
}

.all-fields-dialog {
    display: flex;
    flex-direction: column;
    background-color: var(--app-surface-raised);
}

.dialog-header-info {
    display: flex;
    align-items: center;
    border-bottom: 1px solid var(--app-border-soft);
    padding: 0.55rem 1.25rem;
    background: var(--app-surface-raised);
    box-shadow: var(--app-shadow-subtle);
    position: relative;
    z-index: 20;
}

.case-badge {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.35rem 1rem;
    background: var(--app-surface-soft);
    color: var(--app-text-soft);
    border: 1px solid var(--app-border-soft);
    border-radius: 8px;
    font-weight: 700;
    font-size: 0.85rem;
    box-shadow: var(--app-shadow-soft);
}

.case-badge i,
.case-badge .rz-icon {
    color: var(--rz-primary);
    font-size: 1.1rem;
}

.fields-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 1.25rem;
    width: 100%;
}

.field-card {
    background: white;
    border: 1px solid #eef0f2;
    border-radius: 12px;
    padding: 1rem;
    transition: all 0.2s ease;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.02);
    position: relative;
    overflow: hidden;
}

.field-card::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background: var(--rz-primary);
    opacity: 0.6;
}

.field-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.05);
    border-color: color-mix(in srgb, var(--rz-primary) 20%, #eef0f2);
}

.report-row {
    display: flex;
    border-bottom: 1px solid #e2e8f0;
    border-right: 0;
    padding: 2px 12px;
    transition: background-color 0.1s ease;
    align-items: center;
    justify-content: flex-start;
    text-align: left;
}

.report-row:hover {
    background-color: var(--app-surface-soft);
}

.report-row-placeholder {
    min-height: auto;
    padding: 0;
    pointer-events: none;
    background: transparent;
}

.report-row-placeholder:hover {
    background: transparent;
}

.report-group-header {
    grid-column: span 2;
    background-color: var(--app-surface-soft);
    border-top: 1px solid var(--app-border-soft);
    border-bottom: 1px solid var(--app-border-soft);
    padding: 4px 12px;
    font-size: 0.75rem;
    font-weight: 700;
    color: #475569;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.5rem;
    user-select: none;
    transition: all 0.2s ease;
    text-align: left;
    position: relative;
    top: auto;
    z-index: 1;
}

.report-group-header.level-0 {
    background: linear-gradient(90deg, var(--app-surface-accent-soft), var(--app-surface-raised));
    border-left: 4px solid var(--rz-primary);
    color: var(--rz-primary);
    font-weight: 800;
    margin-top: 0;
    font-size: 0.8rem;
    box-shadow: none;
}

.report-group-header.level-1 {
    background: var(--app-surface-soft);
    border-left: 4px solid var(--app-border-muted);
    color: var(--app-text-muted);
    font-size: 0.75rem;
}

.report-group-header.level-2 {
    background: var(--app-surface-raised);
    border-left: 4px solid var(--app-border-soft);
    color: var(--app-text-faint);
    font-size: 0.7rem;
}

.report-group-header:hover {
    background-color: var(--app-surface-accent-hover);
    color: var(--rz-primary);
}

.report-group-header .rz-icon {
    color: var(--rz-primary);
    transition: transform 0.2s ease;
}

.report-row-child {
    background-color: transparent;
    border-left: none;
}

.report-metadata-row {
    background-color: var(--app-surface-raised) !important;
    border-bottom: 1px dashed var(--app-border-muted) !important;
    padding: 0.45rem 1rem !important;
}

.report-metadata-row .report-label-cell {
    color: var(--app-text-faint);
    font-weight: 500;
    font-style: italic;
    font-size: 0.65rem;
    padding-left: 1.5rem;
}

.report-metadata-row .report-value-text {
    color: var(--app-text-muted);
    font-size: 0.8rem;
}

.dynamic-input-metadata-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 0.5rem 0.75rem;
    margin-top: 0.35rem;
}

.dynamic-input-metadata-item {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    min-width: 0;
}

.dynamic-input-metadata-label {
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--rz-primary-dark);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.dynamic-input-metadata-value {
    font-size: 0.85rem;
    color: var(--app-text-soft);
    word-break: break-word;
}

.file-view-list,
.folder-view-readonly-list {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.2rem;
}

.file-view-link,
.folder-view-readonly-link {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    padding: 0.45rem 0.75rem;
    color: var(--app-text-soft);
    font-size: 0.82rem;
    font-weight: 600;
    text-decoration: none;
    overflow: hidden;
    border: 1px solid var(--app-border-soft);
    border-radius: 0.75rem;
    background: var(--app-surface-soft);
    box-shadow: var(--app-shadow-soft);
    transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease, color 0.15s ease;
}

.file-view-link:hover,
.folder-view-readonly-link:hover {
    color: var(--rz-primary);
    text-decoration: none;
    border-color: color-mix(in srgb, var(--rz-primary) 35%, var(--app-border-soft));
    box-shadow: var(--app-shadow-subtle);
    transform: translateY(-1px);
}

.file-view-icon,
.folder-view-readonly-icon {
    font-size: 1rem;
    color: var(--rz-primary);
    flex: 0 0 auto;
}

.file-view-link-main {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
}

.file-view-action {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    flex: 0 0 auto;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--rz-primary) 10%, white);
    color: var(--rz-primary);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    text-transform: uppercase;
}

.file-view-action-icon {
    font-size: 0.9rem;
}

.file-view-name,
.folder-view-readonly-name {
    display: inline-block;
    flex: 1 1 auto;
    min-width: 0;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.file-card,
.folder-file-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    align-self: stretch;
    box-sizing: border-box;
    flex: 1 1 100%;
    gap: 0.75rem;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--app-border-soft);
    border-radius: 0.75rem;
    background: var(--app-surface-soft);
}

.file-card-readonly {
    max-width: 100%;
    background: var(--app-surface-raised);
}

.file-card-main,
.folder-file-card-main {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
}

.file-card-icon,
.folder-file-card-icon {
    flex: 0 0 auto;
    font-size: 1rem;
    color: var(--rz-primary);
}

.file-card-link,
.file-card-button,
.folder-file-card-name,
.file-card-text {
    display: inline-flex;
    align-items: center;
    min-width: 0;
    max-width: 100%;
    color: var(--app-text-soft);
    font-size: 0.85rem;
    font-weight: 500;
    text-decoration: none;
}

.file-card-link {
    flex: 1 1 auto;
    overflow: hidden;
}

.file-card-button {
    flex: 1 1 auto;
    overflow: hidden;
}

.file-card-text {
    flex: 1 1 auto;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.2rem;
    overflow: hidden;
}

.file-card-button:hover,
.file-card-link:hover {
    color: var(--rz-primary);
}

.file-card-name,
.folder-file-card-name {
    display: inline-block;
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

.file-card-size {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    padding: 0.05rem 0.4rem;
    border-radius: 999px;
    background: var(--app-surface-muted);
    border: 1px solid var(--app-border-soft);
    color: var(--app-text-muted);
    font-size: 0.68rem;
    font-weight: 700;
    line-height: 1;
    margin-left: 0;
}

.report-row-child .report-label-cell {
    padding-left: 1rem;
    position: relative;
    color: var(--app-text-muted);
}

.report-row-child .report-label-cell::before {
    display: none;
}

.report-label-cell {
    flex: 0 0 190px;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--app-text-muted);
    letter-spacing: 0.02rem;
    align-self: center;
    text-align: left;
    margin-right: 1.25rem;
}

.report-value-cell {
    flex: 1;
    min-width: 0;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    text-align: left;
    overflow: visible;
}

.report-value-cell>* {
    min-width: 0;
    max-width: 100%;
}

.report-value-cell .file-view-list,
.report-value-cell .folder-view-readonly-list,
.report-value-cell .file-card,
.report-value-cell .folder-file-card,
.report-value-cell .file-card-main,
.report-value-cell .folder-file-card-main {
    width: 100%;
    min-width: 0;
    max-width: 100%;
}

.report-row.full-width {
    align-items: flex-start;
}

.report-value-cell .file-view-link,
.report-value-cell .folder-view-readonly-link,
.report-value-cell .file-card-link,
.report-value-cell .file-card-button,
.report-value-cell .file-card-name,
.report-value-cell .folder-file-card-name,
.report-value-cell .file-view-name,
.report-value-cell .folder-view-readonly-name {
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

.report-badge {
    background-color: var(--app-surface-muted) !important;
    color: var(--app-text-soft) !important;
    border: 1px solid var(--app-border-soft) !important;
    font-size: 0.75rem !important;
    font-weight: 600 !important;
    border-radius: 6px !important;
}

.btn-report-action {
    border-radius: 8px !important;
    width: 32px !important;
    height: 32px !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-shadow: var(--app-shadow-soft) !important;
}

.report-folder-btn {
    border-radius: 2rem !important;
    padding: 0 1.25rem !important;
    min-height: 32px !important;
    height: 32px !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    background-color: var(--rz-info) !important;
    border: none !important;
    box-shadow: var(--app-shadow-info) !important;
}

.report-folder-btn:hover {
    filter: brightness(0.95);
    box-shadow: var(--app-shadow-info-hover) !important;
}

.btn-report-action .rz-button-icon-left,
.btn-report-action .rz-icon {
    margin: 0 !important;
}

.report-value-text {
    word-break: break-word;
    min-height: 1.5rem;
    width: 100%;
    margin: 0;
    text-align: left;
}

.report-value-text.text-end {
    text-align: right;
}

.report-container {
    background: var(--app-surface-raised);
    border: 1px solid var(--app-border-soft);
    height: 100%;
    overflow-y: auto;
    margin: 0;
    position: relative;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-auto-flow: row;
    align-content: start;
}

.report-group-content {
    grid-column: span 2;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-auto-flow: row;
    align-content: start;
    background-color: var(--app-surface-raised);
    margin-left: 1rem;
    border-left: 1px solid var(--app-border-soft);
}

.report-group-header.level-0+.report-group-content {
    background-color: var(--app-surface-raised);
    margin-bottom: 0;
}

.report-row.full-width {
    grid-column: span 2;
}

@media (max-width: 1200px) {
    .report-container {
        grid-template-columns: 1fr;
    }

    .report-group-content {
        grid-template-columns: 1fr;
    }

    .report-group-content {
        grid-column: span 1;
        margin-left: 0.75rem;
        border-left: 1px solid var(--app-border-soft);
    }

    .report-row,
    .report-row.full-width,
    .report-group-header {
        grid-column: span 1;
        border-right: 0;
    }

    .report-row.full-width {
        grid-column: span 1;
    }
}

@media (max-width: 768px) {

    .report-container,
    .report-group-content {
        grid-template-columns: 1fr !important;
        grid-auto-flow: row !important;
    }

    .report-group-content {
        grid-column: span 1 !important;
        margin-left: 0.55rem !important;
        border-left: 1px solid var(--app-border-soft) !important;
        padding-left: 0.15rem;
    }

    .report-row,
    .report-row.full-width,
    .report-group-header {
        grid-column: span 1 !important;
        border-right: 0 !important;
    }

    .report-row {
        display: flex !important;
        flex-direction: column;
        align-items: flex-start;
        gap: 0.4rem;
        padding: 0.7rem 0.95rem;
        min-height: auto;
    }

    .report-label-cell {
        display: block;
        flex: none;
        width: 100%;
        margin-right: 0;
        align-self: flex-start;
        line-height: 1.25;
    }

    .report-value-cell {
        display: block;
        flex: none;
        width: 100%;
        min-width: 0;
        padding-top: 0.15rem;
        text-align: left;
    }

    .report-value-cell>* {
        display: block;
        width: 100%;
        min-width: 0;
    }

    .report-value-text {
        line-height: 1.35;
    }

    .report-group-header {
        padding: 0.75rem 0.95rem;
    }
}

.report-container::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--rz-primary), #6366f1);
    z-index: 100;
}

.report-row:last-child {
    border-bottom: 1px solid #e2e8f0;
}

@media (max-width: 768px) {
    .fields-grid {
        grid-template-columns: 1fr;
    }
}

.kanban-count-text {
    color: #939393;
}

@media (min-width: 992px) {
    .navbar-dropdown-container {
        width: 400px;
    }
}

@media (max-width: 991px) {
    .navbar-dropdown-container {
        width: 100%;
    }
}

.compact-button {
    padding: 6px 10px;
    font-size: 0.9rem;
    min-width: 2.2rem;
    min-height: 2.2rem;
}

.compact-button.rz-button-icon-only,
.rz-button.compact-button.rz-button-icon-only,
a.compact-button.rz-button-icon-only {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.2rem;
    height: 2.2rem;
    min-width: 2.2rem;
    min-height: 2.2rem;
    padding: 0;
    border-radius: 50% !important;
    aspect-ratio: 1 / 1;
}

.compact-button.rz-button-icon-only.rz-button-xs,
.rz-button.compact-button.rz-button-icon-only.rz-button-xs,
a.compact-button.rz-button-icon-only.rz-button-xs {
    width: 1.6875rem;
    height: 1.6875rem;
    min-width: 1.6875rem;
    min-height: 1.6875rem;
    padding: 0;
}

.compact-button.rz-button-icon-only.rz-button-sm,
.rz-button.compact-button.rz-button-icon-only.rz-button-sm,
a.compact-button.rz-button-icon-only.rz-button-sm {
    width: 2rem;
    height: 2rem;
    min-width: 2rem;
    min-height: 2rem;
    padding: 0;
}

.compact-button.rz-button-icon-only i,
.rz-button.compact-button.rz-button-icon-only i,
a.compact-button.rz-button-icon-only i {
    margin: 0;
    line-height: 1;
    font-size: 0.8125rem;
}

.compact-button.rz-button-icon-only.rz-button-xs i,
.rz-button.compact-button.rz-button-icon-only.rz-button-xs i,
a.compact-button.rz-button-icon-only.rz-button-xs i {
    font-size: 0.75rem;
}

.compact-button.rz-button-icon-only.rz-button-sm i,
.rz-button.compact-button.rz-button-icon-only.rz-button-sm i,
a.compact-button.rz-button-icon-only.rz-button-sm i {
    font-size: 0.8125rem;
}

.compact-button.highlight {
    color: var(--rz-primary-light) !important;
}

.rz-data-grid.rz-density-compact {
    --rz-grid-cell-padding: 0.35rem 0.5rem;
}

.rz-data-grid.rz-density-compact {
    --rz-grid-cell-line-height: 2em;
}

.card {
    background-color: var(--rz-base-background-color);
    color: var(--rz-text-color);
}

.sidenav {
    background-color: var(--rz-base-background-color);
    color: var(--rz-text-color);
}

.dynamic-input-file .rz-fileupload-content {
    display: none !important;
}

.pdf-merge-dialog-root {
    min-height: 0;
}

.pdf-merge-dialog-body {
    flex: 1;
    min-height: 0;
    display: flex;
    gap: 1rem;
    overflow: hidden;
}

.pdf-merge-column {
    flex: 1;
    min-width: 0;
    min-height: 0;
    display: flex;
    flex-direction: column;
}

.pdf-merge-column-available {
    border-left: 1px solid #e0e0e0;
    padding-left: 1rem;
}

.pdf-merge-list-scroll {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
}

.pdf-merge-footer {
    flex-shrink: 0;
}

.dialog-delete-button {
    background-color: var(--rz-dialog-cancel-color) !important;
    color: var(--rz-dialog-cancel-text-color) !important;
}

.dialog-cancel-button {
    background-color: var(--rz-dialog-cancel-color) !important;
    color: var(--rz-dialog-cancel-text-color) !important;
}

.dialog-confirm-button {
    background-color: var(--rz-confirm-color) !important;
    color: var(--rz-confirm-text-color) !important;
}

.rz-datepicker input {
    display: block !important;
}

.breadcrumb-item+.breadcrumb-item::before {
    color: var(--rz-text-color);
}

.rz-popup {
    background: var(--rz-card-background-color);
}

.rz-dropdown-items-wrapper,
.rz-multiselect-items-wrapper {
    border-radius: 0;
}

.rz-button.rz-light {
    color: black;
}

.text-color {
    color: var(--rz-text-color);
}

a .text-color:hover {
    color: var(--rz-primary);
}

.rz-form-field:not(.rz-floating-label) .rz-form-field-label,
.rz-textbox:focus~.rz-form-field-label,
.rz-textarea:focus~.rz-form-field-label,
.rz-numeric:focus-within~.rz-form-field-label,
.rz-autocomplete:focus-within~.rz-form-field-label,
.rz-textbox:not(:placeholder-shown)~.rz-form-field-label,
:not(.rz-state-empty)~.rz-form-field-label,
.rz-form-field.rz-variant-filled .rz-textarea:focus~.rz-form-field-label,
.rz-form-field.rz-variant-flat .rz-textarea:focus~.rz-form-field-label,
.rz-form-field.rz-variant-filled :not(.rz-state-empty)~.rz-form-field-label,
.rz-form-field.rz-variant-flat :not(.rz-state-empty)~.rz-form-field-label,
.rz-radio-button-list-vertical~.rz-form-field-label,
.rz-radio-button-list-horizontal~.rz-form-field-label,
.rz-checkbox-list-vertical~.rz-form-field-label,
.rz-checkbox-list-horizontal~.rz-form-field-label,
.rz-chkbox~.rz-form-field-label,
.rz-fileupload~.rz-form-field-label,
.rz-state-empty:has(.rz-placeholder)~.rz-form-field-label,
.rz-form-field.rz-state-focused .rz-form-field-label {
    color: var(--rz-text-color);
}

.rz-badge[data-field-id] {
    display: inline-block !important;
    padding: 2px 8px !important;
    border-radius: 4px !important;
    font-weight: 600 !important;
    margin: 0 2px !important;
    user-select: all !important;
    cursor: default !important;
    border: 1px solid var(--rz-info-light) !important;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05) !important;
    background-color: var(--rz-info-lighter) !important;
    color: var(--rz-info-darker) !important;
    font-size: 0.85rem !important;
    line-height: normal !important;
}

.rz-badge[data-field-id]:hover {
    filter: brightness(0.95);
}

.navbar-dropdown-container .rz-dropdown {
    border: 1px solid transparent;
}

.navbar-dropdown-container .rz-dropdown {
    box-shadow: var(--rz-card-shadow) !important;
}

/* Mermaid Diagram Card Styling */
.mermaid-container svg {
    max-width: 100%;
    height: auto;
}

/* Card-like styling for Mermaid nodes */
.mermaid-container .node rect,
.mermaid-container .node polygon,
.mermaid-container .node circle,
.mermaid-container .node ellipse {
    filter: drop-shadow(0 1px 3px rgba(0, 0, 0, 0.12)) drop-shadow(0 1px 2px rgba(0, 0, 0, 0.08));
    transition: filter 0.2s ease;
}

.mermaid-container .node:hover rect,
.mermaid-container .node:hover polygon {
    filter: drop-shadow(0 4px 6px rgba(0, 0, 0, 0.15)) drop-shadow(0 2px 4px rgba(0, 0, 0, 0.1));
}

.mermaid-container .node .label {
    font-family: var(--rz-text-font-family);
    font-weight: 500;
}

.mermaid-container .edgePath .path {
    stroke: #6c757d;
    stroke-width: 2px;
}

.mermaid-container .edgePath .arrowheadPath {
    fill: #6c757d;
}

.dialog-xl {
    min-width: 80% !important;
}

.input-button-row .rz-button {
    height: 35px;
    aspect-ratio: 1/1;
}

.no-outline-fieldform .rz-form-field-content {
    border: 0px !important;
}

.no-outline-fieldform .rz-form-field:hover .rz-form-field-content,
.no-outline-fieldform .rz-autocomplete:hover:not(.rz-state-disabled),
.no-outline-fieldform .rz-timespanpicker>.rz-inputtext:not(:disabled):not(.rz-state-disabled):hover,
.no-outline-fieldform .rz-colorpicker:not(:disabled):not(.rz-state-disabled):hover,
.no-outline-fieldform .rz-lookup-search input:not(:disabled):not(.rz-state-disabled):hover,
.no-outline-fieldform .rz-numeric:not(:disabled):not(.rz-state-disabled):hover,
.no-outline-fieldform .rz-datepicker>.rz-inputtext:not(:disabled):not(.rz-state-disabled):hover,
.no-outline-fieldform .rz-multiselect:not(:disabled):not(.rz-state-disabled):hover,
.no-outline-fieldform .rz-dropdown:not(:disabled):not(.rz-state-disabled):hover,
.no-outline-fieldform .mask:not(:disabled):not(.rz-state-disabled):hover,
.no-outline-fieldform .rz-textarea:not(:disabled):not(.rz-state-disabled):hover,
.no-outline-fieldform .rz-textbox:not(:disabled):not(.rz-state-disabled):hover {
    border: 0px !important;
}

.content-filters .rz-form-field-content {
    margin-top: 0px !important;
}

.inbox-switch-filter {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.5rem; /* keep spacing consistent */
    line-height: 1;
}

.inbox-switch-filter-label {
    display: inline-flex;
    align-items: center;
    margin: 0;
    line-height: 1;
    white-space: nowrap;
    /* Nudge label vertically to better align with RadzenSwitch. Adjust as needed per platform. */
    /* Tuned from -2px to -3px for improved vertical alignment (slight upward shift). */
    transform: translateY(-3px);
}

.inbox-switch-filter .rz-switch {
    flex: 0 0 auto;
    /* ensure the switch itself is centered in the flex row */
    align-self: center;
}

.rz-tooltip .rz-context-menu .rz-menu {
    box-shadow: none !important;
}

.configuration-board-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.5rem;
    width: 100%;
    margin-top: 1rem;
    padding: 1rem;
}

.rz-chkbox.rz-state-disabled {
    opacity: 0.3 !important;
}

.rz-chkbox.rz-state-disabled label {
    opacity: 0.3 !important;
}

.cost-table-nonbase td .rz-cell-data {
    color: var(--rz-danger) !important;
}

.cost-table-removed td .rz-cell-data {
    text-decoration: line-through;
    opacity: 0.7;
}

.rz-form-field:hover .rz-form-field-content input {
    border: none !important;
}

.workflow-fields-grid .wf-label-cell {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.workflow-fields-grid .wf-child-dot {
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 999px;
    background: var(--rz-primary);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--rz-primary) 18%, transparent);
    flex: 0 0 auto;
}

/* Base Level 0 */
.workflow-fields-grid .wf-level-0>td {
    background: var(--rz-base-background-color) !important;
}

/* Level 1 */
.workflow-fields-grid .wf-level-1>td {
    background: color-mix(in srgb,
            var(--rz-base-100) 97%,
            var(--rz-primary) 3%) !important;
}

/* Level 2 */
.workflow-fields-grid .wf-level-2>td {
    background: color-mix(in srgb,
            var(--rz-base-100) 94%,
            var(--rz-primary) 6%) !important;
    border-top: 1px dashed color-mix(in srgb, var(--rz-primary) 20%, transparent);
    border-bottom: 1px dashed color-mix(in srgb, var(--rz-primary) 20%, transparent);
}

/* Level 3 */
.workflow-fields-grid .wf-level-3>td {
    background: color-mix(in srgb,
            var(--rz-base-100) 91%,
            var(--rz-primary) 9%) !important;
}

/* Level 4 */
.workflow-fields-grid .wf-level-4>td {
    background: color-mix(in srgb,
            var(--rz-base-100) 88%,
            var(--rz-primary) 12%) !important;
}

/* Base style for dots */
.workflow-fields-grid .wf-child-dot {
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 999px;
    background: var(--rz-primary);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--rz-primary) 18%, transparent);
    flex: 0 0 auto;
}

/* Indentation based on level for the first cell content or wherever appropriate */
.workflow-fields-grid .wf-level-0 .wf-label-cell {
    padding-left: 0;
}

.workflow-fields-grid .wf-level-1 .wf-label-cell {
    padding-left: 1.5rem;
}

.workflow-fields-grid .wf-level-2 .wf-label-cell {
    padding-left: 3rem;
}

.workflow-fields-grid .wf-level-3 .wf-label-cell {
    padding-left: 4.5rem;
}

.workflow-fields-grid .wf-level-4 .wf-label-cell {
    padding-left: 6rem;
}

.workflow-fields-grid .wf-level-1>td:first-child,
.workflow-fields-grid .wf-level-2>td:first-child,
.workflow-fields-grid .wf-level-3>td:first-child,
.workflow-fields-grid .wf-level-4>td:first-child {
    border-left: 4px solid var(--rz-primary);
}

.workflow-fields-grid .wf-level-0:hover>td,
.workflow-fields-grid .wf-level-1:hover>td,
.workflow-fields-grid .wf-level-2:hover>td,
.workflow-fields-grid .wf-level-3:hover>td,
.workflow-fields-grid .wf-level-4:hover>td {
    filter: brightness(0.98);
}

.rz-row-drag-handle,
.workflow-fields-grid .wf-drag-handle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.75rem;
    height: 1.75rem;
    cursor: grab;
    color: var(--rz-text-tertiary-color);
    border-radius: 0.35rem;
    transition: background-color 0.12s ease, color 0.12s ease;
}

.rz-row-drag-handle:hover,
.workflow-fields-grid .wf-drag-handle:hover {
    background: color-mix(in srgb, var(--rz-primary) 10%, transparent);
    color: var(--rz-primary);
}

.rz-row-drag-handle:active,
.workflow-fields-grid .wf-drag-handle:active {
    cursor: grabbing;
}

.rz-data-row.wf-row-dragging > td,
.workflow-fields-grid .rz-data-row.wf-row-dragging > td {
    opacity: 0.7;
    background-image: linear-gradient(
        0deg,
        color-mix(in srgb, var(--rz-primary) 6%, transparent),
        color-mix(in srgb, var(--rz-primary) 6%, transparent)
    ) !important;
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--rz-primary) 22%, transparent);
}

.workflow-fields-grid .rz-data-row.wf-row-dragging > td {
    transform: translateY(-1px);
}

.wf-drag-ghost,
.workflow-fields-grid .wf-drag-ghost {
    position: fixed;
    top: -10000px;
    left: -10000px;
    pointer-events: none;
    opacity: 0.95;
    box-sizing: border-box;
    background: var(--rz-base-background-color);
    border-radius: 6px;
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18);
    z-index: 2147483647;
}

.wf-drag-ghost-table,
.workflow-fields-grid .wf-drag-ghost-table {
    width: 100%;
    border-collapse: collapse;
    table-layout: fixed;
}

.wf-drag-ghost .rz-data-row,
.workflow-fields-grid .wf-drag-ghost .rz-data-row {
    display: table-row;
}

.wf-drag-ghost td,
.workflow-fields-grid .wf-drag-ghost td {
    background: inherit !important;
    white-space: nowrap;
}

.import-preview-dialog {
    padding: 1rem;
    min-width: 500px;
    position: relative;
}

.import-preview-cell.has-error .rz-textbox {
    border-color: var(--bs-danger) !important;
}

.import-preview-grid .rz-datagrid-scrollable-body {
    min-height: 120px;
}

.import-preview-row-invalid {
    background-color: rgba(220, 53, 69, 0.08);
    border-left: 3px solid rgba(220, 53, 69, 0.6);
}

.import-preview-loading-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.6);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    backdrop-filter: blur(2px);
}

.import-preview-loading-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

/* DateFilterInput */
.date-filter-box {
    display: inline-flex;
    border: 1px solid var(--rz-border-color);
    border-radius: 4px;
    background: var(--rz-base-background-color);
    height: 34px;
    width: 100%;
    min-width: 160px;
    transition: all 0.2s;
    align-items: stretch;
    overflow: hidden;
}

.date-filter-box:hover {
    border-color: var(--rz-primary-light);
}

.date-filter-box:focus-within {
    border-color: var(--rz-primary);
    box-shadow: 0 0 0 2px var(--rz-primary-lighter);
}

.date-filter-inner {
    display: flex;
    width: 100%;
    align-items: center;
}

.mode-action {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    cursor: pointer;
    background: var(--rz-base-100);
    color: var(--rz-primary);
    border-right: 1px solid var(--rz-border-color);
    flex-shrink: 0;
    height: 100%;
}

.mode-action:hover {
    background: var(--rz-base-200);
}

.content-area {
    flex: 1;
    display: flex;
    align-items: center;
    min-width: 0;
    position: relative;
}

.relative-ui {
    display: flex;
    align-items: center;
    width: 100%;
    padding: 0 4px 0 8px;
    gap: 4px;
}

.rel-label {
    font-size: 11px;
    color: var(--rz-text-secondary-color);
    white-space: nowrap;
}

.rel-divider {
    width: 1px;
    height: 14px;
    background: var(--rz-border-color);
    margin: 0 2px;
}

.rel-business {
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    width: 30px;
    height: 28px;
    border-radius: 4px;
    color: var(--rz-text-tertiary-color);
    transition: all 0.1s;
    user-select: none;
    flex-shrink: 0;
}

.rel-business:hover {
    background: var(--rz-base-200);
}

.rel-business.is-active {
    color: var(--rz-info);
    background: var(--rz-info-lighter);
}

.rel-b-label {
    font-size: 10px;
    font-weight: 700;
}

/* Radzen Override Fixes */
.date-filter-box .rz-datepicker {
    border: none !important;
    background: transparent !important;
    padding: 0 !important;
}

.date-filter-box .rz-datepicker input {
    border: none !important;
    padding: 0 8px !important;
    background: transparent !important;
}

.date-filter-box .rz-numeric {
    border: none !important;
    background: transparent !important;
    flex: 1;
    min-width: 0;
}

.date-filter-box .rz-numeric.custom-numeric input {
    padding: 0 !important;
    text-align: left !important;
    display: block !important;
    width: 100% !important;
    /* Force display since global material-dashboard.css hides it */
}

/* Empty Group Placeholder */
.wf-empty-group-placeholder {
    padding: 0.75rem;
    border: 2px dashed #d1d4d7;
    border-radius: 6px;
    text-align: center;
    color: #6c757d;
    background-color: #f8f9fa;
    margin: 0.5rem;
    cursor: default;
    transition: all 0.2s ease;
    font-size: 0.9rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}

.wf-empty-group-placeholder:hover {
    border-color: var(--rz-primary-light);
    background-color: #fff;
    color: var(--rz-primary);
}

.wf-empty-group-placeholder.rz-table-drag-drop-item {
    border-color: var(--rz-primary) !important;
    background-color: color-mix(in srgb,
            var(--rz-primary) 8%,
            transparent) !important;
    color: var(--rz-primary) !important;
    border-style: solid !important;
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--rz-primary) 25%, transparent);
    border-width: 2px;
    transform: translateY(-1px);
}

.observations-dialog {
    display: flex !important;
    flex-direction: column !important;
}

.observations-dialog .rz-dialog-titlebar {
    flex-shrink: 0 !important;
}

.observations-dialog .rz-dialog-content {
    padding: 0 !important;
    flex-grow: 1 !important;
    height: 0 !important;
    display: flex;
    flex-direction: column;
    overflow: hidden !important;
}

.observations-dialog .rz-dialog-side-content {
    width: 100%;
    height: 100%;
}

/* Observations Chat Styles */
.chat-scroll-container {
    transform: scaleY(-1);
}

.chat-scroll-container .rz-datalist {
    border: none !important;
    background: transparent !important;
}

.chat-scroll-container .rz-datalist-data {
    border: none !important;
    background: transparent !important;
    padding: 0 !important;
}

.chat-scroll-container .rz-datalist-data>li {
    border: none !important;
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
    box-shadow: none !important;
}

.chat-item-flipped {
    transform: scaleY(-1);
    width: 100%;
}

/* =====================================================
   SIDEBAR COLLAPSED MODE FIXES
   ===================================================== */

/* Reset active state background for collapsed items */
.g-sidenav-hidden .navbar-vertical .navbar-nav>.nav-item .nav-link.active {
    background-color: transparent !important;
    box-shadow: none !important;
}

/* Hide labels and UI noise in collapsed mode */
.g-sidenav-hidden .navbar-vertical .nav-link-text,
.g-sidenav-hidden .navbar-vertical .username-text,
.g-sidenav-hidden .navbar-vertical .env-text,
.g-sidenav-hidden .navbar-vertical .buttons-container,
.g-sidenav-hidden .navbar-vertical .sidebar-footer .copyright-brand,
.g-sidenav-hidden .navbar-vertical .sidebar-footer .copyright-version {
    display: none !important;
}

/* Horizontal Centering: Strictly align everything to the vertical axis */
.g-sidenav-hidden .navbar-vertical .nav-link,
.g-sidenav-hidden .navbar-vertical .env-item,
.g-sidenav-hidden .navbar-vertical .user-item {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.g-sidenav-hidden .navbar-vertical .nav-link:hover,
.g-sidenav-hidden .navbar-vertical .env-item:hover,
.g-sidenav-hidden .navbar-vertical .user-item:hover {
    background: transparent !important;
    box-shadow: none !important;
    transform: none !important;
}

/* Unified sizing for 'bubbles' (LOC, Avatar, Icons) to maintain same visual weight */
.g-sidenav-hidden .navbar-vertical .env-icon-container,
.g-sidenav-hidden .navbar-vertical .user-summary-item .user-avatar,
.g-sidenav-hidden .navbar-vertical ::deep .menu-item-icon {
    width: 2.6rem !important;
    height: 2.6rem !important;
    min-width: 2.6rem !important;
    max-width: 2.6rem !important;
    border-radius: 0.95rem !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 !important;
}

.g-sidenav-hidden .navbar-vertical ::deep .menu-item-link:hover .menu-item-icon,
.g-sidenav-hidden .navbar-vertical .env-item:hover .env-icon-container,
.g-sidenav-hidden .navbar-vertical .user-item:hover .user-avatar {
    transform: translateY(-1px);
    background: color-mix(in srgb, var(--rz-primary) 10%, var(--app-surface-raised)) !important;
    box-shadow: 0 6px 14px color-mix(in srgb, var(--rz-primary) 12%, transparent) !important;
}

.g-sidenav-hidden .navbar-vertical ::deep .nav-link.active:hover .menu-item-icon {
    background: var(--rz-primary) !important;
    color: var(--rz-on-primary) !important;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.18) !important;
}

/* Center containers to ensure perfect vertical axis alignment */
.g-sidenav-hidden .navbar-vertical .env-container,
.g-sidenav-hidden .navbar-vertical .username-container,
.g-sidenav-hidden .navbar-vertical ::deep .menu-item-link {
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Copyright centering */
.g-sidenav-hidden .navbar-vertical .sidebar-footer .copyright-year {
    display: block;
    font-size: 0.65rem;
    text-align: center;
    width: 100%;
}

/* Keep collapsed sidenav fixed even when the theme applies hover expansion */
.g-sidenav-hidden .navbar-vertical:hover {
    max-width: 6rem !important;
}

.g-sidenav-hidden .navbar-vertical:hover.fixed-start+.main-content {
    margin-left: 7.5rem !important;
}

.g-sidenav-hidden .navbar-vertical:hover .navbar-brand span,
.g-sidenav-hidden .navbar-vertical:hover .nav-item .nav-link .nav-link-text,
.g-sidenav-hidden .navbar-vertical:hover .nav-item .nav-link .sidenav-normal,
.g-sidenav-hidden .navbar-vertical:hover .nav-item .nav-link[data-bs-toggle="collapse"]:after,
.g-sidenav-hidden .navbar-vertical:hover .card.card-background .docs-info {
    opacity: 0 !important;
    width: 0 !important;
}

.g-sidenav-hidden .navbar-vertical:hover .card.card-background .icon-shape {
    margin-bottom: 0 !important;
}

/* Reports layout */
.reports-page {
    background-color: var(--rz-layout-body-background-color);
    min-height: 0;
}

.reports-content-shell {
    min-height: 0;
}

.reports-content-card {
    margin-top: 0.75rem;
}

.reports-scroll-region {
    min-height: 0;
}

.favourite-container {
    outline: 2px solid #f1f1f1;
    box-shadow: none;
    background: var(--favourite-background-color);
}

.favourite-container .favorite-fields-header h1,
.favourite-container .favorite-fields-header h2,
.favourite-container .favorite-fields-header h3,
.favourite-container .favorite-fields-header h4,
.favourite-container .favorite-fields-header h5,
.favourite-container .favorite-fields-header h6,
.favourite-container .favorite-fields-header i,
.favourite-container .favorite-fields-header notranslate {
    color: var(--favourite-text-color)
}

.bg-input-group {
    background: var(--input-group-background-color);
}

.bg-input-group .rz-panel-titlebar h1,
.bg-input-group .rz-panel-titlebar h2,
.bg-input-group .rz-panel-titlebar h3,
.bg-input-group .rz-panel-titlebar h4,
.bg-input-group .rz-panel-titlebar h5,
.bg-input-group .rz-panel-titlebar h6,
.bg-input-group .rz-panel-titlebar i,
.bg-input-group .rz-panel-titlebar span {
    color: var(--input-group-text-color);
}

.bg-lighter {
    background-color: #f5f5f5 !important;
}

@media (max-width: 992px) {
    .reports-content-card {
        min-height: auto !important;
    }
}

.file-button button {
    min-height: 28px;
    min-width: 28px;
    padding-block: 0.15rem;
}

/* =====================================================
   REQUIRED FIELD ASTERISK
   ===================================================== */
.rz-required-field .rz-form-field-label::after {
    content: " *";
    color: var(--rz-danger);
    font-weight: 800;
}

/* =====================================================
   FAVORITE FIELDS SIDEBAR
   ===================================================== */
.favorite-fields-sidebar-container {
    min-height: 0;
    background-color: transparent;
    box-shadow: inset -5px 0 5px -5px rgb(207 207 207 / 45%);
}

.favorite-fields-header {
    margin-top: 0.25rem;
}

.favorite-fields-icon {
    font-size: 13px;
    color: #ff9800 !important;
}

.favorite-fields-title {
    font-size: 1.15rem;
    letter-spacing: -0.01em;
    color: var(--rz-text-color);
}

.favorite-fields-see-all-btn {
    border-radius: 20px;
    text-transform: none;
    font-weight: 600;
}

.favorite-fields-loading-container {
    min-height: 0;
}

.favorite-field-skeleton-card {
    background-color: var(--rz-base-background-color);
    border: 1px solid var(--rz-border-color);
}

.favorite-fields-scroll {
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
}

.favorite-fields-scroll::-webkit-scrollbar {
    width: 5px;
}

.favorite-fields-scroll::-webkit-scrollbar-track {
    background: transparent;
}

.favorite-fields-scroll::-webkit-scrollbar-thumb {
    background-color: var(--rz-base-400);
    border-radius: 10px;
}

.favorite-fields-scroll::-webkit-scrollbar-thumb:hover {
    background-color: var(--rz-base-500);
}

.favorite-field-card {
    background-color: var(--rz-base-background-color);
    border: 1px solid rgb(20 20 20 / 9%);
    transition: all 0.25s cubic-bezier(0.165, 0.84, 0.44, 1);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.02);
}

.favorite-field-card:hover {
    border-color: var(--rz-primary) !important;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.06);
    transform: translateY(-2px);
}

.favorite-field-label {
    font-size: 0.725rem;
    text-transform: uppercase;
    letter-spacing: 0.75px;
}

.favorite-field-value {
    font-size: 0.95rem;
    color: var(--rz-text-color);
}

.favorite-fields-empty-container {
    border: 2px dashed var(--rz-border-color);
    background-color: rgba(var(--rz-base-background-color-rgb), 0.5);
}

.favorite-fields-empty-icon {
    font-size: 2.5rem;
    color: var(--rz-text-tertiary-color);
    margin-bottom: 0.75rem;
}

.favorite-fields-empty-title {
    font-size: 0.95rem;
}

.favorite-fields-empty-text {
    font-size: 0.85rem;
}

.file-card-limit-icon,
.file-entry-limit-icon {
    color: var(--rz-danger);
    font-size: 1rem;
    margin-left: 0.25rem;
    vertical-align: middle;
}

.file-entry-limit-icon {
    margin-right: 0.25rem;
}

/* Estilos para o estado de compressão do PDF */
.file-card-compressing {
    opacity: 0.75;
    background: var(--rz-base-100);
    border-radius: var(--rz-border-radius);
}

.file-card-progress {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    margin-top: 0.25rem;
    background: var(--rz-base-50);
    border-radius: var(--rz-border-radius);
}

.file-card-progress .rz-progressbar {
    flex: 1;
    min-height: 6px;
}

.file-card-progress-text {
    font-size: 0.75rem;
    color: var(--rz-text-secondary-color);
    white-space: nowrap;
}

/* Estilos para o estado de compressão do PDF - Folder View */
.folder-file-card-compressing {
    opacity: 0.75;
    background: var(--rz-base-100);
}

.folder-file-card-progress {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    margin-top: 0.25rem;
    background: var(--rz-base-50);
    border-radius: var(--rz-border-radius);
}

.folder-file-card-progress .rz-progressbar {
    flex: 1;
    min-height: 6px;
}

.folder-file-card-progress-text {
    font-size: 0.75rem;
    color: var(--rz-text-secondary-color);
    white-space: nowrap;
}
