/* Reset & Base */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    font-family: var(--font-family);
    background: var(--gradient-bg);
    color: var(--color-text);
    min-height: 100vh;
    font-size: var(--font-size-base);
    transition: background 0.3s ease, color 0.3s ease;
}

/* Glassmorphism Utilities */
.glass-panel {
    background: var(--glass-bg);
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border: 1px solid var(--glass-border);
    border-radius: 16px;
    box-shadow: var(--glass-shadow);
    padding: 24px;
}

.glass-input {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 12px 16px;
    color: var(--color-text);
    width: 100%;
    outline: none;
    transition: border-color 0.2s, background 0.2s;
}

[data-theme="light"] .glass-input {
    background: rgba(0, 0, 0, 0.03);
}

.glass-input:focus {
    border-color: var(--color-primary);
    background: rgba(var(--color-primary-rgb), 0.05);
}

.glass-button {
    background: var(--gradient-primary);
    color: white;
    border: none;
    border-radius: 8px;
    padding: 12px 24px;
    font-weight: 600;
    cursor: pointer;
    transition: transform 0.2s, box-shadow 0.2s;
    backdrop-filter: blur(4px);
}

.glass-button:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(var(--color-primary-rgb), 0.4);
}

/* Layout Utilities */
.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px;
}

.flex-center {
    display: flex;
    justify-content: center;
    align-items: center;
}

.flex-col {
    display: flex;
    flex-direction: column;
}

.gap-16 { gap: 16px; }
.gap-24 { gap: 24px; }

/* Text Utilities */
.text-primary { color: var(--color-primary); }
.text-muted { color: var(--color-text-muted); }
.text-center { text-align: center; }

h1, h2, h3 {
    margin-bottom: 16px;
    font-weight: 700;
}

a {
    color: var(--color-primary);
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

/* App layout: gradient background for all pages */
.app-layout {
    display: flex;
    min-height: 100vh;
    background: var(--gradient-bg) !important;
}
.app-layout .rz-sidebar {
    flex-shrink: 0;
    width: 260px;
    min-height: 100vh;
}
.app-layout .rz-body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    background: var(--gradient-bg) !important;
    transition: margin-left 0.25s ease;
}
.app-layout .rz-body .rz-content {
    flex: 1;
    overflow: auto;
}
/* Fejléc csak a tartalom fölött: ne legyen teljes szélességű, ne takarja az oldalsó menüt */
.app-layout .rz-body .rz-header {
    position: sticky !important;
    top: 0;
    left: auto !important;
    right: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    z-index: 100;
    flex-shrink: 0;
}
/* Becsukott oldalsó menü: tartalom teljes szélességű, a hely felszabadul */
.app-layout.sidebar-collapsed > *:first-child,
.app-layout.sidebar-collapsed .rz-sidebar {
    width: 0 !important;
    min-width: 0 !important;
    max-width: 0 !important;
    overflow: hidden !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    flex-shrink: 0 !important;
    transition: width 0.2s ease, min-width 0.2s ease;
}
.app-layout.sidebar-collapsed .rz-sidebar .rz-sidebar-header,
.app-layout.sidebar-collapsed .rz-sidebar .rz-panel-menu {
    opacity: 0;
    pointer-events: none;
}
/* Becsukott menünél a Radzen rz-body margin-left 0 (felülírja az inline 250px-et) */
.app-layout.sidebar-collapsed .rz-body {
    margin-left: 0 !important;
}
.main-content {
    padding: 20px 32px 32px 32px;
    color: var(--color-text);
    background: transparent;
}
.main-content-public {
    padding: 24px;
}

/* Dashboard: headings and stat cards */
.top-bar h2,
.dashboard-content h2 {
    color: var(--color-text) !important;
    margin: 0 0 4px 0;
}
.stat-card .stat-value,
.stat-card h3 {
    color: var(--color-text) !important;
}
.stat-card .rz-heading {
    color: var(--color-text-muted) !important;
}

/* Dashboard table inside card */
.rz-card table {
    color: var(--color-text) !important;
}
.rz-card th,
.rz-card td {
    border-color: var(--color-border) !important;
}

/* Radzen DataGrid (Foglalások, Szolgáltatások): glass/dark megjelenés, mint a dashboard táblázat */
.rz-card .rz-data-grid,
.rz-card .rz-data-grid .rz-data-grid-data,
.rz-card .rz-data-grid .rz-grid-table,
.rz-card .rz-data-grid table,
.rz-card .rz-data-grid .rz-datatable,
.rz-card .rz-data-grid .rz-datatable-scrollable-body,
.rz-card .rz-data-grid .rz-datatable-thead,
.rz-card .rz-data-grid .rz-datatable-tbody,
.rz-card .rz-data-grid .rz-datatable-tfoot,
.rz-card .rz-data-grid thead,
.rz-card .rz-data-grid tbody,
.rz-card .rz-data-grid tfoot {
    background: transparent !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}
.rz-card .rz-data-grid th,
.rz-card .rz-data-grid td,
.rz-card .rz-data-grid .rz-grid-table th,
.rz-card .rz-data-grid .rz-grid-table td,
.rz-card .rz-data-grid .rz-datatable-thead th,
.rz-card .rz-data-grid .rz-datatable-tbody td {
    background: transparent !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}
/* Grid minden szövege és ikonja olvasható dark mode-ban */
.rz-card .rz-data-grid .rz-column-title,
.rz-card .rz-data-grid th span,
.rz-card .rz-data-grid td span,
.rz-card .rz-data-grid th div,
.rz-card .rz-data-grid td div,
.rz-card .rz-data-grid .rz-grid-table th,
.rz-card .rz-data-grid .rz-grid-table td,
.rz-card .rz-data-grid .rz-grid-table th *,
.rz-card .rz-data-grid .rz-grid-table td *:not(.rz-button.rz-button-danger):not(.rz-badge) {
    color: var(--color-text) !important;
}
    .status-dd span.rz-dropdown-label.rz-inputtext,
    .rz-card .rz-data-grid .rz-dropdown:not(.status-dd) .rz-inputtext
    {
        background: none !important;
        font-size: 0.75rem;
        padding-top: 4px;
    }
/* Radzen DataGrid: vízszintes görgetés, ha a tartalom nem fér el */
.rz-card .rz-data-grid .rz-datatable-scrollable-body,
.rz-card .rz-data-grid .rz-data-grid-data {
    overflow-x: auto !important;
}
/* Grid belső scrollbar – vékony, lágy, DevExpress-szerű (csak a grid scroll területein) */
.rz-card .rz-data-grid .rz-datatable-scrollable-body,
.rz-card .rz-data-grid .rz-data-grid-data {
    scrollbar-width: thin;
    scrollbar-color: rgba(255, 255, 255, 0.25) transparent;
}
.rz-card .rz-data-grid .rz-datatable-scrollable-body::-webkit-scrollbar,
.rz-card .rz-data-grid .rz-data-grid-data::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
.rz-card .rz-data-grid .rz-datatable-scrollable-body::-webkit-scrollbar-track,
.rz-card .rz-data-grid .rz-data-grid-data::-webkit-scrollbar-track {
    background: transparent;
    border-radius: 4px;
}
.rz-card .rz-data-grid .rz-datatable-scrollable-body::-webkit-scrollbar-thumb,
.rz-card .rz-data-grid .rz-data-grid-data::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.2);
    border-radius: 4px;
}
.rz-card .rz-data-grid .rz-datatable-scrollable-body::-webkit-scrollbar-thumb:hover,
.rz-card .rz-data-grid .rz-data-grid-data::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.35);
}
.rz-card .rz-data-grid .rz-datatable-scrollable-body::-webkit-scrollbar-corner,
.rz-card .rz-data-grid .rz-data-grid-data::-webkit-scrollbar-corner {
    background: transparent;
}
/* Light mód: grid scrollbar világos téman */
[data-theme="light"] .rz-card .rz-data-grid .rz-datatable-scrollable-body,
[data-theme="light"] .rz-card .rz-data-grid .rz-data-grid-data {
    scrollbar-color: rgba(0, 0, 0, 0.2) transparent;
}
[data-theme="light"] .rz-card .rz-data-grid .rz-datatable-scrollable-body::-webkit-scrollbar-thumb,
[data-theme="light"] .rz-card .rz-data-grid .rz-data-grid-data::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.18);
}
[data-theme="light"] .rz-card .rz-data-grid .rz-datatable-scrollable-body::-webkit-scrollbar-thumb:hover,
[data-theme="light"] .rz-card .rz-data-grid .rz-data-grid-data::-webkit-scrollbar-thumb:hover {
    background: rgba(0, 0, 0, 0.3);
}
.rz-card .rz-data-grid .rz-grid-table {
    min-width: max-content;
}

/* Radzen téma sötét színének felülírása: grid teljes tartalma */
.rz-card .rz-data-grid .rz-data-grid-data,
.rz-card .rz-data-grid .rz-data-grid-data * {
    --rz-text-color: var(--color-text) !important;
    --rz-text-secondary-color: var(--color-text-muted) !important;
}
.rz-card .rz-data-grid .rz-grid-table th .rzi,
.rz-card .rz-data-grid .rz-grid-table td .rzi,
.rz-card .rz-data-grid .rz-button .rzi {
    color: inherit !important;
    fill: currentColor !important;
}
.rz-card .rz-data-grid .rz-grid-table tbody tr:hover td,
.rz-card .rz-data-grid .rz-datatable-tbody tr:hover td,
.rz-card .rz-data-grid tr.rz-state-highlight td {
    background: rgba(255, 255, 255, 0.05) !important;
}
.rz-card .rz-data-grid .rz-grid-table-striped tbody tr:nth-child(even) td {
    background: rgba(255, 255, 255, 0.03) !important;
}
.rz-card .rz-data-grid input.rz-input-text,
.rz-card .rz-data-grid .rz-textbox,
.rz-card .rz-data-grid input[type="text"],
.rz-card .rz-data-grid .rz-dropdown:not(.status-dd),
.rz-card .rz-data-grid .rz-dropdown:not(.status-dd) .rz-inputtext {
    background: rgba(255, 255, 255, 0.06) !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}

