/* ================================================================
   SYSTEM SERWISOWY - MATERIAL DESIGN 3
   v3.1 — dark sidebar + filled action buttons
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700&display=swap');

/* ================================================================
   MD3 DESIGN TOKENS
   ================================================================ */
:root {
    /* --- Color Roles (Light scheme - Blue-based) --- */
    --md-primary:              #0b57d0;
    --md-on-primary:           #ffffff;
    --md-primary-container:    #d3e3fd;
    --md-on-primary-container: #041e49;

    --md-secondary:              #575e71;
    --md-on-secondary:           #ffffff;
    --md-secondary-container:    #dbe2f9;
    --md-on-secondary-container: #141b2c;

    --md-tertiary:              #715573;
    --md-on-tertiary:           #ffffff;
    --md-tertiary-container:    #fbd7fc;
    --md-on-tertiary-container: #29132d;

    --md-error:              #ba1a1a;
    --md-on-error:           #ffffff;
    --md-error-container:    #ffdad6;
    --md-on-error-container: #410002;

    --md-success:              #006e1c;
    --md-on-success:           #ffffff;
    --md-success-container:    #a6f5a9;
    --md-on-success-container: #002204;

    --md-warning:              #8b5000;
    --md-on-warning:           #ffffff;
    --md-warning-container:    #ffdcbe;
    --md-on-warning-container: #2d1600;

    --md-info:              #006689;
    --md-on-info:           #ffffff;
    --md-info-container:    #c4e7ff;
    --md-on-info-container: #001e2c;

    /* --- Surface tonal levels --- */
    --md-background:              #fdfbff;
    --md-on-background:           #1b1b1f;
    --md-surface:                 #fdfbff;
    --md-on-surface:              #1b1b1f;
    --md-on-surface-variant:      #44464f;
    --md-surface-variant:         #e1e2ec;

    --md-surface-container-lowest:  #ffffff;
    --md-surface-container-low:     #f5f3f7;
    --md-surface-container:         #efedf1;
    --md-surface-container-high:    #e9e7ec;
    --md-surface-container-highest: #e4e1e6;

    --md-outline:         #74777f;
    --md-outline-variant: #c4c6cf;
    --md-scrim:           #000000;

    /* --- Dark sidebar tokens --- */
    --sb-bg:                  #17181c;
    --sb-surface-container:   #1f2025;
    --sb-on-surface:          #e4e2e6;
    --sb-on-surface-variant:  #c5c6d0;
    --sb-outline:             #8e9099;
    --sb-outline-variant:     #44464f;
    --sb-primary:             #acc7ff;
    --sb-on-primary:          #002e69;
    --sb-primary-container:   #2f4156;
    --sb-on-primary-container:#d3e3fd;
    --sb-secondary-container: #3e4759;
    --sb-on-secondary-container:#dbe2f9;

    /* --- Elevation shadows (MD3) --- */
    --md-elev-1: 0 1px 2px rgba(0,0,0,0.30), 0 1px 3px 1px rgba(0,0,0,0.15);
    --md-elev-2: 0 1px 2px rgba(0,0,0,0.30), 0 2px 6px 2px rgba(0,0,0,0.15);
    --md-elev-3: 0 4px 8px 3px rgba(0,0,0,0.15), 0 1px 3px rgba(0,0,0,0.30);
    --md-elev-4: 0 6px 10px 4px rgba(0,0,0,0.15), 0 2px 3px rgba(0,0,0,0.30);
    --md-elev-5: 0 8px 12px 6px rgba(0,0,0,0.15), 0 4px 4px rgba(0,0,0,0.30);

    /* --- Shape tokens --- */
    --md-shape-xs:   4px;
    --md-shape-sm:   8px;
    --md-shape-md:   12px;
    --md-shape-lg:   16px;
    --md-shape-xl:   28px;
    --md-shape-full: 9999px;

    /* --- Motion / easing --- */
    --md-ease-standard:     cubic-bezier(0.2, 0, 0, 1);
    --md-ease-emphasized:   cubic-bezier(0.2, 0, 0, 1);
    --md-ease-emphasized-decel: cubic-bezier(0.05, 0.7, 0.1, 1);
    --md-ease-emphasized-accel: cubic-bezier(0.3, 0, 0.8, 0.15);
    --md-duration-short:    150ms;
    --md-duration-medium:   250ms;
    --md-duration-long:     350ms;
    --md-duration-xlong:    450ms;

    /* Legacy tokens (compat) */
    --primary:    var(--md-primary);
    --success:    var(--md-success);
    --info:       var(--md-info);
    --warning:    var(--md-warning);
    --danger:     var(--md-error);
    --secondary:  var(--md-secondary);
    --dark:       var(--md-on-surface);
    --text:       var(--md-on-surface);
    --text-muted: var(--md-on-surface-variant);
    --border:     var(--md-outline-variant);
    --body-bg:    var(--md-background);
}

/* ================================================================
   DARK THEME
   ================================================================ */
[data-theme="dark"] {
    /* Color roles - softer, lighter shades for dark surface */
    --md-primary:              #acc7ff;
    --md-on-primary:           #002e69;
    --md-primary-container:    #2f4156;
    --md-on-primary-container: #d3e3fd;

    --md-secondary:              #bfc6dc;
    --md-on-secondary:           #283041;
    --md-secondary-container:    #3e4759;
    --md-on-secondary-container: #dbe2f9;

    --md-tertiary:              #debdde;
    --md-on-tertiary:           #401e44;
    --md-tertiary-container:    #59395d;
    --md-on-tertiary-container: #fbd7fc;

    --md-error:              #ffb4ab;
    --md-on-error:           #690005;
    --md-error-container:    #93000a;
    --md-on-error-container: #ffdad6;

    --md-success:              #6fdd76;
    --md-on-success:           #00390a;
    --md-success-container:    #005313;
    --md-on-success-container: #a6f5a9;

    --md-warning:              #ffb780;
    --md-on-warning:           #4a2700;
    --md-warning-container:    #693c00;
    --md-on-warning-container: #ffdcbe;

    --md-info:              #80cfff;
    --md-on-info:           #003549;
    --md-info-container:    #004d68;
    --md-on-info-container: #c4e7ff;

    /* Surface tonal levels */
    --md-background:              #121316;
    --md-on-background:           #e4e2e6;
    --md-surface:                 #121316;
    --md-on-surface:              #e4e2e6;
    --md-on-surface-variant:      #c5c6d0;
    --md-surface-variant:         #44464f;

    --md-surface-container-lowest:  #0d0e11;
    --md-surface-container-low:     #1b1b1f;
    --md-surface-container:         #1f2025;
    --md-surface-container-high:    #2a2a2f;
    --md-surface-container-highest: #34343a;

    --md-outline:         #8e9099;
    --md-outline-variant: #44464f;

    /* Sidebar zostaje ten sam - już ciemny */

    /* Stronger shadows on dark */
    --md-elev-1: 0 1px 2px rgba(0,0,0,0.50), 0 1px 3px 1px rgba(0,0,0,0.40);
    --md-elev-2: 0 1px 2px rgba(0,0,0,0.50), 0 2px 6px 2px rgba(0,0,0,0.40);
    --md-elev-3: 0 4px 8px 3px rgba(0,0,0,0.40), 0 1px 3px rgba(0,0,0,0.50);
    --md-elev-4: 0 6px 10px 4px rgba(0,0,0,0.40), 0 2px 3px rgba(0,0,0,0.50);
    --md-elev-5: 0 8px 12px 6px rgba(0,0,0,0.40), 0 4px 4px rgba(0,0,0,0.50);
}

/* W trybie dark — tabele, pasek użytkownika i niektóre elementy hard-coded
   na białe tło wymagają dodatkowego pokrycia */
[data-theme="dark"] .topbar { background: var(--md-surface-container); }
[data-theme="dark"] .topbar-bell:hover,
[data-theme="dark"] .topbar-user:hover,
[data-theme="dark"] .sidebar-toggle:hover { background: rgba(255,255,255,0.08); }
[data-theme="dark"] .bell-snooze-options a:hover,
[data-theme="dark"] .bell-item:hover { background: rgba(255,255,255,0.06); }
[data-theme="dark"] tbody tr:hover { background: rgba(255,255,255,0.04) !important; }
[data-theme="dark"] .form-control,
[data-theme="dark"] input[type="text"],
[data-theme="dark"] input[type="number"],
[data-theme="dark"] input[type="date"],
[data-theme="dark"] input[type="month"],
[data-theme="dark"] input[type="email"],
[data-theme="dark"] input[type="password"],
[data-theme="dark"] input[type="url"],
[data-theme="dark"] input[type="file"],
[data-theme="dark"] select,
[data-theme="dark"] textarea {
    background: var(--md-surface-container);
    color: var(--md-on-surface);
    border-color: var(--md-outline-variant);
}
[data-theme="dark"] .form-control:focus { border-color: var(--md-primary); }
/* Native date/time picker icon — invert in dark mode (otherwise black icon on dark bg) */
[data-theme="dark"] input[type="date"],
[data-theme="dark"] input[type="time"],
[data-theme="dark"] input[type="datetime-local"],
[data-theme="dark"] input[type="month"],
[data-theme="dark"] input[type="week"] {
    color-scheme: dark;
}
[data-theme="dark"] input[type="date"]::-webkit-calendar-picker-indicator,
[data-theme="dark"] input[type="time"]::-webkit-calendar-picker-indicator,
[data-theme="dark"] input[type="datetime-local"]::-webkit-calendar-picker-indicator,
[data-theme="dark"] input[type="month"]::-webkit-calendar-picker-indicator {
    filter: invert(0.9);
    cursor: pointer;
}
/* Note chip — żółta paleta nieużywalna na dark — przyciemnij */
[data-theme="dark"] .status-badge.note-chip { background: #5a4500; color: #ffe28d; }
[data-theme="dark"] code { background: var(--md-surface-container-high); color: var(--md-on-surface); }
[data-theme="dark"] hr { border-color: var(--md-outline-variant); }
[data-theme="dark"] .stat-compact { background: var(--md-surface-container); }
[data-theme="dark"] .stat-compact:hover { background: var(--md-surface-container-high); }

/* Theme toggle button */
.theme-toggle {
    background: none;
    border: none;
    cursor: pointer;
    width: 44px; height: 44px;
    border-radius: var(--md-shape-full);
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--md-on-surface-variant);
    font-size: 1.05rem;
    transition: background var(--md-duration-short) var(--md-ease-standard);
}
.theme-toggle:hover { background: rgba(0,0,0,0.06); }
[data-theme="dark"] .theme-toggle:hover { background: rgba(255,255,255,0.08); }

