:root {
    --c1: #372a48;
    --c2: #5a3157;
    --c3: #8a416a;
    --c4: #ce5b7b;
    --c5: #f28389;
}

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    font-family: "Segoe UI", Arial, sans-serif;
}

/* =======================
   LOGOWANIE
======================= */

.login-bg {
    height: 100vh;
    background: linear-gradient(135deg, var(--c1), var(--c3));
}

.login-container {
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
}

.login-box {
    width: 340px;
    background: white;
    padding: 30px;
    border-radius: 12px;
    box-shadow: 0 20px 50px rgba(0,0,0,0.35);
    text-align: center;
}

.login-title {
    font-size: 26px;
    color: var(--c1);
    margin-bottom: 20px;
}

.login-title span {
    display: block;
    font-size: 13px;
    color: #777;
}

.login-box input {
    width: 100%;
    padding: 10px;
    margin-bottom: 10px;
}

.login-box button {
    width: 100%;
    padding: 10px;
    background: var(--c3);
    color: white;
    border: none;
    border-radius: 6px;
    cursor: pointer;
}

.error {
    color: red;
    margin-top: 10px;
}

/* =======================
   DESKTOP
======================= */

#desktop {
    height: 100vh;
 width: 100vw;  



    background-image: url("mikol-tlo-v11.png?v=11");

    background-repeat: no-repeat;

    background-position: center center;

    background-size: 100% 100%;
}

/* =======================
   GÓRNE MENU
======================= */

#menubar {
    height: 36px;
    background: var(--c1);
    color: white;
    display: flex;
    align-items: center;
    padding: 0 10px;

    /* KLUCZOWE – dropdown może wyjść poza pasek */
    overflow: visible;
}

.menu-item {
    margin-right: 20px;
    cursor: pointer;
    position: relative;
}

.menu-item.right {
    margin-left: auto;
}

/* =======================
   DROPDOWN – TABLICE
======================= */

.menu-dropdown {
    position: relative;
}

.menu-dropdown-content {
    display: none;
    position: absolute;
    top: 100%;              /* BEZ PRZERWY */
    left: 0;
    background: white;
    border: 1px solid #ccc;
    min-width: 220px;
    z-index: 9999;
}

.menu-dropdown-content div {
    padding: 8px 12px;
    cursor: pointer;
    color: #000;
}

.menu-dropdown-content div:hover {
    background: var(--c5);
    color: white;
}

.menu-dropdown:hover .menu-dropdown-content {
    display: block;
}

/* =======================
   OKNA
======================= */

.window {
    position: absolute;
    width: 500px;
    background: white;
    border: 1px solid var(--c1);
    box-shadow: 0 10px 25px rgba(0,0,0,0.25);
}

.window-header {
    height: 32px;
    background: var(--c1);
    color: white;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 8px;
    cursor: move;
}

.window-content {
    padding: 10px;
}

/* =======================
   STATUS POJAZDU
======================= */

.status {
    cursor: pointer;
    font-weight: bold;
}

.status-on {
    color: green;
}

.status-off {
    color: red;
}


/* ==========================
STRZAŁKA W DÓŁ NA PODPOZYCJE 
===========================*/

.menu-arrow {

    font-size: 10px;

    margin-left: 4px;

    opacity: 0.7;

}

/* ====================================
AUTOMATYCZNA STRZAŁKA DLA MENU Z PODMENU 
======================================== */



.menu-dropdown::after {

    content: "▾";

    font-size: 14px;

    margin-left: 6px;

    opacity: 0.9;

}



/* lekka animacja / feedback */

.menu-dropdown:hover::after {

    opacity: 1;

}


/* ===========================
TABELA SYSTEMOWA (POJAZDY) 
=============================== */





table {

    width: 100%;

    border-collapse: collapse; /* usuwa dziwne odstępy */

    margin-top: 10px;

    font-size: 14px;

}



thead {

    background: var(--c1);

    color: #fff;

}



thead th {

    padding: 8px 6px;

    text-align: left;

    border-bottom: 2px solid var(--c2);

}



tbody td {

    padding: 6px;

    border-bottom: 1px solid #ddd;

}



tbody tr:nth-child(even) {

    background: #f7f7f7;

}



tbody tr:hover {

    background: #f2e8ef;

}



/* kolumna z numeracją */

table th:first-child,

table td:first-child {

    width: 36px;

    text-align: center;

    color: #666;

}



/* =========================
OKNA: ROZCIĄGANIE 
============================ */



.window {

    resize: both;

    overflow: auto;

    min-width: 320px;

    min-height: 200px;

}



/* wizualny uchwyt (prawy dolny róg) */

.window::after {

    content: "⤡";

    position: absolute;

    right: 6px;

    bottom: 4px;

    font-size: 14px;

    color: #999;

    pointer-events: none;

}



/* ==========================
BUTTONY – STYL SYSTEMOWY 
=========================== */



button {

    padding: 6px 12px;

    background: var(--c3);

    color: #fff;

    border: none;

    font-size: 13px;

    cursor: pointer;

    transition: background 0.15s ease, box-shadow 0.15s ease;
    margin-top: 5px;

}



button:hover {

    background: var(--c4);

}



button:active {

    background: var(--c2);

}



/* przyciski w tabelach */

table button {

    padding: 4px 10px;

    font-size: 12px;

}



/* „Usuń” – jeśli kiedyś dodasz klasę */

button.btn-delete {

    background: #c0392b;

}



button.btn-delete:hover {

    background: #e74c3c;

}


/* ===================================
PRZYCISK ZAMYKANIA OKNA – WYJĄTEK 
===================================== */



.window-header button {

    background: transparent;

    color: white;

    border: none;

    padding: 0 6px;

    font-size: 14px;

    cursor: pointer;

    box-shadow: none;

}



.window-header button:hover {

    background: rgba(255,255,255,0.2);

}



.window-header button:active {

    background: rgba(255,255,255,0.35);

}

/* ===================================
PRZYCISK ZUSUWANIE POJAZDÓW Z LISTY
===================================== */



.btn-danger {

    background: #c0392b;

    color: white;

    border: none;

    padding: 4px 8px;

    border-radius: 4px;

    cursor: pointer;

}



.btn-danger:hover {

    background: #e74c3c;

}
/* ==========================
MIKOL — ROZKŁADY / TABLICE / WYKRESY
========================== */

input, select {
    padding: 7px 8px;
    border: 1px solid #bbb;
    margin: 3px 0;
    font-size: 13px;
}

.window-content input,
.window-content select {
    width: 100%;
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(160px, 1fr));
    gap: 6px;
    margin-bottom: 6px;
}

.form-grid.five {
    grid-template-columns: repeat(5, minmax(120px, 1fr));
}

.toolbar-line {
    display: flex;
    gap: 8px;
    align-items: center;
    margin-bottom: 10px;
}

.toolbar-line select {
    width: 260px;
}

.checkline {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin: 4px 0 8px 0;
    font-size: 13px;
}

.checkline input {
    width: auto;
}

.small-input {
    width: 80px !important;
    padding: 4px;
}

.sheet-wrap,
.chart-wrap {
    overflow: auto;
    background: #fff;
    border: 1px solid #ddd;
    padding: 8px;
    min-height: 460px;
}

.rozklad-sheet {
    border-collapse: collapse;
    width: max-content;
    min-width: 100%;
    font-size: 12px;
}

.rozklad-sheet th,
.rozklad-sheet td {
    border: 1px solid #999;
    padding: 4px 6px;
    text-align: center;
    white-space: nowrap;
}

.rozklad-sheet th {
    background: #d9d9d9;
    color: #000;
}

.rozklad-sheet .station-cell {
    text-align: left;
    font-weight: 600;
    background: #f2f2f2;
    min-width: 180px;
}

.train-chart {
    font-family: "Segoe UI", Arial, sans-serif;
    border: 1px solid #bbb;
}

.grid-major {
    stroke: #777;
    stroke-width: 1;
}

.grid-minor {
    stroke: #c8c8c8;
    stroke-width: 1;
    stroke-dasharray: 3 4;
}

.grid-station {
    stroke: #999;
    stroke-width: 1;
    stroke-dasharray: 7 5;
}

.axis-label {
    font-size: 11px;
    fill: #111;
}

.station-label {
    font-size: 12px;
    fill: #111;
    font-weight: 600;
}

.train-line {
    fill: none;
    stroke-width: 3;
    stroke-linejoin: round;
    stroke-linecap: round;
}