/* Státusz dropdown színezés (light + dark módban is) */
.rz-card .rz-data-grid .status-dd.rz-dropdown,
.status-dd.rz-dropdown {
    border-color: transparent !important;
    border-radius: 6px !important;
    color: #fff !important;
}
.rz-card .rz-data-grid .status-dd.rz-dropdown .rz-inputtext,
.rz-card .rz-data-grid .status-dd.rz-dropdown .rz-dropdown-label,
.rz-card .rz-data-grid .status-dd.rz-dropdown .rz-dropdown-trigger,
.status-dd.rz-dropdown .rz-inputtext,
.status-dd.rz-dropdown .rz-dropdown-label,
.status-dd.rz-dropdown .rz-dropdown-trigger {
    background: transparent !important;
    color: #fff !important;
    border-color: transparent !important;
}
.status-dd.rz-dropdown .rz-dropdown-trigger .rzi,
.status-dd.rz-dropdown .rz-dropdown-trigger svg {
    color: #fff !important;
    fill: #fff !important;
}
.rz-card .rz-data-grid .status-confirmed.rz-dropdown,
.status-confirmed.rz-dropdown {
    background: var(--color-primary) !important;
}
.rz-card .rz-data-grid .status-pending.rz-dropdown,
.status-pending.rz-dropdown {
    background: var(--color-cancel) !important;
}
.rz-card .rz-data-grid .status-cancelled.rz-dropdown,
.status-cancelled.rz-dropdown {
    background: var(--rz-danger) !important;
}
.rz-card .rz-data-grid .status-completed.rz-dropdown,
.status-completed.rz-dropdown {
    background: #9e9e9e !important;
}
.rz-card .rz-data-grid .rz-paginator,
.rz-card .rz-data-grid .rz-paginator *,
.rz-card .rz-data-grid .rz-datatable-emptymessage,
.rz-card .rz-data-grid .rz-group-header {
    background: transparent !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}
/* Grid gombok (Szerkesztés, stb.) – világos szöveg/ikon dark mode-ban */
.rz-card .rz-data-grid .rz-button,
.rz-card .rz-data-grid .rz-button.rz-button-secondary,
.rz-card .rz-data-grid .rz-button.rz-button-flat,
.rz-card .rz-data-grid .rz-button.rz-button-light,
.rz-card .rz-data-grid .rz-button.rz-button-icon-only,
.rz-card .rz-data-grid .rz-button.rz-variant-text {
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}
.rz-card .rz-data-grid .rz-button .rzi,
.rz-card .rz-data-grid .rz-button span {
    color: inherit !important;
    fill: currentColor !important;
}
.rz-card .rz-data-grid .rz-button:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    color: var(--color-text) !important;
}
.rz-card .rz-data-grid .rz-button svg,
.rz-card .rz-data-grid .rz-button path {
    fill: currentColor !important;
}
/* Felhasználók grid: Inaktiválás gomb sötét hátterű dark mode-ban, hogy az ikon látszódjon */
html:not([data-theme="light"]) .rz-button.rz-button-light.btn-toggle-active,
html:not([data-theme="light"]) .rz-card .rz-data-grid .rz-button.rz-button-light.btn-toggle-active,
body:not([data-theme="light"]) .rz-button.rz-button-light.btn-toggle-active {
    background: #495057 !important;
    border-color: #495057 !important;
    color: #fff !important;
}
html:not([data-theme="light"]) .rz-button.rz-button-light.btn-toggle-active:hover,
html:not([data-theme="light"]) .rz-card .rz-data-grid .rz-button.rz-button-light.btn-toggle-active:hover,
body:not([data-theme="light"]) .rz-button.rz-button-light.btn-toggle-active:hover {
    background: #5a6268 !important;
    border-color: #5a6268 !important;
    color: #fff !important;
}
html:not([data-theme="light"]) .rz-button.rz-button-light.btn-toggle-active .rzi,
html:not([data-theme="light"]) .rz-button.rz-button-light.btn-toggle-active svg,
html:not([data-theme="light"]) .rz-button.rz-button-light.btn-toggle-active path,
html:not([data-theme="light"]) .rz-card .rz-data-grid .rz-button.rz-button-light.btn-toggle-active .rzi,
html:not([data-theme="light"]) .rz-card .rz-data-grid .rz-button.rz-button-light.btn-toggle-active svg,
html:not([data-theme="light"]) .rz-card .rz-data-grid .rz-button.rz-button-light.btn-toggle-active path,
body:not([data-theme="light"]) .rz-button.rz-button-light.btn-toggle-active .rzi,
body:not([data-theme="light"]) .rz-button.rz-button-light.btn-toggle-active svg,
body:not([data-theme="light"]) .rz-button.rz-button-light.btn-toggle-active path {
    color: #fff !important;
    fill: #fff !important;
}
[data-theme="light"] .rz-card .rz-data-grid input.rz-input-text,
[data-theme="light"] .rz-card .rz-data-grid .rz-textbox,
[data-theme="light"] .rz-card .rz-data-grid input[type="text"] {
    background: rgba(0, 0, 0, 0.04) !important;
    color: #212121 !important;
}
[data-theme="light"] .rz-card .rz-data-grid tr.rz-state-highlight td,
[data-theme="light"] .rz-card .rz-data-grid .rz-grid-table tbody tr:hover td,
[data-theme="light"] .rz-card .rz-data-grid .rz-datatable-tbody tr:hover td {
    background: rgba(0, 0, 0, 0.04) !important;
}

/* Dashboard Layout & Mobile Nav */
/* Sidebar overrides for Radzen or custom */
.rz-sidebar {
    background: rgba(0, 0, 0, 0.2) !important;
    backdrop-filter: blur(10px);
    border-right: 1px solid var(--color-border);
}
.rz-sidebar .rz-sidebar-header {
    display: block;
    min-height: 80px;
    padding: 1rem 1.5rem;
    text-align: center;
    border-bottom: 1px solid var(--color-border);
}
.rz-sidebar .rz-sidebar-header img {
    display: block;
    max-height: 50px;
    width: auto;
    margin: 0 auto;
    object-fit: contain;
}

[data-theme="light"] .rz-sidebar {
    background: rgba(255, 255, 255, 0.6) !important;
    border-right: 1px solid rgba(0,0,0,0.1);
}

/* Mobile Bottom Nav */
.bottom-nav {
    display: none; /* Hidden by default (desktop) */
}