/* Session timer w topbarze */
.session-timer {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: var(--md-shape-full);
    background: var(--md-surface-container);
    color: var(--md-on-surface-variant);
    font-size: 0.8125rem;
    font-weight: 500;
    font-variant-numeric: tabular-nums;
    transition: background var(--md-duration-short) var(--md-ease-standard),
                color var(--md-duration-short) var(--md-ease-standard);
}
.session-timer i { font-size: 0.8rem; opacity: 0.75; }

/* Panel serwisowy — link w topbarze */
.btn-panel-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 14px;
    border-radius: var(--md-shape-full);
    background: var(--md-primary-container);
    color: var(--md-on-primary-container);
    font-size: 0.8125rem;
    font-weight: 500;
    text-decoration: none;
    border: 1px solid transparent;
    transition: background var(--md-duration-short) var(--md-ease-standard),
                box-shadow var(--md-duration-short) var(--md-ease-standard);
}
.btn-panel-link:hover {
    background: var(--md-surface-container-high);
    text-decoration: none;
    box-shadow: var(--md-elev-1);
}
.btn-panel-link i { font-size: 0.75rem; opacity: 0.85; }
@media (max-width: 1024px) {
    .btn-panel-link span { display: none; }
}
@media (max-width: 640px) {
    .btn-panel-link { display: none; }
}
.session-timer.warning {
    background: var(--md-warning-container);
    color: var(--md-on-warning-container);
}
.session-timer.danger {
    background: var(--md-error-container);
    color: var(--md-on-error-container);
    animation: pulse-soft 1.6s ease-in-out infinite;
}
@keyframes pulse-soft {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.7; }
}

/* Na bardzo wąskich ekranach ukryj timer (bell + user wystarczą) */
@media (max-width: 640px) {
    .session-timer { display: none; }
}

/* ================================================================
   RESET & BASE
   ================================================================ */
* { margin: 0; padding: 0; box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }

body {
    font-family: 'Roboto', -apple-system, BlinkMacSystemFont, sans-serif;
    font-size: 0.9375rem;
    line-height: 1.5;
    background: var(--md-background);
    color: var(--md-on-surface);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
h1, h2, h3, h4, h5, h6 { font-weight: 500; color: var(--md-on-surface); letter-spacing: 0; }
a { color: var(--md-primary); text-decoration: none; }
a:hover { text-decoration: underline; }
code {
    font-family: 'Roboto Mono', ui-monospace, monospace;
    background: var(--md-surface-container);
    padding: 2px 6px;
    border-radius: var(--md-shape-xs);
    font-size: 0.85em;
}
hr {
    border: 0; height: 1px;
    background: var(--md-outline-variant);
    margin: 1.25rem 0;
}

/* ================================================================
   SIDEBAR - MD3 DARK Navigation Drawer
   ================================================================ */
#sidebar {
    width: 280px;
    height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
    background: var(--sb-bg);
    color: var(--sb-on-surface);
    transition: width var(--md-duration-medium) var(--md-ease-standard),
                margin-left var(--md-duration-medium) var(--md-ease-standard);
    z-index: 1000;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 12px 0;
    border-right: 1px solid var(--sb-outline-variant);
}
#sidebar::-webkit-scrollbar { width: 6px; }
#sidebar::-webkit-scrollbar-thumb { background: var(--sb-outline-variant); border-radius: var(--md-shape-full); }
#sidebar::-webkit-scrollbar-track { background: transparent; }

#sidebar.toggled { width: 88px; }

.sidebar-brand {
    display: flex;
    align-items: center;
    padding: 16px 24px;
    color: var(--sb-on-surface);
    text-decoration: none;
    gap: 12px;
    margin-bottom: 8px;
    white-space: nowrap;
    overflow: hidden;
}
.sidebar-brand:hover { text-decoration: none; color: var(--sb-on-surface); }

.sidebar-brand-icon {
    width: 40px;
    height: 40px;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--md-shape-md);
    background: var(--sb-primary-container);
    color: var(--sb-on-primary-container);
    font-size: 1.2rem;
}

.sidebar-brand-text {
    font-weight: 500;
    font-size: 1.125rem;
    color: var(--sb-on-surface);
    transition: opacity var(--md-duration-short) var(--md-ease-standard);
}
#sidebar.toggled .sidebar-brand-text { opacity: 0; }
#sidebar.toggled .sidebar-brand { justify-content: center; padding: 16px; }

.sidebar-divider {
    height: 1px;
    background: var(--sb-outline-variant);
    margin: 12px 16px;
}

.sidebar-heading {
    padding: 18px 28px 8px;
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--sb-on-surface-variant);
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
}
#sidebar.toggled .sidebar-heading {
    text-align: center;
    padding: 12px 6px 4px;
    font-size: 0;
}
#sidebar.toggled .sidebar-heading::before {
    content: '•••';
    font-size: 0.75rem;
    letter-spacing: 0.2em;
}

.nav-item { padding: 0 12px; }

.nav-link {
    display: flex;
    align-items: center;
    padding: 0 16px;
    height: 56px;
    color: var(--sb-on-surface-variant);
    text-decoration: none;
    border-radius: var(--md-shape-full);
    margin: 2px 0;
    font-size: 0.875rem;
    font-weight: 500;
    letter-spacing: 0.01em;
    position: relative;
    overflow: hidden;
    transition: background var(--md-duration-short) var(--md-ease-standard),
                color var(--md-duration-short) var(--md-ease-standard);
    white-space: nowrap;
}
.nav-link:hover {
    background: rgba(255,255,255,0.08);
    color: var(--sb-on-surface);
    text-decoration: none;
}
.nav-link:active { background: rgba(255,255,255,0.12); }

.nav-link.active {
    background: var(--sb-secondary-container);
    color: var(--sb-on-secondary-container);
    font-weight: 500;
}
.nav-link.active:hover { background: var(--sb-secondary-container); }

.nav-link i {
    width: 24px;
    margin-right: 12px;
    font-size: 1.1rem;
    text-align: center;
    flex-shrink: 0;
}
#sidebar.toggled .nav-link {
    padding: 0;
    justify-content: center;
    height: 56px;
    width: 56px;
    margin: 4px auto;
}
#sidebar.toggled .nav-link i { margin-right: 0; }
#sidebar.toggled .nav-link span { display: none; }

/* ================================================================
   CONTENT WRAPPER
   ================================================================ */
#content-wrapper {
    margin-left: 280px;
    min-height: 100vh;
    transition: margin-left var(--md-duration-medium) var(--md-ease-standard);
    display: flex;
    flex-direction: column;
    background: var(--md-background);
}
#content-wrapper.toggled { margin-left: 88px; }

/* ================================================================
   TOPBAR - MD3 App Bar
   ================================================================ */
.topbar {
    height: 64px;
    background: var(--md-surface);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 16px;
    position: sticky;
    top: 0;
    z-index: 999;
    border-bottom: 1px solid transparent;
    transition: border-color var(--md-duration-short) var(--md-ease-standard),
                background var(--md-duration-short) var(--md-ease-standard);
}
.topbar.scrolled {
    background: var(--md-surface-container);
    border-bottom-color: var(--md-outline-variant);
}

.sidebar-toggle {
    background: none;
    border: none;
    color: var(--md-on-surface);
    font-size: 1.25rem;
    cursor: pointer;
    width: 48px;
    height: 48px;
    border-radius: var(--md-shape-full);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background var(--md-duration-short) var(--md-ease-standard);
}
.sidebar-toggle:hover { background: rgba(0,0,0,0.08); }
.sidebar-toggle:active { background: rgba(0,0,0,0.12); }

.topbar-user {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--md-on-surface);
    font-size: 0.875rem;
    font-weight: 500;
    padding: 8px 16px 8px 8px;
    border-radius: var(--md-shape-full);
    transition: background var(--md-duration-short) var(--md-ease-standard);
}
.topbar-user:hover { background: rgba(0,0,0,0.04); }
.topbar-user i.fa-user-circle { font-size: 1.75rem; color: var(--md-primary); }

/* ============ Topbar actions container (bell + user) ============ */
.topbar-actions {
    display: flex;
    align-items: center;
    gap: 8px;
}

.topbar-bell {
    background: none;
    border: none;
    cursor: pointer;
    width: 44px; height: 44px;
    border-radius: var(--md-shape-full);
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--md-on-surface-variant);
    font-size: 1.1rem;
    position: relative;
    transition: background var(--md-duration-short) var(--md-ease-standard);
}
.topbar-bell:hover { background: rgba(0,0,0,0.06); }
/* Dzwonienie gdy są aktywne przypomnienia */
.topbar-bell.has-reminders i {
    animation: bell-ring 2.5s ease-in-out infinite;
    transform-origin: top center;
}
.topbar-bell.has-reminders:hover i { animation-play-state: paused; }
@keyframes bell-ring {
    0%, 70%, 100% { transform: rotate(0); }
    72% { transform: rotate(15deg); }
    76% { transform: rotate(-15deg); }
    80% { transform: rotate(12deg); }
    84% { transform: rotate(-12deg); }
    88% { transform: rotate(8deg); }
    92% { transform: rotate(-8deg); }
    96% { transform: rotate(4deg); }
}
.bell-badge {
    position: absolute;
    top: 6px; right: 6px;
    background: var(--md-error); color: var(--md-on-error);
    font-size: 0.65rem; min-width: 18px; height: 18px; padding: 0 5px;
    border-radius: var(--md-shape-full);
    display: inline-flex; align-items: center; justify-content: center;
    font-weight: 600;
    border: 2px solid var(--md-surface);
}
.topbar-role {
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 2px 8px;
    border-radius: var(--md-shape-xs);
    background: var(--md-secondary-container);
    color: var(--md-on-secondary-container);
    margin-left: 4px;
}