.line-0 { stroke: #d35400; }
.line-1 { stroke: #1f618d; }
.line-2 { stroke: #117a65; }
.line-3 { stroke: #922b21; }
.line-4 { stroke: #6c3483; }
.line-5 { stroke: #7d6608; }

.train-label {
    font-size: 12px;
    fill: #111;
    font-weight: 700;
    paint-order: stroke;
    stroke: #fff;
    stroke-width: 3px;
}

@media (max-width: 900px) {
    .form-grid,
    .form-grid.five {
        grid-template-columns: 1fr;
    }

    .toolbar-line {
        flex-direction: column;
        align-items: stretch;
    }

    .toolbar-line select {
        width: 100%;
    }
}

/* ===========================
   MIKOL v2: kalendarz, wykres, eksploatacja
=========================== */
.form-grid.five {
    grid-template-columns: repeat(5, minmax(120px, 1fr));
}

.toolbar-line .inline {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    margin-left: 8px;
}

.hint {
    color: #666;
    font-size: 13px;
}

.color-sample {
    display: inline-block;
    width: 18px;
    height: 18px;
    border: 1px solid #444;
    vertical-align: middle;
    margin-right: 6px;
}

.calendar-grid {
    background: #fff;
    border: 1px solid #ddd;
    padding: 10px;
    max-width: 720px;
}

.cal-head {
    font-weight: bold;
    margin-bottom: 8px;
    color: var(--c1);
}

.cal-weeknames,
.cal-days {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
}

.cal-weeknames span {
    background: var(--c1);
    color: white;
    padding: 6px;
    text-align: center;
    font-size: 12px;
}

.cal-day,
.cal-empty {
    min-height: 62px;
    border: 1px solid #ddd;
    background: #f8f8f8;
    color: #222;
    padding: 5px;
    text-align: left;
    cursor: pointer;
}

.cal-empty {
    background: transparent;
    border: none;
    cursor: default;
}

.cal-day b { display: block; font-size: 16px; }
.cal-day small { display: block; font-size: 11px; margin-top: 10px; }
.cal-day.runs { background: #dff3df; border-color: #69a769; }
.cal-day.noruns { background: #f7d7d7; border-color: #c85b5b; }
.cal-day.unset { background: #f4f4f4; color: #777; }

.train-line {
    fill: none;
    stroke-width: 2.2;
    cursor: pointer;
}

.tail-line {
    fill: none;
    stroke-width: 2.2;
    stroke-dasharray: 5 3;
    cursor: pointer;
}

.tail-label {
    font-size: 10px;
    fill: #333;
}

.train-label {
    font-size: 11px;
    font-weight: 700;
    fill: #111;
    paint-order: stroke;
    stroke: #fff;
    stroke-width: 3px;
}

/* ===========================
   V5: LEKKIE IKONY I OPTYMALIZATOR
=========================== */
.menu-ico {
    display: inline-block;
    width: 20px;
    margin-right: 5px;
    text-align: center;
    font-size: 14px;
    opacity: 0.95;
}

.menu-dropdown-content div {
    white-space: nowrap;
}

.summary-cards {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 10px 0;
}

.summary-card {
    min-width: 140px;
    padding: 10px 12px;
    border: 1px solid #ddd;
    border-radius: 8px;
    background: #fafafa;
    box-shadow: 0 2px 6px rgba(0,0,0,0.08);
}

.summary-card b {
    display: block;
    font-size: 21px;
    color: var(--c1);
}

.summary-card span {
    display: block;
    font-size: 12px;
    color: #666;
    margin-top: 2px;
}

.obieg-card {
    margin: 12px 0;
    padding: 10px;
    border: 1px solid #d7d7d7;
    border-radius: 8px;
    background: #fff;
}

.obieg-card h4 {
    margin: 0 0 6px 0;
    color: var(--c1);
}

.result-box {
    max-height: 220px;
    overflow: auto;
    background: #f8f8f8;
    border: 1px solid #ddd;
    padding: 8px;
}


/* V6: budżet / ostrzeżenia */
.row-alert td {
    background: #ffe0e0 !important;
    color: #7a0000;
    font-weight: 600;
}
textarea {
    font-family: "Segoe UI", Arial, sans-serif;
    border: 1px solid #bbb;
    border-radius: 4px;
    padding: 6px;
}

/* ===========================
   V7: PULPIT ORGANIZATORA NA TLE
=========================== */
.desktop-panel {
    position: absolute;
    left: 34px;
    top: 58px;
    width: min(1180px, calc(100vw - 68px));
    padding: 18px;
    border: 1px solid rgba(255,255,255,0.22);
    border-radius: 18px;
    background: rgba(12, 21, 42, 0.58);
    backdrop-filter: blur(8px);
    box-shadow: 0 18px 55px rgba(0,0,0,0.34);
    color: #fff;
    z-index: 2;
}

.pulpit-top {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: flex-start;
    margin-bottom: 14px;
}

.pulpit-top h1 {
    margin: 0;
    font-size: 26px;
    letter-spacing: 0.3px;
}

.pulpit-top p {
    margin: 4px 0 0 0;
    color: rgba(255,255,255,0.82);
}

.pulpit-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}

.pulpit-filters input {
    min-width: 135px;
    background: rgba(255,255,255,0.94);
}

.kpi-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(145px, 1fr));
    gap: 12px;
}

.kpi-card {
    min-height: 106px;
    padding: 13px 14px;
    border-radius: 16px;
    background: linear-gradient(145deg, rgba(255,255,255,0.96), rgba(244,247,255,0.92));
    color: #15213d;
    box-shadow: 0 10px 30px rgba(0,0,0,0.18);
    border-left: 5px solid var(--c3);
}

.kpi-card b {
    display: block;
    font-size: 22px;
    line-height: 1.12;
    color: #13233f;
}

.kpi-card span {
    display: block;
    margin-top: 7px;
    font-size: 12px;
    color: #3d4d67;
    text-transform: uppercase;
    letter-spacing: 0.35px;
    font-weight: 700;
}

.kpi-card em {
    display: block;
    margin-top: 6px;
    font-size: 12px;
    color: #6d7890;
    font-style: normal;
}

.kpi-blue { border-left-color: #2d8cff; }
.kpi-dark { border-left-color: #1f2c46; }
.kpi-purple { border-left-color: #6f42c1; }
.kpi-orange { border-left-color: #fd7e14; }
.kpi-green { border-left-color: #198754; }
.kpi-good { border-left-color: #198754; }
.kpi-bad { border-left-color: #dc3545; }

.pulpit-alerts {
    margin-top: 12px;
    padding: 10px 12px;
    border-radius: 12px;
    font-weight: 700;
}

.pulpit-alerts-ok {
    background: rgba(25,135,84,0.86);
    color: #fff;
}

.pulpit-alerts-bad {
    background: rgba(220,53,69,0.9);
    color: #fff;
}

.pulpit-tasks {
    margin-top: 12px;
    max-height: 270px;
    overflow: auto;
    border-radius: 12px;
    background: rgba(255,255,255,0.95);
    color: #222;
}

.pulpit-tasks table {
    margin-top: 0;
}

@media (max-width: 1200px) {
    .kpi-grid { grid-template-columns: repeat(3, 1fr); }
    .pulpit-top { flex-direction: column; }
    .pulpit-filters { justify-content: flex-start; }
}

/* V7 fix: widoczny panel kafelków na pulpicie */
#pulpit-organizatora {
    position: absolute;
    left: 34px;
    top: 58px;
    width: min(1220px, calc(100vw - 68px));
    max-height: calc(100vh - 90px);
    overflow: auto;
    padding: 18px;
    border: 1px solid rgba(255,255,255,0.22);
    border-radius: 18px;
    background: rgba(12, 21, 42, 0.58);
    backdrop-filter: blur(8px);
    box-shadow: 0 18px 55px rgba(0,0,0,0.34);
    color: #fff;
    z-index: 1;
}
.pulpit-head { display: flex; justify-content: space-between; gap: 20px; align-items: flex-start; margin-bottom: 14px; }
.pulpit-head h1 { margin: 0; font-size: 26px; letter-spacing: 0.3px; }
.pulpit-head p { margin: 4px 0 0 0; color: rgba(255,255,255,0.82); }
.pulpit-filters select, .pulpit-filters input { min-width: 135px; background: rgba(255,255,255,0.94); color: #111; border: 1px solid rgba(255,255,255,0.4); border-radius: 6px; padding: 6px; }
.pulpit-table { margin-top: 12px; max-height: 270px; overflow: auto; border-radius: 12px; background: rgba(255,255,255,0.95); color: #222; }
.pulpit-table table { margin-top: 0; }
@media (max-width: 1200px) { .pulpit-head { flex-direction: column; } }


/* =========================================================
   V8: PULPIT ORGANIZATORA — prawy panel, białe kafelki
   Poprawka czytelności na tle graficznym.
========================================================= */
#pulpit-organizatora {
    position: absolute !important;
    left: auto !important;
    right: 24px !important;
    top: 54px !important;
    width: min(640px, calc(100vw - 48px)) !important;
    max-height: calc(100vh - 78px) !important;
    overflow: auto !important;
    padding: 0 !important;
    border: none !important;
    border-radius: 18px !important;
    background: transparent !important;
    backdrop-filter: none !important;
    box-shadow: none !important;
    color: #101827 !important;
    z-index: 1 !important;
}

.pulpit-head {
    display: block !important;
    margin-bottom: 12px !important;
    padding: 18px 18px 16px 18px !important;
    border-radius: 18px !important;
    background: #ffffff !important;
    color: #101827 !important;
    box-shadow: 0 14px 34px rgba(0,0,0,0.28) !important;
    border: 1px solid rgba(16,24,39,0.10) !important;
}

.pulpit-head h1 {
    margin: 0 !important;
    font-size: 24px !important;
    line-height: 1.15 !important;
    color: #101827 !important;
    letter-spacing: 0.1px !important;
}

.pulpit-head p {
    margin: 7px 0 14px 0 !important;
    color: #4b5563 !important;
    font-size: 14px !important;
}

.pulpit-filters {
    display: grid !important;
    grid-template-columns: 1fr 1fr 1fr auto !important;
    gap: 8px !important;
    justify-content: stretch !important;
    align-items: center !important;
}

.pulpit-filters select,
.pulpit-filters input {
    min-width: 0 !important;
    width: 100% !important;
    height: 34px !important;
    background: #f9fafb !important;
    color: #111827 !important;
    border: 1px solid #d1d5db !important;
    border-radius: 8px !important;
    padding: 6px 8px !important;
}

.pulpit-filters button {
    height: 34px !important;
    margin-top: 0 !important;
    border-radius: 8px !important;
    white-space: nowrap !important;
    background: #5a3157 !important;
}

.kpi-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
}

.kpi-card {
    min-height: 112px !important;
    padding: 15px 16px !important;
    border-radius: 16px !important;
    background: #ffffff !important;
    color: #111827 !important;
    box-shadow: 0 12px 30px rgba(0,0,0,0.26) !important;
    border: 1px solid rgba(16,24,39,0.08) !important;
    border-left: 7px solid var(--c3) !important;
}

.kpi-card b {
    display: block !important;
    font-size: 24px !important;
    line-height: 1.08 !important;
    color: #111827 !important;
    font-weight: 800 !important;
}

.kpi-card span {
    display: block !important;
    margin-top: 8px !important;
    font-size: 12px !important;
    color: #374151 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.35px !important;
    font-weight: 800 !important;
}

.kpi-card em {
    display: block !important;
    margin-top: 7px !important;
    font-size: 12px !important;
    color: #6b7280 !important;
    font-style: normal !important;
}

.kpi-blue { border-left-color: #2563eb !important; }
.kpi-dark { border-left-color: #111827 !important; }
.kpi-purple { border-left-color: #7c3aed !important; }
.kpi-orange { border-left-color: #f97316 !important; }
.kpi-green { border-left-color: #16a34a !important; }
.kpi-good { border-left-color: #16a34a !important; }
.kpi-bad { border-left-color: #dc2626 !important; }

.pulpit-alerts {
    margin-top: 12px !important;
    padding: 12px 14px !important;
    border-radius: 16px !important;
    background: #ffffff !important;
    color: #111827 !important;
    box-shadow: 0 12px 30px rgba(0,0,0,0.22) !important;
    border: 1px solid rgba(16,24,39,0.08) !important;
    font-weight: 700 !important;
}

.pulpit-alerts-ok {
    border-left: 7px solid #16a34a !important;
    background: #ffffff !important;
    color: #14532d !important;
}

.pulpit-alerts-bad {
    border-left: 7px solid #dc2626 !important;
    background: #ffffff !important;
    color: #7f1d1d !important;
}

.pulpit-table {
    margin-top: 12px !important;
    max-height: 280px !important;
    overflow: auto !important;
    border-radius: 16px !important;
    background: #ffffff !important;
    color: #111827 !important;
    box-shadow: 0 12px 30px rgba(0,0,0,0.22) !important;
    border: 1px solid rgba(16,24,39,0.08) !important;
}

.pulpit-table table {
    margin-top: 0 !important;
    background: #ffffff !important;
}

.pulpit-table thead {
    background: #372a48 !important;
    color: #ffffff !important;
}

@media (max-width: 1050px) {
    #pulpit-organizatora {
        left: 18px !important;
        right: 18px !important;
        width: auto !important;
    }
    .pulpit-filters {
        grid-template-columns: 1fr 1fr !important;
    }
}

@media (max-width: 650px) {
    .kpi-grid {
        grid-template-columns: 1fr !important;
    }
    .pulpit-filters {
        grid-template-columns: 1fr !important;
    }
}

/* =========================================================
   V9: twarda poprawka pulpitu - wymusza prawy biały panel
   także gdy stare reguły CSS zostały wcześniej zcache'owane.
========================================================= */
#desktop > #pulpit-organizatora,
body #desktop #pulpit-organizatora,
body #pulpit-organizatora {
    position: fixed !important;
    left: auto !important;
    right: 26px !important;
    top: 58px !important;
    width: min(670px, calc(100vw - 52px)) !important;
    max-height: calc(100vh - 82px) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    background: transparent !important;
    color: #111827 !important;
    z-index: 20 !important;
}

body #pulpit-organizatora .pulpit-head,
body #pulpit-organizatora #pulpit_cards .kpi-card,
body #pulpit-organizatora #pulpit_alerts,
body #pulpit-organizatora #pulpit_tasks {
    background: #fff !important;
    color: #111827 !important;
    opacity: 1 !important;
    border-radius: 18px !important;
    box-shadow: 0 14px 36px rgba(0,0,0,.30) !important;
    border: 1px solid rgba(17,24,39,.10) !important;
}

body #pulpit-organizatora .pulpit-head {
    padding: 18px !important;
    margin: 0 0 12px 0 !important;
}

body #pulpit-organizatora .pulpit-head h1 {
    margin: 0 !important;
    color: #111827 !important;
    font-size: 25px !important;
    line-height: 1.15 !important;
}

body #pulpit-organizatora .pulpit-head p {
    margin: 7px 0 14px 0 !important;
    color: #4b5563 !important;
    font-size: 14px !important;
}

body #pulpit-organizatora .pulpit-filters {
    display: grid !important;
    grid-template-columns: 1fr 1fr 1fr auto !important;
    gap: 8px !important;
}

body #pulpit-organizatora .pulpit-filters select,
body #pulpit-organizatora .pulpit-filters input {
    width: 100% !important;
    min-width: 0 !important;
    height: 34px !important;
    background: #f9fafb !important;
    color: #111827 !important;
    border: 1px solid #d1d5db !important;
    border-radius: 8px !important;
}

body #pulpit-organizatora .pulpit-filters button {
    height: 34px !important;
    margin: 0 !important;
    border-radius: 8px !important;
    background: #5a3157 !important;
    color: #fff !important;
}

body #pulpit-organizatora #pulpit_cards.kpi-grid,
body #pulpit-organizatora .kpi-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
}

body #pulpit-organizatora .kpi-card {
    min-height: 112px !important;
    padding: 15px 16px !important;
    border-left: 7px solid #8a416a !important;
}

body #pulpit-organizatora .kpi-card b {
    display: block !important;
    color: #111827 !important;
    font-size: 25px !important;
    font-weight: 850 !important;
    line-height: 1.05 !important;
}

body #pulpit-organizatora .kpi-card span {
    display: block !important;
    margin-top: 8px !important;
    color: #374151 !important;
    font-size: 12px !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: .35px !important;
}

body #pulpit-organizatora .kpi-card em {
    display: block !important;
    margin-top: 7px !important;
    color: #6b7280 !important;
    font-size: 12px !important;
    font-style: normal !important;
}

body #pulpit-organizatora .kpi-blue { border-left-color: #2563eb !important; }
body #pulpit-organizatora .kpi-dark { border-left-color: #111827 !important; }
body #pulpit-organizatora .kpi-purple { border-left-color: #7c3aed !important; }
body #pulpit-organizatora .kpi-orange { border-left-color: #f97316 !important; }
body #pulpit-organizatora .kpi-green { border-left-color: #16a34a !important; }
body #pulpit-organizatora .kpi-good { border-left-color: #16a34a !important; }
body #pulpit-organizatora .kpi-bad { border-left-color: #dc2626 !important; }

body #pulpit-organizatora #pulpit_alerts,
body #pulpit-organizatora #pulpit_tasks {
    margin-top: 12px !important;
    padding: 12px 14px !important;
}

body #pulpit-organizatora #pulpit_tasks {
    max-height: 280px !important;
    overflow: auto !important;
}

@media (max-width: 1100px) {
    body #desktop #pulpit-organizatora,
    body #pulpit-organizatora {
        left: 18px !important;
        right: 18px !important;
        width: auto !important;
    }
}
@media (max-width: 720px) {
    body #pulpit-organizatora #pulpit_cards.kpi-grid,
    body #pulpit-organizatora .kpi-grid,
    body #pulpit-organizatora .pulpit-filters {
        grid-template-columns: 1fr !important;
    }
}


/* =====================================================
   V10: pulpit jako tło robocze + twarde obejście cache tła
   ===================================================== */
#desktop {
    position: relative !important;
    isolation: isolate !important;
    background-image: url("mikol-tlo-v11.png?v=11") !important;
    background-repeat: no-repeat !important;
    background-position: center center !important;
    background-size: cover !important;
}