@media (max-width: 768px) {
    /* Design: ne legyen horizontális görgetés mobilon */
    html, body {
        overflow-x: hidden !important;
        max-width: 100vw;
    }
    .app-layout {
        overflow-x: hidden !important;
        max-width: 100vw;
        padding-bottom: 80px; /* design: hely az alsó menünek */
    }
    .app-layout .rz-body,
    .app-layout .rz-body .rz-content,
    .main-content {
        overflow-x: hidden !important;
        max-width: 100% !important;
        min-width: 0 !important;
    }
    
    .rz-sidebar {
        display: none !important; /* Hide sidebar on mobile */
    }

    /* Design: alsó menü mindig látható, fix pozíció, magas z-index */
    .bottom-nav {
        display: flex !important;
        position: fixed !important;
        bottom: 20px;
        left: 20px;
        right: 20px;
        width: calc(100vw - 40px);
        max-width: calc(100% - 40px);
        margin: 0 auto;
        /* Glass effect – design szerint */
        background: rgba(20, 20, 20, 0.1); 
        backdrop-filter: blur(30px);
        -webkit-backdrop-filter: blur(30px);
        border: 1px solid rgba(255, 255, 255, 0.15);
        border-radius: 24px; 
        justify-content: space-around;
        padding: 12px 16px;
        z-index: 9999;
        box-shadow: 0 8px 32px rgba(0,0,0,0.4);
    }

    [data-theme="light"] .bottom-nav {
        background: rgba(255, 255, 255, 0.4);
        border: 1px solid rgba(255, 255, 255, 0.6);
        box-shadow: 0 8px 32px rgba(0,0,0,0.15);
    }

    .bottom-nav-item {
        display: flex;
        flex-direction: column;
        align-items: center;
        color: #A0A0A0;
        text-decoration: none;
        font-size: 0.75rem;
        padding: 4px;
        transition: color 0.3s;
    }

    [data-theme="light"] .bottom-nav-item {
        color: #757575;
    }

    .bottom-nav-item.active {
        color: var(--color-primary) !important;
        font-weight: 600;
    }

    .bottom-nav-icon {
        font-size: 1.5rem;
        margin-bottom: 4px;
    }
    
    .main-content {
        padding: 20px !important; /* design: 20px */
        padding-bottom: 100px !important; /* hely az alsó menünek */
        box-sizing: border-box;
    }
    
    /* Admin: mobilon teljes szélesség, nincs bal margó */
    .app-layout .rz-body {
        margin-left: 0 !important;
        margin-top: 0 !important;
    }
    
    /* Admin fejléc mobilon: kompakt, kevesebb padding */
    .app-layout .rz-header {
        margin: 12px !important;
        padding: 10px 14px !important;
    }
    .app-layout .rz-header .rz-stack {
        flex-wrap: wrap;
        gap: 0.5rem !important;
    }
    .app-layout .rz-header .rz-text {
        font-size: 0.8rem !important;
        max-width: 120px;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
    
    /* Dashboard mobilon: olvasható címek, nincs levágás */
    .dashboard-content .top-bar {
        flex-wrap: wrap;
        margin-bottom: 20px !important;
        gap: 12px;
    }
    .dashboard-content .top-bar h2 {
        font-size: 1.25rem !important;
        word-wrap: break-word;
        overflow-wrap: break-word;
    }
    .dashboard-content .top-bar .text-muted {
        font-size: 0.85rem;
    }
    .dashboard-content .stat-card,
    .dashboard-content .rz-card {
        min-width: 0;
        max-width: 100%;
        overflow: visible;
    }
    .dashboard-content .rz-row,
    .dashboard-content .rz-column {
        min-width: 0 !important;
        max-width: 100% !important;
    }
    .dashboard-content .rz-card > div[style*="overflow-x: auto"],
    .dashboard-content .rz-card div[style*="overflow-x: auto"] {
        max-width: 100% !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch;
    }
    .main-content .rz-card,
    .main-content .dashboard-content {
        max-width: 100%;
    }
    .dashboard-content .stat-card .rz-heading,
    .dashboard-content .stat-card h3 {
        font-size: 0.85rem !important;
        word-wrap: break-word;
    }
    .dashboard-content .stat-value {
        font-size: 1.5rem !important;
    }
    .dashboard-content .rz-row {
        margin-bottom: 20px !important;
    }
    .dashboard-content .rz-column {
        margin-bottom: 12px;
    }
    .dashboard-content .rz-card h3.rz-heading,
    .dashboard-content .rz-card .rz-heading {
        font-size: 1rem !important;
        word-wrap: break-word;
    }
    .dashboard-content .rz-card table {
        font-size: 0.85rem;
    }
    .dashboard-content .rz-card th,
    .dashboard-content .rz-card td {
        padding: 8px 6px !important;
    }
    
    /* Admin oldalak (Foglalások, Szolgáltatások): kártya és grid mobilon */
    .main-content .rz-card {
        padding: 16px !important;
        margin-bottom: 16px;
    }
    .main-content .rz-card .rz-stack {
        flex-wrap: wrap;
    }
    .main-content .rz-card .rz-heading {
        font-size: 1.1rem !important;
    }
    
    /* Bottom nav: egyenlő hely, rövid címkék látszanak */
    .bottom-nav-item {
        min-width: 0;
        flex: 1;
        font-size: 0.7rem;
        text-align: center;
        padding: 6px 4px !important;
    }
}

.desktop-only { display: block; }
@media (max-width: 768px) { .desktop-only { display: none !important; } }

/* Login / Account Layout Styles */
.account-layout-body {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    background: linear-gradient(135deg, #0f0c29 0%, #302b63 50%, #24243e 100%);
}

[data-theme='light'] .account-layout-body {
    background: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%);
}

.login-card {
    width: 100%;
    max-width: 450px;
    position: relative;
    z-index: 1;
}

.logo-container {
    text-align: center;
    margin-bottom: 32px;
}

.logo-img {
    max-height: 100px;
    width: auto;
}

.bg-circle {
    position: fixed;
    border-radius: 50%;
    filter: blur(60px);
    z-index: 0;
    pointer-events: none;
}

.circle-1 {
    width: 300px; height: 300px;
    background: var(--color-primary);
    top: 10%; left: 20%;
    opacity: 0.2;
}

.circle-2 {
    width: 200px; height: 200px;
    background: var(--color-secondary);
    bottom: 10%; right: 20%;
    opacity: 0.2;
}

.theme-toggle-fixed {
    position: fixed;
    top: 20px;
    right: 20px;
    background: none;
    border: none;
    color: var(--color-text);
    cursor: pointer;
    font-size: 1.5rem;
    z-index: 100;
    opacity: 0.8;
}

.theme-toggle-fixed:hover { opacity: 1; }


/* Radzen Overrides for Glassmorphism */
.rz-card {
    background: var(--glass-bg) !important;
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border: 1px solid var(--glass-border) !important;
    border-radius: 16px !important;
    box-shadow: var(--glass-shadow) !important;
    color: var(--color-text) !important;
}

[data-theme='light'] .rz-card {
    background: rgba(255, 255, 255, 0.6) !important;
}

.rz-sidebar-toggle {
    color: var(--color-text) !important;
}

.rz-panel-menu {
    background: transparent !important;
}

.rz-navigation-item-link {
    color: var(--color-text-muted) !important;
}

.rz-navigation-item-wrapper-active .rz-navigation-item-link {
    background: rgba(255, 255, 255, 0.05) !important;
    color: var(--color-primary) !important;
}

.rz-navigation-item-link:hover {
    background: rgba(255, 255, 255, 0.05) !important;
    color: var(--color-primary) !important;
}

html:not([data-theme="light"]) .rz-navigation-item-link:hover .rzi,
html:not([data-theme="light"]) .rz-navigation-item-link:hover i {
    color: #fff !important;
}

.rz-header {
    flex-shrink: 0;
    background: var(--glass-bg) !important;
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border: 1px solid var(--glass-border) !important;
    color: var(--color-text) !important;
}

/* Dark mode: látható feliratok, gombok, ikonok (kontraszt) */
.rz-heading,
.rz-card .rz-heading,
.dashboard-content .rz-heading,
.main-content .rz-heading {
    color: var(--color-text) !important;
}
.rz-header .rz-button,
.rz-header .rz-button .rzi,
.rz-header .glass-button,
.rz-header button.glass-button {
    color: var(--color-text) !important;
    fill: currentColor !important;
}
.rz-header .rz-button .rzi {
    color: inherit !important;
}
.rz-card .rz-button.rz-button-secondary,
.rz-card .rz-button:not(.rz-button-primary):not(.rz-button-danger),
.rz-card .glass-button,
.main-content .rz-button.rz-button-secondary,
.main-content .rz-button:not(.rz-button-primary):not(.rz-button-danger),
.main-content .glass-button.rz-button {
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}
.rz-card .rz-button.rz-button-secondary .rzi,
.rz-card .rz-button:not(.rz-button-primary) .rzi,
.main-content .rz-button.rz-button-secondary .rzi,
.main-content .rz-button:not(.rz-button-primary) .rzi {
    color: inherit !important;
    fill: currentColor !important;
}
.rz-datepicker button.rz-datepicker-trigger.rz-button.rz-button-icon-only span.rz-button-icon-left.rzi.rzi-calendar {
    position: absolute;
    left: 0;
    top: 0;
}
/* Gombok háttérrel (glass), de világos szöveg/ikon dark mode-ban */
.glass-button.rz-button,
button.glass-button.rz-button {
    color: var(--color-text) !important;
}
.glass-button.rz-button .rzi,
button.glass-button .rzi {
    color: inherit !important;
    fill: currentColor !important;
}
/* Radzen Light gomb stílus felülírása dark háttérnél */
.rz-button.rz-button-light,
.rz-button.rz-button-secondary {
    color: var(--color-text) !important;
}
.rz-button.rz-button-light .rzi,
.rz-button.rz-button-secondary .rzi {
    color: inherit !important;
    fill: currentColor !important;
}
/* Ikonok (SVG) dark mode-ban láthatóak */
.rz-header .rz-button svg,
.rz-header .rz-button path,
.rz-card .rz-button:not(.rz-button-primary) svg,
.rz-card .rz-button:not(.rz-button-primary) path,
.main-content .rz-button:not(.rz-button-primary) svg,
.main-content .rz-button:not(.rz-button-primary) path {
    fill: currentColor !important;
}

/* Radzen Card: force glass look (override theme) */
.rz-card,
.rz-card.rz-component,
div.rz-card {
    background: var(--glass-bg) !important;
    backdrop-filter: blur(var(--glass-blur)) !important;
    -webkit-backdrop-filter: blur(var(--glass-blur)) !important;
    border: 1px solid var(--glass-border) !important;
    border-radius: 16px !important;
    box-shadow: var(--glass-shadow) !important;
    color: var(--color-text) !important;
}
.rz-card .rz-card-content,
.rz-card .rz-component-content {
    background: transparent !important;
    color: var(--color-text) !important;
}

[data-theme="light"] .rz-card,
[data-theme="light"] div.rz-card {
    background: rgba(255, 255, 255, 0.75) !important;
    border-color: rgba(0, 0, 0, 0.08) !important;
    color: #212121 !important;
}

/* Calendar page: Scheduler in glass panel, dark theme */
.calendar-glass.rz-card,
.calendar-glass {
    background: var(--glass-bg) !important;
    backdrop-filter: blur(var(--glass-blur)) !important;
    -webkit-backdrop-filter: blur(var(--glass-blur)) !important;
    border: 1px solid var(--glass-border) !important;
    border-radius: 16px !important;
    padding: 24px !important;
    color: var(--color-text) !important;
}
.calendar-glass .rz-scheduler,
.calendar-glass .rz-scheduler table,
.calendar-glass .rz-scheduler-content,
.calendar-glass .rz-scheduler-header,
.calendar-glass .rz-scheduler-body {
    background: rgba(30, 30, 30, 0.5) !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}
.calendar-glass .rz-scheduler .rz-button,
.calendar-glass .rz-scheduler button {
    background: rgba(255, 255, 255, 0.08) !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}
.calendar-glass .rz-scheduler .rz-button:hover,
.calendar-glass .rz-scheduler button:hover {
    background: rgba(255, 255, 255, 0.12) !important;
}
.calendar-glass .rz-scheduler-appointment {
    background: rgba(var(--color-primary-rgb), 0.35) !important;
    border-color: var(--color-primary) !important;
    color: #fff !important;
}
[data-theme="light"] .calendar-glass .rz-scheduler,
[data-theme="light"] .calendar-glass .rz-scheduler table,
[data-theme="light"] .calendar-glass .rz-scheduler-content {
    background: rgba(255, 255, 255, 0.6) !important;
    color: #212121 !important;
}
[data-theme="light"] .calendar-glass .rz-scheduler-appointment {
    background: rgba(var(--color-primary-rgb), 0.2) !important;
    color: #212121 !important;
}
.calendar-glass .calendar-view-btn.rz-button.rz-secondary,
.calendar-glass .rz-button:not(.rz-state-active):not([class*="primary"]) {
    background: rgba(255, 255, 255, 0.1) !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}

/* ========== Sötét mód: naptár (RadzenScheduler) – Foglalások oldal ========== */
html:not([data-theme="light"]) .rz-scheduler,
html:not([data-theme="light"]) .rz-scheduler table,
html:not([data-theme="light"]) .rz-scheduler .rz-scheduler-content,
html:not([data-theme="light"]) .rz-scheduler .rz-scheduler-header,
html:not([data-theme="light"]) .rz-scheduler .rz-scheduler-body,
html:not([data-theme="light"]) .rz-scheduler .rz-scheduler-view-content,
html:not([data-theme="light"]) .rz-scheduler .rz-timeline,
html:not([data-theme="light"]) .rz-scheduler .rz-scheduler-cell,
html:not([data-theme="light"]) .rz-scheduler .rz-scheduler-slot,
html:not([data-theme="light"]) .rz-scheduler td,
html:not([data-theme="light"]) .rz-scheduler th {
    background: var(--color-surface) !important;
    background-color: #252525 !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}
html:not([data-theme="light"]) .rz-scheduler .rz-scheduler-header-cell,
html:not([data-theme="light"]) .rz-scheduler .rz-scheduler-time-bar,
html:not([data-theme="light"]) .rz-scheduler .rz-scheduler-time-cell,
html:not([data-theme="light"]) .rz-scheduler .rz-scheduler-date-group {
    background: #2d2d2d !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}
/* Naptár fejlécsáv (toolbar: Ma, dátum, Hét/Hónap gombok) – sötét háttér, világos szöveg */
html:not([data-theme="light"]) .rz-scheduler .rz-scheduler-nav,
html:not([data-theme="light"]) .rz-scheduler-nav {
    background: #252525 !important;
    background-color: #252525 !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}
html:not([data-theme="light"]) .rz-scheduler .rz-scheduler-nav .rz-scheduler-nav-title,
html:not([data-theme="light"]) .rz-scheduler-nav .rz-scheduler-nav-title {
    color: var(--color-text) !important;
}
html:not([data-theme="light"]) .rz-scheduler .rz-scheduler-nav .rz-scheduler-nav-prev-next .rz-button,
html:not([data-theme="light"]) .rz-scheduler .rz-scheduler-nav .rz-scheduler-nav-views .rz-button,
html:not([data-theme="light"]) .rz-scheduler-nav .rz-scheduler-nav-prev-next .rz-button,
html:not([data-theme="light"]) .rz-scheduler-nav .rz-scheduler-nav-views .rz-button {
    background: rgba(255, 255, 255, 0.1) !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}
html:not([data-theme="light"]) .rz-scheduler .rz-scheduler-nav .rz-scheduler-nav-prev-next .rz-button .rzi,
html:not([data-theme="light"]) .rz-scheduler .rz-scheduler-nav .rz-scheduler-nav-views .rz-button .rzi,
html:not([data-theme="light"]) .rz-scheduler-nav .rz-scheduler-nav-prev-next .rz-button .rzi,
html:not([data-theme="light"]) .rz-scheduler-nav .rz-scheduler-nav-views .rz-button .rzi,
html:not([data-theme="light"]) .rz-scheduler .rz-scheduler-nav .rz-button span,
html:not([data-theme="light"]) .rz-scheduler-nav .rz-button span {
    fill: var(--color-text) !important;
    color: var(--color-text) !important;
}
/* Naptár napfejlécek: két sor (nap neve + hónap. nap) – sortörés megjelenítése */
.rz-scheduler .rz-slot-header {
    white-space: pre-line;
    line-height: 1.25;
    text-align: center;
}
/* Napfejlécek (H, K, SZE...) és időoszlop fejléc sötét módban */
html:not([data-theme="light"]) .rz-scheduler .rz-view-header,
html:not([data-theme="light"]) .rz-scheduler .rz-view-header .rz-slot-header,
html:not([data-theme="light"]) .rz-scheduler .rz-view-header .rz-slot-hour-header {
    background: #2d2d2d !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}
/* Naptár gombok (Előző, Következő, Ma, Hét, Hónap) – sötét háttér, világos szöveg */
html:not([data-theme="light"]) .rz-scheduler .rz-button,
html:not([data-theme="light"]) .rz-scheduler button,
html:not([data-theme="light"]) .rz-scheduler .rz-navigation-item {
    background: rgba(255, 255, 255, 0.08) !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}
html:not([data-theme="light"]) .rz-scheduler .rz-button:hover,
html:not([data-theme="light"]) .rz-scheduler button:hover,
html:not([data-theme="light"]) .rz-scheduler .rz-button.rz-state-active {
    background: rgba(255, 255, 255, 0.15) !important;
    color: #fff !important;
}
html:not([data-theme="light"]) .rz-scheduler .rz-button .rzi,
html:not([data-theme="light"]) .rz-scheduler .rz-button svg,
html:not([data-theme="light"]) .rz-scheduler button .rzi,
html:not([data-theme="light"]) .rz-scheduler button svg {
    fill: var(--color-text) !important;
    color: var(--color-text) !important;
}
/* Naptár görgetősáv sötét módban */
html:not([data-theme="light"]) .rz-scheduler ::-webkit-scrollbar-track,
html:not([data-theme="light"]) .rz-scheduler .rz-scrollable::-webkit-scrollbar-track {
    background: #2d2d2d !important;
}
html:not([data-theme="light"]) .rz-scheduler ::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.2) !important;
    border-radius: 4px;
}
html:not([data-theme="light"]) .rz-scheduler ::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.3) !important;
}

/* ========== Sötét mód: világos gombok a kártyában (Szűrők törlése, Ma, nyilak) ========== */
html:not([data-theme="light"]) .rz-card .rz-button.rz-button-light,
html:not([data-theme="light"]) .main-content .rz-button.rz-button-light {
    background: rgba(255, 255, 255, 0.1) !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}
html:not([data-theme="light"]) .rz-card .rz-button.rz-button-light:hover,
html:not([data-theme="light"]) .main-content .rz-button.rz-button-light:hover {
    background: rgba(255, 255, 255, 0.18) !important;
    color: #fff !important;
}
html:not([data-theme="light"]) .rz-card .rz-button.rz-button-light .rzi,
html:not([data-theme="light"]) .rz-card .rz-button.rz-button-light svg,
html:not([data-theme="light"]) .main-content .rz-button.rz-button-light .rzi,
html:not([data-theme="light"]) .main-content .rz-button.rz-button-light svg {
    fill: var(--color-text) !important;
    color: var(--color-text) !important;
}
html:not([data-theme="light"]) .rz-card .rz-button.rz-button-light:hover .rzi,
html:not([data-theme="light"]) .rz-card .rz-button.rz-button-light:hover svg,
html:not([data-theme="light"]) .main-content .rz-button.rz-button-light:hover .rzi,
html:not([data-theme="light"]) .main-content .rz-button.rz-button-light:hover svg {
    fill: #fff !important;
    color: #fff !important;
}
/* Foglalások: Szűrők törlése, Ma, nyilak – egyedi osztállyal biztosan sötét gomb sötét módban */
html:not([data-theme="light"]) .rz-button.bookings-dark-btn {
    background: rgba(255, 255, 255, 0.12) !important;
    background-color: rgba(255, 255, 255, 0.12) !important;
    color: #fff !important;
    border-color: var(--color-border) !important;
}
html:not([data-theme="light"]) .rz-button.bookings-dark-btn:hover {
    background: rgba(255, 255, 255, 0.2) !important;
    background-color: rgba(255, 255, 255, 0.2) !important;
    color: #fff !important;
}
html:not([data-theme="light"]) .rz-button.bookings-dark-btn .rzi,
html:not([data-theme="light"]) .rz-button.bookings-dark-btn svg,
html:not([data-theme="light"]) .rz-button.bookings-dark-btn span {
    fill: #fff !important;
    color: #fff !important;
}

/* Booking Wizard Styles */
.wizard-progress {
    display: flex;
    justify-content: space-between;
    margin-bottom: 24px;
    position: relative;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
}

.wizard-progress::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    height: 2px;
    background: var(--color-border);
    z-index: 0;
    transform: translateY(-50%);
}