/* ============ Bell panel ============ */
.bell-panel {
    position: fixed;
    top: 60px; right: 16px;
    width: 380px; max-width: calc(100vw - 32px); max-height: 70vh;
    background: var(--md-surface-container-high);
    border-radius: var(--md-shape-lg);
    box-shadow: var(--md-elev-3);
    z-index: 1500;
    overflow: hidden;
    display: flex; flex-direction: column;
    transform: translateY(-10px) scale(0.96);
    opacity: 0; visibility: hidden; pointer-events: none;
    transition: transform var(--md-duration-medium) var(--md-ease-emphasized-decel),
                opacity var(--md-duration-short) var(--md-ease-standard),
                visibility 0s linear var(--md-duration-medium);
}
.bell-panel.show {
    transform: translateY(0) scale(1);
    opacity: 1; visibility: visible; pointer-events: auto;
    transition: transform var(--md-duration-medium) var(--md-ease-emphasized-decel),
                opacity var(--md-duration-short) var(--md-ease-standard),
                visibility 0s linear 0s;
}
.bell-panel-header {
    padding: 16px 20px;
    background: var(--md-primary-container);
    color: var(--md-on-primary-container);
    font-weight: 500;
    display: flex; align-items: center; justify-content: space-between; gap: 8px;
}
.bell-close {
    background: none; border: none; color: inherit;
    font-size: 1.4rem; cursor: pointer;
    width: 32px; height: 32px;
    border-radius: var(--md-shape-full);
    line-height: 1;
}
.bell-close:hover { background: rgba(0,0,0,0.08); }
.bell-empty { padding: 32px 20px; text-align: center; color: var(--md-on-surface-variant); }
.bell-empty p { margin-top: 12px; line-height: 1.5; }
.bell-list { overflow-y: auto; flex: 1; }
.bell-item {
    display: flex; align-items: center; gap: 8px;
    padding: 12px 16px;
    border-bottom: 1px solid var(--md-outline-variant);
    transition: background var(--md-duration-short) var(--md-ease-standard);
}
.bell-item:hover { background: rgba(0,0,0,0.04); }
.bell-item:last-child { border-bottom: none; }
.bell-item-info { flex: 1; min-width: 0; }
.bell-item-title {
    display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap;
    margin-bottom: 3px;
}
.bell-item-title strong { font-size: 0.9375rem; color: var(--md-on-surface); }
.bell-item-device { font-size: 0.8rem; color: var(--md-on-surface-variant); }
.bell-item-meta { font-size: 0.75rem; color: var(--md-on-surface-variant); }
.bell-item-actions { display: flex; gap: 4px; flex-shrink: 0; }
.bell-snooze-menu { position: relative; }
.bell-snooze-options {
    display: none;
    position: absolute; right: 0; top: 100%;
    margin-top: 4px;
    background: var(--md-surface-container-highest);
    border-radius: var(--md-shape-md);
    box-shadow: var(--md-elev-2);
    min-width: 220px;
    overflow: hidden;
    z-index: 1601;
}
.bell-snooze-menu.open .bell-snooze-options { display: block; }
.bell-snooze-options a {
    display: block; padding: 10px 14px;
    color: var(--md-on-surface); font-size: 0.875rem;
    text-decoration: none;
    transition: background var(--md-duration-short);
}
.bell-snooze-options a:hover { background: rgba(0,0,0,0.06); text-decoration: none; }

/* Wiersz reklamacji w tabeli — pomarańczowy akcent */
.repairs-table tbody tr.row-claim {
    background: var(--md-warning-container);
}
.repairs-table tbody tr.row-claim:hover { background: var(--md-warning-container); }

.btn-icon-filled.claim { background: var(--md-warning); color: var(--md-on-warning); }
.btn-icon-filled.reminder { background: #fef3c7; color: #78350f; }

/* Edit modal — zachowuje czytelność dla form-grid w modalu */
.modal-overlay .modal-content.edit-modal {
    max-width: 760px;
}

/* ================================================================
   CONTAINER & PAGE HEADING
   ================================================================ */
.container-fluid {
    padding: 24px 32px;
    flex: 1;
    width: 100%;
}
.page-heading {
    margin-bottom: 24px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
}
.page-heading h1 {
    font-size: 1.75rem;
    font-weight: 400;
    color: var(--md-on-surface);
    letter-spacing: 0;
}
/* Action buttons w nagłówku — zwarte, bez dolnego marginu */
.action-buttons.heading-actions {
    margin: 0;
    flex-wrap: wrap;
}
@media (max-width: 768px) {
    .dashboard-heading { flex-direction: column; align-items: stretch; }
    .action-buttons.heading-actions { justify-content: flex-start; }
}

/* ================================================================
   CARDS - MD3
   ================================================================ */
.card {
    background: var(--md-surface-container-low);
    border: none;
    border-radius: var(--md-shape-lg);
    margin-bottom: 20px;
    overflow: hidden;
    transition: box-shadow var(--md-duration-medium) var(--md-ease-standard);
}
.card.elevated { background: var(--md-surface); box-shadow: var(--md-elev-1); }
.card.outlined { background: var(--md-surface); border: 1px solid var(--md-outline-variant); }

.card-header {
    background: transparent;
    border-bottom: 1px solid var(--md-outline-variant);
    padding: 16px 24px;
    font-weight: 500;
    color: var(--md-on-surface);
    font-size: 1rem;
    display: flex;
    align-items: center;
    gap: 12px;
    letter-spacing: 0;
}
.card-header i { color: var(--md-primary); font-size: 1.125rem; }
.card-body { padding: 20px 24px; }

/* ================================================================
   INFO CARDS
   ================================================================ */
.info-card {
    padding: 20px;
    background: var(--md-surface-container);
    border-radius: var(--md-shape-md);
    margin-bottom: 16px;
    border: none;
    border-left: 4px solid var(--md-primary);
    position: relative;
    overflow: hidden;
    transition: box-shadow var(--md-duration-medium) var(--md-ease-standard);
}
.info-card:hover { box-shadow: var(--md-elev-1); }
.info-card.primary { border-left-color: var(--md-primary);   background: var(--md-primary-container); }
.info-card.success { border-left-color: var(--md-success);   background: var(--md-success-container); }
.info-card.info    { border-left-color: var(--md-info);      background: var(--md-info-container); }
.info-card.warning { border-left-color: var(--md-warning);   background: var(--md-warning-container); }
.info-card.danger  { border-left-color: var(--md-error);     background: var(--md-error-container); }
.info-card-text {
    font-size: 0.75rem;
    text-transform: uppercase;
    color: var(--md-on-primary-container);
    font-weight: 500;
    letter-spacing: 0.1em;
    margin-bottom: 6px;
}
.info-card.success .info-card-text { color: var(--md-on-success-container); }
.info-card.info    .info-card-text { color: var(--md-on-info-container); }
.info-card.warning .info-card-text { color: var(--md-on-warning-container); }
.info-card.danger  .info-card-text { color: var(--md-on-error-container); }
.info-card-value {
    font-size: 1.5rem;
    font-weight: 500;
    color: var(--md-on-surface);
}
.info-card.primary .info-card-value { color: var(--md-on-primary-container); }
.info-card.success .info-card-value { color: var(--md-on-success-container); }
.info-card.info    .info-card-value { color: var(--md-on-info-container); }
.info-card.warning .info-card-value { color: var(--md-on-warning-container); }
.info-card.danger  .info-card-value { color: var(--md-on-error-container); }
.info-card-icon {
    float: right;
    font-size: 2rem;
    color: rgba(0,0,0,0.15);
    margin-top: -4px;
}

/* ================================================================
   FORMS - MD3 Filled Text Fields
   ================================================================ */
.form-group { margin-bottom: 18px; }
.form-label {
    display: block;
    margin-bottom: 6px;
    font-weight: 500;
    font-size: 0.8125rem;
    color: var(--md-on-surface-variant);
    letter-spacing: 0.01em;
}
.form-control,
input[type="text"].form-control,
input[type="number"].form-control,
input[type="email"].form-control,
input[type="password"].form-control,
input[type="url"].form-control,
input[type="month"].form-control,
input[type="date"].form-control,
select.form-control,
textarea.form-control {
    display: block;
    width: 100%;
    padding: 14px 16px;
    font-size: 0.9375rem;
    line-height: 1.4;
    font-family: inherit;
    color: var(--md-on-surface);
    background: var(--md-surface-container-highest);
    border: 1px solid transparent;
    border-bottom: 1px solid var(--md-on-surface-variant);
    border-radius: var(--md-shape-xs) var(--md-shape-xs) 0 0;
    transition: background var(--md-duration-short) var(--md-ease-standard),
                border-color var(--md-duration-short) var(--md-ease-standard);
    outline: none;
}
.form-control:hover { background: var(--md-surface-container-high); }
.form-control:focus {
    border-bottom: 2px solid var(--md-primary);
    padding-bottom: 13px;
    background: var(--md-surface-container-high);
    outline: 0;
    box-shadow: none;
}
.form-control::placeholder { color: var(--md-on-surface-variant); opacity: 0.7; }
textarea.form-control { min-height: 100px; resize: vertical; line-height: 1.5; }
select.form-control {
    appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='%2344464f'><path d='M7 10l5 5 5-5z'/></svg>");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 44px;
}
input[type="date"]::-webkit-calendar-picker-indicator,
input[type="month"]::-webkit-calendar-picker-indicator {
    cursor: pointer;
    opacity: 0.7;
    filter: invert(0.25);
}
input[type="date"]::-webkit-calendar-picker-indicator:hover,
input[type="month"]::-webkit-calendar-picker-indicator:hover { opacity: 1; }

/* ================================================================
   BUTTONS - MD3
   ================================================================ */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-weight: 500;
    text-align: center;
    white-space: nowrap;
    user-select: none;
    border: none;
    padding: 0 24px;
    min-height: 40px;
    font-size: 0.875rem;
    font-family: inherit;
    line-height: 1;
    border-radius: var(--md-shape-full);
    letter-spacing: 0.0071em;
    transition: background var(--md-duration-short) var(--md-ease-standard),
                box-shadow var(--md-duration-short) var(--md-ease-standard),
                color var(--md-duration-short) var(--md-ease-standard);
    cursor: pointer;
    text-decoration: none;
    position: relative;
    overflow: hidden;
}
.btn:hover { box-shadow: var(--md-elev-1); text-decoration: none; }
.btn:active { box-shadow: none; }
.btn:focus-visible { outline: 2px solid var(--md-primary); outline-offset: 2px; }
.btn::after {
    content: '';
    position: absolute;
    inset: 0;
    background: currentColor;
    opacity: 0;
    transition: opacity var(--md-duration-short) var(--md-ease-standard);
    pointer-events: none;
}
.btn:hover::after  { opacity: 0.08; }
.btn:active::after { opacity: 0.12; }
.btn i { font-size: 1.125rem; }

/* Filled */
.btn-primary { background: var(--md-primary); color: var(--md-on-primary); }
.btn-success { background: var(--md-success); color: var(--md-on-success); }
.btn-danger  { background: var(--md-error);   color: var(--md-on-error); }
.btn-warning { background: var(--md-warning); color: var(--md-on-warning); }
.btn-info    { background: var(--md-info);    color: var(--md-on-info); }
/* Tonal */
.btn-secondary { background: var(--md-secondary-container); color: var(--md-on-secondary-container); }
/* Outlined */
.btn-outlined {
    background: transparent;
    color: var(--md-primary);
    border: 1px solid var(--md-outline);
}
.btn-outlined:hover { background: rgba(11, 87, 208, 0.08); box-shadow: none; }
/* Text */
.btn-text {
    background: transparent;
    color: var(--md-primary);
    padding: 0 12px;
    box-shadow: none;
}
.btn-text:hover { background: rgba(11, 87, 208, 0.08); box-shadow: none; }