/* Pulpit organizatora ma być NA DNIE stosu.
   Okna aplikacji, dropdowny i menu zawsze mają go przykrywać. */
#desktop > #pulpit-organizatora,
body #desktop #pulpit-organizatora,
body #pulpit-organizatora {
    position: absolute !important;
    right: 28px !important;
    top: 74px !important;
    left: auto !important;
    bottom: auto !important;
    width: min(880px, calc(100vw - 56px)) !important;
    max-height: calc(100vh - 105px) !important;
    overflow: auto !important;
    z-index: 1 !important;
}

/* Każde okno systemowe nad pulpitem. */
.window {
    z-index: 1000;
}

.window[style*="display: block"],
.window.active-window {
    z-index: 1500 !important;
}

#menubar,
.menu-dropdown-content {
    z-index: 10000 !important;
}

/* Kafelki nadal czytelne, ale już bez dominowania nad oknami. */
body #pulpit-organizatora .pulpit-head,
body #pulpit-organizatora #pulpit_cards .kpi-card,
body #pulpit-organizatora #pulpit_alerts,
body #pulpit-organizatora #pulpit_tasks {
    background: #ffffff !important;
    opacity: 1 !important;
}


/* =====================================================
   V11: poprawka pulpitu, tła i kafelków
   - całe tło ma się mieścić w ekranie bez ucinania,
   - pulpit jest dyskretny i niżej w stosie,
   - kafelki są ok. 50% mniejsze.
===================================================== */
#desktop {
    background-image: url("mikol-tlo-v11.png?v=11") !important;
    background-repeat: no-repeat !important;
    background-position: center center !important;
    background-size: contain !important;
    background-color: #071323 !important;
    overflow: hidden !important;
}

#desktop > #pulpit-organizatora,
body #desktop #pulpit-organizatora,
body #pulpit-organizatora {
    position: absolute !important;
    right: 20px !important;
    top: 56px !important;
    left: auto !important;
    width: min(560px, calc(100vw - 40px)) !important;
    max-height: calc(100vh - 76px) !important;
    overflow: auto !important;
    z-index: 1 !important;
    pointer-events: auto !important;
}

body #pulpit-organizatora .pulpit-head {
    padding: 12px 14px !important;
    margin-bottom: 8px !important;
    border-radius: 13px !important;
    box-shadow: 0 8px 18px rgba(0,0,0,.20) !important;
}

body #pulpit-organizatora .pulpit-head h1 {
    font-size: 18px !important;
    line-height: 1.1 !important;
}

body #pulpit-organizatora .pulpit-head p {
    font-size: 12px !important;
    margin: 5px 0 9px 0 !important;
}

body #pulpit-organizatora .pulpit-filters {
    grid-template-columns: 1fr 1fr 1fr auto !important;
    gap: 6px !important;
}

body #pulpit-organizatora .pulpit-filters select,
body #pulpit-organizatora .pulpit-filters input,
body #pulpit-organizatora .pulpit-filters button {
    height: 28px !important;
    font-size: 12px !important;
    padding: 4px 7px !important;
    border-radius: 7px !important;
}

body #pulpit-organizatora #pulpit_cards.kpi-grid,
body #pulpit-organizatora .kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
}

body #pulpit-organizatora #pulpit_cards .kpi-card,
body #pulpit-organizatora .kpi-card {
    min-height: 58px !important;
    padding: 8px 10px !important;
    border-radius: 12px !important;
    border-left-width: 4px !important;
    box-shadow: 0 7px 15px rgba(0,0,0,.18) !important;
}

body #pulpit-organizatora .kpi-card b {
    font-size: 16px !important;
    line-height: 1.05 !important;
}

body #pulpit-organizatora .kpi-card span {
    font-size: 9.5px !important;
    margin-top: 4px !important;
    letter-spacing: .22px !important;
}

body #pulpit-organizatora .kpi-card em {
    font-size: 10px !important;
    margin-top: 3px !important;
}