.step-dot {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--color-surface);
    border: 2px solid var(--color-border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    z-index: 1;
    position: relative;
    transition: all 0.3s;
    background-color: var(--glass-bg); /* Ensure background is set */
}

.step-dot.active {
    border-color: var(--color-primary);
    color: var(--color-primary);
    box-shadow: 0 0 10px rgba(var(--color-primary-rgb), 0.3);
}

.step-dot.completed {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: white;
}

/* Selection Cards */
.selection-card {
    background: var(--glass-bg);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 16px;
    margin-bottom: 12px;
    cursor: pointer;
    transition: all 0.2s;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.selection-card:hover {
    background: rgba(255, 255, 255, 0.05);
}

.selection-card.selected {
    border-color: var(--color-primary);
    background: rgba(var(--color-primary-rgb), 0.1);
}

/* Custom Calendar Grid */
.calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 8px;
    text-align: center;
    margin-bottom: 20px;
}

.cal-day {
    padding: 8px;
    border-radius: 8px;
    cursor: pointer;
    font-size: 1rem;
}

.cal-day.selected {
    background: var(--color-primary);
    color: white;
}

.cal-day.disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

/* Hét címe: asztalon egy sor, kötőjellel */
.calendar-week-title .calendar-week-from::after {
    content: " – ";
}