/* Sizes */
.btn-sm { min-height: 32px; padding: 0 16px; font-size: 0.8125rem; }
.btn-sm i { font-size: 0.95rem; }
.btn-lg { min-height: 48px; padding: 0 28px; font-size: 0.9375rem; }

.btn:disabled, .btn.disabled {
    opacity: 1;
    background: rgba(0,0,0,0.12);
    color: rgba(0,0,0,0.38);
    cursor: not-allowed;
    box-shadow: none;
}
.btn:disabled:hover, .btn.disabled:hover { box-shadow: none; background: rgba(0,0,0,0.12); }

/* ================================================================
   TABLES
   ================================================================ */
.table {
    width: 100%;
    margin-bottom: 0;
    color: var(--md-on-surface);
    border-collapse: separate;
    border-spacing: 0;
    background: transparent;
}
.table th, .table td {
    padding: 14px 16px;
    vertical-align: middle;
    border-top: none;
    border-bottom: 1px solid var(--md-outline-variant);
    font-size: 0.875rem;
}
.table thead th {
    border-bottom: 1px solid var(--md-outline);
    font-weight: 500;
    color: var(--md-on-surface-variant);
    font-size: 0.8125rem;
    letter-spacing: 0.01em;
    background: transparent;
}
.table tbody tr { transition: background var(--md-duration-short) var(--md-ease-standard); }
.table tbody tr:hover { background: rgba(0,0,0,0.04); }
.table tbody tr:last-child td { border-bottom: none; }
.table-sm th, .table-sm td { padding: 10px 12px; font-size: 0.8125rem; }

/* ================================================================
   BADGES / CHIPS (MD3)
   ================================================================ */
.badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 12px;
    min-height: 24px;
    font-size: 0.75rem;
    font-weight: 500;
    line-height: 1.4;
    white-space: nowrap;
    border-radius: var(--md-shape-sm);
    letter-spacing: 0.01em;
    border: 1px solid transparent;
}
.badge-primary   { background: var(--md-primary-container);   color: var(--md-on-primary-container); }
.badge-success   { background: var(--md-success-container);   color: var(--md-on-success-container); }
.badge-danger    { background: var(--md-error-container);     color: var(--md-on-error-container); }
.badge-warning   { background: var(--md-warning-container);   color: var(--md-on-warning-container); }
.badge-info      { background: var(--md-info-container);      color: var(--md-on-info-container); }
.badge-secondary { background: var(--md-secondary-container); color: var(--md-on-secondary-container); }

/* ================================================================
   ALERTS
   ================================================================ */
.alert {
    padding: 14px 18px;
    margin-bottom: 16px;
    border: none;
    border-radius: var(--md-shape-md);
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 0.9375rem;
    line-height: 1.4;
    position: relative;
    overflow: hidden;
    animation: alert-slide-in var(--md-duration-medium) var(--md-ease-emphasized-decel);
}
.alert.dismissing {
    animation: alert-slide-out var(--md-duration-medium) var(--md-ease-standard) forwards;
}
.alert i { font-size: 1.25rem; flex-shrink: 0; }
.alert-success { background: var(--md-success-container); color: var(--md-on-success-container); }
.alert-danger  { background: var(--md-error-container);   color: var(--md-on-error-container); }
.alert-info    { background: var(--md-info-container);    color: var(--md-on-info-container); }
.alert-warning { background: var(--md-warning-container); color: var(--md-on-warning-container); }

/* Progressbar na dole alertu auto-dismiss */
.alert-progress {
    position: absolute;
    bottom: 0;
    left: 0;
    height: 3px;
    background: rgba(0, 0, 0, 0.18);
    width: 100%;
    transform-origin: left;
    animation: alert-progress 5s linear forwards;
}
[data-theme="dark"] .alert-progress { background: rgba(255, 255, 255, 0.25); }
.alert.is-paused .alert-progress { animation-play-state: paused; }

@keyframes alert-slide-in {
    from { opacity: 0; transform: translateY(-12px) scale(0.98); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes alert-slide-out {
    to { opacity: 0; transform: translateY(-12px) scale(0.98); max-height: 0; padding-top: 0; padding-bottom: 0; margin-bottom: 0; }
}
@keyframes alert-progress {
    from { transform: scaleX(1); }
    to   { transform: scaleX(0); }
}

/* ================================================================
   GRID UTILITIES
   ================================================================ */
.row {
    display: flex;
    flex-wrap: wrap;
    margin-right: -10px;
    margin-left: -10px;
}
.col, .col-xl-3, .col-xl-4, .col-xl-6, .col-xl-12,
.col-lg-3, .col-lg-4, .col-lg-6, .col-lg-12,
.col-md-3, .col-md-4, .col-md-6, .col-md-12 {
    position: relative;
    width: 100%;
    padding-right: 10px;
    padding-left: 10px;
}
.col-xl-3, .col-lg-3, .col-md-3 { flex: 0 0 25%; max-width: 25%; }
.col-xl-4, .col-lg-4, .col-md-4 { flex: 0 0 33.333333%; max-width: 33.333333%; }
.col-xl-6, .col-lg-6, .col-md-6 { flex: 0 0 50%; max-width: 50%; }
.col-xl-12, .col-lg-12, .col-md-12 { flex: 0 0 100%; max-width: 100%; }

.mb-4 { margin-bottom: 1.5rem; } .mb-3 { margin-bottom: 1rem; } .mb-2 { margin-bottom: 0.5rem; }
.mt-4 { margin-top: 1.5rem; }    .mt-3 { margin-top: 1rem; }
.text-xs { font-size: 0.7rem; } .text-sm { font-size: 0.875rem; }
.font-weight-bold { font-weight: 500; }
.text-uppercase { text-transform: uppercase; letter-spacing: 0.1em; }
.d-flex { display: flex; }
.justify-content-between { justify-content: space-between; }
.align-items-center { align-items: center; }

/* ================================================================
   MODAL - MD3 Dialog with smooth animations
   ================================================================ */
.modal {
    display: none;
    position: fixed;
    z-index: 10000;
    left: 0; top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgba(0,0,0,0);
    transition: background-color var(--md-duration-medium) var(--md-ease-standard);
}
.modal.show {
    display: block;
    background-color: rgba(0,0,0,0.4);
    backdrop-filter: blur(2px);
}
.modal-dialog {
    position: relative;
    width: auto;
    max-width: 560px;
    margin: 1.75rem auto;
    transform: scale(0.9);
    opacity: 0;
    transition: all var(--md-duration-medium) var(--md-ease-emphasized);
}
.modal.show .modal-dialog { transform: scale(1); opacity: 1; }
.modal-content {
    position: relative;
    display: flex;
    flex-direction: column;
    background: var(--md-surface-container-high);
    border: none;
    border-radius: var(--md-shape-xl);
    box-shadow: var(--md-elev-3);
}
.modal-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 24px 24px 16px;
    border-bottom: none;
}
.modal-title {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 400;
    color: var(--md-on-surface);
}
.modal-close {
    background: none; border: none;
    font-size: 1.5rem; font-weight: 400;
    color: var(--md-on-surface-variant);
    cursor: pointer; padding: 0;
    width: 40px; height: 40px; line-height: 1;
    border-radius: var(--md-shape-full);
    transition: background var(--md-duration-short) var(--md-ease-standard);
}
.modal-close:hover { background: rgba(0,0,0,0.08); color: var(--md-on-surface); }
.modal-body {
    padding: 0 24px 24px;
    max-height: calc(100vh - 200px);
    overflow-y: auto;
    color: var(--md-on-surface-variant);
}
.modal-footer {
    display: flex; align-items: center; justify-content: flex-end;
    padding: 8px 24px 24px;
    gap: 8px;
}

/* Modal Overlay — MD3 Dialog z poprawnymi animacjami wejścia i wyjścia.
   Element pozostaje cały czas w DOM i display:flex, ukrywanie przez
   visibility + opacity + pointer-events żeby transition działał. */
.modal-overlay {
    display: flex;
    position: fixed;
    inset: 0;
    align-items: center;
    justify-content: center;
    padding: 16px;
    z-index: 1000;
    background: rgba(0, 0, 0, 0);
    backdrop-filter: blur(0);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
        opacity var(--md-duration-medium) var(--md-ease-standard),
        background var(--md-duration-medium) var(--md-ease-standard),
        backdrop-filter var(--md-duration-medium) var(--md-ease-standard),
        visibility 0s linear var(--md-duration-medium);
}
.modal-overlay.show {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    background: rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(3px);
    transition:
        opacity var(--md-duration-medium) var(--md-ease-standard),
        background var(--md-duration-medium) var(--md-ease-standard),
        backdrop-filter var(--md-duration-medium) var(--md-ease-standard),
        visibility 0s linear 0s;
}
.modal-overlay .modal-content {
    background: var(--md-surface-container-high);
    border-radius: var(--md-shape-xl);
    padding: 28px;
    max-width: 600px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    transform: translateY(30px) scale(0.92);
    opacity: 0;
    box-shadow: var(--md-elev-3);
    transition:
        transform var(--md-duration-long) var(--md-ease-emphasized-decel),
        opacity var(--md-duration-medium) var(--md-ease-standard);
}
.modal-overlay.show .modal-content {
    transform: translateY(0) scale(1);
    opacity: 1;
}

/* Confirm sub-modal — MD3, z-index nad głównym modalem */
.confirm-modal {
    display: flex;
    position: fixed;
    inset: 0;
    align-items: center;
    justify-content: center;
    padding: 16px;
    z-index: 10001;
    background: rgba(0, 0, 0, 0);
    backdrop-filter: blur(0);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
        opacity var(--md-duration-medium) var(--md-ease-standard),
        background var(--md-duration-medium) var(--md-ease-standard),
        backdrop-filter var(--md-duration-medium) var(--md-ease-standard),
        visibility 0s linear var(--md-duration-medium);
}
.confirm-modal.show {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    background: rgba(0, 0, 0, 0.45);
    backdrop-filter: blur(4px);
    transition:
        opacity var(--md-duration-medium) var(--md-ease-standard),
        background var(--md-duration-medium) var(--md-ease-standard),
        backdrop-filter var(--md-duration-medium) var(--md-ease-standard),
        visibility 0s linear 0s;
}
.confirm-modal .confirm-content {
    background: var(--md-surface-container-high);
    border-radius: var(--md-shape-xl);
    padding: 24px;
    max-width: 380px;
    width: 100%;
    box-shadow: var(--md-elev-4);
    transform: scale(0.85);
    opacity: 0;
    transition:
        transform var(--md-duration-medium) var(--md-ease-emphasized-decel),
        opacity var(--md-duration-short) var(--md-ease-standard);
}
.confirm-modal.show .confirm-content {
    transform: scale(1);
    opacity: 1;
}
.confirm-modal .confirm-title {
    font-size: 1.375rem;
    font-weight: 400;
    color: var(--md-on-surface);
    margin-bottom: 12px;
}
.confirm-modal .confirm-message {
    font-size: 0.9375rem;
    color: var(--md-on-surface-variant);
    line-height: 1.5;
    margin-bottom: 24px;
}
.confirm-modal .confirm-actions {
    display: flex;
    gap: 8px;
    justify-content: flex-end;
}

/* ================================================================
   TOGGLE SWITCH - MD3 Switch
   ================================================================ */
.toggle-switch {
    position: relative;
    display: inline-block;
    width: 52px;
    height: 32px;
    flex-shrink: 0;
}
.toggle-switch input { opacity: 0; width: 0; height: 0; }
.toggle-slider {
    position: absolute;
    cursor: pointer;
    inset: 0;
    background: var(--md-surface-container-highest);
    border: 2px solid var(--md-outline);
    transition: all var(--md-duration-short) var(--md-ease-standard);
    border-radius: var(--md-shape-full);
}
.toggle-slider:before {
    position: absolute;
    content: "";
    height: 16px; width: 16px;
    left: 6px; bottom: 6px;
    background: var(--md-outline);
    transition: all var(--md-duration-short) var(--md-ease-standard);
    border-radius: var(--md-shape-full);
}
.toggle-switch input:checked + .toggle-slider {
    background: var(--md-primary);
    border-color: var(--md-primary);
}
.toggle-switch input:checked + .toggle-slider:before {
    transform: translateX(20px);
    background: var(--md-on-primary);
    width: 22px; height: 22px;
    left: 3px; bottom: 3px;
}
.toggle-label {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    cursor: pointer;
    user-select: none;
    font-size: 0.9375rem;
    color: var(--md-on-surface);
}

/* ================================================================
   DASHBOARD-SPECIFIC
   ================================================================ */
.dashboard-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}
.stat-card {
    background: var(--md-surface-container-low);
    border-radius: var(--md-shape-lg);
    padding: 20px;
    transition: box-shadow var(--md-duration-medium) var(--md-ease-standard),
                transform var(--md-duration-medium) var(--md-ease-standard);
    position: relative;
    overflow: hidden;
    border: 1px solid var(--md-outline-variant);
}
.stat-card:hover {
    box-shadow: var(--md-elev-2);
    transform: translateY(-2px);
}
.stat-card.revenue       { --accent: var(--md-primary);   --accent-container: var(--md-primary-container); }
.stat-card.profit        { --accent: var(--md-success);   --accent-container: var(--md-success-container); }
.stat-card.repairs       { --accent: var(--md-info);      --accent-container: var(--md-info-container); }
.stat-card.unreleased    { --accent: var(--md-warning);   --accent-container: var(--md-warning-container); }
.stat-card.bonus         { --accent: var(--md-tertiary);  --accent-container: var(--md-tertiary-container); }
.stat-card.bonus-pending { --accent: #7a4e00;             --accent-container: #ffdcbe; }
.stat-card.claims        { --accent: var(--md-warning);   --accent-container: var(--md-warning-container); }

.stat-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 4px;
    background: var(--accent);
}
.stat-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 10px;
}
.stat-label {
    font-size: 0.75rem;
    font-weight: 500;
    text-transform: uppercase;
    color: var(--md-on-surface-variant);
    letter-spacing: 0.1em;
}
.stat-icon {
    width: 44px; height: 44px;
    border-radius: var(--md-shape-md);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.25rem;
    background: var(--accent-container);
    color: var(--accent);
}
.stat-value {
    font-size: 2rem;
    font-weight: 400;
    color: var(--md-on-surface);
    margin: 4px 0 6px;
    letter-spacing: -0.02em;
    line-height: 1.2;
}
.stat-subtitle { font-size: 0.8125rem; color: var(--md-on-surface-variant); }