body #pulpit-organizatora #pulpit_alerts,
body #pulpit-organizatora #pulpit_tasks,
body #pulpit-organizatora .pulpit-alerts,
body #pulpit-organizatora .pulpit-table {
    margin-top: 8px !important;
    padding: 8px 10px !important;
    border-radius: 12px !important;
    box-shadow: 0 7px 15px rgba(0,0,0,.18) !important;
    font-size: 12px !important;
}

body #pulpit-organizatora #pulpit_tasks {
    max-height: 190px !important;
}

.window,
.window.active-window,
.window[style*="display: block"] {
    z-index: 2000 !important;
}

#menubar, .menu-dropdown-content {
    z-index: 20000 !important;
}

@media (max-width: 850px) {
    body #desktop #pulpit-organizatora,
    body #pulpit-organizatora {
        left: 12px !important;
        right: 12px !important;
        width: auto !important;
    }
    body #pulpit-organizatora .pulpit-filters {
        grid-template-columns: 1fr 1fr !important;
    }
}


/* =========================================================
   V12: MIKOL DK — nowe tło, zwężony prawy pulpit, spójna kolorystyka
========================================================= */
:root {
    --mikol-ink: #0b1320;
    --mikol-navy: #111927;
    --mikol-panel: rgba(255,255,255,0.94);
    --mikol-panel-solid: #ffffff;
    --mikol-border: rgba(209,217,230,0.72);
    --mikol-accent: #e20f13;
    --mikol-accent-dark: #9b1118;
    --mikol-slate: #475569;
    --mikol-purple: #2f2442;
}

body {
    color: var(--mikol-ink);
}

#desktop {
    min-height: 100vh;
    width: 100vw;
    background-image:
        linear-gradient(90deg, rgba(5,10,18,0.22) 0%, rgba(5,10,18,0.04) 38%, rgba(5,10,18,0.14) 100%),
        url("mikol-tlo-v12.png?v=13") !important;
    background-repeat: no-repeat !important;
    background-position: center center !important;
    background-size: cover !important;
    overflow: hidden;
}

#menubar {
    height: 38px !important;
    background: linear-gradient(90deg, rgba(30,23,43,0.97), rgba(48,36,65,0.96)) !important;
    border-bottom: 1px solid rgba(255,255,255,0.10);
    box-shadow: 0 8px 22px rgba(0,0,0,0.28);
    backdrop-filter: blur(10px);
    padding: 0 12px !important;
    gap: 2px;
    z-index: 1000;
}

.menu-item {
    height: 38px;
    display: flex;
    align-items: center;
    margin-right: 14px !important;
    padding: 0 7px;
    border-radius: 9px;
    font-weight: 650;
    letter-spacing: 0.01em;
    transition: background .14s ease, transform .14s ease;
}

.menu-item:hover {
    background: rgba(255,255,255,0.10);
}

.menu-ico {
    opacity: .88;
    margin-right: 5px;
}

.menu-dropdown-content {
    border: 1px solid rgba(216,222,232,0.85) !important;
    border-radius: 12px !important;
    overflow: hidden;
    box-shadow: 0 18px 38px rgba(0,0,0,0.24) !important;
    background: rgba(255,255,255,0.98) !important;
    padding: 5px !important;
}

.menu-dropdown-content div {
    border-radius: 8px;
    padding: 8px 12px !important;
}

.menu-dropdown-content div:hover {
    background: linear-gradient(90deg, #2f2442, #5b2f52) !important;
    color: #fff !important;
}

#desktop > #pulpit-organizatora,
body #desktop #pulpit-organizatora,
body #pulpit-organizatora {
    position: fixed !important;
    left: auto !important;
    right: 24px !important;
    top: 64px !important;
    width: min(470px, calc(100vw - 48px)) !important;
    max-height: calc(100vh - 88px) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    color: var(--mikol-ink) !important;
    z-index: 20 !important;
    scrollbar-width: thin;
}

body #pulpit-organizatora .pulpit-head,
body #pulpit-organizatora #pulpit_cards .kpi-card,
body #pulpit-organizatora #pulpit_alerts,
body #pulpit-organizatora #pulpit_tasks {
    background: linear-gradient(145deg, rgba(255,255,255,0.97), rgba(245,248,252,0.94)) !important;
    color: var(--mikol-ink) !important;
    opacity: 1 !important;
    border-radius: 18px !important;
    box-shadow: 0 16px 38px rgba(0,0,0,.25) !important;
    border: 1px solid var(--mikol-border) !important;
    backdrop-filter: blur(8px);
}

body #pulpit-organizatora .pulpit-head {
    padding: 16px 17px !important;
    margin: 0 0 10px 0 !important;
}

body #pulpit-organizatora .pulpit-head h1 {
    font-size: 22px !important;
    letter-spacing: -0.02em !important;
    color: #07111f !important;
}

body #pulpit-organizatora .pulpit-head p {
    margin: 7px 0 13px 0 !important;
    color: #516070 !important;
    font-size: 13px !important;
    line-height: 1.38 !important;
}

body #pulpit-organizatora .pulpit-filters {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
}

body #pulpit-organizatora .pulpit-filters select {
    grid-column: 1 / -1;
}

body #pulpit-organizatora .pulpit-filters button {
    grid-column: 1 / -1;
    height: 34px !important;
    border: 0 !important;
    border-radius: 10px !important;
    background: linear-gradient(135deg, #2f2442, #5b2f52) !important;
    color: #fff !important;
    font-weight: 750 !important;
    box-shadow: 0 8px 18px rgba(47,36,66,0.23);
}

body #pulpit-organizatora .pulpit-filters select,
body #pulpit-organizatora .pulpit-filters input {
    height: 34px !important;
    border-radius: 10px !important;
    border: 1px solid #ccd5e1 !important;
    background: rgba(248,250,252,0.96) !important;
    color: #111827 !important;
    padding: 6px 9px !important;
}

body #pulpit-organizatora #pulpit_cards.kpi-grid,
body #pulpit-organizatora .kpi-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 9px !important;
}

body #pulpit-organizatora .kpi-card {
    min-height: 74px !important;
    padding: 11px 14px 10px 15px !important;
    border-left: 5px solid var(--mikol-accent) !important;
}

body #pulpit-organizatora .kpi-card b {
    font-size: 21px !important;
    line-height: 1.05 !important;
    letter-spacing: -0.02em !important;
}

body #pulpit-organizatora .kpi-card span {
    margin-top: 5px !important;
    font-size: 11px !important;
    color: #273242 !important;
}

body #pulpit-organizatora .kpi-card em {
    margin-top: 4px !important;
    font-size: 11px !important;
    color: #64748b !important;
}

body #pulpit-organizatora .kpi-blue { border-left-color: #4c83d9 !important; }
body #pulpit-organizatora .kpi-dark { border-left-color: #1f2937 !important; }
body #pulpit-organizatora .kpi-purple { border-left-color: #6d4ca2 !important; }
body #pulpit-organizatora .kpi-orange { border-left-color: #d7592b !important; }
body #pulpit-organizatora .kpi-green,
body #pulpit-organizatora .kpi-good { border-left-color: #169b62 !important; }
body #pulpit-organizatora .kpi-bad { border-left-color: #dc2626 !important; }

body #pulpit-organizatora #pulpit_alerts {
    margin-top: 10px !important;
    padding: 10px 12px !important;
    border-left: 5px solid #169b62 !important;
    font-size: 13px !important;
}

body #pulpit-organizatora #pulpit_tasks {
    margin-top: 10px !important;
    padding: 0 !important;
    max-height: 220px !important;
    overflow: auto !important;
}

body #pulpit-organizatora #pulpit_tasks table,
body #pulpit-organizatora .pulpit-table table {
    font-size: 12px !important;
}

body #pulpit-organizatora #pulpit_tasks thead,
body #pulpit-organizatora .pulpit-table thead {
    background: linear-gradient(90deg, #2f2442, #49315a) !important;
    color: #fff !important;
}

.window {
    border: 1px solid rgba(209,217,230,0.78) !important;
    border-radius: 16px !important;
    overflow: hidden;
    box-shadow: 0 20px 55px rgba(0,0,0,0.34) !important;
}

.window-header {
    height: 36px !important;
    background: linear-gradient(90deg, #2f2442, #49315a) !important;
}

.window-content {
    background: rgba(255,255,255,0.98);
}

button {
    border-radius: 9px;
    font-weight: 700;
}

/* LOGOWANIE */
.login-bg {
    min-height: 100vh;
    background-image:
        radial-gradient(circle at 78% 28%, rgba(255,255,255,0.13), transparent 30%),
        linear-gradient(90deg, rgba(6,12,22,0.72), rgba(6,12,22,0.30)),
        url("mikol-tlo-v12.png?v=13");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
}

.login-container {
    justify-content: flex-end;
    padding: 32px 7vw 32px 32px;
}

.login-box {
    width: min(390px, calc(100vw - 44px));
    padding: 30px 30px 28px;
    border-radius: 22px;
    background: rgba(255,255,255,0.94);
    border: 1px solid rgba(255,255,255,0.72);
    box-shadow: 0 24px 70px rgba(0,0,0,0.40);
    backdrop-filter: blur(12px);
}

.login-logo {
    display: block;
    width: 235px;
    max-width: 88%;
    height: auto;
    margin: 0 auto 18px auto;
}

.login-title {
    margin-bottom: 20px;
    color: #1e293b;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: .02em;
    text-transform: uppercase;
}

.login-title span {
    margin-top: 4px;
    color: #64748b;
    font-size: 12px;
    font-weight: 600;
    text-transform: none;
}

.login-box input {
    height: 42px;
    padding: 10px 12px;
    margin-bottom: 11px;
    border: 1px solid #cbd5e1;
    border-radius: 11px;
    background: #f8fafc;
    color: #111827;
    outline: none;
    transition: border-color .14s ease, box-shadow .14s ease, background .14s ease;
}

.login-box input:focus {
    background: #fff;
    border-color: #5b2f52;
    box-shadow: 0 0 0 3px rgba(91,47,82,0.14);
}

.login-box button {
    height: 42px;
    margin-top: 2px;
    background: linear-gradient(135deg, #2f2442, #5b2f52) !important;
    border-radius: 11px;
    font-size: 15px;
    box-shadow: 0 10px 23px rgba(47,36,66,0.28);
}

.error {
    color: #b91c1c;
    font-weight: 700;
    font-size: 13px;
}

@media (max-width: 1100px) {
    body #desktop #pulpit-organizatora,
    body #pulpit-organizatora {
        right: 16px !important;
        width: min(430px, calc(100vw - 32px)) !important;
    }
}

@media (max-width: 760px) {
    #desktop {
        overflow: auto;
    }
    body #desktop #pulpit-organizatora,
    body #pulpit-organizatora {
        position: absolute !important;
        left: 14px !important;
        right: 14px !important;
        top: 54px !important;
        width: auto !important;
        max-height: none !important;
    }
    .login-container {
        justify-content: center;
        padding: 24px;
    }
}


