html {
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
    /* Egész app: rem-alapú szöveg ~6% nagyobb (Bootstrap, Mud felülírás, téma változók) */
    font-size: calc(1rem * var(--app-font-scale, 1.0625));
}

html, body {
    font-family: var(--app-font-family, 'Helvetica Neue', Helvetica, Arial, system-ui, sans-serif) !important;
    line-height: var(--app-line-height-body, 1.5);
    width: 100%;
    max-width: 100vw;
    margin: 0;
    padding: 0;
    overflow-x: hidden;
}

body {
    font-size: var(--app-font-size-base, 1rem);
}

/* MudBlazor vászon: a téma betűje minden méreten (különben mobilon a Material/Roboto-stack dominálhat a tartalomban) */
.mud-layout,
.mud-main-content,
.mud-main-content .mud-container {
    font-family: var(--app-font-family) !important;
    font-size: var(--app-font-size-base);
    line-height: var(--app-line-height-body);
}

/* Radzen dialógus / megerősítő – gyökéren kívül jelenhet meg, örökítse a témát */
body .rz-dialog,
body .rz-dialog-wrap,
body .rz-popup,
body .rz-confirmdialog,
body .rz-notification {
    font-family: var(--app-font-family) !important;
    font-size: var(--app-font-size-base);
    line-height: var(--app-line-height-body);
}

/* MudBlazor typography: téma betűtípusa és betűmérete (app-theme.css változóiból) */
.mud-typography-body1,
.mud-typography-body2,
.mud-typography-h1, .mud-typography-h2, .mud-typography-h3,
.mud-typography-h4, .mud-typography-h5, .mud-typography-h6,
.mud-typography-caption, .mud-typography-subtitle1, .mud-typography-subtitle2 {
    font-family: var(--app-font-family) !important;
}
.mud-typography-body1 { font-size: var(--app-font-size-body1) !important; }
.mud-typography-body2 { font-size: var(--app-font-size-body2) !important; }
.mud-typography-h1, .mud-typography-h2, .mud-typography-h3 { font-size: var(--app-font-size-h4) !important; }
.mud-typography-h4 { font-size: var(--app-font-size-h4) !important; }
.mud-typography-h5, .mud-typography-h6 { font-size: var(--app-font-size-h6) !important; }
.mud-typography-caption { font-size: var(--app-font-size-caption) !important; }
.mud-typography-subtitle1, .mud-typography-subtitle2 { font-size: var(--app-font-size-body2) !important; }

/* MudBlazor layout és AppBar teljes képernyőszélesség */
.mud-layout {
    width: 100% !important;
    max-width: 100% !important;
}

.mud-appbar {
    width: 100% !important;
    max-width: 100% !important;
}

/* AppBar toolbar: flex és spacer, hogy a felhasználói menü jobbra kerüljön */
.mud-appbar .mud-toolbar-appbar {
    display: flex !important;
    flex-wrap: nowrap;
    width: 100%;
}

/* MudAppBarSpacer kitölti a maradék helyet (Blazor custom element) */
.mud-appbar .mud-toolbar-appbar mudappbarspacer,
.mud-appbar .mud-toolbar-appbar .mud-appbar-spacer {
    flex: 1 1 auto !important;
    min-width: 0.5rem;
}

/* Felhasználói menü jobbra (ha a spacer nem elég) */
.mud-appbar .mud-toolbar-appbar > .mud-menu,
.mud-appbar .mud-toolbar-appbar > .mud-button {
    margin-left: auto;
}

/* Fejléc felhasználónév: kisebb sorköz, ha két sorba törik */
.mud-appbar .mud-toolbar-appbar > .mud-menu .mud-button-root {
    line-height: 1.25;
}
.mud-appbar .mud-toolbar-appbar > .mud-menu .mud-button-root .mud-button-label {
    line-height: 1.25;
}