/* Mały inline przycisk w kafelku stat-card */
.stat-card-action {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 12px;
    padding: 6px 14px;
    border-radius: var(--md-shape-full);
    background: var(--md-surface-container);
    color: var(--md-primary);
    font-size: 0.75rem;
    font-weight: 500;
    text-decoration: none;
    transition: background var(--md-duration-short) var(--md-ease-standard);
    width: fit-content;
}
.stat-card-action:hover {
    background: var(--md-surface-container-highest);
    text-decoration: none;
}
.stat-card-action i { font-size: 0.7rem; }

.points-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(380px, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}
.point-card {
    background: var(--md-surface-container-low);
    border-radius: var(--md-shape-lg);
    padding: 20px;
    border: 1px solid var(--md-outline-variant);
    transition: box-shadow var(--md-duration-medium) var(--md-ease-standard);
}
.point-card:hover { box-shadow: var(--md-elev-1); }
.point-header {
    font-size: 1.0625rem;
    font-weight: 500;
    color: var(--md-on-surface);
    margin-bottom: 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--md-outline-variant);
    display: flex;
    align-items: center;
    gap: 8px;
}
.point-header::before {
    content: '\f3c5';
    font-family: 'Font Awesome 6 Free';
    font-weight: 900;
    color: var(--md-primary);
    font-size: 1rem;
}
.point-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.point-stat {
    padding: 14px;
    background: var(--md-surface-container);
    border-radius: var(--md-shape-md);
    border: 2px solid var(--accent-color);
    transition: box-shadow var(--md-duration-short) var(--md-ease-standard);
}
.point-stat:hover { box-shadow: 0 0 0 1px var(--accent-color); }
.point-stat.repairs  { --accent-color: var(--md-primary); }
.point-stat.services { --accent-color: var(--md-success); }
.point-stat-label {
    font-size: 0.7rem;
    font-weight: 500;
    color: var(--md-on-surface-variant);
    text-transform: uppercase;
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 6px;
    letter-spacing: 0.08em;
}
.point-stat-value { font-size: 0.8125rem; color: var(--md-on-surface-variant); margin: 2px 0; }
.point-stat-amount { font-size: 0.9375rem; font-weight: 500; color: var(--md-on-surface); margin: 2px 0; }

/* Action buttons row */
.action-buttons {
    display: flex;
    gap: 12px;
    margin-bottom: 24px;
    flex-wrap: wrap;
}
.btn-action {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 0 24px;
    min-height: 40px;
    border-radius: var(--md-shape-full);
    font-weight: 500;
    font-size: 0.875rem;
    text-decoration: none;
    transition: background var(--md-duration-short) var(--md-ease-standard),
                box-shadow var(--md-duration-short) var(--md-ease-standard);
    border: none;
    cursor: pointer;
    font-family: inherit;
    position: relative;
    overflow: hidden;
}
.btn-action:hover { text-decoration: none; box-shadow: var(--md-elev-1); }
.btn-action:disabled,
.btn-action[disabled] {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}
.btn-action::after {
    content: ''; position: absolute; inset: 0;
    background: currentColor; opacity: 0;
    transition: opacity var(--md-duration-short);
    pointer-events: none;
}
.btn-action:hover::after  { opacity: 0.08; }
.btn-action:active::after { opacity: 0.12; }
.btn-primary-gradient { background: var(--md-primary); color: var(--md-on-primary); }
.btn-success-gradient { background: var(--md-success); color: var(--md-on-success); }

/* ================================================================
   REPAIRS LIST - Filters, table, filled action buttons
   ================================================================ */
.filters-card.card {
    background: var(--md-surface-container-low);
    border-radius: var(--md-shape-lg);
    overflow: hidden;
}
.filters-card .card-header {
    background: var(--md-primary-container);
    color: var(--md-on-primary-container);
    padding: 16px 24px;
    border-radius: 0;
    font-weight: 500;
    border-bottom: none;
}
.filters-card .card-header i { color: var(--md-on-primary-container); }
.filters-card .card-body { padding: 20px 24px; }

.filter-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 16px;
    margin-bottom: 12px;
}
.filter-group { display: flex; flex-direction: column; }
.filter-label {
    font-weight: 500;
    color: var(--md-on-surface-variant);
    margin-bottom: 6px;
    font-size: 0.8125rem;
}
.filter-control {
    padding: 14px 16px;
    border: 1px solid transparent;
    border-bottom: 1px solid var(--md-on-surface-variant);
    background: var(--md-surface-container-highest);
    border-radius: var(--md-shape-xs) var(--md-shape-xs) 0 0;
    font-size: 0.9375rem;
    color: var(--md-on-surface);
    transition: all var(--md-duration-short) var(--md-ease-standard);
    outline: none;
    font-family: inherit;
}
.filter-control:focus {
    border-bottom: 2px solid var(--md-primary);
    padding-bottom: 13px;
}

.filters-toolbar {
    display: flex;
    gap: 12px;
    align-items: center;
    flex-wrap: wrap;
}

/* Main repairs table */
.repairs-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    background: transparent;
}
.repairs-table thead th {
    background: transparent;
    color: var(--md-on-surface-variant);
    font-weight: 500;
    font-size: 0.8125rem;
    letter-spacing: 0.01em;
    padding: 16px 12px;
    text-align: center;
    vertical-align: middle;
    border-bottom: 1px solid var(--md-outline);
}
.repairs-table thead th.sortable {
    cursor: pointer;
    user-select: none;
    transition: background var(--md-duration-short) var(--md-ease-standard);
}
.repairs-table thead th.sortable:hover { background: rgba(0,0,0,0.03); }
.repairs-table thead th.sortable .sort-icon {
    margin-left: 4px;
    opacity: 0.5;
    font-size: 0.75rem;
}
.repairs-table thead th.sortable.active .sort-icon {
    opacity: 1;
    color: var(--md-primary);
}
.repairs-table tbody td {
    padding: 14px 12px;
    text-align: center;
    vertical-align: middle;
    border-bottom: 1px solid var(--md-outline-variant);
    font-size: 0.875rem;
    color: var(--md-on-surface);
}
.repairs-table tbody tr { transition: background var(--md-duration-short) var(--md-ease-standard); }
.repairs-table tbody tr:hover { background: rgba(0,0,0,0.03); }
.repairs-table tbody tr:last-child td { border-bottom: none; }