/* =========================================================
   V13: węższy pulpit, bez rolowania, pulpit zawsze pod oknami
========================================================= */
#desktop {
    isolation: isolate;
}

#desktop > #pulpit-organizatora,
body #desktop #pulpit-organizatora,
body #pulpit-organizatora {
    right: 16px !important;
    top: 56px !important;
    width: 238px !important;
    max-height: none !important;
    overflow: visible !important;
    z-index: 0 !important;
    transform: none !important;
}

body #pulpit-organizatora .pulpit-head,
body #pulpit-organizatora #pulpit_cards .kpi-card,
body #pulpit-organizatora #pulpit_alerts {
    border-radius: 14px !important;
    box-shadow: 0 10px 24px rgba(0,0,0,.20) !important;
    background: linear-gradient(145deg, rgba(255,255,255,0.92), rgba(243,246,250,0.88)) !important;
}

body #pulpit-organizatora .pulpit-head {
    padding: 11px 12px !important;
    margin-bottom: 7px !important;
}

body #pulpit-organizatora .pulpit-head h1 {
    font-size: 16px !important;
    line-height: 1.12 !important;
    margin: 0 !important;
}

body #pulpit-organizatora .pulpit-head p {
    font-size: 11px !important;
    line-height: 1.28 !important;
    margin: 5px 0 8px 0 !important;
}

body #pulpit-organizatora .pulpit-filters {
    grid-template-columns: 1fr !important;
    gap: 6px !important;
}

body #pulpit-organizatora .pulpit-filters select,
body #pulpit-organizatora .pulpit-filters input,
body #pulpit-organizatora .pulpit-filters button {
    grid-column: 1 / -1 !important;
    width: 100% !important;
    height: 28px !important;
    min-width: 0 !important;
    font-size: 11px !important;
    border-radius: 8px !important;
    padding: 4px 7px !important;
}

body #pulpit-organizatora #pulpit_cards.kpi-grid,
body #pulpit-organizatora .kpi-grid {
    gap: 7px !important;
}

body #pulpit-organizatora .kpi-card {
    min-height: 53px !important;
    padding: 8px 10px 7px 11px !important;
    border-left-width: 4px !important;
}

body #pulpit-organizatora .kpi-card b {
    font-size: 17px !important;
    line-height: 1 !important;
}

body #pulpit-organizatora .kpi-card span {
    margin-top: 4px !important;
    font-size: 9.5px !important;
    letter-spacing: .02em !important;
}

body #pulpit-organizatora .kpi-card em {
    margin-top: 3px !important;
    font-size: 9.5px !important;
}

body #pulpit-organizatora #pulpit_alerts {
    margin-top: 7px !important;
    padding: 8px 10px !important;
    font-size: 10.5px !important;
    line-height: 1.25 !important;
    border-left-width: 4px !important;
}

body #pulpit-organizatora #pulpit_tasks,
body #pulpit-organizatora .pulpit-table {
    display: none !important;
}

.window,
.window.active-window {
    z-index: 3000;
}

#menubar,
.menu-dropdown-content {
    z-index: 30000 !important;
}

.menu-item {
    margin-right: 9px !important;
    padding: 0 7px !important;
    font-size: 14px !important;
    white-space: nowrap;
}

.menu-dropdown-content.menu-wide {
    min-width: 260px !important;
}

.menu-separator {
    height: 1px !important;
    margin: 4px 6px !important;
    padding: 0 !important;
    background: #e2e8f0 !important;
    cursor: default !important;
}

.menu-separator:hover {
    background: #e2e8f0 !important;
}

.menu-budget {
    margin-left: 4px !important;
}

@media (max-height: 820px) {
    body #desktop #pulpit-organizatora,
    body #pulpit-organizatora {
        top: 48px !important;
        width: 226px !important;
    }
    body #pulpit-organizatora .pulpit-head p { display: none !important; }
    body #pulpit-organizatora .pulpit-head { padding: 9px 10px !important; }
    body #pulpit-organizatora .kpi-card { min-height: 48px !important; padding: 7px 9px !important; }
    body #pulpit-organizatora .kpi-card b { font-size: 16px !important; }
    body #pulpit-organizatora #pulpit_alerts { font-size: 10px !important; padding: 7px 9px !important; }
}

@media (max-width: 1280px) {
    .menu-item { margin-right: 5px !important; font-size: 13px !important; }
    body #desktop #pulpit-organizatora,
    body #pulpit-organizatora { width: 224px !important; right: 10px !important; }
}

/* =========================================================
   V14: menu zawsze nad kaflami pulpitu
   Problem: prawy pulpit nachodził wizualnie na rozwijane menu.
   Rozwiązanie: osobne warstwy — pulpit na dnie, okna wyżej, pasek i dropdown najwyżej.
========================================================= */
#desktop {
    position: relative !important;
    isolation: isolate !important;
    overflow: hidden !important;
}

#menubar {
    position: relative !important;
    z-index: 1000000 !important;
    overflow: visible !important;
    transform: translateZ(0);
}

#menubar .menu-item,
#menubar .menu-dropdown {
    position: relative !important;
    z-index: 1000001 !important;
}

#menubar .menu-dropdown:hover {
    z-index: 1000003 !important;
}

#menubar .menu-dropdown-content,
.menu-dropdown-content,
.menu-dropdown-content.menu-wide {
    z-index: 1000004 !important;
    position: absolute !important;
    box-shadow: 0 16px 36px rgba(0, 0, 0, .28) !important;
}

#desktop > #pulpit-organizatora,
body #desktop #pulpit-organizatora,
body #pulpit-organizatora {
    z-index: 1 !important;
    pointer-events: auto !important;
}

.window,
.window.active-window {
    z-index: 5000 !important;
}

.window.active-window {
    z-index: 6000 !important;
}

/* =========================================================
   V15: menedżer okien jak w desktopie
   - kliknięte okno wchodzi na wierzch,
   - minimalizacja do dolnego paska,
   - górne dropdowny bezwzględnie nad wszystkim,
   - pulpit/kafelki na samym dnie stosu.
========================================================= */
#desktop {
    overflow: hidden !important;
}

#desktop > #pulpit-organizatora,
body #desktop #pulpit-organizatora,
body #pulpit-organizatora {
    z-index: 0 !important;
}

.window {
    z-index: 1000 !important;
}

.window.active-window {
    box-shadow: 0 18px 42px rgba(0,0,0,.38) !important;
    outline: 1px solid rgba(226,15,19,.42) !important;
}

#menubar {
    position: relative !important;
    z-index: 2147483000 !important;
    isolation: isolate !important;
    overflow: visible !important;
}

#menubar .menu-item,
#menubar .menu-dropdown {
    position: relative !important;
    z-index: 2147483001 !important;
}

#menubar .menu-dropdown-content,
.menu-dropdown-content,
.menu-dropdown:hover .menu-dropdown-content {
    z-index: 2147483002 !important;
    pointer-events: auto !important;
}

.window-header {
    gap: 8px !important;
}

.window-header > span {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.window-actions {
    margin-left: auto !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 4px !important;
}

.window-header .window-minimize,
.window-header .window-close {
    width: 26px !important;
    height: 24px !important;
    line-height: 20px !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 6px !important;
    background: rgba(255,255,255,.10) !important;
    color: #fff !important;
}

.window-header .window-minimize:hover,
.window-header .window-close:hover {
    background: rgba(255,255,255,.24) !important;
}

.taskbar {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    height: 42px !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 5px 10px !important;
    background: linear-gradient(90deg, rgba(23,28,43,.96), rgba(47,36,66,.96)) !important;
    border-top: 1px solid rgba(255,255,255,.16) !important;
    box-shadow: 0 -10px 24px rgba(0,0,0,.28) !important;
    z-index: 2147482000 !important;
}

.taskbar-start,
.taskbar-window {
    height: 30px !important;
    margin: 0 !important;
    border-radius: 9px !important;
    border: 1px solid rgba(255,255,255,.18) !important;
    background: rgba(255,255,255,.10) !important;
    color: #fff !important;
    font-weight: 700 !important;
    white-space: nowrap !important;
}

.taskbar-start {
    min-width: 94px !important;
}

.taskbar-buttons {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    min-width: 0 !important;
    overflow: hidden !important;
}

.taskbar-window {
    max-width: 190px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    padding: 0 12px !important;
}

.taskbar-window.is-active {
    background: rgba(226,15,19,.72) !important;
    border-color: rgba(255,255,255,.35) !important;
}

.taskbar-window.is-minimized {
    opacity: .72 !important;
}

body #pulpit-organizatora {
    max-height: calc(100vh - 110px) !important;
}

body #pulpit-organizatora #pulpit_tasks {
    display: none !important;
}

.chart-wrap {
    min-height: 520px !important;
}


/* ======================
   V16 — dolny pasek jak górny, konto użytkownika
   ====================== */
body {
    padding-bottom: 44px !important;
}

#desktop {
    min-height: calc(100vh - 44px) !important;
}