@media (max-width: 400px) {
    .calendar-grid {
        gap: 4px;
    }
    .cal-day {
        padding: 6px 2px;
        font-size: 0.85rem;
    }
}

/* Time Slots */
.time-slots {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}

.time-slot {
    padding: 10px;
    border: 1px solid var(--color-border);
    border-radius: 8px;
    text-align: center;
    cursor: pointer;
}
.time-slot.selected {
    background: var(--color-primary);
    color: white;
    border-color: var(--color-primary);
}
.time-slot.disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Bottom Action Bar */
.bottom-action-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 16px;
    background: var(--glass-bg);
    backdrop-filter: blur(20px);
    border-top: 1px solid var(--color-border);
    display: flex;
    justify-content: space-between;
    align-items: center;
    z-index: 1001; /* Above mobile nav */
}

/* Ensure content has space for bottom bar */
.has-bottom-bar {
    padding-bottom: 80px;
}

/* Public layout (naptár / foglalás): design fejléc + tartalom, nincs átfedés */
.public-layout {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    background: var(--gradient-bg);
    color: var(--color-text);
}
.booking-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    flex-shrink: 0;
    background: var(--glass-bg);
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border-bottom: 1px solid var(--glass-border);
}
/* Naptár: fejlécsor háttér nélkül, logó középen, téma jobbra */
.booking-header-minimal {
    background: transparent !important;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border-bottom: none;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    padding: 12px 20px;
}
.booking-header-minimal .booking-header-spacer {
    width: 100%;
}
.booking-header-minimal .booking-logo-center {
    justify-self: center;
}
.booking-header-minimal .booking-header-actions {
    justify-self: end;
}
.booking-header .booking-logo img {
    height: 60px;
    width: auto;
}
.booking-header-actions {
    display: flex;
    align-items: center;
    gap: 12px;
}
.public-main {
    flex: 1;
    overflow-y: auto;
    padding: 20px;
    box-sizing: border-box;
    padding-bottom: 80px;
}
.public-main .booking-container {
    padding-top: 0;
}

/* Mobilon szélesebb tartalom: kis oldalmargó */
@media (max-width: 768px) {
    .public-main {
        padding-left: 12px;
        padding-right: 12px;
    }
    .booking-container {
        max-width: none;
        padding-left: 8px;
        padding-right: 8px;
    }
    .booking-header-minimal {
        padding-left: 12px;
        padding-right: 12px;
    }
    /* Hétváltó sor: mobilon csak nyilak, szöveg elrejtve */
    .calendar-nav-label {
        display: none;
    }
    .calendar-week-nav .glass-button {
        padding: 8px 12px !important;
        min-width: 44px;
    }
    /* Mobilon: év, dátum-tól, dátum-ig 3 sorban, kötőjel nélkül */
    .calendar-week-title {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 0;
        line-height: 1.3;
    }
    .calendar-week-title .calendar-week-from::after {
        content: none;
    }
}

/* Booking / Calendar wizard container */
.booking-container {
    max-width: 600px;
    margin: 0 auto;
    padding: 20px;
}
.step-content {
    display: none;
}
.step-content.active {
    display: block;
    animation: fadeIn 0.3s ease;
}
@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ========== Egységes gomb- és lista stílusok ========== */

/* Kék -> zöld: Primary gombok (Mentés, Új blokk, stb.) = téma zöldje – erős felülírás */
.rz-button.rz-button-primary,
.rz-btn.rz-button-primary,
button.rz-button.rz-button-primary,
.rz-card .rz-button.rz-button-primary,
.main-content .rz-button.rz-button-primary,
body .rz-button.rz-button-primary,
.rz-card .rz-component .rz-button.rz-button-primary,
html body .rz-button.rz-button-primary {
    background: var(--color-primary) !important;
    border-color: var(--color-primary) !important;
    color: #fff !important;
}
.rz-button.rz-button-primary:hover,
button.rz-button.rz-button-primary:hover,
.rz-card .rz-button.rz-button-primary:hover,
body .rz-button.rz-button-primary:hover {
    background: color-mix(in srgb, var(--color-primary) 85%, black) !important;
    border-color: color-mix(in srgb, var(--color-primary) 85%, black) !important;
    color: #fff !important;
}
.rz-button.rz-button-primary .rzi,
.rz-button.rz-button-primary svg,
.rz-button.rz-button-primary path,
.rz-card .rz-button.rz-button-primary .rzi,
.rz-card .rz-button.rz-button-primary svg,
.rz-card .rz-button.rz-button-primary path {
    fill: #fff !important;
    color: #fff !important;
}

/* Mégse gombok: narancssárga (Class="btn-cancel" a RadzenButton-on) */
.rz-button.btn-cancel,
button.rz-button.btn-cancel {
    background: var(--color-cancel) !important;
    border-color: var(--color-cancel) !important;
    color: #fff !important;
}
.rz-button.btn-cancel:hover,
button.rz-button.btn-cancel:hover {
    background: color-mix(in srgb, var(--color-cancel) 85%, black) !important;
    border-color: color-mix(in srgb, var(--color-cancel) 85%, black) !important;
    color: #fff !important;
}
.rz-button.btn-cancel .rzi,
.rz-button.btn-cancel svg,
.rz-button.btn-cancel path {
    fill: #fff !important;
    color: #fff !important;
}

/* Törlés gomb: mély piros, fehér ikon (sötét és világos módban is) */
.rz-button.rz-button-danger,
.rz-btn.rz-button-danger,
button.rz-button.rz-button-danger {
    background: var(--color-danger) !important;
    border-color: var(--color-danger) !important;
    color: #fff !important;
}
.rz-button.rz-button-danger:hover {
    background: color-mix(in srgb, var(--color-danger) 80%, black) !important;
    border-color: color-mix(in srgb, var(--color-danger) 80%, black) !important;
    color: #fff !important;
}
.rz-button.rz-button-danger .rzi,
.rz-button.rz-button-danger svg,
.rz-button.rz-button-danger path {
    fill: #fff !important;
    color: #fff !important;
}

/* Szerkesztés gombok: zöld (class="btn-edit" a RadzenButton-on) */
.rz-button.btn-edit,
button.rz-button.btn-edit {
    background: var(--color-primary) !important;
    border-color: var(--color-primary) !important;
    color: #fff !important;
}
.rz-button.btn-edit:hover,
button.rz-button.btn-edit:hover {
    background: color-mix(in srgb, var(--color-primary) 85%, black) !important;
    border-color: color-mix(in srgb, var(--color-primary) 85%, black) !important;
    color: #fff !important;
}
.rz-button.btn-edit .rzi,
.rz-button.btn-edit svg,
.rz-button.btn-edit path {
    fill: #fff !important;
    color: #fff !important;
}

/* Gombok magassága: ne legyenek túl magasak (kisebb padding) */
.rz-button {
    min-height: auto !important;
    padding: 0.45rem 0.9rem !important;
}
.rz-button.rz-button-sm,
.rz-button[data-size="Small"] {
    padding: 0.35rem 0.6rem !important;
}
/* Új blokk és hasonló gombok: még laposabb */
.rz-button.btn-compact,
button.rz-button.btn-compact {
    padding: 0.3rem 0.6rem !important;
    min-height: unset !important;
    line-height: 1.3 !important;
}

/* Táblázat-szerű listák: tartalom középre igazítva (blokkolt idősávok, stb.) */
table.radzen-table,
.radzen-table {
    border-collapse: collapse;
    width: 100%;
}
.radzen-table th,
.radzen-table td {
    text-align: center !important;
    vertical-align: middle !important;
}
/* RadzenDataGrid: cellák tartalma középen */
.rz-data-grid .rz-grid-table th,
.rz-data-grid .rz-grid-table td,
.rz-data-grid .rz-datatable-tbody td {
    text-align: center !important;
}

/* Sötét mód: naptár (datepicker) ikon látható – ne legyen túl világos szürke */
.rz-datepicker .rz-inputgroup-addon .rzi,
.rz-datepicker .rz-inputgroup-addon svg,
.rz-datepicker .rz-inputgroup-addon path,
.rz-inputgroup-addon .rzi,
.rz-inputgroup-addon svg,
.rz-inputgroup-addon path {
    fill: var(--color-text) !important;
    color: var(--color-text) !important;
}
[data-theme="light"] .rz-datepicker .rz-inputgroup-addon .rzi,
[data-theme="light"] .rz-datepicker .rz-inputgroup-addon svg,
[data-theme="light"] .rz-inputgroup-addon .rzi,
[data-theme="light"] .rz-inputgroup-addon svg {
    fill: var(--color-text) !important;
    color: var(--color-text) !important;
}