/* Description cell */
.desc-cell {
    text-align: left !important;
    max-width: 260px;
    font-size: 0.8125rem;
    color: var(--md-on-surface-variant);
    line-height: 1.4;
}
.desc-cell strong {
    display: block;
    color: var(--md-on-surface);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 500;
    margin-bottom: 2px;
}
.desc-cell .desc-block { margin-bottom: 6px; }
.desc-cell .desc-block:last-child { margin-bottom: 0; }
.desc-cell .desc-empty { color: var(--md-on-surface-variant); opacity: 0.5; font-style: italic; }

/* Status badges stack (two chips side-by-side) */
.status-stack {
    display: flex;
    flex-direction: column;
    gap: 4px;
    align-items: center;
}
.status-badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 12px;
    min-height: 24px;
    border-radius: var(--md-shape-sm);
    font-size: 0.7rem;
    font-weight: 500;
    letter-spacing: 0.01em;
    white-space: nowrap;
}
.status-badge.success   { background: var(--md-success-container);   color: var(--md-on-success-container); }
.status-badge.warning   { background: var(--md-warning-container);   color: var(--md-on-warning-container); }
.status-badge.secondary { background: var(--md-secondary-container); color: var(--md-on-secondary-container); }
.status-badge.danger    { background: var(--md-error-container);     color: var(--md-on-error-container); }

/* Notatka jako dymek w kolumnie statusu */
.status-badge.note-chip {
    background: #fff4d3;
    color: #5f4a00;
    max-width: 240px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    cursor: help;
}
.status-badge.note-chip i { font-size: 0.7rem; }

/* Wiersz oznaczony jako zwrot — subtelnie wyciemniony */
.repairs-table tbody tr.row-returned {
    background: var(--md-error-container);
    opacity: 0.85;
}
.repairs-table tbody tr.row-returned:hover {
    background: var(--md-error-container);
    opacity: 1;
}
.status-badge.danger    { background: var(--md-error-container);     color: var(--md-on-error-container); }

/* Action buttons for table rows — MD3 FILLED square icon buttons */
.action-buttons.table-actions {
    justify-content: center;
    gap: 6px;
    margin-bottom: 0;
    flex-wrap: nowrap;
}
.btn-icon-filled {
    width: 40px;
    height: 40px;
    padding: 0;
    border-radius: var(--md-shape-md);
    border: none;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background var(--md-duration-short) var(--md-ease-standard),
                box-shadow var(--md-duration-short) var(--md-ease-standard),
                transform var(--md-duration-short) var(--md-ease-standard);
    text-decoration: none;
    font-size: 0.95rem;
    position: relative;
    overflow: hidden;
}
.btn-icon-filled:hover {
    box-shadow: var(--md-elev-2);
    text-decoration: none;
    transform: translateY(-1px);
}
.btn-icon-filled:active { transform: translateY(0); box-shadow: var(--md-elev-1); }
.btn-icon-filled::after {
    content: ''; position: absolute; inset: 0;
    background: currentColor; opacity: 0;
    transition: opacity var(--md-duration-short);
    pointer-events: none;
    border-radius: inherit;
}
.btn-icon-filled:hover::after  { opacity: 0.12; }
.btn-icon-filled:active::after { opacity: 0.18; }

.btn-icon-filled.view    { background: var(--md-primary); color: var(--md-on-primary); }
.btn-icon-filled.edit    { background: var(--md-info);    color: var(--md-on-info); }
.btn-icon-filled.release { background: var(--md-success); color: var(--md-on-success); }
.btn-icon-filled.return  { background: var(--md-warning); color: var(--md-on-warning); }
.btn-icon-filled.return.active { background: var(--md-error); color: var(--md-on-error); }
.btn-icon-filled.delete  { background: var(--md-error);   color: var(--md-on-error); }
.btn-icon-filled.delete  { background: var(--md-error);   color: var(--md-on-error); }

/* Legacy icon buttons (transparent) - keep for places that still use them */
.btn-icon {
    width: 40px;
    height: 40px;
    padding: 0;
    border-radius: var(--md-shape-full);
    border: none;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background var(--md-duration-short) var(--md-ease-standard);
    text-decoration: none;
    color: var(--md-on-surface-variant);
    background: transparent;
}
.btn-icon:hover { background: rgba(0,0,0,0.08); text-decoration: none; }

.btn-clear-filters {
    background: transparent;
    color: var(--md-primary);
    border: 1px solid var(--md-outline);
    padding: 0 20px;
    min-height: 40px;
    border-radius: var(--md-shape-full);
    font-weight: 500;
    font-size: 0.875rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
    font-family: inherit;
    transition: background var(--md-duration-short) var(--md-ease-standard);
}
.btn-clear-filters:hover { background: rgba(11, 87, 208, 0.08); text-decoration: none; }

/* Sort toggle button */
.sort-toggle {
    background: var(--md-surface-container-high);
    color: var(--md-on-surface);
    border: none;
    padding: 0 16px;
    min-height: 40px;
    border-radius: var(--md-shape-full);
    font-weight: 500;
    font-size: 0.8125rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: inherit;
    transition: background var(--md-duration-short) var(--md-ease-standard);
}
.sort-toggle:hover { background: var(--md-surface-container-highest); }
.sort-toggle i { color: var(--md-primary); }

/* ================================================================
   SERVICE POINTS - order controls
   ================================================================ */
.point-order-controls {
    display: inline-flex;
    gap: 2px;
    margin-right: 8px;
}
.point-order-btn {
    width: 32px;
    height: 32px;
    padding: 0;
    border-radius: var(--md-shape-full);
    border: none;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--md-on-surface-variant);
    background: transparent;
    font-size: 0.875rem;
    transition: background var(--md-duration-short) var(--md-ease-standard);
    text-decoration: none;
}
.point-order-btn:hover { background: rgba(0,0,0,0.08); color: var(--md-on-surface); }
.point-order-btn.disabled { opacity: 0.3; pointer-events: none; }

/* ================================================================
   COMPACT STATS (reports page — kompaktowe statystyki)
   ================================================================ */
.stats-group {
    margin-bottom: 18px;
}
.stats-group:last-child { margin-bottom: 0; }

.stats-group-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 0 12px;
    margin-bottom: 12px;
    border-bottom: 1px solid var(--md-outline-variant);
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--md-on-surface);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}
.stats-group-header i {
    width: 28px; height: 28px;
    border-radius: var(--md-shape-sm);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
}
.stats-group-header.repairs i { background: var(--md-primary-container); color: var(--md-on-primary-container); }
.stats-group-header.services i { background: var(--md-success-container); color: var(--md-on-success-container); }
.stats-group-header.total i { background: var(--md-tertiary-container); color: var(--md-on-tertiary-container); }

/* Łączna karta (wszystkie punkty) — wyróżniony nagłówek */
.grand-total-card .card-header {
    background: var(--md-primary-container);
    color: var(--md-on-primary-container);
}
.grand-total-card { border: 2px solid var(--md-primary); }

/* Sekcja Razem — wyróżniona tłem */
.stats-group.total-group {
    margin-top: 18px;
    padding: 14px 16px;
    background: var(--md-surface-container);
    border-radius: var(--md-shape-md);
    border: 2px solid var(--md-tertiary);
}
.stats-group.total-group .stats-group-header {
    border-bottom: 1px solid var(--md-outline-variant);
    padding-top: 0;
    margin-bottom: 10px;
    color: var(--md-on-surface);
}

.stats-compact {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 10px;
}

.stat-compact {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    background: var(--md-surface-container);
    border-radius: var(--md-shape-md);
    border: 2px solid var(--accent, var(--md-primary));
    transition: background var(--md-duration-short) var(--md-ease-standard),
                box-shadow var(--md-duration-short) var(--md-ease-standard);
}
.stat-compact:hover {
    background: var(--md-surface-container-high);
    box-shadow: 0 0 0 1px var(--accent, var(--md-primary));
}

.stat-compact.primary { --accent: var(--md-primary);  --accent-bg: var(--md-primary-container);  --accent-fg: var(--md-on-primary-container); }
.stat-compact.success { --accent: var(--md-success);  --accent-bg: var(--md-success-container);  --accent-fg: var(--md-on-success-container); }
.stat-compact.info    { --accent: var(--md-info);     --accent-bg: var(--md-info-container);     --accent-fg: var(--md-on-info-container); }
.stat-compact.warning { --accent: var(--md-warning);  --accent-bg: var(--md-warning-container);  --accent-fg: var(--md-on-warning-container); }

.stat-compact-icon {
    width: 36px; height: 36px;
    flex-shrink: 0;
    border-radius: var(--md-shape-sm);
    background: var(--accent-bg, var(--md-primary-container));
    color: var(--accent-fg, var(--md-on-primary-container));
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95rem;
}
.stat-compact-content {
    display: flex;
    flex-direction: column;
    min-width: 0;
    gap: 2px;
}
.stat-compact-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    color: var(--md-on-surface-variant);
    letter-spacing: 0.05em;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.stat-compact-value {
    font-size: 1.125rem;
    font-weight: 500;
    color: var(--md-on-surface);
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ================================================================
   DASHBOARD CHART CARD
   ================================================================ */
.chart-card {
    background: var(--md-surface-container-low);
    border-radius: var(--md-shape-lg);
    padding: 20px 24px 16px;
    margin-bottom: 24px;
    box-shadow: none;
    border: 1px solid var(--md-outline-variant);
}
.chart-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 18px;
    flex-wrap: wrap;
    gap: 12px;
}
.chart-card-title {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 1rem;
    font-weight: 500;
    color: var(--md-on-surface);
}
.chart-card-title .chart-icon {
    width: 40px; height: 40px;
    border-radius: var(--md-shape-md);
    background: var(--md-primary-container);
    color: var(--md-on-primary-container);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
}
.chart-card-title .chart-subtitle {
    font-size: 0.75rem;
    color: var(--md-on-surface-variant);
    font-weight: 400;
    margin-top: 2px;
    display: block;
}
.chart-legend {
    display: inline-flex;
    align-items: center;
    gap: 18px;
    font-size: 0.8125rem;
    color: var(--md-on-surface-variant);
}
/* Pasek kontroli wykresu (toggle + legend) */
.chart-controls {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}
.chart-type-toggle {
    display: inline-flex;
    background: var(--md-surface-container);
    border-radius: var(--md-shape-full);
    padding: 3px;
    gap: 2px;
}
.chart-type-btn {
    background: none;
    border: none;
    cursor: pointer;
    width: 32px;
    height: 32px;
    border-radius: var(--md-shape-full);
    color: var(--md-on-surface-variant);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    transition: background var(--md-duration-short) var(--md-ease-standard),
                color var(--md-duration-short) var(--md-ease-standard);
}
.chart-type-btn:hover { background: rgba(0,0,0,0.06); }
.chart-type-btn.active {
    background: var(--md-primary);
    color: var(--md-on-primary);
}
.chart-legend .legend-dot {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.chart-legend .legend-dot::before {
    content: '';
    width: 12px;
    height: 12px;
    border-radius: var(--md-shape-xs);
    background: var(--dot-color, var(--md-primary));
}
.chart-legend .legend-dot.revenue::before { background: var(--md-primary); }
.chart-legend .legend-dot.profit::before  { background: var(--md-success); }

.chart-canvas-wrap {
    position: relative;
    width: 100%;
    height: 320px;
}
@media (max-width: 768px) {
    .chart-canvas-wrap { height: 260px; }
}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width: 768px) {
    /* Sidebar mobile = bottom-nav (zdefiniowane niżej w bloku Mobile bottom nav) */
    #content-wrapper { margin-left: 0; }
    #content-wrapper.toggled { margin-left: 0; }
    .container-fluid { padding: 16px; }
    .col-xl-3, .col-xl-4, .col-xl-6,
    .col-lg-3, .col-lg-4, .col-lg-6,
    .col-md-3, .col-md-4, .col-md-6 {
        flex: 0 0 100%; max-width: 100%;
    }
    .page-heading h1 { font-size: 1.5rem; }
}