.taskbar {
    height: 40px !important;
    padding: 0 14px !important;
    gap: 10px !important;
    background: linear-gradient(90deg, #21182f, #342241, #21182f) !important;
    border-top: 1px solid rgba(255,255,255,.15) !important;
    box-shadow: 0 -8px 20px rgba(0,0,0,.35) !important;
    font-size: 15px !important;
}

.taskbar-start,
.taskbar-window,
.taskbar-logout {
    height: 30px !important;
    border-radius: 8px !important;
    border: 1px solid rgba(255,255,255,.18) !important;
    background: rgba(255,255,255,.08) !important;
    color: #fff !important;
    font-weight: 700 !important;
    cursor: pointer !important;
}

.taskbar-start:hover,
.taskbar-window:hover,
.taskbar-logout:hover {
    background: rgba(255,255,255,.16) !important;
}

.taskbar-buttons {
    flex: 1 1 auto !important;
}

.taskbar-spacer {
    flex: 0 0 auto !important;
}

.taskbar-user {
    color: rgba(255,255,255,.92) !important;
    font-weight: 700 !important;
    white-space: nowrap !important;
    padding: 0 8px !important;
}

.taskbar-logout {
    min-width: 104px !important;
    background: rgba(255,255,255,.10) !important;
}

.window {
    z-index: 1500;
}

#menubar,
#menubar .menu-dropdown-content,
.menu-dropdown-content,
.menu-dropdown:hover .menu-dropdown-content {
    z-index: 2147483600 !important;
}

.actions-cell {
    white-space: nowrap !important;
}

#window-uzytkownicy input,
#window-uzytkownicy select {
    min-width: 120px;
}

#window-uzytkownicy .sheet-wrap {
    max-height: 360px;
    overflow: auto;
}

/* =========================================================
   V17 — tło i układ jak desktop: sztywne pole robocze między paskami,
   kafle zawsze mieszczą się między paskami, okna resizable.
========================================================= */
:root {
    --topbar-h: 38px;
    --taskbar-h: 40px;
    --desktop-pad: 12px;
}

html, body {
    width: 100% !important;
    height: 100% !important;
    margin: 0 !important;
    overflow: hidden !important;
    padding: 0 !important;
    background: #071323 !important;
}

body {
    padding-bottom: 0 !important;
}

#desktop {
    position: fixed !important;
    inset: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    min-height: 100vh !important;
    overflow: hidden !important;
    isolation: isolate !important;
    background: #071323 !important;
}

/* Sztywne tło portalu: nie jest tłem dokumentu, tylko stałym panelem roboczym
   pomiędzy górnym i dolnym paskiem. Nie przewija się z zawartością. */
#desktop::before {
    content: "";
    position: fixed;
    left: 0;
    right: 0;
    top: var(--topbar-h);
    bottom: var(--taskbar-h);
    background-image:
        linear-gradient(90deg, rgba(5,10,18,0.18) 0%, rgba(5,10,18,0.02) 42%, rgba(5,10,18,0.12) 100%),
        url("mikol-tlo-v12.png?v=17");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    z-index: -2;
    pointer-events: none;
}

#menubar {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    height: var(--topbar-h) !important;
    z-index: 2147483600 !important;
}

#menubar .menu-dropdown-content,
.menu-dropdown-content,
.menu-dropdown:hover .menu-dropdown-content {
    z-index: 2147483640 !important;
}

.taskbar {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    height: var(--taskbar-h) !important;
    z-index: 2147483000 !important;
}

/* Kafle: warstwa denna, bez wchodzenia pod paski i bez przewijania całej strony. */
#desktop > #pulpit-organizatora,
body #desktop #pulpit-organizatora,
body #pulpit-organizatora {
    position: fixed !important;
    top: calc(var(--topbar-h) + 12px) !important;
    bottom: calc(var(--taskbar-h) + 12px) !important;
    right: 18px !important;
    left: auto !important;
    width: 300px !important;
    height: auto !important;
    max-height: none !important;
    overflow: hidden !important;
    z-index: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    pointer-events: auto !important;
}

body #pulpit-organizatora .pulpit-head,
body #pulpit-organizatora #pulpit_cards .kpi-card,
body #pulpit-organizatora #pulpit_alerts {
    flex: 0 0 auto !important;
}

body #pulpit-organizatora .pulpit-head {
    padding: 10px 12px !important;
    margin: 0 !important;
    border-radius: 15px !important;
}

body #pulpit-organizatora .pulpit-head h1 {
    font-size: 17px !important;
    line-height: 1.08 !important;
}

body #pulpit-organizatora .pulpit-head p {
    display: none !important;
}

body #pulpit-organizatora .pulpit-filters {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 7px !important;
    margin-top: 8px !important;
}

body #pulpit-organizatora .pulpit-filters select,
body #pulpit-organizatora .pulpit-filters input,
body #pulpit-organizatora .pulpit-filters button {
    grid-column: auto !important;
    height: 30px !important;
    font-size: 12px !important;
    padding: 4px 8px !important;
}

body #pulpit-organizatora #pulpit_cards.kpi-grid,
body #pulpit-organizatora .kpi-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
}

body #pulpit-organizatora .kpi-card {
    min-height: 58px !important;
    padding: 8px 11px !important;
    border-radius: 13px !important;
}

body #pulpit-organizatora .kpi-card b {
    font-size: 18px !important;
}

body #pulpit-organizatora .kpi-card span {
    font-size: 10px !important;
    margin-top: 3px !important;
}

body #pulpit-organizatora .kpi-card em {
    font-size: 10px !important;
    margin-top: 2px !important;
}

body #pulpit-organizatora #pulpit_alerts {
    margin-top: 0 !important;
    padding: 8px 10px !important;
    border-radius: 13px !important;
    font-size: 11px !important;
    line-height: 1.2 !important;
}

body #pulpit-organizatora #pulpit_tasks,
body #pulpit-organizatora .pulpit-table {
    display: none !important;
}

/* Okna: zawsze między paskami przy starcie; kliknięcie/JS podbija z-index, dropdown nadal najwyżej. */
.window {
    min-width: 420px !important;
    min-height: 260px !important;
    max-width: calc(100vw - 24px) !important;
    max-height: calc(100vh - var(--topbar-h) - var(--taskbar-h) - 18px) !important;
    overflow: hidden !important;
    resize: none !important;
    z-index: 1500 !important;
}

.window-content {
    height: calc(100% - 32px) !important;
    max-height: none !important;
    overflow: auto !important;
    box-sizing: border-box !important;
}

.window-resizer {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 18px;
    height: 18px;
    cursor: nwse-resize;
    z-index: 3;
    border-bottom-right-radius: 14px;
    background:
        linear-gradient(135deg, transparent 0 48%, rgba(15, 23, 42, .88) 49% 100%);
}

.window-resizer::after {
    content: "";
    position: absolute;
    right: 4px;
    bottom: 4px;
    width: 7px;
    height: 7px;
    border-right: 2px solid rgba(255,255,255,.72);
    border-bottom: 2px solid rgba(255,255,255,.72);
}

#window-kalendarz .calendar-pattern-line {
    align-items: stretch !important;
}

#window-kalendarz #kal_wzorzec { min-width: 230px; }
#window-kalendarz #kal_kod { min-width: 130px; }
#window-kalendarz #kal_nazwa { min-width: 240px; flex: 1 1 260px; }
#window-kalendarz #kal_rok { width: 95px; }

.cal-head span {
    color: #64748b;
    font-size: 12px;
    margin-left: 8px;
}

@media (max-height: 720px) {
    body #pulpit-organizatora {
        width: 280px !important;
        right: 12px !important;
        gap: 6px !important;
    }
    body #pulpit-organizatora .kpi-card {
        min-height: 50px !important;
        padding: 7px 10px !important;
    }
    body #pulpit-organizatora .kpi-card b { font-size: 16px !important; }
    body #pulpit-organizatora #pulpit_alerts { font-size: 10px !important; padding: 7px 9px !important; }
}

/* v18 - edycja tabelaryczna i szersze kalendarze */
.table-input {
    width: 100%;
    min-width: 90px;
    box-sizing: border-box;
    padding: 7px 8px;
    border: 1px solid #c7c7cf;
    border-radius: 6px;
    background: #fff;
}
.small-input {
    width: 86px;
    box-sizing: border-box;
    padding: 7px 8px;
    border: 1px solid #c7c7cf;
    border-radius: 6px;
    background: #fff;
}
.calendar-grid.multi-month {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
    gap: 14px;
    align-items: start;
}
.calendar-grid.multi-month .cal-head {
    grid-column: 1 / -1;
}
.cal-month {
    border: 1px solid rgba(55,42,72,.18);
    border-radius: 12px;
    padding: 10px;
    background: rgba(255,255,255,.92);
}
.cal-month h4 {
    margin: 0 0 8px 0;
    color: #1d2130;
}
.cal-day.holiday em {
    display: block;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    font-style: normal;
    font-size: 10px;
    opacity: .75;
    margin-top: 3px;
}
.color-sample {
    display: inline-block;
    width: 22px;
    height: 14px;
    border-radius: 4px;
    border: 1px solid rgba(0,0,0,.2);
    margin-right: 6px;
    vertical-align: middle;
}


/* v20: login background repair */
.login-bg {
    min-height: 100vh !important;
    background-color: #071323 !important;
    background-image: linear-gradient(90deg, rgba(7,19,35,.38), rgba(7,19,35,.18)), url("mikol-tlo-v12.png?v=20") !important;
    background-repeat: no-repeat !important;
    background-position: center center !important;
    background-size: cover !important;
    overflow: hidden !important;
}