/* ========== Radzen Dialog / felugró ablakok – pozícionálás ========== */
/* Minden popup legyen vízszintesen középen, témától függetlenül */
/* A maszk mindig a teljes viewportot fedje (fix pozíció), ne csússzon el nyitott menünél */
.rz-dialog-mask {
    position: fixed !important;
    inset: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    display: flex;
    justify-content: center;
    align-items: flex-start;
}

.rz-dialog-wrapper {
    margin: 2rem auto 0 auto;
}

/* Nyitott bal oldali menü esetén csak a popup tartalmat (a fehér dobozt) toljuk balra,
   a szürke maszk marad a helyén (a menü 260px, lásd .app-layout .rz-sidebar) */
.app-layout.sidebar-open .rz-dialog-wrapper {
    transform: translateX(-260px);
}

/* ========== Radzen Dialog / felugró ablakok – sötét mód ========== */
.app-layout.sidebar-open .rz-dialog-mask {
    top: -32px !important;
    left: -6px !important;
}
html:not([data-theme="light"]) .rz-dialog-mask {
    background: rgba(0, 0, 0, 0.6) !important;
}
html:not([data-theme="light"]) .rz-dialog-wrapper,
html:not([data-theme="light"]) .rz-dialog,
html:not([data-theme="light"]) .rz-dialog-content {
    background: var(--color-surface) !important;
    background-color: #1e1e1e !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}
/* Dialog fejléc (titlebar) – sötét háttér, ne fehér */
html:not([data-theme="light"]) .rz-dialog-titlebar {
    background: var(--color-surface) !important;
    background-color: #1e1e1e !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
    border-bottom: 1px solid var(--color-border);
}
html:not([data-theme="light"]) .rz-dialog .rz-dialog-title,
html:not([data-theme="light"]) .rz-dialog .rz-dialog-titlebar .rz-dialog-title,
html:not([data-theme="light"]) .rz-dialog .rz-window-title,
html:not([data-theme="light"]) .rz-dialog-header,
html:not([data-theme="light"]) .rz-dialog .rz-heading,
html:not([data-theme="light"]) .rz-dialog .rz-label,
html:not([data-theme="light"]) .rz-dialog-content .rz-label {
    color: var(--color-text) !important;
}
html:not([data-theme="light"]) .rz-dialog .rz-textbox input,
html:not([data-theme="light"]) .rz-dialog .rz-textbox,
html:not([data-theme="light"]) .rz-dialog .rz-inputtext,
html:not([data-theme="light"]) .rz-dialog-content .rz-textbox input,
html:not([data-theme="light"]) .rz-dialog-content .rz-textbox,
html:not([data-theme="light"]) .rz-dialog-content .rz-inputtext {
    background: rgba(40, 40, 40, 0.9) !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}
html:not([data-theme="light"]) .rz-dialog .rz-button.rz-button-light,
html:not([data-theme="light"]) .rz-dialog-content .rz-button.rz-button-light {
    background: rgba(255, 255, 255, 0.1) !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}
html:not([data-theme="light"]) .rz-dialog .rzi,
html:not([data-theme="light"]) .rz-dialog svg,
html:not([data-theme="light"]) .rz-dialog-content .rzi,
html:not([data-theme="light"]) .rz-dialog-content svg {
    fill: var(--color-text) !important;
    color: var(--color-text) !important;
}
html:not([data-theme="light"]) .rz-dialog-titlebar .rz-dialog-titlebar-close,
html:not([data-theme="light"]) .rz-dialog-titlebar .rz-dialog-titlebar-icon {
    background: transparent !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}
html:not([data-theme="light"]) .rz-dialog-titlebar .rz-dialog-titlebar-close .rzi,
html:not([data-theme="light"]) .rz-dialog-titlebar .rz-dialog-titlebar-close svg {
    fill: var(--color-text) !important;
    color: var(--color-text) !important;
}

/* ========== Sötét mód: input, select, textarea, pager, fieldset, ikonok ========== */

/* Sötét módban input/textarea/select belső része sötét, szöveg világos (ugyanolyan színű mint kívül) */
html:not([data-theme="light"]) .rz-textbox input,
html:not([data-theme="light"]) .rz-textbox.rz-inputtext,
html:not([data-theme="light"]) .rz-textbox,
html:not([data-theme="light"]) .rz-textbox input.rz-inputtext,
html:not([data-theme="light"]) input.rz-inputtext,
html:not([data-theme="light"]) .rz-inputtext,
html:not([data-theme="light"]) .rz-dropdown,
html:not([data-theme="light"]) .rz-dropdown .rz-inputtext,
html:not([data-theme="light"]) .rz-dropdown .rz-inputgroup,
html:not([data-theme="light"]) .rz-dropdown-trigger,
html:not([data-theme="light"]) .rz-textarea,
html:not([data-theme="light"]) .rz-textarea textarea,
html:not([data-theme="light"]) textarea.rz-inputtext,
html:not([data-theme="light"]) .rz-numeric,
html:not([data-theme="light"]) .rz-numeric input,
html:not([data-theme="light"]) .rz-numeric .rz-inputgroup,
html:not([data-theme="light"]) .rz-datepicker input,
html:not([data-theme="light"]) .rz-datepicker .rz-inputgroup,
html:not([data-theme="light"]) .rz-timepicker input,
html:not([data-theme="light"]) .rz-timepicker .rz-inputgroup,
html:not([data-theme="light"]) .rz-textbox input[readonly],
html:not([data-theme="light"]) .rz-textbox.rz-readonly {
    background: var(--color-surface) !important;
    background-color: rgba(40, 40, 40, 0.9) !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}

/* Natív time/date input ikon invertálása sötét módban */
html:not([data-theme="light"]) input[type="time"]::-webkit-calendar-picker-indicator,
html:not([data-theme="light"]) input[type="date"]::-webkit-calendar-picker-indicator,
html:not([data-theme="light"]) input[type="datetime-local"]::-webkit-calendar-picker-indicator {
    filter: invert(1);
    cursor: pointer;
}
/* Select trigger (zárt állapot) egységes: ne legyen fehér keret, sötét legyen */
html:not([data-theme="light"]) .rz-dropdown .rz-inputgroup-addon,
html:not([data-theme="light"]) .rz-dropdown-trigger {
    background: rgba(40, 40, 40, 0.9) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text) !important;
}
/* Select legördülő panel (belső lista) is sötét, szöveg látható */
html:not([data-theme="light"]) .rz-dropdown-panel,
html:not([data-theme="light"]) .rz-listbox-container,
html:not([data-theme="light"]) .rz-dropdown-items,
html:not([data-theme="light"]) .rz-listbox {
    background: var(--color-surface) !important;
    background-color: rgba(40, 40, 40, 0.98) !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}

html:not([data-theme="light"]) .rz-dropdown-panel .rz-dropdown-item,
html:not([data-theme="light"]) .rz-listbox .rz-listbox-option {
    color: var(--color-text) !important;
}
html:not([data-theme="light"]) .rz-dropdown-panel .rz-dropdown-item:hover,
html:not([data-theme="light"]) .rz-listbox .rz-listbox-option:hover {
    background: rgba(255, 255, 255, 0.08) !important;
    color: var(--color-text) !important;
}

/* Smooth open animáció a legördülő select listákhoz (light + dark mód).
   Csak nyitáskor avatkozunk be, hogy ne takarjuk el véletlenül a panelt. */