/* ================================================================
   PRINT
   ================================================================ */
@media print {
    #sidebar, .topbar, .sidebar-toggle, .btn, .btn-action { display: none !important; }
    #content-wrapper { margin-left: 0 !important; }
    .card { box-shadow: none; border: 1px solid #ccc; }
    body { background: white; }
}

/* ============ Point services-enabled toggle (mini) ============ */
.point-toggle-mini {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
    cursor: pointer;
    user-select: none;
}
.point-toggle-mini-track {
    width: 36px;
    height: 20px;
    border-radius: var(--md-shape-full);
    background: var(--md-outline-variant);
    position: relative;
    transition: background var(--md-duration-short) var(--md-ease-standard);
    flex-shrink: 0;
}
.point-toggle-mini-thumb {
    position: absolute;
    top: 2px; left: 2px;
    width: 16px; height: 16px;
    border-radius: var(--md-shape-full);
    background: white;
    transition: left var(--md-duration-short) var(--md-ease-emphasized-decel);
    box-shadow: 0 1px 2px rgba(0,0,0,0.2);
}
.point-toggle-mini.on .point-toggle-mini-track { background: var(--md-success); }
.point-toggle-mini.on .point-toggle-mini-thumb { left: 18px; }
.point-toggle-mini-label {
    font-size: 0.75rem;
    color: var(--md-on-surface-variant);
    font-weight: 500;
}
.point-toggle-mini.on .point-toggle-mini-label { color: var(--md-success); }
.point-toggle-mini:hover .point-toggle-mini-track {
    box-shadow: 0 0 0 4px rgba(0, 110, 28, 0.08);
}

/* ============ Bonus chips inside profit card ============ */
.stat-card-bonuses {
    display: flex;
    gap: 8px;
    margin-top: 12px;
    flex-wrap: wrap;
}
.bonus-chip {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    background: var(--md-surface-container);
    border-radius: var(--md-shape-md);
    border: 1px solid var(--md-outline-variant);
    flex: 1;
    min-width: 130px;
}
.bonus-chip-icon {
    width: 28px; height: 28px;
    background: var(--md-success-container);
    color: var(--md-on-success-container);
    border-radius: var(--md-shape-full);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 0.75rem;
    flex-shrink: 0;
}
.bonus-chip.pending .bonus-chip-icon {
    background: var(--md-warning-container);
    color: var(--md-on-warning-container);
}
.bonus-chip-info {
    display: flex;
    flex-direction: column;
    line-height: 1.2;
    min-width: 0;
}
.bonus-chip-label {
    font-size: 0.7rem;
    color: var(--md-on-surface-variant);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    white-space: nowrap;
}
.bonus-chip-value {
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--md-on-surface);
    white-space: nowrap;
}

/* BETA tag */
.beta-tag {
    display: inline-block;
    margin-left: 6px;
    padding: 2px 6px;
    font-size: 0.6rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    background: var(--md-warning);
    color: var(--md-on-warning);
    border-radius: var(--md-shape-xs);
    vertical-align: middle;
}

/* ============ Mobile responsive — bottom navigation ============ */
@media (max-width: 768px) {
    /* Sidebar = bottom navigation bar.
       Struktura HTML jest flat (brand + heading + divider + nav-item).
       Po prostu robimy z niego flex-row, ukrywamy non-tab elementy,
       a same nav-item rozdzielamy równomiernie. */
    #sidebar {
        position: fixed !important;
        top: auto !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        width: 100vw !important;
        max-width: 100vw !important;
        min-width: 100vw !important;
        margin: 0 !important;
        margin-left: 0 !important;
        height: 76px !important;
        padding: 0 !important;
        z-index: 1000;
        border-right: none !important;
        border-top: 1px solid var(--md-outline-variant);
        background: var(--md-surface-container);
        box-shadow: 0 -2px 12px rgba(0,0,0,0.12);
        overflow-x: auto;
        overflow-y: hidden;
        display: flex !important;
        flex-direction: row !important;
        align-items: stretch;
        justify-content: flex-start;
        transform: none !important;
        box-sizing: border-box;
    }
    /* Override potencjalnego .toggled/hover */
    #sidebar.toggled,
    #sidebar:hover {
        transform: none !important;
        width: 100vw !important;
        max-width: 100vw !important;
        margin-left: 0 !important;
    }

    /* Ukryj hamburger button w topbarze na mobile (sidebar zawsze widoczny) */
    .topbar .sidebar-toggle {
        display: none !important;
    }

    /* Ukryj wszystko co NIE jest pojedynczym tabem */
    #sidebar .sidebar-brand,
    #sidebar .sidebar-heading,
    #sidebar .sidebar-divider {
        display: none !important;
    }

    /* Każdy nav-item to równa porcja paska, min-width żeby labele się mieściły */
    #sidebar .nav-item {
        flex: 1 1 0 !important;
        min-width: 80px !important;
        margin: 0 !important;
        padding: 0 !important;
        display: flex;
        align-items: stretch;
    }

    /* Link wewnątrz nav-item — ikona nad podpisem */
    #sidebar .nav-link {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 4px !important;
        padding: 10px 4px !important;
        font-size: 0.7rem !important;
        text-align: center;
        height: 100%;
        width: 100%;
        border-radius: 0 !important;
        color: var(--md-on-surface-variant) !important;
        position: relative;
        line-height: 1.15;
    }
    #sidebar .nav-link i {
        font-size: 1.3rem !important;
        margin: 0 !important;
        width: auto !important;
    }
    /* PODPIS pod ikoną — ZAWSZE widoczny na mobile */
    #sidebar .nav-link span {
        display: block !important;
        font-size: 0.7rem !important;
        font-weight: 500;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        max-width: 100%;
    }

    /* Aktywny tab — kolorowy pasek na górze + accent */
    #sidebar .nav-link.active {
        background: transparent !important;
        color: var(--md-primary) !important;
    }
    #sidebar .nav-link.active::before {
        content: '';
        position: absolute;
        top: 0; left: 30%; right: 30%;
        height: 3px;
        background: var(--md-primary);
        border-radius: 0 0 var(--md-shape-xs) var(--md-shape-xs);
    }

    /* NIE chowamy żadnych tabów — wszystkie w paseku, można scrollować w lewo/prawo */

    /* Content wrapper bez marginesu, padding na dole na pasek */
    #content-wrapper,
    #content-wrapper.toggled {
        margin-left: 0 !important;
        padding-bottom: 84px !important;
    }
    .container-fluid {
        padding: 16px;
    }

    /* Topbar mobile — kompaktowy */
    .topbar { padding: 8px 12px; }
    .topbar h1 { font-size: 1rem; }

    /* Tabele scroll-x */
    .table-responsive { overflow-x: auto; }
    .table { font-size: 0.85rem; }
    .table th, .table td { padding: 8px 6px; white-space: nowrap; }

    /* Modale full-screen */
    .modal-content {
        max-width: 100% !important;
        max-height: 100vh;
        margin: 0;
        border-radius: 0;
    }
    .modal-overlay { padding: 0; }

    /* Page heading w pion */
    .page-heading { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 480px) {
    /* Bardzo małe ekrany — labele zostają widoczne, tylko mniejsza ikona */
    #sidebar .nav-link {
        padding: 8px 2px !important;
        gap: 2px !important;
    }
    #sidebar .nav-link i { font-size: 1.15rem !important; }
    #sidebar .nav-link span { font-size: 0.62rem !important; }
    #sidebar .nav-item { min-width: 64px !important; }
}

/* Zostawiam mobile-more-sheet bo niektórzy mogą chcieć użyć — ale hide przycisku więcej */
.nav-item-mobile-more { display: none !important; }

/* Mobile bottom-sheet z dodatkowymi zakładkami */
.mobile-more-sheet {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 1100;
    background: rgba(0, 0, 0, 0.5);
    align-items: flex-end;
    justify-content: center;
}
.mobile-more-sheet.show { display: flex; }
.mobile-more-content {
    width: 100%;
    max-height: 70vh;
    background: var(--md-surface-container);
    border-radius: var(--md-shape-xl) var(--md-shape-xl) 0 0;
    padding: 8px 16px 24px;
    overflow-y: auto;
    animation: sheet-slide-up 0.25s var(--md-ease-emphasized-decel);
}
@keyframes sheet-slide-up {
    from { transform: translateY(100%); }
    to   { transform: translateY(0); }
}
.mobile-more-handle {
    width: 32px;
    height: 4px;
    background: var(--md-outline-variant);
    border-radius: var(--md-shape-full);
    margin: 4px auto 12px;
}
.mobile-more-title {
    font-size: 1.1rem;
    font-weight: 500;
    margin: 0 0 12px;
    color: var(--md-on-surface);
}
.mobile-more-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}
.mobile-more-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px;
    background: var(--md-surface);
    border-radius: var(--md-shape-md);
    text-decoration: none;
    color: var(--md-on-surface);
    font-size: 0.875rem;
    border: 1px solid var(--md-outline-variant);
    transition: background var(--md-duration-short) var(--md-ease-standard);
}
.mobile-more-item i {
    font-size: 1.25rem;
    color: var(--md-primary);
    width: 24px;
    text-align: center;
}
.mobile-more-item:active,
.mobile-more-item:hover {
    background: var(--md-surface-container-high);
    text-decoration: none;
}
.mobile-more-item.mobile-more-logout i { color: var(--md-error); }
.mobile-more-close {
    width: 100%;
    margin-top: 16px;
    justify-content: center;
}