a, .btn-link {
    color: var(--app-color-link, #006bb7);
}

/* Ikon színezés – AppThemeManager.BootstrapSemantic / app-theme.css --app-icon-* */
.app-icon-tone-primary {
    color: var(--app-icon-primary, #0d6efd) !important;
}
.app-icon-tone-secondary {
    color: var(--app-icon-secondary, #6c757d) !important;
}
.app-icon-tone-success {
    color: var(--app-icon-success, #198754) !important;
}
.app-icon-tone-info {
    color: var(--app-icon-info, #0dcaf0) !important;
}
.app-icon-tone-warning {
    color: var(--app-icon-warning, #ffc107) !important;
}
.app-icon-tone-danger {
    color: var(--app-icon-danger, #dc3545) !important;
}

.btn-primary {
    color: #fff;
    background-color: var(--app-color-primary, #1b6ec2);
    border-color: var(--app-color-primary-dark, #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 #258cfb;
}

.content {
    padding-top: 1.1rem;
}

h1:focus {
    outline: none;
}

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

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

.validation-message {
    color: #e50000;
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
    color: var(--bs-secondary-color);
    text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
    text-align: start;
}

/* Bootstrap táblázat: kis képernyőn kártyaszerű layout – oszlop + érték törhet; végső esetben vízszintes görgetés a kártyán belül */
@media (max-width: 768px) {
    .table-responsive-cards.table-responsive {
        overflow-x: auto;
        max-width: 100%;
        -webkit-overflow-scrolling: touch;
    }
    .table-responsive-cards .table {
        margin-bottom: 0;
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
    }
    .table-responsive-cards thead {
        display: none;
    }
    .table-responsive-cards tbody tr {
        display: block;
        border: 1px solid #dee2e6;
        border-radius: 0.25rem;
        margin-bottom: 1rem;
        background: #fff;
        box-shadow: 0 1px 3px rgba(0,0,0,0.06);
        max-width: 100%;
        box-sizing: border-box;
    }
    .table-responsive-cards tbody td {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        align-items: flex-start;
        gap: 0.75rem;
        padding: 0.5rem 0.75rem;
        border: none;
        border-bottom: 1px solid #f0f0f0;
        min-width: 0;
        max-width: 100%;
        overflow-wrap: break-word;
        word-break: break-word;
        font-family: var(--app-font-family) !important;
        font-size: var(--app-font-size-body1);
        line-height: var(--app-line-height-body);
    }
    .table-responsive-cards tbody td:last-child {
        border-bottom: none;
    }
    .table-responsive-cards tbody td::before {
        content: attr(data-label);
        font-weight: var(--app-table-card-data-label-font-weight);
        flex-shrink: 0;
        font-family: var(--app-font-family) !important;
        font-size: var(--app-font-size-compact-label);
        line-height: var(--app-line-height-body);
        color: var(--bs-secondary-color, #6c757d);
    }
}

/*
 * Adatlistához tartozó kártya fejléc: műveletgombok (Bootstrap .btn).
 * Mobil: teljes szélesség, egymás alatt; tablet: törhető sor; asztali: egy sor, jobbra igazítva, kompakt egyenlő cellák.
 * Használat: a .card-header belsejében <div class="table-card-header-actions w-100 w-md-auto">…</div>
 */
.table-card-header-actions {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    width: 100%;
}

.table-card-header-actions .btn {
    width: 100%;
    text-align: center;
}

@media (min-width: 576px) and (max-width: 767.98px) {
    .table-card-header-actions {
        flex-direction: row;
        flex-wrap: wrap;
    }

    .table-card-header-actions .btn {
        width: auto;
        flex: 1 1 12rem;
    }
}

@media (min-width: 768px) {
    /* Kitölti a fejléc vízszintes maradék helyét, a gombok sorát jobbra zárja (LTR). */
    .table-card-header-actions {
        flex: 1 1 auto;
        flex-direction: row;
        flex-wrap: nowrap;
        justify-content: flex-end;
        gap: 0.5rem;
        min-width: 0;
        width: auto;
        margin-left: auto;
    }

    .table-card-header-actions > .btn,
    .table-card-header-actions > a.btn {
        flex: 1 1 0;
        min-width: 0;
        width: auto;
        max-width: var(--app-table-card-header-btn-col-max, 11rem);
        white-space: normal;
        line-height: 1.25;
        font-size: var(--app-table-card-header-btn-font-size, 0.8rem);
        padding-left: 0.35rem;
        padding-right: 0.35rem;
    }
}

/* Árajánlatok: Bootstrap „Radzen-szerű” szűrősáv címkék (kompakt, fejléc-szerű) */
.app-offers-bootstrap-demo .app-offers-filter-label {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--bs-secondary-color);
}

.app-offers-bootstrap-demo .app-offers-filter-panel {
    border-color: rgba(var(--bs-secondary-rgb, 108, 117, 125), 0.35) !important;
}

.app-offers-bootstrap-demo .app-offers-pageload {
    min-height: 12rem;
}

/* Árajánlatok: client-side lapozás – átlátszó réteg + halvány táblázat */
.app-offers-bootstrap-demo .app-offers-paging-overlay {
    position: absolute;
    inset: 0;
    z-index: 2;
    background: rgba(var(--bs-body-bg-rgb, 255, 255, 255), 0.68);
    backdrop-filter: blur(2px);
    pointer-events: all;
    cursor: wait;
}

.app-offers-bootstrap-demo .app-offers-paging-dim {
    opacity: 0.45;
    transition: opacity 0.12s ease-out;
    pointer-events: none;
}

/*
 * Számlák – Radzen oldal: tipográfia = Bootstrap 5 + AppThemeManager / app-theme.css (:root).
 */
.app-invoices-radzen-page {
    font-family: var(--app-font-family) !important;
    font-size: var(--app-font-size-base);
    line-height: var(--app-line-height-body);
}

.app-invoices-radzen-page h2 {
    font-family: var(--app-font-family) !important;
    font-size: var(--app-font-size-h4);
    font-weight: 600;
    line-height: 1.2;
}

.app-invoices-radzen-page .card {
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
}

.app-invoices-radzen-page .rz-badge {
    font-size: var(--app-font-size-caption);
    font-weight: var(--app-table-list-header-badge-font-weight);
    line-height: 1.5;
}

/* Számlák – fizetési státusz: Bootstrap .badge + app-theme.css (--app-invoice-pay-*) */
.app-invoices-radzen-page .app-inv-pay-badge {
    font-size: var(--app-font-size-caption);
    font-weight: var(--app-table-list-header-badge-font-weight);
    line-height: 1.5;
}

.app-invoices-radzen-page .app-inv-pay-badge--paid {
    background-color: var(--app-invoice-pay-paid-bg) !important;
    color: var(--app-invoice-pay-paid-color) !important;
}

.app-invoices-radzen-page .app-inv-pay-badge--partial {
    background-color: var(--app-invoice-pay-partial-bg) !important;
    color: var(--app-invoice-pay-partial-color) !important;
}

.app-invoices-radzen-page .app-inv-pay-badge--outstanding {
    background-color: var(--app-invoice-pay-outstanding-bg) !important;
    color: var(--app-invoice-pay-outstanding-color) !important;
}

.app-invoices-radzen-page .app-inv-pay-badge--expired {
    background-color: var(--app-invoice-pay-expired-bg) !important;
    color: var(--app-invoice-pay-expired-color) !important;
}

.app-invoices-radzen-page .app-inv-pay-badge--none,
.app-invoices-radzen-page .app-inv-pay-badge--unknown {
    background-color: var(--app-invoice-pay-none-bg) !important;
    color: var(--app-invoice-pay-none-color) !important;
}

/* Számlák: szűrők a rács felett, külön DOM */
.app-inv-external-filters {
    box-sizing: border-box;
    padding: 0.85rem 1rem;
    margin-bottom: 0.35rem;
    border: 1px solid rgba(33, 37, 41, 0.12);
    border-radius: var(--rz-border-radius, 4px);
    background-color: rgba(33, 37, 41, 0.03);
    font-size: var(--app-font-size-table-filter);
    line-height: var(--app-line-height-body);
}

.app-inv-external-filters .rz-label,
.app-inv-external-filters .rz-textbox,
.app-inv-external-filters .rz-datepicker,
.app-inv-external-filters .rz-dropdown {
    font-size: inherit;
}

.app-inv-external-filters__actions {
    flex: 0 0 auto;
    margin-inline-start: auto;
    align-self: flex-end;
}

.app-invoices-datagrid {
    font-size: var(--app-font-size-table-cell);
    line-height: var(--app-line-height-body);
}

/*
 * Tábla szöveg: alkalmazás betűje.
 * Ne legyen font-family a teljes table / thead th elemen: a rendezés ikonok (rzi) külön ikonfontot használnak.
 */
.app-invoices-datagrid .rz-grid-table thead th .rz-column-title,
.app-invoices-datagrid .rz-grid-table tbody td,
.app-invoices-datagrid .rz-grid-table tbody td .rz-cell-data,
.app-invoices-datagrid .rz-grid-table tbody td .rz-link,
.app-invoices-datagrid .rz-data-grid > nav.rz-pager .rz-pager-summary,
.app-invoices-datagrid .rz-data-grid > nav.rz-pager .rz-pagesize-text {
    font-family: var(--app-font-family) !important;
}

.app-invoices-datagrid .rz-button,
.app-invoices-datagrid a.rz-button,
.app-invoices-datagrid .rz-pager-element,
.app-invoices-datagrid .rz-paginator .rz-button,
.app-invoices-datagrid .rz-paginator .rz-dropdown,
.app-invoices-datagrid .rz-data-grid > nav.rz-pager .rz-dropdown,
.app-invoices-datagrid .rz-data-grid > nav.rz-pager .rz-pager-pages {
    font-family: var(--app-font-family) !important;
}

.app-invoices-datagrid .rz-grid-table tbody td,
.app-invoices-datagrid .rz-grid-table .rz-cell-data {
    font-size: var(--app-font-size-table-cell);
    line-height: var(--app-line-height-body);
}

/* Ne a teljes .rz-stack legyen félkövér: a rendezés ikon (.rzi) Material fonttal elromlik vastagítás + nem Material betűnél */
.app-invoices-datagrid .rz-grid-table thead th .rz-stack {
    font-size: var(--app-font-size-table-header);
    line-height: var(--app-line-height-body);
    font-weight: normal;
}

.app-invoices-datagrid .rz-grid-table thead th .rz-column-title {
    font-size: var(--app-font-size-table-header);
    line-height: var(--app-line-height-body);
    font-weight: var(--app-table-column-header-font-weight);
}

/* A rendezés ikon gyakran span.rzi a cím belsejében — ne örökölje aHelvetica + félkövért a .rz-column-title span selektor nélkül */
.app-invoices-datagrid .rz-grid-table thead .rzi,
.app-invoices-datagrid .rz-grid-table thead th .rz-column-title .rzi {
    font-family: 'Material Icons', sans-serif !important;
    font-weight: normal !important;
    font-style: normal !important;
    font-size: 1.5em !important;
    line-height: 1 !important;
    letter-spacing: normal !important;
    text-transform: none !important;
    display: inline-block !important;
}

/* Számlák rács: „Műveletek” – ikonok egymás mellett, csoport középre igazítva */
.app-invoices-datagrid .app-inv-row-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 0.35rem 0.5rem;
    min-width: 0;
    width: 100%;
    box-sizing: border-box;
}

.app-invoices-datagrid .app-inv-row-actions__none {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2rem;
    padding-inline: 0.25rem;
    flex: 0 0 auto;
}

.app-invoices-datagrid .app-inv-row-actions .app-inv-action-btn.btn {
    flex: 0 0 auto;
    width: auto;
    min-width: 0;
    box-sizing: border-box;
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
}

/* Asztal: műveletgombok csak ikon – négyzetes, középre zárt ikon; ≤768px: ikon + felirat */
@media (min-width: 769px) {
    .app-invoices-datagrid .app-inv-row-actions .app-inv-action-btn--compact-desktop .app-inv-action-btn__label {
        display: none !important;
    }

    /* Közelít a táblabeli btn-sm ikonos gombokhoz (Árajánlatok listája) */
    .app-invoices-datagrid .app-inv-row-actions .app-inv-action-btn--compact-desktop.btn {
        width: 2rem;
        height: 2rem;
        min-width: 2rem;
        min-height: 2rem;
        padding: 0;
        gap: 0;
        line-height: 1;
    }

    .app-invoices-datagrid .app-inv-row-actions .app-inv-action-btn--compact-desktop.btn .bi {
        font-size: 1rem;
        line-height: 1;
    }
}

@media (max-width: 768px) {
    .app-invoices-datagrid .app-inv-row-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .app-invoices-datagrid .app-inv-row-actions .app-inv-action-btn.btn {
        width: 100%;
    }
}

/* Számlaszám (első oszlop) értékek – fejléccel azonos félkövér */
.app-invoices-datagrid tbody > tr.rz-data-row > td:first-child .rz-cell-data {
    font-weight: var(--app-table-column-header-font-weight);
}

.app-invoices-datagrid .rz-paginator,
.app-invoices-datagrid .rz-paginator .rz-dropdown,
.app-invoices-datagrid .rz-paginator .rz-pager-element,
.app-invoices-datagrid .rz-data-grid > nav.rz-pager,
.app-invoices-datagrid .rz-data-grid > nav.rz-pager .rz-dropdown,
.app-invoices-datagrid .rz-data-grid > nav.rz-pager .rz-pager-element {
    font-size: var(--app-font-size-table-filter);
}

/*
 * Számlák grid: két lapozó (TopAndBottom). Fent összeg + „Oldalméret” + legördülő; lent csak gombok.
 * Fent: összeg balra; címke + legördülő egy csoportban jobbra (margin-inline-start: auto a címkén).
 */
.app-invoices-datagrid .rz-data-grid > nav.rz-pager:first-of-type {
    display: flex !important;
    box-sizing: border-box;
    width: 100%;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-start !important;
    gap: 0.5rem 0.35rem;
}

.app-invoices-datagrid .rz-data-grid > nav.rz-pager:first-of-type .rz-pager-pages {
    display: none !important;
}

.app-invoices-datagrid .rz-data-grid > nav.rz-pager:first-of-type .rz-pager-summary {
    order: 1;
    text-align: left;
    flex: 0 0 auto;
    background-color: var(--app-datagrid-paging-summary-bg, #cfe2ff);
    color: var(--app-datagrid-paging-summary-color, #052c65) !important;
    padding: 0.4rem 0.75rem;
    border-radius: var(--rz-border-radius, 4px);
    box-sizing: border-box;
    font-weight: 600;
    line-height: 1.35;
}

.app-invoices-datagrid .rz-data-grid > nav.rz-pager:first-of-type .rz-pager-summary * {
    color: inherit !important;
}

/* „Oldalméret:” közvetlenül a legördülő balján, a pár együtt jobbra igazítva */
.app-invoices-datagrid .rz-data-grid > nav.rz-pager:first-of-type .rz-pagesize-text {
    order: 2;
    flex: 0 0 auto;
    white-space: nowrap;
    text-align: start;
    margin-inline-start: auto;
    margin-inline-end: 0.1rem;
    padding-inline: 0;
}

.app-invoices-datagrid .rz-data-grid > nav.rz-pager:first-of-type .rz-dropdown {
    order: 3;
    margin-inline-start: 0 !important;
    flex: 0 0 auto;
}

/* Alsó lapozó: összeg és oldalméret rejtve; csak gombok */
.app-invoices-datagrid .rz-data-grid > nav.rz-pager:last-of-type .rz-pager-summary,
.app-invoices-datagrid .rz-data-grid > nav.rz-pager:last-of-type .rz-dropdown,
.app-invoices-datagrid .rz-data-grid > nav.rz-pager:last-of-type .rz-pagesize-text {
    display: none !important;
}

.app-invoices-datagrid .rz-data-grid > nav.rz-pager:last-of-type {
    display: flex !important;
    box-sizing: border-box;
    width: 100%;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.45rem 0.65rem;
    padding-block: 0.4rem;
}

.app-invoices-datagrid .rz-data-grid > nav.rz-pager:last-of-type .rz-pager-pages {
    flex: 0 1 auto;
    justify-content: center !important;
    min-width: 0;
    gap: 0.3rem;
}

/* Radzen alapból „szétfeszíti” az első/előző vs. következő/utolsó gombokat (.rz-pager-pages space-between + auto margók) */
.app-invoices-datagrid .rz-data-grid > nav.rz-pager:last-of-type .rz-pager-pages > .rz-pager-item {
    margin-inline: 0 !important;
}

.app-invoices-datagrid .rz-data-grid > nav.rz-pager:last-of-type .rz-pager-pages .rz-pager-first,
.app-invoices-datagrid .rz-data-grid > nav.rz-pager:last-of-type .rz-pager-pages .rz-pager-prev,
.app-invoices-datagrid .rz-data-grid > nav.rz-pager:last-of-type .rz-pager-pages .rz-pager-next,
.app-invoices-datagrid .rz-data-grid > nav.rz-pager:last-of-type .rz-pager-pages .rz-pager-last {
    margin-inline-start: 0 !important;
    margin-inline-end: 0 !important;
}

/* Alsó lapozó: nagyobb gombok (olvashatóság + érintés) */
.app-invoices-datagrid .rz-data-grid > nav.rz-pager:last-of-type .rz-pager-element {
    font-size: 1.125rem;
    line-height: 1.3;
    min-height: 2.75rem;
    min-width: 2.65rem;
    padding-inline: 0.5rem;
}

@media (max-width: 768px) {
    /*
     * Felső lapozó: első sor = összeg teljes szélesség; második soron „Oldalméret” + legördülő jobbra
     * (justify-content: flex-end – a margin-inline-start: auto egyes böngészőkön nem vált második sort).
     */
    .app-invoices-datagrid .rz-data-grid > nav.rz-pager:first-of-type {
        padding-block: 0.25rem;
        overflow-x: visible;
        justify-content: flex-end !important;
    }

    .app-invoices-datagrid .rz-data-grid > nav.rz-pager:first-of-type .rz-pager-summary {
        flex: 0 0 100%;
        width: 100%;
        max-width: 100%;
        min-width: 0;
        padding: 0.45rem 0.65rem !important;
        text-align: center !important;
        white-space: normal;
        overflow-wrap: anywhere;
        word-break: break-word;
        font-size: var(--app-font-size-caption);
        font-weight: 600;
        line-height: 1.4;
    }

    .app-invoices-datagrid .rz-data-grid > nav.rz-pager:first-of-type .rz-pagesize-text {
        margin-inline-start: 0 !important;
        font-size: var(--app-font-size-caption);
    }

    .app-invoices-datagrid .rz-data-grid > nav.rz-pager:first-of-type .rz-dropdown {
        flex: 0 1 auto;
        min-width: 0;
        width: auto;
        max-width: min(10rem, 42vw);
    }

    .app-invoices-datagrid .rz-data-grid > nav.rz-pager:first-of-type .rz-pagesize-text,
    .app-invoices-datagrid .rz-data-grid > nav.rz-pager:first-of-type .rz-dropdown {
        align-self: center;
    }

    /* Alsó: Radzen néha gridet ad – felülírás; szűkebb vízszintes rés a tördelésnél */
    .app-invoices-datagrid .rz-data-grid > nav.rz-pager:last-of-type {
        justify-content: center !important;
        grid-template-columns: unset !important;
        gap: 0.45rem 0.5rem;
    }

    .app-invoices-datagrid .rz-data-grid > nav.rz-pager:last-of-type .rz-pager-pages {
        display: flex !important;
        flex: 1 1 100%;
        flex-wrap: wrap;
        justify-content: center !important;
        align-items: center;
        align-content: center;
        width: 100%;
        max-width: 100%;
        min-width: 0;
    }

    .app-invoices-datagrid .rz-data-grid > nav.rz-pager:last-of-type .rz-pager-item {
        grid-column: unset !important;
        margin-inline-start: 0 !important;
        margin-inline-end: 0 !important;
    }
}

.app-invoices-datagrid .rz-cell-filter .rz-textbox,
.app-invoices-datagrid .rz-cell-filter .rz-numeric,
.app-invoices-datagrid .rz-cell-filter .rz-datepicker,
.app-invoices-datagrid .rz-cell-filter .rz-dropdown {
    font-size: var(--app-font-size-table-filter);
}

/*
 * Számlák – külső szűrőpanel: asztalon a szűrőmezőknél nincs dupla címke; keskeny nézetben a panelen látszanak a címkék.
 */
@media (min-width: 769px) {
    .app-invoices-datagrid .app-inv-filter-field__label {
        display: none !important;
    }
}

/* Számlák grid: enyhén kontúrosabb sorok (vonalszín + csíkozás), táblafejléc félkövér */
.app-invoices-datagrid .rz-grid-table tbody > tr.rz-data-row > td {
    border-bottom: 1px solid rgba(33, 37, 41, 0.13);
}

.app-invoices-datagrid .rz-grid-table-striped tbody > tr:nth-child(even):not(.rz-state-highlight) > td:not(.rz-frozen-cell) {
    background-color: rgba(33, 37, 41, 0.055);
}

/* Számlák: teljesítés dátum – Tól / Ig egy szűrőcellában */
.app-invoices-datagrid .app-inv-filter-field--date-range {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.35rem;
    width: 100%;
    min-width: 0;
}

.app-invoices-datagrid .app-inv-filter-field--date-range .app-inv-filter-field__row {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem 0.5rem;
    min-width: 0;
}

.app-invoices-datagrid .app-inv-filter-field--date-range .app-inv-filter-field__sublabel {
    flex: 0 0 auto;
    width: 1.75rem;
    font-family: var(--app-font-family) !important;
    font-size: var(--app-font-size-compact-label);
    font-weight: var(--app-table-filter-sublabel-font-weight);
    line-height: 1.2;
    color: var(--rz-text-secondary-color, rgba(33, 37, 41, 0.7));
}

.app-invoices-datagrid .app-inv-filter-field--date-range .app-inv-filter-field__ctrl {
    flex: 1 1 8rem;
    min-width: 0;
}

/*
 * Számlák reflow (≤768px): szűrés külön DOM → thead rejtve.
 * Egy sorban: cím balra, érték jobbra. Ha nem férnek el: flex-wrap → az érték blokk a cím alá kerül (nincs vízszintes scrollbar), szöveg természetes törde.
 */
@media (max-width: 768px) {
    .app-invoices-radzen-page .app-invoices-datagrid,
    .app-invoices-radzen-page .app-invoices-datagrid .rz-datatable-reflow tbody tr.rz-data-row > td,
    .app-invoices-radzen-page .app-invoices-datagrid .rz-datatable-reflow tbody .rz-cell-data {
        font-family: var(--app-font-family) !important;
    }

    .app-invoices-datagrid .rz-datatable-reflow thead {
        display: none !important;
    }

    .app-invoices-datagrid .rz-datatable-reflow tbody tr.rz-data-row > td {
        display: flex !important;
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
        justify-content: flex-start;
        gap: 0.35rem 0.75rem;
        padding-top: 0.5rem;
        padding-bottom: 0.5rem;
        box-sizing: border-box;
        min-width: 0;
        max-width: 100%;
    }

    .app-invoices-datagrid .rz-datatable-reflow tbody tr.rz-data-row > td > .rz-column-title {
        display: block !important;
        flex: 0 1 auto;
        min-width: 0;
        max-width: 100%;
        text-align: start;
        font-family: var(--app-font-family) !important;
        font-weight: var(--app-table-reflow-row-label-font-weight);
        font-size: var(--app-font-size-compact-label);
        line-height: 1.35;
        text-transform: uppercase;
        letter-spacing: 0.03em;
        color: var(--rz-text-tertiary-color, #6c757d);
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .app-invoices-datagrid .rz-datatable-reflow tbody tr.rz-data-row > td > .rz-cell-data {
        flex: 1 1 10rem;
        min-width: 0;
        max-width: 100%;
        font-family: var(--app-font-family) !important;
        font-size: var(--app-font-size-table-cell);
        line-height: var(--app-line-height-body);
        text-align: end !important;
        white-space: normal;
        overflow: visible;
        overflow-wrap: break-word;
        word-break: break-word;
    }

    .app-invoices-datagrid .rz-datatable-reflow tbody tr.rz-data-row > td > .rz-cell-data.rz-text-align-center {
        text-align: center !important;
    }
}

/* Bejelentkezési / nyilvános oldalak layout (EmptyLayout) */
.auth-layout {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(160deg, #1b6ec2 0%, #1861ac 40%, #0d3d6b 100%);
    padding: 1.5rem;
    box-sizing: border-box;
}

.auth-layout__inner {
    width: 100%;
    max-width: 420px;
}

.auth-card {
    width: 100%;
    border-radius: 12px;
    overflow: hidden;
}

.auth-card-header {
    flex-direction: column;
    padding: 1.5rem 1.5rem 0.5rem;
}

.auth-card-logo {
    margin-bottom: 0.75rem;
}

.auth-card-logo img {
    height: 48px;
    width: auto;
    display: block;
    margin: 0 auto;
}

.auth-card-title {
    font-weight: 600 !important;
}

.auth-card-subtitle {
    opacity: 0.85;
}

.auth-submit-btn {
    text-transform: none;
    font-weight: 600;
    padding: 0.6rem 1rem;
}

.auth-link {
    color: var(--app-color-primary, #1b6ec2) !important;
    text-decoration: none;
}

.auth-link:hover {
    text-decoration: underline;
}

/* Bejelentkezési form natív inputok (POST-hoz name szükséges) */
.auth-field {
    display: block;
}

.auth-label {
    display: block;
    margin-bottom: 0.35rem;
    font-size: 0.75rem;
    font-weight: 500;
    color: rgba(0, 0, 0, 0.6);
}

.auth-input {
    width: 100%;
    padding: 0.6rem 1rem;
    font-size: 1rem;
    font-family: inherit;
    border: 1px solid rgba(0, 0, 0, 0.23);
    border-radius: 4px;
    background: #fff;
    box-sizing: border-box;
    transition: border-color 0.2s;
}

.auth-input:hover {
    border-color: rgba(0, 0, 0, 0.4);
}

.auth-input:focus {
    outline: none;
    border-color: var(--app-color-primary, #1b6ec2);
    border-width: 2px;
    padding: calc(0.6rem - 1px) calc(1rem - 1px);
}

.auth-input::placeholder {
    color: rgba(0, 0, 0, 0.4);
}