/* NANO-IT Panel — operator UI
   Palette: canvas #f7f8fa · surface #fff · ink #1a1d29 · muted #6b7280
            line #e6e8ee · accent #5b4ee5 · accent-soft #eeecff */
:root{
  --canvas:#f7f8fa; --surface:#fff; --ink:#1a1d29; --muted:#6b7280;
  --line:#e6e8ee; --accent:#5b4ee5; --accent-soft:#eeecff; --accent-ink:#3b2fc4;
  --ok:#0f9d58; --warn:#c77700; --danger:#d23f3f;
  --mono:ui-monospace,"SF Mono",SFMono-Regular,Menlo,Consolas,"Liberation Mono",monospace;
  --sans:system-ui,-apple-system,"Segoe UI",Roboto,Inter,"Helvetica Neue",Arial,sans-serif;
  --radius:10px; --shadow:0 1px 2px rgba(16,18,30,.06),0 4px 16px rgba(16,18,30,.05);
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:var(--sans);color:var(--ink);background:var(--canvas);font-size:14px;line-height:1.45}
b{font-weight:600}
a{color:var(--accent-ink);text-decoration:none}
.muted{color:var(--muted)}
.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}

/* ---- Topbar ---- */
.topbar{display:flex;align-items:center;gap:16px;padding:10px 18px;background:var(--surface);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.brand{display:flex;align-items:center;gap:10px;font-weight:700}
.mark{display:grid;place-items:center;width:28px;height:28px;border-radius:8px;
  background:var(--accent);color:#fff;font-weight:800;font-family:var(--mono)}
.brand-name{display:flex;flex-direction:column;line-height:1.05;letter-spacing:.2px}
.brand-sub{font-size:10.5px;font-weight:500;color:var(--muted);letter-spacing:.4px;text-transform:uppercase}
.acct{font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:6px;margin-left:6px}
.acct b{color:var(--ink)}
.acct-sync{color:var(--muted)}
.acct-dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.acct-dot.ok{background:var(--ok)} .acct-dot.off{background:#c2c6d0}
.actions{margin-left:auto;display:flex;align-items:center;gap:8px}

/* ---- Buttons ---- */
.btn{font:inherit;border:1px solid transparent;border-radius:8px;padding:7px 13px;cursor:pointer;
  background:none;color:var(--ink);transition:background .12s,border-color .12s}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-ink)}
.btn-ghost{border-color:var(--line);background:var(--surface)}
.btn-ghost:hover{border-color:#cfd3dd;background:#fbfbfe}
.btn-link{padding:6px 6px;color:var(--accent-ink)}
.btn-link:hover{text-decoration:underline}
.btn-link.danger{color:var(--danger)}
.btn-block{width:100%}
.btn.disabled{opacity:.45;pointer-events:none}
.iconbtn{display:grid;place-items:center;width:34px;height:34px;border-radius:8px;border:1px solid var(--line);
  background:var(--surface);font-size:16px;color:var(--ink)}
.iconbtn:hover{border-color:#cfd3dd}

.main{max-width:1180px;margin:18px auto;padding:0 18px}

/* ---- Status tabs ---- */
.tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.tab{padding:7px 12px;border:1px solid var(--line);border-radius:999px;background:var(--surface);
  color:var(--muted);font-weight:600;font-size:13px;display:inline-flex;align-items:center;gap:7px}
.tab:hover{border-color:#cfd3dd}
.tab.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.tab .cnt{font-family:var(--mono);font-size:11px;background:rgba(0,0,0,.06);padding:1px 6px;border-radius:999px}
.tab.on .cnt{background:rgba(255,255,255,.18)}

/* ---- Toolbar / filters ---- */
.toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:14px}
.fld{font:inherit;padding:7px 10px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--ink)}
.fld:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}
.search{flex:1;min-width:220px}
.fld-group{display:flex;align-items:center;gap:6px;border:1px solid var(--line);border-radius:8px;padding:3px 8px;background:var(--surface)}
.fld-group .date{border:none;padding:4px 2px}
.fld-group .date:focus{outline:none}
.mini{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}

/* ---- Table ---- */
.table-wrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
table.orders{width:100%;border-collapse:collapse}
.orders thead th{text-align:left;font-size:11.5px;letter-spacing:.4px;text-transform:uppercase;color:var(--muted);
  font-weight:600;padding:11px 12px;border-bottom:1px solid var(--line);background:#fcfcfe}
.orders th .sort{color:var(--muted);display:inline-flex;gap:4px}
.orders th .sort.on{color:var(--ink)}
.orders th .sort span{font-size:9px}
.orders tbody .row td{padding:11px 12px;border-bottom:1px solid var(--line);vertical-align:middle}
.orders tbody .row:hover{background:#fafaff;cursor:pointer}
.c-exp{width:34px} .c-status{width:120px} .c-date{width:140px;white-space:nowrap}
.c-items{width:64px;text-align:center} .c-total{width:130px;white-space:nowrap} .c-src{width:84px}
.c-id{color:var(--muted);font-size:12px}
.exp{border:none;background:none;cursor:pointer;color:var(--muted);font-size:14px;transition:transform .15s;padding:2px 6px}
.row.open .exp{transform:rotate(90deg);color:var(--accent-ink)}

/* status pills */
.pill{display:inline-block;padding:3px 9px;border-radius:999px;font-size:12px;font-weight:600;border:1px solid transparent}
.st-nowe{background:#eaf1ff;color:#1f5bd6;border-color:#d4e3ff}
.st-gotowe{background:#e7f7ee;color:#0f8a4d;border-color:#cdeed9}
.st-wstrzymane{background:#fff3e0;color:#b86c00;border-color:#ffe3b8}
.st-zwrocone{background:#f1ecff;color:#6b46c1;border-color:#e2d8ff}
.st-anulowane{background:#f3f4f6;color:#8a8f9c;border-color:#e6e8ee}
.tab.st-nowe.on,.tab.st-gotowe.on,.tab.st-wstrzymane.on,.tab.st-zwrocone.on,.tab.st-anulowane.on{color:#fff}
.src{font-size:11px;padding:2px 7px;border-radius:6px;background:#f3f4f6;color:var(--muted);font-weight:600}
.src-manual{background:var(--accent-soft);color:var(--accent-ink)}

/* ---- Detail sheet ---- */
.detail td{background:#fbfbfe;padding:0!important;border-bottom:1px solid var(--line)}
.sheet{padding:16px 18px}
.sheet-grid{display:grid;grid-template-columns:1fr 1fr 1.1fr;gap:18px}
.sheet fieldset{border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin:0;background:var(--surface)}
.sheet legend{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700;padding:0 6px}
.sheet label{display:block;font-size:12px;color:var(--muted);margin-top:8px}
.sheet input,.sheet textarea,.sheet select{width:100%;font:inherit;color:var(--ink);margin-top:3px;
  padding:6px 9px;border:1px solid var(--line);border-radius:7px;background:#fff}
.sheet input:focus,.sheet textarea:focus,.sheet select:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.items{display:flex;flex-direction:column;gap:6px;margin-top:6px}
.item-row{display:grid;grid-template-columns:1fr 56px 84px 26px;gap:6px;align-items:center}
.item-row input{margin-top:0}
.i-qty,.i-price{text-align:right}
.i-del{border:none;background:none;color:var(--muted);cursor:pointer;font-size:13px}
.i-del:hover{color:var(--danger)}
.note textarea{resize:vertical}
.sheet-foot{display:flex;align-items:center;justify-content:space-between;margin-top:14px;gap:12px;flex-wrap:wrap}
.sheet-status{display:flex;align-items:center;gap:14px}
.sheet-status label{display:flex;align-items:center;gap:8px;margin:0;color:var(--ink)}
.sheet-status select{width:auto;margin:0}
.sheet-status .meta{font-size:11.5px;color:var(--muted);font-family:var(--mono)}
.sheet-actions{display:flex;align-items:center;gap:12px}
.save-msg{font-size:12.5px;color:var(--ok)}
.save-msg.err{color:var(--danger)}

/* ---- Pager / empty ---- */
.pager{display:flex;align-items:center;justify-content:center;gap:16px;margin:16px 0}
.pg{padding:7px 12px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}
.pg.off{opacity:.4;pointer-events:none}
.pg-info{color:var(--muted);font-size:13px}
.empty{background:var(--surface);border:1px dashed var(--line);border-radius:var(--radius);padding:40px;text-align:center}
.empty p{margin:4px 0}

/* ---- Modal ---- */
.modal{position:fixed;inset:0;background:rgba(16,18,30,.42);display:grid;place-items:center;z-index:50;padding:20px}
.modal[hidden]{display:none}
.modal-card{background:var(--surface);border-radius:14px;width:100%;max-width:560px;max-height:90vh;overflow:auto;box-shadow:0 20px 60px rgba(16,18,30,.25)}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line)}
.modal-head h2{margin:0;font-size:16px}
.modal-x{border:none;background:none;font-size:16px;cursor:pointer;color:var(--muted)}
.modal-body{padding:16px 20px;display:flex;flex-direction:column;gap:4px}
.modal-body label{display:block;font-size:12px;color:var(--muted);margin-top:8px}
.modal-body input,.modal-body textarea{width:100%;font:inherit;color:var(--ink);margin-top:3px;
  padding:7px 9px;border:1px solid var(--line);border-radius:7px}
.modal-body fieldset{border:1px solid var(--line);border-radius:10px;padding:10px 12px;margin-top:10px}
.modal-body legend{font-size:11px;text-transform:uppercase;color:var(--muted);font-weight:700}
.modal-foot{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:14px 20px;border-top:1px solid var(--line)}
.modal-foot .save-msg{margin-right:auto}

/* ---- Settings ---- */
.settings{max-width:720px;margin:0 auto}
.back{font-size:13px;color:var(--muted)}
.settings h1{margin:8px 0 18px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;margin-bottom:16px;box-shadow:var(--shadow)}
.card h2{margin:0 0 4px;font-size:15px}
.conn-state{margin:12px 0;font-size:13.5px;display:flex;align-items:center;gap:8px}
.steps{margin:10px 0 16px;padding-left:20px;color:var(--ink);font-size:13px;line-height:1.7}
.steps code{background:#f3f4f6;padding:1px 6px;border-radius:5px;font-family:var(--mono);font-size:12px}
.copybox{display:flex;align-items:center;gap:8px;background:#f3f4f6;border-radius:7px;padding:6px 10px;margin-top:5px}
.copybox code{font-family:var(--mono);font-size:12.5px;word-break:break-all}
.stack{display:flex;flex-direction:column;gap:6px}
.stack label{font-size:12px;color:var(--muted)}
.stack input,.stack select{font:inherit;padding:8px 10px;border:1px solid var(--line);border-radius:8px;margin-top:3px;width:100%}
.row-actions{display:flex;gap:10px;align-items:center;margin-top:10px}
.alert{border-radius:8px;padding:10px 14px;margin-bottom:14px;font-size:13.5px}
.alert.err{background:#fdecec;color:#a32424;border:1px solid #f7c9c9}
.alert.ok{background:#e7f7ee;color:#0f7a45;border:1px solid #c8ecd6}

/* ---- Login ---- */
body.bare{display:grid;place-items:center;min-height:100vh;background:linear-gradient(160deg,#f7f8fa,#eef0fb)}
.main-bare{width:100%;max-width:380px;padding:20px}
.login-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:28px;box-shadow:var(--shadow);text-align:center}
.login-mark{width:44px;height:44px;border-radius:12px;background:var(--accent);color:#fff;font-weight:800;
  font-family:var(--mono);display:grid;place-items:center;font-size:22px;margin:0 auto 14px}
.login-card h1{font-size:18px;margin:0 0 4px}
.login-hint{color:var(--muted);font-size:13px;margin:0 0 16px}
.login-form{display:flex;flex-direction:column;gap:10px;text-align:left}
.login-form label{font-size:12px;color:var(--muted);display:flex;flex-direction:column;gap:4px}
.login-form input{font:inherit;padding:9px 11px;border:1px solid var(--line);border-radius:9px}

/* ---- Responsive ---- */
@media(max-width:900px){
  .sheet-grid{grid-template-columns:1fr}
  .topbar{flex-wrap:wrap}
  .acct{order:3;width:100%;margin-left:0}
}
@media(max-width:680px){
  .c-id,.c-src,.c-items{display:none}
  .actions .btn{padding:7px 10px;font-size:13px}
  .brand-sub{display:none}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important}}

/* ===== v2: nowe statusy, dokumenty, automatyzacje, statystyki ===== */
.st-eog{background:#e6f6f8;color:#0b7a8a;border-color:#c7eaee}
.st-wstrzymane_zwrot{background:#fff3e0;color:#b86c00;border-color:#ffe3b8}
.st-zwrot{background:#f1ecff;color:#6b46c1;border-color:#e2d8ff}
.st-blad{background:#fdecec;color:#c0392b;border-color:#f7c9c9}
.tab.st-eog.on,.tab.st-wstrzymane_zwrot.on,.tab.st-zwrot.on,.tab.st-blad.on{color:#fff}

/* numery Allegro — mały druk */
.sheet-refs{display:flex;flex-wrap:wrap;gap:6px 18px;font-size:11.5px;color:var(--muted);margin-bottom:12px}
.sheet-refs b{color:var(--ink)}

/* checkboxy w arkuszu */
.checks{display:flex;flex-wrap:wrap;gap:14px;margin-top:10px}
.chk{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--ink);margin:0}
.chk input{width:auto;margin:0}

/* sekcja dokumentów */
.docs{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin-top:14px}
.docs-title{color:var(--muted)}
.docs-reason{font-size:12px;margin-top:4px}
.docs-state{font-size:11.5px;color:var(--muted);margin-top:6px}
.docs-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.infakt-note{font-size:12px;color:var(--warn)}

/* changelog */
.changelog{margin-top:14px;border-top:1px solid var(--line);padding-top:10px}
.changelog summary{cursor:pointer;font-size:12.5px;color:var(--muted);font-weight:600}
.log{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:6px;max-height:240px;overflow:auto}
.log li{font-size:12.5px;display:flex;gap:8px;align-items:baseline;flex-wrap:wrap}
.log-ts{color:var(--muted);font-size:11px;min-width:120px}
.log-kind{font-size:10px;text-transform:uppercase;letter-spacing:.4px;padding:1px 6px;border-radius:5px;background:#f3f4f6;color:var(--muted)}
.k-status{background:#eaf1ff;color:#1f5bd6}.k-auto{background:#eef9f0;color:#0f8a4d}.k-doc{background:#f1ecff;color:#6b46c1}.k-import,.k-create{background:var(--accent-soft);color:var(--accent-ink)}.k-tracking{background:#e6f6f8;color:#0b7a8a}

/* przełączniki (switche) */
.autos{display:flex;flex-direction:column;gap:10px}
.auto-row{display:flex;align-items:center;gap:12px;font-size:13.5px;color:var(--ink)}
.switch{position:relative;display:inline-block;width:40px;height:22px;flex:0 0 40px}
.switch input{opacity:0;width:0;height:0;position:absolute}
.slider{position:absolute;inset:0;background:#cfd3dd;border-radius:999px;transition:.15s;cursor:pointer}
.slider::before{content:"";position:absolute;width:16px;height:16px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.15s}
.switch input:checked + .slider{background:var(--accent)}
.switch input:checked + .slider::before{transform:translateX(18px)}
.auto-txt{flex:1}
.tag-infakt{font-size:10px;background:#fff3e0;color:var(--warn);padding:1px 6px;border-radius:5px;margin-left:4px}

/* statystyki */
.stats-page{max-width:880px;margin:0 auto}
.stats-page h1{margin:8px 0 16px}
.invoices-page.stats-page{max-width:1180px;width:100%}
.invoices-page .card{width:100%}
.invoices-page .row-actions{flex-wrap:wrap}
.invoices-page #run-invoicing{min-width:220px}
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:6px}
.stat-k{font-size:12px;color:var(--muted)}
.stat-v{font-size:20px;font-weight:700}
.bars{display:flex;flex-direction:column;gap:8px}
.bar-row{display:grid;grid-template-columns:64px 1fr auto;gap:10px;align-items:center;font-size:12.5px}
.bar-track{background:#f0f1f6;border-radius:6px;height:16px;overflow:hidden}
.bar-fill{display:block;height:100%;background:var(--accent);border-radius:6px}
.bar-val{color:var(--muted);white-space:nowrap}
.mini-table{width:100%;border-collapse:collapse}
.mini-table th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);padding:8px 10px;border-bottom:1px solid var(--line)}
.mini-table td{padding:8px 10px;border-bottom:1px solid var(--line);font-size:13px}
.mini-table .r{text-align:right}

@media(max-width:760px){.cards{grid-template-columns:repeat(2,1fr)}.docs{flex-direction:column}}

/* v2.1: kraj nieobsługiwany */
.warn-txt{color:var(--danger)}
.act-invoice.danger{border-color:#f3c0c0;color:var(--danger);background:#fff}
.act-invoice.danger:hover{background:#fdecec}

/* ===== v3: trzy bloki danych, blokada podglądu, GUS/VIES, kolory statusów ===== */
/* kolory statusów zbliżone do BaseLinker */
.st-nowe{background:#e8f0fe;color:#1a56db;border-color:#cfe0fd}
.st-gotowe{background:#e6f7ec;color:#1f9d4d;border-color:#c9eed5}
.st-eog{background:#e6f4ff;color:#0a6ebd;border-color:#c5e3fb}
.st-wstrzymane_zwrot{background:#fff4e0;color:#c47f00;border-color:#ffe2b0}
.st-zwrot{background:#f0e9ff;color:#7338d4;border-color:#dccdfb}
.st-anulowane{background:#fdeaea;color:#cf3030;border-color:#f6cccc}
.st-blad{background:#fbe3e3;color:#9e1b1b;border-color:#f1bcbc}
.tab.on .cnt{background:rgba(255,255,255,.22)}

/* układ bloków: auto-fit (4 boksy → 2x2 / 1 kolumna na wąskich) */
.sheet-grid{grid-template-columns:repeat(auto-fit,minmax(248px,1fr))}

/* blok tylko-do-odczytu (Kupujący) */
.fs-ro{background:#fafafc}
.ro-hint{font-size:11px;color:var(--muted);margin:2px 0 8px}
.sheet input:disabled,.sheet textarea:disabled{background:#f3f4f6;cursor:not-allowed}
.sheet input:disabled{color:#566}
.ro-badge{font-size:12px;color:var(--muted);background:#f3f4f6;padding:6px 12px;border-radius:8px}

/* NIP + przycisk GUS/MF */
.nip-wrap{display:flex;gap:6px;align-items:center;margin-top:3px}
.nip-in{flex:1}
.nip-gus{white-space:nowrap;border:1px solid var(--line);border-radius:7px;padding:6px 8px;font-size:12px}
.nip-gus:hover{background:var(--accent-soft)}

/* VIES */
.vies-box{margin-top:10px;padding-top:8px;border-top:1px dashed var(--line);display:flex;flex-wrap:wrap;align-items:center;gap:10px}
.vies-check{border:1px solid var(--line);border-radius:7px;padding:5px 8px;font-size:12px}
.vies-check:hover{background:var(--accent-soft)}
.vies-result{font-size:11.5px;color:var(--muted);width:100%}
.ok-txt{color:var(--ok)}

/* ===== v4: nowy układ arkusza, Kupujący kopiowalny, waluta ===== */
.sheet-layout{display:grid;grid-template-columns:1.55fr 1fr;gap:16px;align-items:stretch}
.left-col{display:flex;flex-direction:column;gap:14px;min-width:0}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:14px;min-width:0}
.fs-items{display:flex;flex-direction:column}
@media(max-width:880px){.sheet-layout{grid-template-columns:1fr}.two-col{grid-template-columns:1fr}}

/* Kupujący — pola do kopiowania w jednym rzędzie */
.fs-buyer .copy-fields{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.cf{display:flex;flex-direction:column;align-items:flex-start;gap:2px;border:1px solid var(--line);
  border-radius:8px;background:#fff;padding:6px 11px;cursor:pointer;text-align:left;font:inherit;
  min-width:130px;transition:background .12s,border-color .12s}
.cf:hover:not(:disabled){background:var(--accent-soft);border-color:var(--accent)}
.cf:disabled{opacity:.55;cursor:default}
.cf-lab{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.cf-val{font-size:13px;color:var(--ink);max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cf.copied{background:#e7f7ee;border-color:#bfe6cd}
.cf.copied .cf-lab::after{content:" · skopiowano";color:var(--ok)}

/* waluta płatności */
.currency-row{margin-top:auto;padding-top:10px;border-top:1px solid var(--line);font-size:13px}
.currency-row .muted{font-size:11.5px}

/* ===== v5: tryb ciemny ===== */
body.theme-dark{
  --canvas:#14161d; --surface:#1b1e27; --ink:#e7e9f0; --muted:#9aa1ae;
  --line:#2a2e39; --accent:#7c6cff; --accent-soft:#262236; --accent-ink:#b3a9ff;
  --shadow:0 1px 2px rgba(0,0,0,.4),0 4px 16px rgba(0,0,0,.35);
}
body.theme-dark .mark,body.theme-dark .login-mark{color:#fff}
/* powierzchnie wcześniej zakodowane na jasno */
body.theme-dark .orders thead th{background:#20242f}
body.theme-dark .orders tbody .row:hover{background:#222633}
body.theme-dark .detail td{background:#181b23}
body.theme-dark fieldset,body.theme-dark .fs-buyer,body.theme-dark .fs-ro,body.theme-dark .cf{background:#20242f}
body.theme-dark .sheet input,body.theme-dark .sheet textarea,body.theme-dark .sheet select,
body.theme-dark .fld,body.theme-dark .fld-group,body.theme-dark .stack input,body.theme-dark .stack select,
body.theme-dark .modal-body input,body.theme-dark .modal-body textarea,body.theme-dark .nip-in,
body.theme-dark .login-form input{background:#262b37;color:var(--ink);border-color:#333a48}
body.theme-dark .sheet input:disabled,body.theme-dark .sheet textarea:disabled{background:#1a1d25;color:#aab0bd}
body.theme-dark .tab{background:#20242f}
body.theme-dark .tab.on{background:#e7e9f0;color:#14161d;border-color:#e7e9f0}
body.theme-dark .tab .cnt,body.theme-dark .src,body.theme-dark .ro-badge,body.theme-dark .log-kind,
body.theme-dark .copybox,body.theme-dark .steps code,body.theme-dark .bar-track{background:#2a2f3b}
body.theme-dark .src-manual{background:var(--accent-soft);color:var(--accent-ink)}
body.theme-dark .modal-card{background:var(--surface)}
body.theme-dark .stat-card,body.theme-dark .card,body.theme-dark .table-wrap{background:var(--surface)}
body.theme-dark .docs,body.theme-dark .sheet fieldset input{background:#262b37}
body.theme-dark .docs{background:#20242f}
body.theme-dark .empty{background:var(--surface)}
body.theme-dark.bare{background:linear-gradient(160deg,#14161d,#1b1e2b)}
body.theme-dark .iconbtn,body.theme-dark .btn-ghost{background:var(--surface)}
/* pigułki statusów — czytelne na ciemnym (przyciemnione tła) */
body.theme-dark .st-nowe{background:#16243f;color:#7fb0ff;border-color:#26466f}
body.theme-dark .st-gotowe{background:#13301f;color:#74d99b;border-color:#235e3a}
body.theme-dark .st-eog{background:#10293c;color:#6cc3f5;border-color:#1f4a66}
body.theme-dark .st-wstrzymane_zwrot{background:#3a2a10;color:#f0b860;border-color:#5e451c}
body.theme-dark .st-zwrot{background:#28203f;color:#bda3f5;border-color:#443a66}
body.theme-dark .st-anulowane{background:#3a1c1c;color:#f08a8a;border-color:#5e2c2c}
body.theme-dark .st-blad{background:#3f1818;color:#f59a9a;border-color:#612626}

/* ===== v6: nieopłacone, panel administratorski (Błąd) ===== */
.pill-unpaid{background:#fde7d2;color:#9a4a06;border:1px solid #f6cfa6;margin-left:4px}
body.theme-dark .pill-unpaid{background:#3a2710;color:#f0b060;border-color:#5e4520}
.docs-admin{border:1px solid #f1c4c4;background:#fdecec}
body.theme-dark .docs-admin{background:#2a1a1a;border-color:#5e2c2c}
.admin-tag{display:inline-block;font-size:11px;font-weight:600;color:#9e1b1b;background:#fbe3e3;border:1px solid #f1bcbc;border-radius:6px;padding:2px 8px;margin-bottom:8px}
body.theme-dark .admin-tag{background:#3f1818;color:#f59a9a;border-color:#612626}
.admin-edit{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-bottom:6px}
.admin-edit label{font-size:12px;color:var(--muted);display:flex;flex-direction:column;gap:3px}
.admin-edit input{width:120px}
.admin-edit .adm-vat{width:90px}

/* podpowiedź pod polem (np. nr przewozowy edytowalny w Błąd) */
.fld-hint{display:block;font-size:10.5px;color:var(--muted);margin-top:2px}

/* ===== v7: fulfillment, zaznaczanie grupowe, kreator korekty, statystyki ===== */
/* kolumna zaznaczenia */
.c-sel{width:34px;text-align:center}
.orders td.c-sel input,.orders th.c-sel input{cursor:pointer}

/* znacznik One Fulfillment — ciemnozielony */
.pill-ff{background:#0c5a32;color:#eafff2;border:1px solid #0a4a29;margin-left:4px}
.row.is-ff td.c-sel{box-shadow:inset 3px 0 0 #0c5a32}
.ff-note{font-weight:400;font-size:11px;color:#0c5a32}
body.theme-dark .ff-note{color:#5fd99a}
body.theme-dark .pill-ff{background:#0c5a32;color:#eafff2}

/* komentarz kupującego */
.buyer-comment{margin-top:8px;font-size:12.5px;background:#fff7e6;border:1px solid #f3dca0;border-radius:8px;padding:6px 10px}
body.theme-dark .buyer-comment{background:#332a12;border-color:#5e4f20}

/* pasek grupowy */
.bulk-bar{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  background:var(--accent-soft);border:1px solid var(--line);border-radius:10px;padding:10px 14px;margin:0 0 12px}
.bulk-bar label{display:flex;align-items:center;gap:6px;font-size:13px}
.bulk-count{font-size:13px}

/* skok do strony */
.pg-jump{margin:0 4px;padding:3px 6px;border:1px solid var(--line);border-radius:6px;background:var(--surface);color:var(--ink)}

/* statystyki — okres + rozbicie dzienne */
.stats-period{display:flex;flex-wrap:wrap;align-items:flex-end;gap:12px;margin:0 0 18px}
.stats-period label{display:flex;flex-direction:column;gap:3px;font-size:12px;color:var(--muted)}

/* kreator korekty */
.corr-table{width:100%;border-collapse:collapse;margin:10px 0;font-size:13px}
.corr-table th,.corr-table td{padding:7px 8px;border-bottom:1px solid var(--line);text-align:left}
.corr-table th:not(:first-child),.corr-table td:not(:first-child){text-align:right}
.corr-table .c-qty{width:80px;text-align:right}
.corr-sum{text-align:right;font-size:14px;margin-top:6px}
.corr-return{background:var(--accent-soft);border:1px solid var(--line);border-radius:8px;padding:6px 10px;margin-bottom:8px;font-size:12.5px}

/* ===== v8: statystyki — pionowe słupki dzienne, wybór statusów, miesiąc/rok ===== */
/* formularz okresu + statusy */
.stats-period{display:block;margin:0 0 18px}
.sp-dates{display:flex;flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:10px}
.sp-dates label{display:flex;flex-direction:column;gap:3px;font-size:12px;color:var(--muted)}
.sp-status{display:flex;flex-wrap:wrap;align-items:center;gap:6px 14px}
.sp-status .sp-lab{font-size:12px;color:var(--muted);margin-right:4px}
.sp-chk{display:inline-flex;align-items:center;gap:4px;font-size:12.5px;white-space:nowrap}
.sp-chk input{margin:0}

/* sekcja dzienna rozwijana */
.day-stats>summary{cursor:pointer;list-style:none;display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;padding:2px 0}
.day-stats>summary::-webkit-details-marker{display:none}
.day-stats>summary::before{content:"▸";color:var(--muted);font-size:12px}
.day-stats[open]>summary::before{content:"▾"}
.ds-head{font-size:16px;font-weight:650}
.ds-today{font-size:13px}
.ds-hint{font-size:12px}

/* pionowy wykres słupkowy */
.vbars{display:flex;align-items:flex-end;gap:6px;overflow-x:auto;padding:14px 2px 4px;min-height:170px}
.vbar{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:4px;min-width:26px;height:150px}
.vbar-num{font-size:11px;color:var(--muted)}
.vbar-col{width:18px;background:var(--accent);border-radius:4px 4px 0 0;transition:height .2s;min-height:3px}
.vbar-col.is-today{background:#0c5a32}
.vbar-lab{font-size:10px;color:var(--muted);transform:rotate(-45deg);transform-origin:top left;white-space:nowrap;margin-top:4px}
body.theme-dark .vbar-col{background:var(--accent)}

/* wąska rubryka miesięczna */
.card-narrow{max-width:520px}
.month-pick{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.month-pick label{display:flex;flex-direction:column;gap:3px;font-size:12px;color:var(--muted)}
.month-pick .muted{font-size:11px}

/* ===== v9: zakładka Faktury ===== */
.info-bar{background:var(--accent-soft);border:1px solid var(--line);border-radius:10px;padding:10px 14px;margin:0 0 16px;font-size:13px}

/* ── Faktury: przeglądarka ─────────────────────────────────────────────── */
.invoices-page .filters{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-bottom:14px}
.invoices-page .filters label{display:flex;flex-direction:column;font-size:.82rem;color:var(--muted);gap:4px}
.invoices-page .filters .row-actions{display:flex;gap:8px;align-items:center}
.row.two{display:flex;gap:12px}
.row.two label{flex:1}
.small{font-size:.78rem}
table.inv-table{width:100%;border-collapse:collapse;font-size:.9rem}
table.inv-table th,table.inv-table td{padding:8px 10px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
table.inv-table th.r,table.inv-table td.r{text-align:right}
table.inv-table tbody tr:hover{background:var(--accent-soft)}
.inv-actions{white-space:nowrap}
.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:.78rem;line-height:1.5;font-family:var(--mono)}
.badge.ok{background:color-mix(in srgb,var(--ok) 18%,transparent);color:var(--ok)}
.badge.warn{background:color-mix(in srgb,var(--warn) 18%,transparent);color:var(--warn)}
.badge.err{background:color-mix(in srgb,var(--danger) 18%,transparent);color:var(--danger)}
.badge.muted{background:color-mix(in srgb,var(--muted) 14%,transparent);color:var(--muted)}
.btn-link.danger{color:var(--danger)}

/* Stan ładowania na przyciskach (np. wystawianie faktury) */
.btn.loading{pointer-events:none;opacity:.85}
.btn.loading::before{content:"";display:inline-block;width:12px;height:12px;margin-right:7px;vertical-align:-1px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:btnspin .6s linear infinite}
@keyframes btnspin{to{transform:rotate(360deg)}}

/* Pasek filtrów: wyszukiwarka w osobnym rzędzie, filtry pod spodem */
.toolbar{flex-wrap:wrap}
.toolbar .search{flex:1 1 100%}

/* ── Faktury: filtry i układ tabeli ────────────────────────────────────── */
.invoices-page .filters{display:flex;flex-direction:column;gap:12px;margin-bottom:14px}
.invoices-page .filters-row{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}
.series-pick{border:1px solid var(--line);border-radius:var(--radius);padding:8px 12px;display:flex;flex-wrap:wrap;gap:10px 14px;align-items:center}
.series-pick legend{font-size:.82rem;color:var(--muted);padding:0 4px}
.series-pick .chip{display:inline-flex;align-items:center;gap:5px;font-size:.86rem;white-space:nowrap;cursor:pointer}
.table-scroll{width:100%;overflow-x:auto}
table.inv-table{min-width:880px}
table.inv-table td.nowrap,table.inv-table th.nowrap,.inv-table .nowrap{white-space:nowrap}
table.inv-table td.breakall{word-break:break-all;max-width:180px}
.pager{display:flex;gap:14px;align-items:center;justify-content:center;margin:12px 0}
.btn-link.disabled{opacity:.4;pointer-events:none}

.orders-layout{display:flex;gap:16px;align-items:flex-start}.tabs-vertical{display:flex;flex-direction:column;width:180px;flex:0 0 180px}.orders-main{flex:1;min-width:0}.toolbar-single{flex-wrap:nowrap;overflow-x:auto}.toolbar-single .search{flex:1 1 auto}.main{max-width:1600px}.bulk-bar #bulk-invoice{background:#6c4cf1;color:#fff}@media(max-width:900px){.orders-layout{flex-direction:column}.tabs-vertical{width:100%}.toolbar-single{flex-wrap:wrap}}
/* ===== v15: lista zamówień — pionowe statusy, jeden rząd filtrów, faktury masowe ===== */
.main{
  width:100%;
  max-width:1800px;
  margin:16px auto;
  padding:0 14px;
}
.orders-layout{
  display:grid;
  grid-template-columns:174px minmax(0,1fr);
  gap:14px;
  align-items:start;
}
.status-sidebar{
  position:sticky;
  top:66px;
  min-width:0;
}
.tabs-vertical{
  display:flex;
  flex-direction:column;
  gap:7px;
  width:100%;
  margin:0;
}
.tabs-vertical .tab{
  display:flex;
  width:100%;
  min-width:0;
  justify-content:space-between;
  align-items:center;
  gap:8px;
  border-radius:10px;
  padding:8px 10px;
  white-space:nowrap;
}
.tabs-vertical .tab > span:first-child{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
}
.tabs-vertical .cnt{margin-left:auto;flex:0 0 auto}
.orders-main{min-width:0;width:100%}

.orders-toolbar{
  display:block;
  margin-bottom:12px;
}
.orders-toolbar > .search{
  display:block;
  width:100%;
  min-width:0;
  margin:0 0 8px;
}
.filters-row{
  display:grid;
  grid-template-columns:minmax(276px,1.55fr) minmax(104px,.62fr) minmax(144px,.85fr) minmax(135px,.8fr) minmax(136px,.82fr) 78px auto auto;
  gap:7px;
  align-items:center;
  min-width:0;
}
.filters-row > *{min-width:0}
.filters-row .fld{
  width:100%;
  min-width:0;
  padding:7px 8px;
  font-size:13px;
  white-space:nowrap;
}
.filters-row .date-range{
  display:grid;
  grid-template-columns:auto minmax(104px,1fr) auto minmax(104px,1fr);
  gap:5px;
  align-items:center;
  min-width:0;
  padding:3px 7px;
}
.filters-row .date-range .date{
  width:100%;
  min-width:0;
  padding:4px 1px;
}
.filters-row .filter-submit,
.filters-row .filter-clear{
  white-space:nowrap;
  justify-self:start;
}
.filters-row .filter-submit{padding:7px 11px}
.filters-row .filter-clear{padding:7px 4px}

.bulk-bar{
  position:sticky;
  top:60px;
  z-index:6;
  display:flex;
  flex-wrap:nowrap;
  align-items:center;
  gap:10px;
  min-width:0;
  padding:10px 12px;
  background:linear-gradient(90deg,var(--accent-soft),color-mix(in srgb,var(--accent-soft) 78%,#fff));
  border-color:color-mix(in srgb,var(--accent) 24%,var(--line));
  box-shadow:0 2px 9px rgba(67,52,175,.08);
}
.bulk-bar .bulk-count,
.bulk-bar .bulk-status-control,
.bulk-bar .btn{white-space:nowrap;flex:0 0 auto}
.bulk-bar .bulk-status-control select{
  min-width:132px;
  max-width:170px;
  padding:5px 7px;
  border:1px solid var(--line);
  border-radius:7px;
  background:var(--surface);
  color:var(--ink);
}
.btn-bulk-invoice{
  background:var(--accent);
  color:#fff;
  border-color:var(--accent);
  font-weight:650;
}
.btn-bulk-invoice:hover:not(:disabled){background:var(--accent-ink);border-color:var(--accent-ink)}
.btn:disabled,
.btn-bulk-invoice:disabled{
  cursor:not-allowed;
  opacity:.5;
}
.bulk-hint{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  color:var(--muted);
  font-size:12px;
}
.bulk-bar .save-msg{margin-left:auto;white-space:nowrap}

.table-wrap{overflow-x:auto}
table.orders{min-width:940px}

@media(max-width:1180px){
  .orders-layout{grid-template-columns:158px minmax(0,1fr);gap:11px}
  .filters-row{
    grid-template-columns:276px 110px 150px 142px 144px 82px auto auto;
    overflow-x:auto;
    overscroll-behavior-inline:contain;
    padding-bottom:4px;
  }
  .bulk-bar{overflow-x:auto;overscroll-behavior-inline:contain}
  .bulk-hint{display:none}
  .bulk-bar .save-msg{margin-left:0}
}

@media(max-width:860px){
  .main{padding:0 10px;margin-top:12px}
  .orders-layout{display:block}
  .status-sidebar{position:static;margin-bottom:10px}
  .tabs-vertical{
    flex-direction:row;
    width:100%;
    overflow-x:auto;
    padding-bottom:3px;
    overscroll-behavior-inline:contain;
  }
  .tabs-vertical .tab{width:auto;flex:0 0 auto}
  .filters-row{display:flex;flex-wrap:nowrap;overflow-x:auto}
  .filters-row .date-range{flex:0 0 276px}
  .filters-row select{flex:0 0 140px}
  .filters-row .per-page{flex-basis:82px}
  .filters-row .filter-submit,.filters-row .filter-clear{flex:0 0 auto}
  .bulk-bar{top:0;position:relative}
}

@media(max-width:620px){
  .orders-toolbar > .search{font-size:13px}
  .bulk-bar{gap:8px;padding:9px 10px}
  .bulk-bar .bulk-status-control{display:none}
  .bulk-bar #bulk-apply{display:none}
  .btn-bulk-invoice{order:2}
  .bulk-bar #bulk-clear{order:3}
  .bulk-bar .save-msg{order:4}
}

body.theme-dark .bulk-bar{
  background:linear-gradient(90deg,var(--accent-soft),#211e31);
  box-shadow:0 2px 9px rgba(0,0,0,.24);
}

/* ===== v16: kraje multi-select, korekty/OSS i responsywne statystyki ===== */
.country-filter{
  position:relative;
  display:block;
  padding:0!important;
  min-width:135px;
  overflow:visible;
  background:var(--surface);
}
.country-filter>summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:7px;
  min-height:34px;
  padding:7px 9px;
  list-style:none;
  cursor:pointer;
  color:var(--ink);
  white-space:nowrap;
}
.country-filter>summary::-webkit-details-marker{display:none}
.country-filter>summary::after{content:"▾";font-size:10px;color:var(--muted)}
.country-filter[open]>summary::after{content:"▴"}
.country-filter>summary span{color:var(--muted)}
.country-filter>summary b{max-width:72px;overflow:hidden;text-overflow:ellipsis;font-size:12px}
.country-menu{
  position:absolute;
  z-index:30;
  top:calc(100% + 6px);
  left:0;
  width:220px;
  padding:10px;
  border:1px solid var(--line);
  border-radius:10px;
  background:var(--surface);
  box-shadow:0 12px 28px rgba(20,22,35,.16);
}
.country-menu-title{display:block;margin:0 0 7px;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.35px}
.country-check{display:flex;align-items:center;gap:8px;padding:7px 6px;border-radius:7px;font-size:12.5px;cursor:pointer}
.country-check:hover{background:var(--accent-soft)}
.country-check input{width:auto;margin:0}
.country-all{margin-top:5px;padding:5px 6px}

.stats-page.stats-responsive{
  width:100%;
  max-width:1440px;
  margin:0 auto;
}
.stats-title-row{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:14px}
.stats-title-row h1{margin:7px 0 2px}
.stats-subtitle{margin:0;color:var(--muted);font-size:13px}
.stats-period.card{margin-bottom:14px;padding:14px 16px}
.stats-period-main{
  display:grid;
  grid-template-columns:minmax(150px,190px) minmax(145px,180px) minmax(145px,180px) minmax(230px,1fr);
  gap:10px;
  align-items:end;
}
.stats-field{display:flex;flex-direction:column;gap:4px;min-width:0;font-size:11px;font-weight:650;color:var(--muted);text-transform:uppercase;letter-spacing:.35px}
.stats-field input,.stats-field select{
  width:100%;
  min-width:0;
  height:36px;
  padding:7px 9px;
  border:1px solid var(--line);
  border-radius:8px;
  background:var(--surface);
  color:var(--ink);
  font:inherit;
  font-size:13px;
  text-transform:none;
  letter-spacing:0;
}
.stats-period-actions{display:flex;align-items:center;gap:8px;min-width:0;padding-bottom:1px}
.stats-status-filter{margin:13px 0 0;padding:10px 12px;border:1px solid var(--line);border-radius:9px}
.stats-status-filter legend{padding:0 6px;font-size:11px;font-weight:650;color:var(--muted)}
.stats-status-list{display:flex;align-items:center;flex-wrap:wrap;gap:7px 15px}
.stats-status-list .sp-chk{margin:0;padding:3px 0}
.stats-kpis{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.stats-kpis .stat-card{min-width:0;min-height:112px;justify-content:center}
.stat-note{font-size:11.5px;color:var(--muted)}
.stats-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:12px}
.stats-section-head h2{margin:0;font-size:15px}
.stats-section-head p{margin:3px 0 0;font-size:12px}
.stats-today{flex:0 0 auto;padding:5px 9px;border-radius:999px;background:var(--accent-soft);font-size:12px;color:var(--accent-ink);white-space:nowrap}
.stats-chart-card{overflow:hidden}
.stats-chart-card .vbars{
  width:100%;
  min-height:220px;
  padding:18px 8px 22px;
  gap:8px;
  scroll-snap-type:x proximity;
}
.stats-chart-card .vbar{min-width:30px;height:178px;scroll-snap-align:start}
.stats-chart-card .vbar-col{width:20px}
.stats-grid-two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.stats-table-card{min-width:0;margin-bottom:14px}
.stats-table-scroll{width:100%;overflow-x:auto}
.stats-table-scroll .mini-table{min-width:430px}
.stats-footnote{margin:10px 0 0;font-size:11.5px}
.stats-month-card{margin-bottom:20px}
.stats-month-row{color:inherit;text-decoration:none;border-radius:7px;padding:5px 7px;margin:0 -7px}
.stats-month-row:hover{background:var(--accent-soft)}
.stats-empty{padding:24px}

@media(max-width:1180px){
  .country-filter[open]{min-width:220px}
  .country-menu{
    position:static;
    width:100%;
    margin-top:0;
    border:0;
    border-top:1px solid var(--line);
    border-radius:0 0 8px 8px;
    box-shadow:none;
  }
}

@media(max-width:1050px){
  .stats-period-main{grid-template-columns:repeat(3,minmax(0,1fr))}
  .stats-period-actions{grid-column:1/-1}
  .stats-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:760px){
  .stats-page.stats-responsive{max-width:none}
  .stats-title-row{align-items:flex-start}
  .stats-period.card{padding:12px}
  .stats-period-main{grid-template-columns:1fr 1fr}
  .stats-period-main .stats-field:first-child{grid-column:1/-1}
  .stats-period-actions{grid-column:1/-1;flex-wrap:wrap}
  .stats-grid-two{grid-template-columns:1fr}
  .stats-section-head{align-items:flex-start;flex-direction:column;gap:7px}
  .stats-today{white-space:normal}
  .stats-chart-card .vbars{min-height:205px}
}
@media(max-width:480px){
  .stats-period-main{grid-template-columns:1fr}
  .stats-period-main .stats-field:first-child,.stats-period-actions{grid-column:auto}
  .stats-kpis{grid-template-columns:1fr}
  .stats-kpis .stat-card{min-height:94px}
  .stats-status-list{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .bar-row{grid-template-columns:58px minmax(90px,1fr);gap:8px}
  .bar-row .bar-val{grid-column:1/-1;text-align:right;font-size:11px}
}
body.theme-dark .country-menu{box-shadow:0 14px 30px rgba(0,0,0,.42)}

/* ── Przeglądarka faktur: czytelny, szeroki i responsywny układ ───────── */
.invoices-page{
  width:100%;
  max-width:1540px;
  margin:0 auto;
  min-width:0;
}
.invoices-page > h1{margin:10px 0 18px;font-size:clamp(25px,2.2vw,34px)}
.invoices-page > .card{width:100%;min-width:0;padding:20px;margin-bottom:16px}
.invoices-page > .card > h2{margin:0 0 16px;font-size:17px}
.invoice-filters{display:flex;flex-direction:column;gap:14px;min-width:0}
.invoice-series{
  min-width:0;
  margin:0;
  padding:10px 12px 12px;
  border:1px solid var(--line);
  border-radius:11px;
  background:color-mix(in srgb,var(--surface) 95%,var(--accent-soft));
}
.invoice-series legend{padding:0 6px;font-size:11px;font-weight:750;color:var(--muted);letter-spacing:.35px;text-transform:uppercase}
.invoice-series-options{display:flex;flex-wrap:wrap;gap:8px}
.invoice-series-chip{
  display:inline-flex;
  align-items:center;
  gap:7px;
  min-height:36px;
  margin:0;
  padding:7px 10px;
  border:1px solid var(--line);
  border-radius:9px;
  background:var(--surface);
  color:var(--ink);
  font-size:12.5px;
  font-weight:650;
  cursor:pointer;
  transition:border-color .15s ease,background .15s ease,transform .15s ease;
}
.invoice-series-chip:hover{border-color:color-mix(in srgb,var(--accent) 45%,var(--line));transform:translateY(-1px)}
.invoice-series-chip input{width:15px;height:15px;margin:0;accent-color:var(--accent)}
.invoice-series-chip:has(input:checked){border-color:var(--accent);background:var(--accent-soft);color:var(--accent-ink)}
.invoice-series-help{display:block;margin-top:8px;font-size:11.5px;color:var(--muted)}
.invoice-filter-row{
  display:grid;
  grid-template-columns:minmax(250px,1.7fr) minmax(125px,.65fr) minmax(115px,.58fr) minmax(120px,.62fr) minmax(180px,auto);
  gap:11px;
  align-items:end;
  min-width:0;
}
.invoice-filter-row label{
  display:flex;
  flex-direction:column;
  gap:5px;
  min-width:0;
  margin:0;
  color:var(--muted);
  font-size:11px;
  font-weight:750;
  letter-spacing:.3px;
  text-transform:uppercase;
}
.invoice-filter-row input,.invoice-filter-row select{
  width:100%;
  min-width:0;
  height:40px;
  padding:8px 10px;
  border:1px solid var(--line);
  border-radius:9px;
  background:var(--surface);
  color:var(--ink);
  font:inherit;
  font-size:13px;
  letter-spacing:0;
  text-transform:none;
}
.invoice-filter-row input:focus,.invoice-filter-row select:focus{outline:2px solid color-mix(in srgb,var(--accent) 25%,transparent);border-color:var(--accent)}
.invoice-filter-number small{min-height:14px;color:var(--muted);font-size:10.5px;font-weight:500;letter-spacing:0;text-transform:none}
.invoice-filter-actions{display:flex;align-items:center;justify-content:flex-end;gap:9px;min-height:40px;padding-bottom:14px;white-space:nowrap}
.invoice-filter-actions .btn{min-height:40px;display:inline-flex;align-items:center;justify-content:center}
.invoice-filter-state{min-width:0;color:var(--muted);font-size:11.5px;white-space:normal}
.invoices-page .table-scroll{
  width:100%;
  overflow-x:auto;
  margin-top:10px;
  border:1px solid var(--line);
  border-radius:12px;
  background:var(--surface);
  -webkit-overflow-scrolling:touch;
}
.invoices-page table.inv-table{width:100%;min-width:1080px;border-collapse:separate;border-spacing:0;margin:0}
.invoices-page table.inv-table th{
  position:sticky;
  top:0;
  z-index:1;
  padding:11px 10px;
  border-bottom:1px solid var(--line);
  background:color-mix(in srgb,var(--surface) 92%,var(--accent-soft));
  color:var(--muted);
  font-size:11px;
  font-weight:800;
  letter-spacing:.3px;
  text-transform:uppercase;
  white-space:nowrap;
}
.invoice-sort{display:inline-flex;align-items:center;gap:5px;color:inherit;text-decoration:none;white-space:nowrap}
.invoice-sort:hover{color:var(--accent)}
.invoice-sort.is-active{color:var(--ink)}
.invoice-sort span{font-size:13px;line-height:1}
.invoices-page table.inv-table td{padding:11px 10px;border-bottom:1px solid var(--line);vertical-align:middle;font-size:12.5px}
.invoices-page table.inv-table tbody tr:last-child td{border-bottom:0}
.invoices-page table.inv-table tbody tr:hover td{background:color-mix(in srgb,var(--accent-soft) 38%,transparent)}
.inv-actions{display:flex;align-items:center;gap:7px}
.btn-invoice-pdf{
  min-width:68px;
  min-height:40px;
  padding:9px 16px;
  border-radius:9px;
  font-size:13px;
  font-weight:800;
  letter-spacing:.25px;
  text-decoration:none;
}
.invoice-delete-lock{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;background:var(--accent-soft);font-size:15px;cursor:not-allowed}
.invoices-page .pager{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:14px}

@media(max-width:1080px){
  .invoice-filter-row{grid-template-columns:minmax(220px,1.4fr) repeat(3,minmax(110px,.65fr))}
  .invoice-filter-actions{grid-column:1/-1;justify-content:flex-start;padding-bottom:0}
}
@media(max-width:760px){
  .invoices-page > .card{padding:14px}
  .invoice-filter-row{grid-template-columns:1fr 1fr}
  .invoice-filter-number{grid-column:1/-1}
  .invoice-filter-actions{grid-column:1/-1}
  .invoice-series-options{display:grid;grid-template-columns:1fr 1fr}
  .invoice-series-chip{width:100%}
  .invoices-page table.inv-table{min-width:960px}
}
@media(max-width:480px){
  .invoice-filter-row{grid-template-columns:1fr}
  .invoice-filter-number,.invoice-filter-actions{grid-column:auto}
  .invoice-filter-actions{align-items:flex-start;flex-direction:column;white-space:normal}
  .invoice-filter-actions .btn{width:100%}
  .invoice-series-options{grid-template-columns:1fr}
  .invoices-page > h1{font-size:25px}
}

/* Mapowanie płatności inFakt */
.payment-map-box{padding:12px 14px;border:1px solid var(--line);border-radius:11px;background:color-mix(in srgb,var(--surface) 92%,var(--accent-soft));font-size:12px}
.payment-map-grid{display:grid;grid-template-columns:minmax(220px,1fr) minmax(120px,.45fr);gap:7px 16px;margin-top:9px;align-items:center}
.payment-map-grid span{color:var(--muted);font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
.payment-map-grid strong{font-weight:750}
@media(max-width:620px){.payment-map-grid{grid-template-columns:1fr}.payment-map-grid strong{margin-bottom:6px}}


/* ===== v22: stabilna tabela faktur i widok mobilny ===== */
.invoices-page .table-scroll{
  width:100%;
  overflow-x:auto;
  border:1px solid var(--line);
  border-radius:13px;
  background:var(--surface);
}
table.inv-table{
  width:100%;
  min-width:1080px;
  table-layout:fixed;
  border-collapse:collapse;
  margin:0;
}
table.inv-table col.inv-col-number{width:14%}
table.inv-table col.inv-col-order{width:16%}
table.inv-table col.inv-col-buyer{width:16%}
table.inv-table col.inv-col-gross{width:11%}
table.inv-table col.inv-col-date{width:9%}
table.inv-table col.inv-col-correction{width:7%}
table.inv-table col.inv-col-ksef{width:10%}
table.inv-table col.inv-col-allegro{width:7%}
table.inv-table col.inv-col-actions{width:10%}
table.inv-table th,
table.inv-table td{
  box-sizing:border-box;
  padding:12px 10px;
  border-bottom:1px solid var(--line);
  vertical-align:middle;
  line-height:1.35;
}
table.inv-table tbody tr:last-child td{border-bottom:0}
table.inv-table td:nth-child(2),
table.inv-table td:nth-child(3){overflow-wrap:anywhere;word-break:normal}
table.inv-table td.r{text-align:right}
.inv-actions-cell{white-space:nowrap}
.inv-actions{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:8px;
  min-height:38px;
  white-space:nowrap;
}
.btn-invoice-pdf{min-width:68px;min-height:38px;display:inline-flex;align-items:center;justify-content:center;font-weight:800}
.invoice-delete-lock{display:inline-flex;align-items:center;justify-content:center;min-width:32px;min-height:32px}

@media (max-width:900px){
  .invoices-page > .card{padding:14px}
  .invoices-page .table-scroll{overflow:visible;border:0;background:transparent}
  table.inv-table,table.inv-table tbody,table.inv-table tr,table.inv-table td{display:block;width:100%}
  table.inv-table{min-width:0;border-collapse:separate;border-spacing:0;background:transparent}
  table.inv-table colgroup,table.inv-table thead{display:none}
  table.inv-table tbody{display:grid;gap:12px}
  table.inv-table tbody tr{
    display:grid;
    grid-template-columns:minmax(0,1fr) minmax(0,1fr);
    gap:0;
    overflow:hidden;
    border:1px solid var(--line);
    border-radius:13px;
    background:var(--surface);
    box-shadow:0 3px 12px color-mix(in srgb,var(--ink) 7%,transparent);
  }
  table.inv-table tbody tr:hover{background:var(--surface)}
  table.inv-table td{
    display:grid;
    grid-template-columns:minmax(92px,35%) minmax(0,1fr);
    gap:10px;
    align-items:start;
    min-width:0;
    padding:10px 12px;
    border-bottom:1px solid var(--line);
    text-align:left!important;
    white-space:normal!important;
  }
  table.inv-table td::before{
    content:attr(data-label);
    color:var(--muted);
    font-size:11px;
    font-weight:800;
    letter-spacing:.03em;
    text-transform:uppercase;
  }
  table.inv-table td:nth-last-child(-n+2){border-bottom:0}
  table.inv-table td.inv-actions-cell{grid-column:1/-1;border-top:1px solid var(--line)}
  table.inv-table td.inv-actions-cell::before{align-self:center}
  .inv-actions{flex-wrap:wrap;justify-content:flex-start}
}
@media (max-width:620px){
  table.inv-table tbody tr{grid-template-columns:1fr}
  table.inv-table td:nth-last-child(-n+2){border-bottom:1px solid var(--line)}
  table.inv-table td:last-child{border-bottom:0}
  table.inv-table td.inv-actions-cell{grid-column:auto}
  .invoice-filter-row{grid-template-columns:1fr!important}
  .invoice-filter-actions{justify-content:flex-start}
}

/* ===== v23: operacje masowe faktur, Zwroty, Logi live i czytelność KSeF ===== */
.main{max-width:1580px}
.main:has(.page-wide),
.main:has(.invoices-wide){
  max-width:1580px;
}
.page-wide{width:100%;max-width:1540px;margin:0 auto;min-width:0}
.page-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin:8px 0 16px}
.page-title-row h1{margin:0 0 4px;font-size:clamp(25px,2.2vw,34px)}
.page-title-row p{margin:0}

/* Filtry faktur mają sześć pól + akcje i zawijają się bez ściskania. */
.invoice-filter-row{
  grid-template-columns:minmax(230px,1.5fr) repeat(5,minmax(118px,.72fr)) minmax(150px,auto);
}
.invoice-filter-actions{padding-bottom:14px}
.invoice-bulk-bar{
  display:flex;align-items:center;flex-wrap:wrap;gap:10px;
  margin:12px 0;padding:10px 12px;border:1px solid var(--line);border-radius:11px;
  background:color-mix(in srgb,var(--accent-soft) 55%,var(--surface));
}
.invoice-bulk-bar .chk{display:inline-flex;align-items:center;gap:7px;margin:0;font-weight:650}
.invoice-bulk-bar input{width:16px;height:16px;margin:0;accent-color:var(--accent)}
.invoice-bulk-bar .save-msg{margin-left:auto}

.invoices-page table.inv-table{min-width:1260px;table-layout:fixed}
table.inv-table col.inv-col-select{width:42px}
table.inv-table col.inv-col-number{width:12%}
table.inv-table col.inv-col-order{width:14%}
table.inv-table col.inv-col-buyer{width:13%}
table.inv-table col.inv-col-gross{width:9%}
table.inv-table col.inv-col-date{width:8%}
table.inv-table col.inv-col-correction{width:7%}
table.inv-table col.inv-col-ksef{width:13%}
table.inv-table col.inv-col-allegro{width:9%}
table.inv-table col.inv-col-actions{width:12%}
table.inv-table .c-sel{text-align:center;padding-left:8px;padding-right:8px}
table.inv-table .c-sel input{width:17px;height:17px;margin:0;accent-color:var(--accent)}
.btn-invoice-push{
  min-height:36px;margin-left:7px;padding:7px 11px;font-weight:750;
  border-color:color-mix(in srgb,var(--accent) 45%,var(--line));color:var(--accent-ink);
}
.btn-invoice-push:hover{background:var(--accent-soft);border-color:var(--accent)}
.ksef-code{
  display:inline-block;max-width:100%;padding:6px 9px;border-radius:9px;
  font-family:var(--mono);font-size:11px;line-height:1.45;white-space:normal;
  overflow-wrap:anywhere;word-break:break-word;text-align:left;
}
.inv-actions .btn-link.danger{min-width:34px;min-height:34px;display:inline-flex;align-items:center;justify-content:center;font-size:17px}

/* Zwroty */
.return-filters{display:flex;align-items:end;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.return-filters label{display:flex;flex-direction:column;gap:5px;color:var(--muted);font-size:11px;font-weight:750;text-transform:uppercase;letter-spacing:.3px}
.return-filters input{height:38px;padding:7px 10px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--ink);font:inherit}
.returns-table,.logs-table{width:100%;min-width:980px;border-collapse:collapse}
.returns-table th,.logs-table th{padding:11px 10px;border-bottom:1px solid var(--line);text-align:left;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.35px}
.returns-table td,.logs-table td{padding:11px 10px;border-bottom:1px solid var(--line);vertical-align:middle}
.returns-table tr:last-child td,.logs-table tr:last-child td{border-bottom:0}
.return-status{max-width:220px;white-space:normal;overflow-wrap:anywhere}

/* Logi live */
.logs-card{padding:0;overflow:hidden}
.logs-card .table-scroll{border:0;border-radius:0;margin:0}
.logs-table{min-width:1080px}
.logs-table th:nth-child(1){width:155px}.logs-table th:nth-child(2){width:90px}.logs-table th:nth-child(3){width:150px}.logs-table th:nth-child(4){width:130px}.logs-table th:nth-child(5){width:130px}
.log-message{white-space:normal;overflow-wrap:anywhere}
.log-context{margin-top:5px;color:var(--muted);font-size:10.5px;line-height:1.4;white-space:normal;overflow-wrap:anywhere}
.log-level{text-transform:uppercase;font-size:10.5px;letter-spacing:.35px}
.log-error .log-level{background:#fde8e8;color:#a92323}
.log-warning .log-level{background:#fff1d9;color:#985d00}
.log-info .log-level{background:#e8f1ff;color:#245ea7}
body.theme-dark .log-error .log-level{background:#4a252b;color:#ffadb6}
body.theme-dark .log-warning .log-level{background:#45351f;color:#ffd38c}
body.theme-dark .log-info .log-level{background:#23364e;color:#a9cffc}

@media(max-width:1320px){
  .invoice-filter-row{grid-template-columns:minmax(220px,1.4fr) repeat(3,minmax(120px,.75fr))}
  .invoice-filter-actions{grid-column:auto;padding-bottom:0;justify-content:flex-start}
}
@media(max-width:900px){
  .page-title-row{flex-direction:column}
  .invoice-bulk-bar .save-msg{width:100%;margin-left:0}
  table.inv-table .c-sel{display:grid}
  table.inv-table td.c-sel::before{content:"Wybór"}
  .ksef-code{max-width:380px}
}
@media(max-width:760px){
  .return-filters>*{flex:1 1 150px}
  .return-filters .btn{min-height:38px;display:inline-flex;align-items:center;justify-content:center}
}
@media(max-width:620px){
  .invoice-bulk-bar{align-items:stretch}
  .invoice-bulk-bar .btn{flex:1 1 100%;justify-content:center}
  .invoice-bulk-bar .chk,.invoice-bulk-bar strong{flex:1 1 auto}
}


/* ===== v24: szersza lista zamówień, skróty i czytelniejsze One FF ===== */
.main{
  max-width:1800px;
}
.main:has(.orders-layout){
  max-width:1800px;
  padding-left:12px;
  padding-right:12px;
}
.orders-shortcuts{
  display:grid;
  grid-template-columns:repeat(4,minmax(92px,118px));
  gap:8px;
  width:max-content;
  max-width:100%;
  margin:0 0 10px;
}
.orders-shortcut{
  min-height:44px;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:8px;
  padding:8px 10px;
  border:1px solid var(--line);
  border-radius:10px;
  background:var(--surface);
  color:var(--ink);
  text-decoration:none;
  font-size:12px;
  font-weight:750;
  box-shadow:0 2px 8px rgba(16,24,40,.05);
  transition:border-color .15s ease,background .15s ease,transform .15s ease;
}
.orders-shortcut:hover{
  border-color:color-mix(in srgb,var(--accent) 55%,var(--line));
  background:var(--accent-soft);
  transform:translateY(-1px);
}
.orders-shortcut-icon{
  width:25px;
  height:25px;
  flex:0 0 25px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  background:var(--accent-soft);
  color:var(--accent-ink);
  font-size:15px;
  font-weight:850;
}
.orders-layout{
  grid-template-columns:184px minmax(0,1fr);
  gap:12px;
}
table.orders .c-status{width:148px}
.order-status-stack{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:5px;
}
.pill-ff{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin-left:0;
  padding:3px 8px;
  border:1px solid #178d53;
  border-radius:999px;
  background:#0c6a3b;
  color:#f2fff7;
  font-size:10px;
  font-weight:850;
  letter-spacing:.45px;
  line-height:1.2;
  text-transform:uppercase;
  box-shadow:0 0 0 1px rgba(41,211,124,.08),0 2px 7px rgba(0,80,43,.18);
}
.pill-ff::before{
  content:"";
  width:7px;
  height:7px;
  flex:0 0 7px;
  border-radius:50%;
  background:#77f1ae;
  box-shadow:0 0 0 3px rgba(119,241,174,.16);
}
.row.is-ff td.c-sel{
  box-shadow:inset 4px 0 0 #16a864;
}
body.theme-dark .orders-shortcut{
  box-shadow:0 2px 8px rgba(0,0,0,.2);
}
body.theme-dark .pill-ff{
  border-color:#1a9b5b;
  background:#0b5e36;
  color:#edfff5;
}
@media(max-width:1180px){
  .orders-layout{grid-template-columns:166px minmax(0,1fr)}
  .orders-shortcuts{grid-template-columns:repeat(4,minmax(86px,108px))}
}
@media(max-width:860px){
  .orders-shortcuts{
    width:100%;
    grid-template-columns:repeat(4,minmax(0,1fr));
  }
  .orders-shortcut{justify-content:center}
}
@media(max-width:620px){
  .orders-shortcuts{grid-template-columns:repeat(2,minmax(0,1fr))}
  .orders-shortcut{justify-content:flex-start}
}


/* ===== v25: układ boczny zamówień i czytelniejsze ikonki górne ===== */
.topbar .actions{gap:9px}
.iconbtn{
  width:38px;
  height:38px;
  border-radius:11px;
  border-color:color-mix(in srgb,var(--line) 68%,transparent);
  background:linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface) 85%,var(--accent-soft)));
  color:var(--accent-ink);
  font-size:17px;
  font-weight:800;
  box-shadow:0 4px 12px rgba(32,34,53,.08);
  transition:transform .15s ease,border-color .15s ease,background .15s ease,box-shadow .15s ease;
}
.iconbtn:hover{
  transform:translateY(-1px);
  border-color:color-mix(in srgb,var(--accent) 40%,var(--line));
  background:var(--accent-soft);
  box-shadow:0 6px 16px rgba(32,34,53,.12);
}
body.theme-dark .iconbtn{
  border-color:#30374a;
  background:linear-gradient(180deg,#1b2030,#171c2b);
  color:#d8dcff;
  box-shadow:0 6px 16px rgba(0,0,0,.26);
}
body.theme-dark .iconbtn:hover{
  border-color:#4b56a3;
  background:#202744;
}

.orders-layout{
  grid-template-columns:244px minmax(0,1fr);
  gap:14px;
}
.status-sidebar{
  top:58px;
}
.orders-shortcuts{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
  width:100%;
  margin:0;
}
.orders-shortcut{
  min-height:46px;
  padding:8px 10px;
  justify-content:flex-start;
}
.orders-shortcut-icon{
  width:24px;
  height:24px;
  flex:0 0 24px;
  border-radius:7px;
}
.status-sidebar .tabs-vertical{
  width:100%;
  margin-top:12px;
}
.status-sidebar .tab{
  min-height:44px;
  padding:9px 12px;
}
.status-sidebar .tab .cnt{
  min-width:30px;
  padding:3px 9px;
  justify-content:center;
  font-size:12px;
  font-weight:800;
  letter-spacing:.02em;
  color:#d8ecff;
  background:linear-gradient(180deg,#2d3850,#1c2437);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.06),0 0 14px rgba(91,78,229,.18);
}
.status-sidebar .tab.on .cnt{
  color:#fff;
  background:linear-gradient(180deg,#6e7cff,#5660eb);
  box-shadow:0 0 14px rgba(102,118,255,.38);
}
.tab.st-nowe .cnt{background:linear-gradient(180deg,#264785,#1a2d56);color:#8fc2ff}
.tab.st-eog .cnt{background:linear-gradient(180deg,#194d76,#11334f);color:#7ccfff}
.tab.st-gotowe .cnt{background:linear-gradient(180deg,#1a5b34,#103a21);color:#76f8a2}
.tab.st-wstrzymane_zwrot .cnt{background:linear-gradient(180deg,#654000,#482d00);color:#ffc96d}
.tab.st-zwrot .cnt{background:linear-gradient(180deg,#48306e,#2c1d45);color:#d0a8ff}
.tab.st-anulowane .cnt{background:linear-gradient(180deg,#6a2323,#451515);color:#ff9e9e}
.tab.st-blad .cnt{background:linear-gradient(180deg,#7f1717,#520e0e);color:#ff8b8b}

.pill-ff{
  gap:7px;
  padding:4px 10px;
  font-size:11px;
  letter-spacing:.55px;
  border-color:#1da861;
  background:linear-gradient(180deg,#0f7d47,#0b5e36);
  color:#f4fff8;
  box-shadow:0 0 0 1px rgba(59,221,141,.08),0 4px 10px rgba(0,66,37,.22);
}
.pill-ff::before{
  width:8px;
  height:8px;
  flex:0 0 8px;
  background:#8cffbd;
  box-shadow:0 0 0 4px rgba(140,255,189,.18);
}

@media(max-width:1320px){
  .orders-layout{grid-template-columns:232px minmax(0,1fr)}
}
@media(max-width:1180px){
  .orders-layout{grid-template-columns:220px minmax(0,1fr)}
}
@media(max-width:860px){
  .orders-layout{display:block}
  .status-sidebar{position:static;margin-bottom:10px}
  .orders-shortcuts{margin-bottom:10px}
  .status-sidebar .tabs-vertical{margin-top:0}
}
@media(max-width:620px){
  .orders-shortcuts{grid-template-columns:repeat(2,minmax(0,1fr))}
  .orders-shortcut{min-height:44px;padding:8px 9px;font-size:12px}
  .status-sidebar .tab{min-height:42px}
}