.topbar-user-wrap { position: relative; }
.topbar-user {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px 6px 8px;
    background: transparent;
    border: 1px solid transparent;
    border-radius: var(--md-shape-full);
    color: var(--md-on-surface);
    font: inherit;
    font-size: 0.875rem;
    cursor: pointer;
    transition: background var(--md-duration-short) var(--md-ease-standard),
                border-color var(--md-duration-short) var(--md-ease-standard);
}
.topbar-user:hover {
    background: var(--md-surface-container-high);
    border-color: var(--md-outline-variant);
}
.topbar-user[aria-expanded="true"] {
    background: var(--md-surface-container-high);
    border-color: var(--md-outline-variant);
}
.topbar-user > i.fa-user-circle {
    font-size: 1.4rem;
    color: var(--md-primary);
}
.topbar-user-caret {
    font-size: 0.75rem;
    color: var(--md-on-surface-variant);
    transition: transform var(--md-duration-short) var(--md-ease-standard);
}
.topbar-user[aria-expanded="true"] .topbar-user-caret { transform: rotate(180deg); }

.user-menu {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 220px;
    background: var(--md-surface-container);
    border: 1px solid var(--md-outline-variant);
    border-radius: var(--md-shape-md);
    box-shadow: var(--md-elev-3);
    padding: 6px;
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px);
    transition: opacity var(--md-duration-short) var(--md-ease-standard),
                transform var(--md-duration-short) var(--md-ease-standard),
                visibility var(--md-duration-short) var(--md-ease-standard);
}
.user-menu.show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.user-menu-header {
    padding: 10px 14px 8px;
    border-bottom: 1px solid var(--md-outline-variant);
    margin-bottom: 4px;
}
.user-menu-name {
    font-weight: 500;
    font-size: 0.9375rem;
    color: var(--md-on-surface);
}
.user-menu-role {
    font-size: 0.75rem;
    color: var(--md-on-surface-variant);
    text-transform: capitalize;
    margin-top: 2px;
}
.user-menu-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    color: var(--md-on-surface);
    text-decoration: none;
    font-size: 0.875rem;
    border-radius: var(--md-shape-sm);
    transition: background var(--md-duration-short) var(--md-ease-standard);
    cursor: pointer;
}
.user-menu-item:hover {
    background: var(--md-surface-container-high);
    text-decoration: none;
    color: var(--md-on-surface);
}
.user-menu-item i {
    width: 20px;
    color: var(--md-primary);
    font-size: 0.95rem;
}
.user-menu-divider {
    height: 1px;
    background: var(--md-outline-variant);
    margin: 4px 8px;
}
.user-menu-logout {
    color: var(--md-error);
}
.user-menu-logout i {
    color: var(--md-error);
}
.user-menu-logout:hover {
    background: var(--md-error-container);
    color: var(--md-on-error-container);
}


@media (max-width: 768px) {
    .topbar-user > span:not(.topbar-role) { display: none; }
    .topbar-user-caret { display: none; }
    .topbar-user { padding: 6px 8px; }
    .user-menu { min-width: 200px; }
}



.flatpickr-calendar {
    background: var(--md-surface-container);
    box-shadow: var(--md-elev-3);
    border: 1px solid var(--md-outline-variant);
    border-radius: var(--md-shape-md);
    color: var(--md-on-surface);
    font-family: inherit;
    width: 320px;
    padding: 4px;
}
.flatpickr-calendar.arrowTop:before,
.flatpickr-calendar.arrowTop:after {
    border-bottom-color: var(--md-outline-variant);
}
.flatpickr-calendar.arrowBottom:before,
.flatpickr-calendar.arrowBottom:after {
    border-top-color: var(--md-outline-variant);
}
.flatpickr-calendar:before { display: none !important; }
.flatpickr-calendar:after { display: none !important; }


.flatpickr-months {
    padding: 8px 8px 4px;
    background: transparent;
}
.flatpickr-month {
    background: transparent;
    color: var(--md-on-surface);
    height: 38px;
    overflow: visible;
}
.flatpickr-current-month {
    color: var(--md-on-surface);
    font-size: 0.9375rem;
    font-weight: 500;
    padding-top: 6px;
}
.flatpickr-current-month .flatpickr-monthDropdown-months {
    background: transparent;
    color: var(--md-on-surface);
    font-size: 0.9375rem;
    font-weight: 500;
    border-radius: var(--md-shape-sm);
    padding: 4px 8px;
}
.flatpickr-current-month .flatpickr-monthDropdown-months:hover {
    background: var(--md-surface-container-high);
}
.flatpickr-current-month input.cur-year {
    color: var(--md-on-surface);
    font-weight: 500;
    font-size: 0.9375rem;
}
.flatpickr-current-month .numInputWrapper:hover {
    background: var(--md-surface-container-high);
    border-radius: var(--md-shape-sm);
}
.flatpickr-monthDropdown-months .flatpickr-monthDropdown-month {
    background: var(--md-surface-container);
    color: var(--md-on-surface);
}


.flatpickr-prev-month,
.flatpickr-next-month {
    color: var(--md-on-surface-variant);
    fill: var(--md-on-surface-variant);
    height: 38px;
    padding: 8px;
    border-radius: 50%;
    transition: background var(--md-duration-short) var(--md-ease-standard);
}
.flatpickr-prev-month:hover,
.flatpickr-next-month:hover {
    background: var(--md-surface-container-high);
    color: var(--md-primary);
    fill: var(--md-primary);
}
.flatpickr-prev-month svg,
.flatpickr-next-month svg {
    fill: currentColor;
}


.flatpickr-weekdays {
    background: transparent;
    height: 32px;
    padding: 0 4px;
}
.flatpickr-weekday {
    background: transparent !important;
    color: var(--md-on-surface-variant) !important;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}


.flatpickr-days {
    padding: 4px;
    width: 100%;
}
.dayContainer {
    width: 100%;
    min-width: 100%;
    max-width: 100%;
    padding: 0;
    gap: 2px;
}

.flatpickr-day {
    color: var(--md-on-surface) !important;
    background: transparent;
    border: none;
    border-radius: var(--md-shape-sm);
    max-width: none;
    height: 36px;
    line-height: 36px;
    margin: 1px 0;
    font-size: 0.875rem;
    font-weight: 400;
    transition: background var(--md-duration-short) var(--md-ease-standard),
                color var(--md-duration-short) var(--md-ease-standard);
}
.flatpickr-day:hover,
.flatpickr-day:focus {
    background: var(--md-surface-container-highest) !important;
    color: var(--md-on-surface) !important;
    border: none;
}
.flatpickr-day.today {
    border: 1px solid var(--md-primary) !important;
    color: var(--md-primary) !important;
    font-weight: 600;
    background: transparent;
}
.flatpickr-day.today:hover {
    background: var(--md-primary-container) !important;
    color: var(--md-on-primary-container) !important;
    border-color: var(--md-primary) !important;
}
.flatpickr-day.selected,
.flatpickr-day.selected:hover,
.flatpickr-day.selected:focus,
.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.selected.inRange,
.flatpickr-day.startRange.inRange,
.flatpickr-day.endRange.inRange {
    background: var(--md-primary) !important;
    color: var(--md-on-primary) !important;
    border-color: var(--md-primary) !important;
    font-weight: 500;
}
.flatpickr-day.inRange {
    background: var(--md-primary-container) !important;
    color: var(--md-on-primary-container) !important;
    box-shadow: none;
    border-color: transparent;
}
.flatpickr-day.flatpickr-disabled,
.flatpickr-day.flatpickr-disabled:hover,
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay,
.flatpickr-day.notAllowed,
.flatpickr-day.notAllowed.prevMonthDay,
.flatpickr-day.notAllowed.nextMonthDay {
    color: var(--md-outline) !important;
    background: transparent;
    opacity: 0.5;
}
.flatpickr-day.prevMonthDay:hover,
.flatpickr-day.nextMonthDay:hover {
    background: var(--md-surface-container-high);
    color: var(--md-on-surface);
}


.flatpickr-monthSelect-months {
    background: var(--md-surface-container);
    padding: 8px;
}
.flatpickr-monthSelect-month {
    color: var(--md-on-surface);
    background: transparent;
    border-radius: var(--md-shape-sm);
    padding: 14px 8px;
    margin: 2px;
    transition: background var(--md-duration-short) var(--md-ease-standard);
    font-size: 0.875rem;
}
.flatpickr-monthSelect-month:hover {
    background: var(--md-surface-container-highest);
}
.flatpickr-monthSelect-month.selected {
    background: var(--md-primary) !important;
    color: var(--md-on-primary) !important;
    font-weight: 500;
}
.flatpickr-monthSelect-month.flatpickr-disabled {
    color: var(--md-outline);
}


.flatpickr-input.form-control[readonly],
.flatpickr-input.form-control:read-only {
    background: var(--md-surface-container-highest);
    cursor: pointer;
}
input.flatpickr-input {
    background: var(--md-surface-container-highest);
}


.numInputWrapper span.arrowUp,
.numInputWrapper span.arrowDown {
    border-color: var(--md-outline-variant);
}
.numInputWrapper span.arrowUp:after { border-bottom-color: var(--md-on-surface-variant); }
.numInputWrapper span.arrowDown:after { border-top-color: var(--md-on-surface-variant); }
.numInputWrapper span:hover { background: var(--md-surface-container-high); }


[data-theme="dark"] .flatpickr-calendar {
    background: var(--md-surface-container-high);
    border: 1px solid var(--md-outline-variant);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5);
}
[data-theme="dark"] .flatpickr-day {
    color: var(--md-on-surface) !important;
}
[data-theme="dark"] .flatpickr-day:hover,
[data-theme="dark"] .flatpickr-day:focus {
    background: var(--md-surface-container-highest) !important;
    color: var(--md-on-surface) !important;
}
[data-theme="dark"] .flatpickr-day.prevMonthDay,
[data-theme="dark"] .flatpickr-day.nextMonthDay,
[data-theme="dark"] .flatpickr-day.flatpickr-disabled {
    color: rgba(228, 226, 230, 0.35) !important;
}
[data-theme="dark"] .flatpickr-weekday {
    color: var(--md-on-surface-variant) !important;
}
[data-theme="dark"] .flatpickr-current-month input.cur-year,
[data-theme="dark"] .flatpickr-current-month .flatpickr-monthDropdown-months {
    color: var(--md-on-surface) !important;
}
[data-theme="dark"] .flatpickr-monthDropdown-months .flatpickr-monthDropdown-month {
    background: var(--md-surface-container-high);
    color: var(--md-on-surface);
}