/* v20: Excel-like timetable */
.rozklad-scroll { width: 100%; overflow: auto; border: 1px solid #d7d7d7; background: #fff; }
.rozklad-sheet.excel-like { table-layout: fixed !important; border-collapse: collapse; width: max-content; min-width: 100%; font-size: 13px; }
.rozklad-sheet.excel-like .station-col { width: 220px; }
.rozklad-sheet.excel-like .train-col { width: 74px; }
.rozklad-sheet.excel-like th, .rozklad-sheet.excel-like td { border: 1px solid #999 !important; padding: 3px 5px !important; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; text-align: center; }
.rozklad-sheet.excel-like .station-cell { text-align: left; font-weight: 600; background: #f3f3f3; }
.rozklad-sheet.excel-like .train-head { background: #d9d9d9 !important; color: #000 !important; font-weight: 700; }
.rozklad-sheet.excel-like .train-head.term { color: #b40000 !important; font-style: italic; font-weight: 600; }
.rozklad-sheet.excel-like .time-cell { font-weight: 700; }
.legend-box { margin-top: 10px; padding: 10px; border: 1px solid #ddd; background: #fafafa; font-size: 13px; }
.obieg-table { table-layout: fixed; width: 100%; border-collapse: collapse; }
.obieg-table th, .obieg-table td { border: 1px solid #bbb; padding: 5px 6px; font-size: 13px; vertical-align: top; }

.stop-panel{margin:10px 0;padding:10px;border:1px solid rgba(55,42,72,.22);border-radius:10px;background:#fafafa;}
.stop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:8px 10px;}
.stop-grid label{font-size:12px;color:#1a2030;display:flex;align-items:center;gap:6px;justify-content:space-between;background:#fff;border:1px solid #ddd;border-radius:8px;padding:6px 8px;}
.stop-grid input{width:70px;min-width:70px;}
.compact-table input[type="time"], .compact-table input[type="number"]{width:105px;min-width:80px;}
.compact-table input.stop_note{width:100%;min-width:160px;}
.rozklad-sheet{table-layout:fixed;border-collapse:collapse;}
.rozklad-sheet .station-col{width:210px;}
.rozklad-sheet .train-col{width:86px;}
.rozklad-sheet th,.rozklad-sheet td{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.rozklad-sheet .time-cell{text-align:center;font-variant-numeric:tabular-nums;}

/* V23 — globalny kontener rozkładu jazdy */
.global-schedule-picker {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 10px;
    min-height: 38px;
    border-right: 1px solid rgba(255,255,255,.18);
    background: rgba(255,255,255,.06);
}
.global-schedule-picker select {
    max-width: 240px;
    min-width: 190px;
    height: 28px;
    border-radius: 8px;
    border: 1px solid rgba(255,255,255,.25);
    background: rgba(255,255,255,.92);
    color: #241932;
    padding: 0 8px;
}
.global-schedule-info {
    font-size: 12px;
    opacity: .9;
    white-space: nowrap;
}
.strong-hint {
    font-weight: 700;
    color: #372a48;
}
.row-selected td {
    background: rgba(138,65,106,.12) !important;
    border-top: 2px solid #8a416a;
    border-bottom: 2px solid #8a416a;
}
#window-wyszukiwarka-polaczen table th,
#window-wyszukiwarka-polaczen table td {
    white-space: nowrap;
}
#window-wyszukiwarka-polaczen .sheet-wrap {
    max-height: calc(100% - 150px);
    overflow: auto;
}

/* V24 — globalny wybór rozkładu na dolnym pasku + czytelne podpowiedzi stacji */
.taskbar-schedule-picker {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 360px;
    max-width: 620px;
    color: rgba(255,255,255,.92);
    font-weight: 700;
    padding: 0 10px;
    border-left: 1px solid rgba(255,255,255,.12);
    border-right: 1px solid rgba(255,255,255,.12);
}
.taskbar-schedule-picker select {
    max-width: 260px;
    min-width: 210px;
    height: 28px;
    border-radius: 8px;
    border: 1px solid rgba(255,255,255,.25);
    background: rgba(255,255,255,.94);
    color: #241932;
    padding: 0 8px;
}
.taskbar-schedule-picker .global-schedule-info {
    max-width: 230px;
    overflow: hidden;
    text-overflow: ellipsis;
}
.station-suggest-wrap {
    position: relative;
    min-width: 230px;
}
.station-suggest-wrap input {
    width: 100%;
    box-sizing: border-box;
}
.station-suggest {
    display: none;
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 3px);
    z-index: 99999;
    background: #fff;
    border: 1px solid #cfc7d8;
    border-radius: 10px;
    box-shadow: 0 10px 25px rgba(0,0,0,.18);
    max-height: 240px;
    overflow-y: auto;
    padding: 4px;
}
.station-suggest button {
    display: block;
    width: 100%;
    text-align: left;
    border: 0;
    background: transparent;
    color: #241932;
    padding: 8px 10px;
    border-radius: 8px;
    font-weight: 600;
    cursor: pointer;
}
.station-suggest button:hover {
    background: rgba(138,65,106,.13);
}
.station-suggest-empty {
    padding: 8px 10px;
    color: #6b6371;
}
.inline-check {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    white-space: nowrap;
    font-weight: 700;
    color: #372a48;
}

.consist-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin: 8px 0 10px;
}
.consist-row {
    display: grid;
    grid-template-columns: 210px 240px 80px 1fr 80px;
    gap: 8px;
    align-items: center;
}
.consist-row select,
.consist-row input {
    min-width: 0;
}
@media (max-width: 900px) {
    .consist-row { grid-template-columns: 1fr; }
}

.time-anchor-field {
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: 12px;
    color: #5f5f68;
}
.time-anchor-field input {
    width: 100%;
}
.route-preview {
    border: 1px dashed #b9b0bf;
    border-radius: 8px;
    padding: 9px 11px;
    background: #faf8fb;
    color: #3b294a;
    font-size: 13px;
    line-height: 1.35;
}


/* V28: okno wyboru pociągów do łączenia relacji */
.mikol-modal-backdrop {
    position: fixed;
    inset: 0;
    display: none;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.38);
    z-index: 9000;
}

.mikol-modal {
    width: min(1180px, calc(100vw - 48px));
    max-height: calc(100vh - 70px);
    background: #fff;
    border: 1px solid rgba(137, 61, 105, 0.75);
    border-radius: 14px;
    box-shadow: 0 18px 45px rgba(0, 0, 0, 0.32);
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.mikol-modal-header {
    background: #39264d;
    color: #fff;
    padding: 10px 14px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 18px;
}

.mikol-modal-header button {
    min-width: 34px;
    padding: 3px 10px;
    font-size: 22px;
    line-height: 1;
}

.mikol-modal-body {
    padding: 14px;
    overflow: auto;
}

.mikol-modal-footer {
    padding: 12px 14px;
    border-top: 1px solid #ddd;
    display: flex;
    gap: 10px;
    justify-content: flex-end;
}

.link-train-toolbar {
    display: grid;
    grid-template-columns: minmax(340px, 1fr) 260px;
    gap: 10px;
    margin: 10px 0;
}

.link-train-toolbar input,
.link-train-toolbar select,
#linkTrainOpis {
    width: 100%;
    box-sizing: border-box;
}

.link-train-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 10px 0;
}

.link-train-table-wrap {
    border: 1px solid #ddd;
    max-height: 470px;
    overflow: auto;
}

.link-train-table {
    width: 100%;
    border-collapse: collapse;
}

.link-train-table th {
    position: sticky;
    top: 0;
    z-index: 2;
}

.link-train-table td,
.link-train-table th {
    padding: 8px 10px;
    border-bottom: 1px solid #ddd;
    text-align: left;
    white-space: nowrap;
}

.link-train-table td:nth-child(4) {
    white-space: normal;
    min-width: 280px;
}

@media (max-width: 900px) {
    .link-train-toolbar { grid-template-columns: 1fr; }
    .mikol-modal { width: calc(100vw - 18px); }
}

.train-context-row {
    cursor: context-menu;
}

.train-context-row:hover,
.train-context-row.context-open {
    background: rgba(142, 65, 106, 0.10);
}

.train-actions-cell {
    white-space: nowrap;
}

.context-hint {
    color: #666;
    font-size: 13px;
    font-weight: 700;
}

.train-context-menu {
    position: fixed;
    z-index: 99999;
    display: none;
    min-width: 250px;
    padding: 8px;
    border: 1px solid rgba(50, 33, 68, 0.35);
    border-radius: 10px;
    background: #fff;
    box-shadow: 0 18px 50px rgba(0,0,0,0.28);
}

.context-menu-title {
    padding: 8px 10px;
    margin-bottom: 6px;
    color: #3b294c;
    font-weight: 800;
    border-bottom: 1px solid #e3dce8;
}

.train-context-menu button {
    display: block;
    width: 100%;
    margin: 2px 0;
    padding: 9px 10px;
    border: 0;
    border-radius: 8px;
    background: transparent;
    color: #111827;
    text-align: left;
    font-weight: 700;
    cursor: pointer;
}

.train-context-menu button:hover {
    background: #f2edf5;
}

.train-context-menu button.danger {
    color: #b8322a;
}

.return-train-modal {
    width: min(760px, calc(100vw - 40px));
}

.return-train-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-top: 12px;
}

.return-train-grid label {
    display: flex;
    flex-direction: column;
    gap: 5px;
    font-weight: 700;
}

.return-train-grid input,
.return-train-grid select {
    width: 100%;
    box-sizing: border-box;
}

@media (max-width: 760px) {
    .return-train-grid { grid-template-columns: 1fr; }
}

/* V30: jednolita typografia i poprawione okna dialogowe */
html, body, button, input, select, textarea, table, .window, .window-content, .menu-dropdown-content {
    font-family: Tahoma, Verdana, Arial, sans-serif !important;
}

.dynamic-window {
    resize: both !important;
    overflow: hidden !important;
    min-width: 520px !important;
    min-height: 340px !important;
}

.dynamic-window .window-header {
    height: 34px !important;
    min-height: 34px !important;
    padding: 5px 10px !important;
    font-size: 15px !important;
}

.dynamic-window-content {
    padding: 14px !important;
    height: calc(100% - 34px) !important;
    overflow: auto !important;
}

.dynamic-window-footer {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    border-top: 1px solid #ddd;
    margin-top: 14px;
    padding-top: 12px;
}

.return-train-modal {
    max-width: calc(100vw - 24px) !important;
    max-height: calc(100vh - var(--topbar-h, 54px) - var(--taskbar-h, 42px) - 18px) !important;
}

.return-train-window-body .muted {
    line-height: 1.45;
}

.train-context-menu {
    z-index: 2147483500 !important;
    max-height: min(420px, calc(100vh - 16px));
    overflow: auto;
}

.consist-row {
    grid-template-columns: 220px 260px 100px 1fr 82px !important;
    align-items: end !important;
    padding: 10px !important;
    border: 1px solid #ddd !important;
    border-radius: 10px !important;
    background: #fafafa !important;
}

.consist-row label {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
    margin: 0;
    font-weight: 700;
    color: #322340;
}

.consist-row label span {
    font-size: 12px;
    color: #6b6372;
}

.consist-row button {
    height: 38px;
}

@media (max-width: 1050px) {
    .consist-row { grid-template-columns: 1fr 1fr !important; }
    .consist-row button { width: 100%; }
}

.generator-section {
    border: 1px solid #ddd;
    border-radius: 12px;
    background: #fff;
    padding: 12px;
    margin: 10px 0 14px;
}

.generator-section h4 {
    margin: 0 0 10px;
    color: #251a32;
    font-size: 16px;
}

.generator-section .hint {
    margin: 0 0 10px;
}

/* V31 — pojazdy: skonsolidowana karta techniczna */
.vehicle-form-section {
    border: 1px solid #d7d2dc;
    border-radius: 12px;
    padding: 12px;
    margin: 10px 0;
    background: rgba(255,255,255,0.72);
}
.vehicle-form-section h4 {
    margin: 0 0 10px 0;
    color: #2f213f;
}
.form-grid-3 {
    grid-template-columns: repeat(3, minmax(160px, 1fr));
}
.form-grid-5 {
    grid-template-columns: repeat(5, minmax(110px, 1fr));
}
.checkbox-line {
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 36px;
    padding: 0 10px;
    border: 1px solid #bfbfbf;
    background: #fff;
}
.checkbox-line input {
    width: auto;
    margin: 0;
}
@media (max-width: 900px) {
    .form-grid-3,
    .form-grid-5 {
        grid-template-columns: 1fr 1fr;
    }
}

/* V32: zagęszczenie widoków roboczych i obiegów */
html, body, button, input, select, textarea, table, .window, .window-content, .menu-dropdown-content {
    font-family: Tahoma, Verdana, Arial, sans-serif !important;
    font-size: 13px;
}
.window-content h2, .window-content h3 { font-size: 18px; margin: 10px 0; }
.window-content h4 { font-size: 15px; }
.window-content input, .window-content select, .window-content textarea {
    min-height: 30px;
    padding: 5px 8px;
    font-size: 13px;
}
.window-content button, button {
    padding: 7px 11px;
    font-size: 13px;
    line-height: 1.15;
}
.window table { border-collapse: collapse; width: 100%; }
.window table th, .window table td {
    padding: 4px 6px !important;
    line-height: 1.15 !important;
    font-size: 12.5px !important;
    vertical-align: middle !important;
}
#window-pociag-generator { min-width: 1180px; min-height: 720px; }
#window-pociag-generator .window-content { font-size: 13px; }
#window-pociag-generator .form-grid,
#window-obiegi .form-grid,
#window-lista-pojazdow .form-grid { gap: 8px; }
#window-pociag-generator table td,
#window-pociag-generator table th { white-space: nowrap; }
#window-pociag-generator .sheet-wrap { overflow: auto; }
.train-context-row td { height: 28px !important; max-height: 28px; }
.train-context-row .context-hint { font-size: 11px; opacity: .7; }
.consist-row {
    grid-template-columns: minmax(170px,220px) minmax(220px,300px) minmax(95px,120px) minmax(180px,1fr) 78px !important;
    gap: 8px !important;
    padding: 8px !important;
}
.consist-row button { height: 32px !important; padding: 6px 10px !important; }
.service-item-panel {
    border: 1px solid rgba(55,42,72,.25);
    border-radius: 10px;
    padding: 10px;
    margin: 10px 0;
    background: #fafafa;
}
.obieg-table-v32 { table-layout: fixed; min-width: 1220px; }
.obieg-table-v32 th:nth-child(1), .obieg-table-v32 td:nth-child(1) { width: 130px; }
.obieg-table-v32 th:nth-child(2), .obieg-table-v32 td:nth-child(2) { width: 135px; }
.obieg-table-v32 th:nth-child(3), .obieg-table-v32 td:nth-child(3) { width: 42px; text-align:center; }
.obieg-table-v32 th:nth-child(4), .obieg-table-v32 td:nth-child(4) { width: 70px; }
.obieg-table-v32 th:nth-child(5), .obieg-table-v32 td:nth-child(5) { width: 95px; }
.obieg-table-v32 th:nth-child(6), .obieg-table-v32 td:nth-child(6) { width: 80px; }
.obieg-table-v32 th:nth-child(7), .obieg-table-v32 td:nth-child(7),
.obieg-table-v32 th:nth-child(9), .obieg-table-v32 td:nth-child(9) { width: 75px; text-align:center; }
.obieg-table-v32 th:nth-child(8), .obieg-table-v32 td:nth-child(8),
.obieg-table-v32 th:nth-child(10), .obieg-table-v32 td:nth-child(10) { width: 145px; }
.obieg-table-v32 th:nth-child(11), .obieg-table-v32 td:nth-child(11) { width: 80px; text-align:right; }
.obieg-table-v32 th:nth-child(13), .obieg-table-v32 td:nth-child(13) { width: 65px; }
.obieg-table-v32 .obieg-first-row td { border-top: 3px solid #372a48 !important; }
.obieg-table-v32 .obieg-total-row td { border-bottom: 3px solid #372a48 !important; background: #f6f3f8; font-weight: 700; }
.mini-btn { padding: 4px 7px !important; font-size: 11px !important; border-radius: 6px !important; }
.time-cell { font-variant-numeric: tabular-nums; }
.num-cell { font-variant-numeric: tabular-nums; text-align:right; }
#window-lista-pojazdow table th, #window-lista-pojazdow table td { white-space: nowrap; }

/* V33 — klarowniejsze formularze, ciaśniejsze tabele i obiegi na PPM */
body, input, select, textarea, button, table { font-family: Tahoma, Arial, sans-serif !important; }
.window { max-width: calc(100vw - 36px); max-height: calc(100vh - 36px); }
#window-pociag-generator { width: min(1280px, calc(100vw - 42px)) !important; height: min(820px, calc(100vh - 54px)) !important; }
#window-obiegi { width: min(1500px, calc(100vw - 36px)) !important; height: min(860px, calc(100vh - 48px)) !important; }
.window-content { font-size: 14px; }
.form-grid label, .generator-section label, .service-item-panel label { display:flex; flex-direction:column; gap:4px; font-weight:600; color:#372a48; }
.form-grid label span, .generator-section label span, .field-label { font-size:12px; line-height:1.2; color:#5f526b; font-weight:700; }
.form-grid label input, .form-grid label select, .generator-section label input, .generator-section label select { width:100%; box-sizing:border-box; }
.generator-section { margin: 10px 0 16px; padding: 14px 16px; border: 1px solid #ddd; border-radius: 14px; background: rgba(255,255,255,.92); }
.generator-section h4 { margin: 0 0 10px; font-size: 18px; }
.generator-section .hint { margin: 0 0 10px; color:#666; }
#listaPociagow tr, .obieg-table tr { height: 28px; }
#listaPociagow td, #listaPociagow th, .obieg-table td, .obieg-table th { padding: 5px 7px !important; font-size: 13px; line-height: 1.15; vertical-align: middle; }
#listaPociagow td { max-width: 210px; }
.obieg-table-v33 { border-collapse: collapse; width: 100%; min-width: 1180px; }
.obieg-table-v33 .obieg-first-row td { border-top: 3px solid #372a48; }
.obieg-table-v33 .obieg-total-row td { border-top: 2px solid #372a48; border-bottom: 3px solid #372a48; background:#f7f4f8; font-weight:700; }
.obieg-context-row.context-open, .train-context-row.context-open { outline: 2px solid #9b4778; outline-offset: -2px; background:#fff7fb; }
.obieg-context-menu { z-index: 999999; min-width: 245px; }
.sheet-wrap { overflow:auto; }
button { padding: 7px 12px; }
.mini-btn { padding: 4px 8px; font-size: 12px; }
.service-item-panel { border:1px solid #ddd; border-radius:12px; padding:12px; margin:10px 0; background:#fbfbfb; }
.form-grid-5 { grid-template-columns: repeat(5, minmax(120px, 1fr)); }
@media (max-width: 1100px) { .form-grid, .form-grid-5 { grid-template-columns: repeat(2, minmax(160px,1fr)) !important; } }

/* V34 — globalne opisy pól, mniejsze checkboxy, PPM w tabelach */
html, body, button, input, select, textarea, table, .window, .window-content, .menu-dropdown-content {
    font-family: Tahoma, Arial, sans-serif !important;
}
.window-content {
    font-size: 13px;
}
.field-wrap {
    display: flex;
    flex-direction: column;
    gap: 3px;
    min-width: 0;
}
.field-wrap .field-label,
.window-content .field-label {
    display: block;
    font-size: 11px;
    line-height: 1.15;
    font-weight: 700;
    color: #554360;
    margin: 0 0 1px 1px;
}
.field-wrap input,
.field-wrap select,
.field-wrap textarea {
    width: 100%;
    box-sizing: border-box;
}
.window-content input,
.window-content select,
.window-content textarea {
    box-sizing: border-box;
    min-height: 30px;
}
.checkbox-line,
.form-grid label.checkbox-line {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    min-height: 30px !important;
    height: auto !important;
    padding: 5px 8px !important;
    font-size: 13px !important;
    line-height: 1.2 !important;
    font-weight: 700 !important;
    color: #2f213f !important;
}
.checkbox-line input[type="checkbox"],
.form-grid label.checkbox-line input[type="checkbox"],
.window-content input[type="checkbox"] {
    width: 16px !important;
    height: 16px !important;
    min-width: 16px !important;
    min-height: 16px !important;
    max-width: 16px !important;
    max-height: 16px !important;
    padding: 0 !important;
    margin: 0 4px 0 0 !important;
    flex: 0 0 16px !important;
    transform: none !important;
    accent-color: #8f3f72;
}
.vehicle-context-row {
    cursor: context-menu;
}
.vehicle-context-row:hover,
.vehicle-context-row.context-open {
    background: #fff7fb !important;
    outline: 2px solid #9b4778;
    outline-offset: -2px;
}
.vehicle-context-menu {
    z-index: 999999 !important;
    min-width: 230px;
}
#window-lista-pojazdow table td,
#window-lista-pojazdow table th {
    padding: 5px 7px !important;
    font-size: 12.5px !important;
    line-height: 1.15 !important;
    vertical-align: middle;
}
#window-lista-pojazdow table tr {
    height: 28px;
}
#window-lista-pojazdow {
    width: min(1450px, calc(100vw - 40px)) !important;
    height: min(820px, calc(100vh - 54px)) !important;
}
#window-lista-pojazdow .form-grid {
    align-items: end;
}
#window-lista-pojazdow .vehicle-form-section {
    padding: 10px 12px;
}
#window-lista-pojazdow .vehicle-form-section h4 {
    margin-bottom: 6px;
}
#window-lista-pojazdow .hint {
    font-size: 12px;
    margin: 4px 0 8px;
}
.table-compact td,
.table-compact th {
    padding: 4px 6px !important;
    font-size: 12px !important;
}