@keyframes rz-dropdown-open {
    from {
        transform: translateY(-4px);
        opacity: 0;
    }
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

.rz-dropdown-panel.rz-popup,
.rz-listbox.rz-popup,
.rz-listbox-container.rz-popup,
.rz-dropdown-items.rz-popup {
    transform-origin: top;
    animation: rz-dropdown-open 190ms ease-out;
}
/* Sötét mód: input/select belsejében az ikonok fehérek (naptár, óra, nyíl, föl-le) */
html:not([data-theme="light"]) .rz-inputgroup-addon .rzi,
html:not([data-theme="light"]) .rz-inputgroup-addon svg,
html:not([data-theme="light"]) .rz-inputgroup-addon path,
html:not([data-theme="light"]) .rz-dropdown-trigger .rzi,
html:not([data-theme="light"]) .rz-dropdown-trigger svg,
html:not([data-theme="light"]) .rz-dropdown-trigger path,
html:not([data-theme="light"]) .rz-dropdown .rz-inputgroup-addon .rzi,
html:not([data-theme="light"]) .rz-dropdown .rz-inputgroup-addon svg,
html:not([data-theme="light"]) .rz-datepicker .rz-inputgroup-addon .rzi,
html:not([data-theme="light"]) .rz-datepicker .rz-inputgroup-addon svg,
html:not([data-theme="light"]) .rz-timepicker .rz-inputgroup-addon .rzi,
html:not([data-theme="light"]) .rz-timepicker .rz-inputgroup-addon svg,
html:not([data-theme="light"]) .rz-numeric-button .rzi,
html:not([data-theme="light"]) .rz-numeric-button svg,
html:not([data-theme="light"]) .rz-numeric-button path,
html:not([data-theme="light"]) .rz-numeric .rz-inputgroup-addon .rzi,
html:not([data-theme="light"]) .rz-numeric .rz-inputgroup-addon svg {
    fill: #fff !important;
    color: #fff !important;
}
/* Numeric föl-le gomb háttér sötét, ikon fehér (ne maradjon fekete) */
html:not([data-theme="light"]) .rz-numeric-button {
    background: rgba(40, 40, 40, 0.95) !important;
    border-color: var(--color-border) !important;
    color: #fff !important;
}
/* Select és numeric: föl-le / nyíl gomb igazítás (ne csússzon el) */
.rz-inputgroup,
.rz-dropdown .rz-inputgroup,
.rz-numeric .rz-inputgroup {
    display: flex !important;
    align-items: stretch !important;
}
.rz-inputgroup-addon,
.rz-dropdown-trigger {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}
.rz-numeric .rz-numeric-buttons,
.rz-numeric .rz-inputgroup-addon {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
}
.rz-numeric-button {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 1 !important;
    min-height: 0 !important;
}
/* DatePicker: naptár ikon ne csússzon el – input és addon egy sorban, középre igazítva */
.rz-datepicker .rz-inputgroup,
.rz-datepicker .rz-inputgroup-inner,
.rz-datepicker .rz-widget {
    display: flex !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
}
.rz-datepicker .rz-inputgroup-addon,
.rz-datepicker .rz-inputgroup .rz-inputgroup-addon,
.rz-datepicker .rz-inputgroup-inner .rz-inputgroup-addon {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-shrink: 0 !important;
    min-width: 2.25rem !important;
    width: 2.25rem !important;
    align-self: stretch !important;
    margin-left: 0 !important;
}
.rz-datepicker .rz-inputgroup input.rz-inputtext {
    flex: 1 !important;
    min-width: 0 !important;
}
/* Checkbox és radio bekattintott = téma zöldje */
.rz-chkbox-box.rz-state-active,
.rz-chkbox-box.rz-state-active:hover,
.rz-radiobutton-box.rz-state-active,
.rz-radiobutton-box.rz-state-active:hover {
    background: var(--color-primary) !important;
    border-color: var(--color-primary) !important;
}
.rz-chkbox-box.rz-state-active .rzi,
.rz-chkbox-box.rz-state-active svg,
.rz-radiobutton-box.rz-state-active .rzi,
.rz-radiobutton-box.rz-state-active::after {
    fill: #fff !important;
    color: #fff !important;
}
/* Natív HTML checkbox (pl. Elfogadott fizetési módok, Szolgáltatások a naptárhoz) = téma zöldje */
input[type="checkbox"],
.rz-card input[type="checkbox"],
.rz-fieldset input[type="checkbox"] {
    accent-color: var(--color-primary) !important;
}
input[type="radio"],
.rz-card input[type="radio"],
.rz-fieldset input[type="radio"] {
    accent-color: var(--color-primary) !important;
}
/* Grid pager sötét módban: szöveg fehér */
html:not([data-theme="light"]) .rz-pager,
html:not([data-theme="light"]) .rz-pager *,
html:not([data-theme="light"]) .rz-pager button.rz-pager-element,
html:not([data-theme="light"]) .rz-pager button.rz-pager-page,
html:not([data-theme="light"]) .rz-pager .rz-pager-first,
html:not([data-theme="light"]) .rz-pager .rz-pager-prev,
html:not([data-theme="light"]) .rz-pager .rz-pager-next,
html:not([data-theme="light"]) .rz-pager .rz-pager-last,
html:not([data-theme="light"]) .rz-pager .rz-pager-summary,
html:not([data-theme="light"]) .rz-pager .rz-pager-icon,
html:not([data-theme="light"]) .rz-paginator,
html:not([data-theme="light"]) .rz-paginator *,
html:not([data-theme="light"]) nav.rz-pager,
html:not([data-theme="light"]) nav.rz-pager * {
    color: #fff !important;
    fill: #fff !important;
}
html:not([data-theme="light"]) .rz-pager .rzi,
html:not([data-theme="light"]) .rz-pager svg,
html:not([data-theme="light"]) .rz-pager path,
html:not([data-theme="light"]) .rz-paginator .rzi,
html:not([data-theme="light"]) .rz-paginator svg,
html:not([data-theme="light"]) .rz-paginator path {
    fill: #fff !important;
    color: #fff !important;
}
html:not([data-theme="light"]) .rz-pager button:hover,
html:not([data-theme="light"]) .rz-pager button.rz-pager-element:hover,
html:not([data-theme="light"]) .rz-pager button.rz-pager-page:hover,
html:not([data-theme="light"]) .rz-paginator button:hover,
html:not([data-theme="light"]) nav.rz-pager button:hover,
html:not([data-theme="light"]) .rz-card .rz-data-grid nav.rz-pager button:hover,
html:not([data-theme="light"]) .rz-pager button:focus,
html:not([data-theme="light"]) .rz-pager button.rz-state-focused {
    background: rgba(255, 255, 255, 0.1) !important;
    background-color: rgba(255, 255, 255, 0.1) !important;
    color: #fff !important;
}
html:not([data-theme="light"]) .rz-pager button::before,
html:not([data-theme="light"]) .rz-pager button::after,
html:not([data-theme="light"]) .rz-pager button:hover::before,
html:not([data-theme="light"]) .rz-pager button:hover::after,
html:not([data-theme="light"]) .rz-pager button:focus::before,
html:not([data-theme="light"]) .rz-pager button:focus::after,
html:not([data-theme="light"]) .rz-pager button.rz-state-focused::before,
html:not([data-theme="light"]) .rz-pager button.rz-state-focused::after {
    background: rgba(255, 255, 255, 0.1) !important;
    background-color: rgba(255, 255, 255, 0.1) !important;
}
html:not([data-theme="light"]) .rz-pager button.rz-state-active {
    background: var(--color-primary) !important;
    background-color: var(--color-primary) !important;
    color: #fff !important;
}
html:not([data-theme="light"]) .rz-pager button.rz-state-active::before,
html:not([data-theme="light"]) .rz-pager button.rz-state-active::after {
    background: var(--color-primary) !important;
    background-color: var(--color-primary) !important;
}
/* Fieldset cím (pl. Fizetés, Blokkolt idősávok) – sötét módban világos, világos módban sötét */
.rz-fieldset-legend,
.rz-fieldset legend,
.rz-fieldset .rz-fieldset-legend {
    color: var(--color-text) !important;
}

/* ========== Naptár (datepicker) felugró ablak sötét módban ========== */
html:not([data-theme="light"]) .rz-datepicker-panel,
html:not([data-theme="light"]) .rz-datepicker-overlay,
html:not([data-theme="light"]) .rz-calendar,
html:not([data-theme="light"]) .rz-datepicker .rz-calendar {
    background: var(--color-surface) !important;
    background-color: #2d2d2d !important;
    border-color: var(--color-border) !important;
    color: var(--color-text) !important;
}
/* Datepicker fejléc sötét háttér */
html:not([data-theme="light"]) .rz-calendar .rz-calendar-header,
html:not([data-theme="light"]) .rz-datepicker-panel .rz-calendar-header {
    background: #252525 !important;
    border-bottom-color: var(--color-border) !important;
}
/* Naptár számok végig fehérek */
html:not([data-theme="light"]) .rz-calendar table,
html:not([data-theme="light"]) .rz-calendar th,
html:not([data-theme="light"]) .rz-calendar td,
html:not([data-theme="light"]) .rz-calendar .rz-datepicker-month,
html:not([data-theme="light"]) .rz-calendar .rz-datepicker-year,
html:not([data-theme="light"]) .rz-calendar .rz-datepicker-calendar td,
html:not([data-theme="light"]) .rz-calendar td span,
html:not([data-theme="light"]) .rz-calendar .rz-state-default,
html:not([data-theme="light"]) .rz-calendar .rz-state-other-month {
    background: transparent !important;
    color: #fff !important;
    border-color: var(--color-border) !important;
}
/* Naptár hónap/év select sötét (zárt és nyitott állapot) */
html:not([data-theme="light"]) .rz-calendar .rz-dropdown,
html:not([data-theme="light"]) .rz-calendar .rz-dropdown .rz-inputgroup,
html:not([data-theme="light"]) .rz-calendar .rz-dropdown-trigger {
    background: rgba(40, 40, 40, 0.95) !important;
    color: #fff !important;
    border-color: var(--color-border) !important;
}
/* Naptár select legördülő panel (hónap/év lista) – sötét, mint a fejléc */
html:not([data-theme="light"]) .rz-calendar .rz-dropdown-panel,
html:not([data-theme="light"]) .rz-datepicker-panel .rz-dropdown-panel,
html:not([data-theme="light"]) .rz-calendar .rz-listbox-container,
html:not([data-theme="light"]) .rz-calendar .rz-dropdown-items {
    background: #252525 !important;
    background-color: rgba(40, 40, 40, 0.98) !important;
    color: #fff !important;
    border-color: var(--color-border) !important;
}
html:not([data-theme="light"]) .rz-calendar .rz-dropdown-panel .rz-dropdown-item,
html:not([data-theme="light"]) .rz-calendar .rz-listbox .rz-listbox-option {
    color: #fff !important;
}
html:not([data-theme="light"]) .rz-calendar .rz-dropdown-panel .rz-dropdown-item:hover {
    background: rgba(255, 255, 255, 0.1) !important;
}
html:not([data-theme="light"]) .rz-calendar .rz-dropdown-trigger .rzi,
html:not([data-theme="light"]) .rz-calendar .rz-dropdown-trigger svg {
    fill: #fff !important;
}
/* Naptár kiválasztott nap = téma zöldje (ne pink/piros) */
.rz-calendar .rz-state-active,
.rz-calendar td.rz-state-active,
.rz-datepicker-panel .rz-state-active {
    background: var(--color-primary) !important;
    color: #fff !important;
    border-color: var(--color-primary) !important;
}
/* Naptár navigáció nyilak: ne ovális világosabb háttér, csak fehér nyíl */
html:not([data-theme="light"]) .rz-calendar .rz-button,
html:not([data-theme="light"]) .rz-calendar button,
html:not([data-theme="light"]) .rz-datepicker-panel .rz-calendar .rz-button,
html:not([data-theme="light"]) .rz-datepicker-panel .rz-calendar button {
    background: transparent !important;
    color: #fff !important;
    border-color: transparent !important;
    box-shadow: none !important;
}
html:not([data-theme="light"]) .rz-calendar .rz-button .rzi,
html:not([data-theme="light"]) .rz-calendar .rz-button svg,
html:not([data-theme="light"]) .rz-calendar .rz-button path,
html:not([data-theme="light"]) .rz-calendar button .rzi,
html:not([data-theme="light"]) .rz-calendar button svg,
html:not([data-theme="light"]) .rz-calendar button path {
    fill: #fff !important;
}
/* Datepicker felugró: időválasztó (óra/perc) sötét hátterű, fehér szöveg – panelben mindig */
.rz-datepicker-panel .rz-numeric,
.rz-datepicker-panel .rz-numeric input,
.rz-datepicker-panel .rz-numeric .rz-inputgroup,
.rz-datepicker-panel .rz-numeric-button,
.rz-datepicker-panel .rz-timepicker input,
.rz-datepicker-panel .rz-timepicker .rz-inputgroup,
.rz-datepicker-panel input.rz-inputtext,
.rz-datepicker-panel input[type="text"],
.rz-datepicker-panel input {
    background: #2d2d2d !important;
    background-color: rgba(40, 40, 40, 0.95) !important;
    color: #fff !important;
    border-color: var(--color-border) !important;
}
/* TimePicker konténer (fehér sáv eltüntetése) */
.rz-datepicker-panel .rz-timepicker,
.rz-popup .rz-timepicker,
.rz-datepicker-popup .rz-timepicker {
    background: #252525 !important;
    background-color: #252525 !important;
    border-top: 1px solid var(--color-border) !important;
    padding: 0.5rem !important;
}
.rz-datepicker-panel .rz-numeric-button,
.rz-datepicker-panel .rz-numeric .rz-inputgroup-addon {
    background: rgba(40, 40, 40, 0.95) !important;
    border-color: var(--color-border) !important;
}
.rz-datepicker-panel .rz-numeric-button .rzi,
.rz-datepicker-panel .rz-numeric-button svg,
.rz-datepicker-panel .rz-numeric .rz-inputgroup-addon .rzi,
.rz-datepicker-panel .rz-timepicker .rz-inputgroup-addon .rzi,
.rz-datepicker-panel .rz-timepicker .rz-inputgroup-addon svg {
    fill: #fff !important;
}
/* Datepicker felugró ablak OK gombja = zöld (ne rózsaszín) – footer gomb és primary mindig */
.rz-datepicker-panel .rz-button.rz-button-primary,
.rz-datepicker-panel .rz-calendar-footer .rz-button,
.rz-datepicker-panel .rz-calendar-footer button,
.rz-popup .rz-timepicker .rz-button,
.rz-datepicker-popup .rz-timepicker .rz-button,
html:not([data-theme="light"]) .rz-datepicker-panel .rz-button.rz-button-primary {
    background: var(--color-primary) !important;
    background-color: var(--color-primary) !important;
    border-color: var(--color-primary) !important;
    color: #fff !important;
}
.rz-datepicker-panel .rz-button.rz-button-primary .rzi,
.rz-datepicker-panel .rz-button.rz-button-primary svg,
.rz-datepicker-panel .rz-button.rz-button-primary path,
.rz-datepicker-panel .rz-calendar-footer .rz-button .rzi,
.rz-datepicker-panel .rz-calendar-footer .rz-button svg,
.rz-datepicker-panel .rz-calendar-footer button .rzi,
.rz-datepicker-panel .rz-calendar-footer button svg,
.rz-popup .rz-timepicker .rz-button span,
.rz-datepicker-popup .rz-timepicker .rz-button span {
    fill: #fff !important;
    color: #fff !important;
}

/* Maradt fehér mezők eltüntetése: minden Radzen input/textarea a kártyában és main-contentben */
html:not([data-theme="light"]) .rz-card .rz-textbox input,
html:not([data-theme="light"]) .rz-card .rz-textbox,
html:not([data-theme="light"]) .rz-card .rz-textarea,
html:not([data-theme="light"]) .rz-card .rz-textarea textarea,
html:not([data-theme="light"]) .rz-card .rz-dropdown .rz-inputtext,
html:not([data-theme="light"]) .rz-card .rz-dropdown .rz-inputgroup,
html:not([data-theme="light"]) .rz-card .rz-numeric input,
html:not([data-theme="light"]) .rz-card .rz-numeric .rz-inputgroup,
html:not([data-theme="light"]) .main-content .rz-textbox input,
html:not([data-theme="light"]) .main-content .rz-textbox,
html:not([data-theme="light"]) .main-content .rz-textarea,
html:not([data-theme="light"]) .main-content .rz-textarea textarea,
html:not([data-theme="light"]) .main-content .rz-dropdown .rz-inputtext,
html:not([data-theme="light"]) .main-content .rz-dropdown .rz-inputgroup,
html:not([data-theme="light"]) .main-content .rz-numeric input,
html:not([data-theme="light"]) .main-content .rz-numeric .rz-inputgroup,
html:not([data-theme="light"]) .rz-card .rz-timepicker input,
html:not([data-theme="light"]) .rz-card .rz-timepicker .rz-inputgroup,
html:not([data-theme="light"]) .rz-card .rz-textbox input[readonly],
html:not([data-theme="light"]) .rz-card .rz-textbox.rz-readonly {
    background: var(--color-surface) !important;
    background-color: rgba(40, 40, 40, 0.9) !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}

/* Naptár szerkesztése (és minden admin): primary gombok biztosan zöldek */
.rz-card .rz-button.rz-button-primary,
.rz-card .rz-card-content .rz-button.rz-button-primary,
.rz-card .rz-component-content .rz-button.rz-button-primary {
    background: var(--color-primary) !important;
    border-color: var(--color-primary) !important;
    color: #fff !important;
}
.rz-card .rz-button.rz-button-primary.btn-compact {
    padding: 0.25rem 0.5rem !important;
    min-height: 2rem !important;
    height: 2rem !important;
    line-height: 1 !important;
    align-self: center !important;
}
.rz-card .rz-button.rz-button-primary .rzi,
.rz-card .rz-button.rz-button-primary svg,
.rz-card .rz-button.rz-button-primary path {
    fill: #fff !important;
    color: #fff !important;
}

/* Inaktiválás gomb: sötét hátterű dark mode-ban (felülírja a Radzen light gombot) */
html:not([data-theme="light"]) button.rz-button.rz-button-light.btn-toggle-active,
html:not([data-theme="light"]) .rz-button.rz-button-light.btn-toggle-active {
    background-color: #495057 !important;
    background: #495057 !important;
    border-color: #495057 !important;
    color: #fff !important;
}
html:not([data-theme="light"]) button.rz-button.rz-button-light.btn-toggle-active:hover,
html:not([data-theme="light"]) .rz-button.rz-button-light.btn-toggle-active:hover {
    background-color: #5a6268 !important;
    background: #5a6268 !important;
    border-color: #5a6268 !important;
    color: #fff !important;
}
html:not([data-theme="light"]) button.rz-button.rz-button-light.btn-toggle-active .rzi,
html:not([data-theme="light"]) button.rz-button.rz-button-light.btn-toggle-active svg,
html:not([data-theme="light"]) button.rz-button.rz-button-light.btn-toggle-active path,
html:not([data-theme="light"]) .rz-button.rz-button-light.btn-toggle-active .rzi,
html:not([data-theme="light"]) .rz-button.rz-button-light.btn-toggle-active svg,
html:not([data-theme="light"]) .rz-button.rz-button-light.btn-toggle-active path {
    color: #fff !important;
    fill: #fff !important;
}

/* Foglalások: Szűrők törlése, Ma, nyilak – utolsó szó sötét módban (felülírja a Radzen stílust) */
html:not([data-theme="light"]) button.rz-button.bookings-dark-btn,
html:not([data-theme="light"]) .rz-card button.bookings-dark-btn,
html:not([data-theme="light"]) .rz-card .rz-stack button.bookings-dark-btn {
    background: #3d3d3d !important;
    background-color: #3d3d3d !important;
    color: #fff !important;
    border-color: rgba(255,255,255,0.25) !important;
}
html:not([data-theme="light"]) button.rz-button.bookings-dark-btn:hover,
html:not([data-theme="light"]) .rz-card button.bookings-dark-btn:hover,
html:not([data-theme="light"]) .rz-card .rz-stack button.bookings-dark-btn:hover {
    background: #4a4a4a !important;
    background-color: #4a4a4a !important;
    color: #fff !important;
}
html:not([data-theme="light"]) button.bookings-dark-btn .rzi,
html:not([data-theme="light"]) button.bookings-dark-btn svg,
html:not([data-theme="light"]) button.bookings-dark-btn span,
html:not([data-theme="light"]) button.bookings-dark-btn .rz-button-text {
    fill: #fff !important;
    color: #fff !important;
}