/* =========================================================
   APP.CSS v7
========================================================= */

/* ========== 01 Tokens ========== */
:root{
  --brand-logo-url:url("assets/plaiuchy.png");
  --fg:#0b1220;
  --muted:#6b7280;
  --bg:#f6f7fb;
  --bg-soft:#f6f7fb;
  --card:#fff;
  --border:rgba(15,23,42,.14);
  --bar:#0f1a2e;
  --primary:#0f172a;
  --primary-strong:#1e293b;
  --danger:#be123c;
  --danger-strong:#9f1239;
  --secondary:#fff;
  --secondary-strong:#f8fafc;
  --fld-h:42px;
  --fld-br:10px;
  --fld-bc:rgba(15,23,42,.14);
  --fld-bc-hover:rgba(15,23,42,.22);
  --fld-bc-focus:#2563eb;
  --fld-bg:#f8fafc;
  --fld-bg-disabled:#f5f7fa;
  --fld-txt:#111827;
  --fld-ph:#9aa3af;
  --ring:0 0 0 4px rgba(37,99,235,.15);
  --page-max:1260px;
}

/* ========== 02 Reset i typografia ========== */
html,body{height:100%}
*{box-sizing:border-box}
body{
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  margin:0;
  background:var(--bg);
  color:var(--fg);
  line-height:1.35;
  min-height:100vh;
  display:flex;
  flex-direction:column;
}
h1{margin:0;font-size:clamp(20px,2.2vw,30px);font-weight:700}
h2{font-size:20px;margin:0 0 14px}
h3{font-size:16px;margin:0 0 10px}
h4{margin:0}
a{color:inherit;text-decoration:none}

/* ========== 03 Layout ========== */
.wrap,.container{
  width:100%;
  max-width:var(--page-max);
  margin:0 auto;
  padding:0 16px;
}

header.topbar{
  background:#0f1a2e;
  border-bottom:1px solid rgba(255,255,255,.12);
  position:sticky;
  top:0;
  z-index:20;
}
.topbar .wrap{
  min-height:68px;
  padding-top:12px;
  padding-bottom:12px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.topbar h1{
  font-size:clamp(24px,2.5vw,36px);
  line-height:1.15;
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
  color:#fff;
}
.topbar .muted{color:rgba(255,255,255,.72)}
.brand-logo,
.brand-fallback{
  width:40px;
  height:40px;
  flex:0 0 auto;
}
.brand-logo{
  object-fit:contain;
  border-radius:10px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  padding:5px;
  box-shadow:0 4px 12px rgba(2,6,23,.18);
}
.brand-fallback{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:10px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 4px 12px rgba(2,6,23,.18);
  font-size:9px;
  font-weight:800;
  letter-spacing:.08em;
  color:#fff;
}

nav.nav{display:flex;gap:8px;flex-wrap:wrap}
.topbar .nav .btn-logout{
  margin-left:auto;
  order:99;
}
.topbar .nav .btn-queue{
  white-space:nowrap;
  border-color:#d1d5db;
  color:#0f172a;
}

/* Strona magazynu: stała 1 linia nawigacji na desktopie */
@media (min-width:861px){
  body.page-magazyn .topbar h1{
    font-size:clamp(22px,2.1vw,30px);
    white-space:nowrap;
    flex:0 0 auto;
  }
  body.page-magazyn nav.nav{
    flex:1 1 auto;
    min-width:0;
    justify-content:flex-end;
    flex-wrap:nowrap;
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:thin;
  }
  body.page-magazyn nav.nav .btn{
    flex:0 0 auto;
    white-space:nowrap;
    min-height:36px;
    padding:7px 11px;
    font-size:14px;
  }
  body.page-magazyn .topbar .nav .btn-logout{
    margin-left:0;
    order:0;
  }
}

.nav-toggle{
  display:none;
  width:44px;
  height:44px;
  border:1px solid rgba(255,255,255,.24);
  border-radius:10px;
  background:rgba(255,255,255,.08);
  color:#fff;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.nav-toggle .bars{
  width:20px;
  height:14px;
  position:relative;
}
.nav-toggle .bars::before,
.nav-toggle .bars::after,
.nav-toggle .bars span{
  content:"";
  position:absolute;
  left:0;
  width:100%;
  height:2px;
  background:currentColor;
  border-radius:1px;
  transition:transform .2s ease,opacity .2s ease,top .2s ease;
}
.nav-toggle .bars::before{top:0}
.nav-toggle .bars span{top:6px}
.nav-toggle .bars::after{top:12px}
body.is-nav-open .nav-toggle .bars::before{top:6px;transform:rotate(45deg)}
body.is-nav-open .nav-toggle .bars span{opacity:0}
body.is-nav-open .nav-toggle .bars::after{top:6px;transform:rotate(-45deg)}

footer.foot{
  margin-top:auto;
  background:var(--bar);
  border-top:1px solid var(--border);
}
.foot .wrap{
  font-size:12px;
  color:rgba(255,255,255,.72);
  padding-top:12px;
  padding-bottom:12px;
}

main{
  width:100%;
  max-width:var(--page-max);
  margin:24px auto;
  padding:0 16px 40px;
}

/* ========== 04 Komponenty ========== */
.card{
  background:var(--card);
  border-radius:12px;
  padding:16px;
  margin-bottom:24px;
  box-shadow:0 8px 20px rgba(16,24,40,.06);
  border:1px solid var(--border);
}

/* uniwersalny kontener pola */
.item{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-bottom:8px;
}
.item .label{font-size:14px}
.item .unit{
  background:#f0f2f5;
  padding:4px 10px;
  border-radius:999px;
  font-size:12px;
  text-align:center;
  border:1px solid var(--border);
}

/* układ pozycji prac */
#instalacyjne .item,
#budowlane .item{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto minmax(110px,130px);
  gap:10px;
  align-items:center;
  margin-bottom:6px;
  padding:4px;
}
#instalacyjne .item:nth-child(even),
#budowlane .item:nth-child(even){
  background:#fafafa;
  border-radius:6px;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:9px 14px;
  border:1px solid transparent;
  border-radius:10px;
  font-weight:600;
  cursor:pointer;
  line-height:1.1;
  position:relative;
  overflow:hidden;
  background-repeat:no-repeat;
  background-size:220% 220%;
  background-position:100% 100%;
  transition:
    background-color .36s cubic-bezier(.22,.61,.36,1),
    border-color .36s cubic-bezier(.22,.61,.36,1),
    box-shadow .36s cubic-bezier(.22,.61,.36,1),
    transform .36s cubic-bezier(.22,.61,.36,1),
    color .36s cubic-bezier(.22,.61,.36,1),
    background-position .46s cubic-bezier(.22,.61,.36,1);
}
.btn:active{transform:translateY(0)}
.btn:focus-visible{outline:2px solid #6f86ac;outline-offset:2px}
.btn-primary{
  background-color:var(--primary);
  background-image:linear-gradient(120deg,rgba(255,255,255,.18),rgba(255,255,255,0) 42%);
  color:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.22);
}
.btn-secondary{
  background-color:var(--secondary);
  background-image:linear-gradient(120deg,rgba(255,255,255,.92),rgba(255,255,255,0) 46%);
  color:var(--fg);
  border-color:var(--border);
  box-shadow:0 1px 2px rgba(15,23,42,.08);
}
.btn-danger{
  background-color:var(--danger);
  background-image:linear-gradient(120deg,rgba(255,255,255,.16),rgba(255,255,255,0) 42%);
  color:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.2);
}
.btn-primary:focus-visible{background-color:var(--primary-strong);box-shadow:0 7px 18px rgba(17,24,39,.3)}
.btn-secondary:focus-visible{background-color:var(--secondary-strong);border-color:#d2d9e3;box-shadow:0 6px 14px rgba(15,23,42,.12)}
.btn-danger:focus-visible{background-color:var(--danger-strong);box-shadow:0 7px 18px rgba(190,18,60,.32)}
@media (hover:hover){
  .btn:hover{background-position:0% 0%}
  .btn:hover{transform:translateY(-1px)}
  .btn-primary:hover{background-color:var(--primary-strong);box-shadow:0 7px 18px rgba(17,24,39,.3)}
  .btn-secondary:hover{background-color:var(--secondary-strong);border-color:#d2d9e3;box-shadow:0 6px 14px rgba(15,23,42,.12)}
  .btn-danger:hover{background-color:var(--danger-strong);box-shadow:0 7px 18px rgba(190,18,60,.32)}
}
.btn.input-sized{height:var(--fld-h);padding:0 16px}
.btn.mag-action-icon{
  width:40px;
  height:40px;
  min-width:40px;
  min-height:40px;
  padding:0;
}
.btn.mag-action-icon svg{
  width:18px;
  height:18px;
  pointer-events:none;
}
body.page-magazyn .mag-actions-row .btn.mag-action-icon{
  width:40px !important;
  min-width:40px !important;
  flex:0 0 auto !important;
}

.mag-icon-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:30px;
  height:30px;
  min-width:30px;
  min-height:30px;
  padding:0;
  border:1px solid #cbd5e1;
  border-radius:8px;
  background:#fff;
  color:#1f2937;
  cursor:pointer;
  transition:
    background-color .2s ease,
    border-color .2s ease,
    box-shadow .2s ease,
    color .2s ease;
}
.mag-icon-btn svg{
  width:15px;
  height:15px;
  pointer-events:none;
}
.mag-icon-btn.is-delete{
  color:#be123c;
  border-color:#f3c4d1;
  background:#fff7f9;
}
.mag-icon-btn.is-view{
  color:#0f4c81;
  border-color:#bfdbfe;
  background:#f1f7ff;
}
.mag-icon-btn:focus-visible{
  outline:2px solid #334155;
  outline-offset:1px;
}
.mag-icon-btn:disabled{
  opacity:.45;
  cursor:not-allowed;
}
@media (hover:hover){
  .mag-icon-btn:hover{
    border-color:#94a3b8;
    background:#f8fafc;
  }
  .mag-icon-btn.is-delete:hover{
    border-color:#e11d48;
    background:#ffe4ea;
  }
  .mag-icon-btn.is-view:hover{
    border-color:#3b82f6;
    background:#dbeafe;
  }
}

.hstack{display:flex;align-items:center;gap:12px}
.actions{
  margin-top:16px;
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}
.actions-separated{
  margin-bottom:24px;
}
.muted{color:var(--muted);font-size:12px;margin-left:2px}
.status-line{
  display:inline-flex;
  align-items:center;
  min-height:20px;
  font-size:13px;
  line-height:1.3;
}
.ui-inline-message{
  display:block;
  margin-top:8px;
}
.state-info{color:var(--muted)}
.state-loading{color:#475569}
.state-empty{color:#64748b}
.state-success{color:#166534}
.state-error{color:#b91c1c}
.table .state-row,
.table .state-row:nth-child(even){
  background:#f8fafc;
}
.table .state-row .state-cell{
  text-align:center;
  font-style:italic;
}
.table .state-row.state-error .state-cell{color:#b91c1c}

.mobile-action-bar{display:none}

.table-scroll{
  display:block;
  width:100%;
  max-width:100%;
  min-width:0;
  position:relative;
  overflow-x:auto;
  overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior-x:contain;
  touch-action:pan-x pan-y;
  border:1px solid var(--border);
  border-radius:10px;
  background:#fff;
  transition:box-shadow .2s ease;
}
.table-scroll-hint{display:none}
.table{
  width:100%;
  min-width:700px;
  border-collapse:collapse;
}
.table th,.table td{
  padding:10px 12px;
  border-bottom:1px solid var(--border);
  text-align:left;
  font-size:14px;
  vertical-align:middle;
}
.table tr:nth-child(even){background:#f9f9f9}
.table thead th{background:#f8fafc}

/* ========== 05 Formularze ========== */
.form-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
}
.form-grid .field{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}
.form-grid .field.field-full{
  grid-column:1 / -1;
}
body.page-report-form .gps-row{
  display:flex;
  gap:8px;
  align-items:center;
}
body.page-report-form .gps-row input{
  flex:1 1 auto;
  min-width:0;
  width:auto;
}
body.page-report-form .gps-row .btn{
  flex:0 0 auto;
  white-space:nowrap;
}
.field label{
  display:block;
  font-size:12px;
  color:#6b7280;
  margin-bottom:6px;
  min-height:18px;
}
.item > label{
  display:block;
  font-size:12px;
  color:#6b7280;
  margin-bottom:6px;
  min-height:18px;
}
.field .help{font-size:12px;color:#6b7280;margin-top:6px}

input[type="text"],
input[type="password"],
input[type="email"],
input[type="date"],
input[type="datetime-local"],
input[type="number"],
input[type="search"],
select,
textarea{
  width:100%;
  min-width:0;
  height:var(--fld-h);
  padding:8px 12px;
  border:1px solid var(--fld-bc);
  border-radius:var(--fld-br);
  background:var(--fld-bg);
  color:var(--fld-txt);
  font-size:15px;
  line-height:1.2;
  transition:border-color .15s ease,box-shadow .15s ease,background .15s ease;
  outline:none;
}
textarea{min-height:96px;resize:vertical}
input::placeholder,textarea::placeholder{color:var(--fld-ph)}
input:hover,select:hover,textarea:hover{border-color:var(--fld-bc-hover)}
input:focus,select:focus,textarea:focus{border-color:var(--fld-bc-focus);box-shadow:var(--ring)}
input:disabled,select:disabled,textarea:disabled{background:var(--fld-bg-disabled);color:#9aa3af;cursor:not-allowed}

input[type="file"]{
  width:100%;
  min-width:0;
  min-height:var(--fld-h);
  padding:0;
  border:0;
  background:transparent;
  color:var(--muted);
  font-size:14px;
}
input[type="file"]::file-selector-button,
input[type="file"]::-webkit-file-upload-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  margin-right:10px;
  padding:9px 14px;
  border:1px solid var(--border);
  border-radius:10px;
  background-color:var(--secondary);
  background-image:linear-gradient(120deg,rgba(255,255,255,.92),rgba(255,255,255,0) 46%);
  background-repeat:no-repeat;
  background-size:220% 220%;
  background-position:100% 100%;
  color:var(--fg);
  font-weight:600;
  line-height:1.1;
  box-shadow:0 1px 2px rgba(15,23,42,.08);
  cursor:pointer;
  transition:
    background-color .36s cubic-bezier(.22,.61,.36,1),
    border-color .36s cubic-bezier(.22,.61,.36,1),
    box-shadow .36s cubic-bezier(.22,.61,.36,1),
    color .36s cubic-bezier(.22,.61,.36,1),
    transform .36s cubic-bezier(.22,.61,.36,1),
    background-position .46s cubic-bezier(.22,.61,.36,1);
}
@media (hover:hover){
  input[type="file"]::file-selector-button:hover,
  input[type="file"]::-webkit-file-upload-button:hover{
    background-color:var(--secondary-strong);
    border-color:#d2d9e3;
    box-shadow:0 6px 14px rgba(15,23,42,.12);
    transform:translateY(-1px);
    background-position:0% 0%;
  }
}
input[type="file"]::file-selector-button:active,
input[type="file"]::-webkit-file-upload-button:active{
  transform:translateY(0);
}
input[type="file"]:focus-visible{
  outline:2px solid #6f86ac;
  outline-offset:2px;
}

.is-invalid,
input:invalid,select:invalid,textarea:invalid{
  border-color:#ef4444;
  box-shadow:0 0 0 3px rgba(239,68,68,.16), inset 0 0 0 999px rgba(254,242,242,.55);
}

.input-sm{height:34px;padding:6px 10px;font-size:13px}
.input-lg{height:48px;padding:10px 14px;font-size:15px}

select{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  padding-right:36px;
  background-image:
    linear-gradient(transparent,transparent),
    url("data:image/svg+xml,%3Csvg width='16' height='16' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M7 10l5 5 5-5' stroke='%235b6b8a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 10px center;
  background-size:16px;
  line-height:normal;
}
select::-ms-expand{display:none}

/* ========== 06 Upload ========== */
.dropzone{
  border:2px dashed var(--border);
  border-radius:12px;
  padding:16px;
  text-align:center;
  background:#fafafa;
}
.dropzone.drag{background:#f0f8ff}
.linklike{color:var(--primary);cursor:pointer;text-decoration:underline}

.thumbs{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.thumb{
  position:relative;
  width:120px;
  height:90px;
  border:1px solid var(--border);
  border-radius:8px;
  overflow:hidden;
  background:#fff;
}
.thumb img{width:100%;height:100%;object-fit:cover}
.thumb .rm{
  position:absolute;
  top:4px;
  right:4px;
  background:rgba(0,0,0,.6);
  color:#fff;
  border:0;
  border-radius:6px;
  font-size:12px;
  padding:2px 6px;
  cursor:pointer;
}

/* ========== 07 Toolbar + Utils ========== */
.toolbar{
  display:grid;
  grid-template-columns:minmax(240px,1fr) 160px 160px auto auto;
  gap:10px;
  align-items:center;
  margin-bottom:12px;
}
.toolbar-inline{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}
.view-switch{
  display:none;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
  margin-top:4px;
  margin-bottom:8px;
}
.view-switch .btn{
  min-height:34px;
  padding:7px 12px;
  font-size:13px;
}
.view-switch .btn.is-active{
  background:var(--primary);
  color:#fff;
  border-color:var(--primary);
}
.list-cards{
  display:none;
  gap:10px;
}
.list-card{
  border:1px solid var(--border);
  border-radius:10px;
  background:#fff;
  padding:10px;
}
.list-card-grid{
  display:grid;
  gap:8px;
}
.list-card-grid .label{
  display:block;
  margin-bottom:2px;
  color:var(--muted);
  font-size:11px;
}
.list-card-actions{
  margin-top:10px;
}
.list-card-state{
  display:block;
  border:1px solid var(--border);
  border-radius:10px;
  background:#f8fafc;
  padding:10px 12px;
}
.grid-2{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.grid-4{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
}
.row-actions{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  align-items:center;
}
.actions-cell{
  vertical-align:middle;
}
.row-actions .btn{white-space:nowrap}
.table .row-actions{
  min-width:0;
  flex-wrap:nowrap;
  align-items:center;
}
.table .row-actions .btn{flex:0 0 auto}
.table td.nowrap .btn{white-space:nowrap}
.input-search{max-width:320px}
.text-right{text-align:right}
.nowrap{white-space:nowrap}
.mt-6{margin-top:6px}
.mt-8{margin-top:8px}
.hidden{display:none}
.note-text{white-space:pre-wrap;word-break:break-word}

/* Podsekcja: ekran logowania */
.login-page{
  min-height:100%;
  display:grid;
  place-items:center;
  padding:22px 12px;
}
.login-card{
  width:min(100%,430px);
  padding:20px;
}
.login-logo-wrap{
  display:flex;
  justify-content:center;
  margin-bottom:12px;
}
.login-logo,
.login-logo-fallback{
  width:min(230px,76%);
  min-width:130px;
  height:56px;
}
.login-logo{
  object-fit:contain;
  background:transparent;
  border:0;
  border-radius:0;
  padding:0;
  box-shadow:none;
}
.login-logo-fallback{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:transparent;
  border:0;
  border-radius:0;
  box-shadow:none;
  font-weight:800;
  letter-spacing:.15em;
  color:var(--primary);
  font-size:13px;
}
.login-card h1{margin-bottom:16px}
.login-card .field{margin-bottom:12px}
.login-card > .btn{margin-top:12px}
.password-wrap{
  position:relative;
  display:grid;
}
.password-wrap input{
  grid-area:1 / 1;
  padding-right:42px;
}
.toggle-pass{
  grid-area:1 / 1;
  justify-self:end;
  align-self:center;
  margin-right:6px;
  width:28px;
  height:28px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:0;
  background:transparent;
  padding:0;
  cursor:pointer;
  color:#8a8a8a;
}
.toggle-pass svg{display:block;width:20px;height:20px;fill:currentColor}
.toggle-pass .eye-closed{display:none}
.toggle-pass.is-open .eye-open{display:none}
.toggle-pass.is-open .eye-closed{display:block}
.msg{margin-top:12px;color:#c00;font-size:14px;line-height:1.35}

/* ========== 08 Strony (Style Lokalne Przeniesione Z HTML) ========== */
/* Strona: index.html (wybór typu raportu) */
body.page-home .grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
body.page-home .tile{
  --tile-accent:#0f172a;
  --tile-accent-strong:#1e293b;
  --tile-accent-soft:rgba(15,23,42,.16);
  --tile-surface:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);
  display:flex;
  flex-direction:column;
  gap:10px;
  height:100%;
  padding:16px;
  border:1px solid var(--border);
  border-radius:12px;
  position:relative;
  overflow:hidden;
  isolation:isolate;
  background:var(--tile-surface);
  box-shadow:0 4px 14px rgba(16,24,40,.05);
  transition:
    transform .24s ease,
    box-shadow .24s ease,
    border-color .24s ease;
}
body.page-home .tile::before{
  content:"";
  position:absolute;
  inset:auto -36px -54px auto;
  width:170px;
  height:170px;
  border-radius:50%;
  background:radial-gradient(circle,var(--tile-accent-soft) 0%,rgba(255,255,255,0) 68%);
  opacity:.95;
  pointer-events:none;
}
body.page-home .tile::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:linear-gradient(140deg,rgba(255,255,255,.78),rgba(255,255,255,0) 46%);
  pointer-events:none;
}
body.page-home .tile > *{
  position:relative;
  z-index:1;
}
body.page-home .tile-head{
  display:flex;
  align-items:flex-start;
  gap:14px;
}
body.page-home .tile-meta{
  display:grid;
  gap:4px;
}
body.page-home .tile-kicker{
  display:inline-flex;
  align-items:center;
  width:max-content;
  min-height:24px;
  padding:0 10px;
  border-radius:999px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(255,255,255,.7);
  color:var(--tile-accent-strong);
  box-shadow:0 6px 16px rgba(15,23,42,.06);
  font-size:11px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
}
body.page-home .tile-icon{
  width:58px;
  height:58px;
  flex:0 0 auto;
  display:grid;
  place-items:center;
  border-radius:18px;
  color:#fff;
  background:
    radial-gradient(circle at 30% 25%,rgba(255,255,255,.36),rgba(255,255,255,0) 35%),
    linear-gradient(145deg,var(--tile-accent),var(--tile-accent-strong));
  box-shadow:
    0 12px 28px var(--tile-accent-soft),
    inset 0 1px 0 rgba(255,255,255,.32);
}
body.page-home .tile-icon svg{
  width:28px;
  height:28px;
  stroke:currentColor;
  stroke-width:1.75;
  stroke-linecap:round;
  stroke-linejoin:round;
}
body.page-home .tile h3{margin:0;font-size:18px}
body.page-home .tile p{margin:0;color:var(--muted);font-size:14px}
body.page-home .tile .row{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:auto;
  justify-content:flex-start;
}
body.page-home #reportsTile{
  --tile-accent:#0f766e;
  --tile-accent-strong:#115e59;
  --tile-accent-soft:rgba(15,118,110,.18);
  --tile-surface:linear-gradient(180deg,#ffffff 0%,#f1fbf9 100%);
}
body.page-home #fiberTile{
  --tile-accent:#7c3aed;
  --tile-accent-strong:#6d28d9;
  --tile-accent-soft:rgba(124,58,237,.18);
  --tile-surface:linear-gradient(180deg,#ffffff 0%,#f6f2ff 100%);
}
body.page-home #magazynTile{
  --tile-accent:#b45309;
  --tile-accent-strong:#92400e;
  --tile-accent-soft:rgba(180,83,9,.18);
  --tile-surface:linear-gradient(180deg,#ffffff 0%,#fff7ed 100%);
}
body.page-home #postepTile{
  --tile-accent:#2563eb;
  --tile-accent-strong:#1d4ed8;
  --tile-accent-soft:rgba(37,99,235,.18);
  --tile-surface:linear-gradient(180deg,#ffffff 0%,#eff6ff 100%);
}
body.page-home #flotaTile{
  --tile-accent:#c2410c;
  --tile-accent-strong:#9a3412;
  --tile-accent-soft:rgba(194,65,12,.18);
  --tile-surface:linear-gradient(180deg,#ffffff 0%,#fff7ed 100%);
}
body.page-home #etykietyTile{
  --tile-accent:#059669;
  --tile-accent-strong:#047857;
  --tile-accent-soft:rgba(5,150,105,.18);
  --tile-surface:linear-gradient(180deg,#ffffff 0%,#ecfdf5 100%);
}
body.page-home #protocolsTile{
  --tile-accent:#475569;
  --tile-accent-strong:#334155;
  --tile-accent-soft:rgba(71,85,105,.18);
  --tile-surface:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);
}
@media (hover:hover){
  body.page-home .tile:hover{
    transform:translateY(-3px);
    border-color:var(--tile-accent-soft);
    box-shadow:0 18px 34px rgba(15,23,42,.1);
  }
}

/* Strona: magazyn/index.html (projekt magazynu) */
body.page-magazyn main{
  display:grid;
  gap:16px;
}
body.page-magazyn .mag-hero{
  border-color:#ccd6e2;
  background:linear-gradient(180deg,#ffffff 0%,#f7f9fc 100%);
}
body.page-magazyn .mag-lead{
  margin:10px 0 0;
  color:#1f2937;
  font-size:15px;
  line-height:1.52;
}
body.page-magazyn .mag-doc-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
body.page-magazyn .mag-section h2{
  margin:0 0 10px;
}
body.page-magazyn .mag-section p{
  margin:0 0 10px;
  color:#1f2937;
}
body.page-magazyn .mag-section p:last-child{
  margin-bottom:0;
}
body.page-magazyn .mag-section ol{
  margin:0;
  padding-left:20px;
  display:grid;
  gap:8px;
}
body.page-magazyn .mag-headline-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:10px;
}
body.page-magazyn .mag-kicker{
  font-size:13px;
  font-weight:700;
  color:#334155;
}
body.page-magazyn .mag-progress{
  height:11px;
  border-radius:999px;
  background:#dbe3ee;
  overflow:hidden;
  margin:0 0 12px;
}
body.page-magazyn .mag-progress > span{
  display:block;
  width:0%;
  height:100%;
  background:linear-gradient(90deg,#0f1a2e 0%,#2f4f78 100%);
  border-radius:999px;
  transition:width .24s ease;
}
body.page-magazyn .mag-phase-list{
  display:grid;
  gap:10px;
}
body.page-magazyn .mag-phase-item{
  border:1px solid #d4dde8;
  border-radius:11px;
  background:#f9fbfd;
  padding:10px 11px;
}
body.page-magazyn .mag-phase-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  margin-bottom:8px;
}
body.page-magazyn .mag-phase-title{
  margin:0;
  font-size:15px;
  line-height:1.32;
}
body.page-magazyn .mag-phase-status{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:2px 8px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
  border:1px solid transparent;
  white-space:nowrap;
}
body.page-magazyn .mag-phase-status.is-done{
  color:#14532d;
  background:#dcfce7;
  border-color:#bbf7d0;
}
body.page-magazyn .mag-phase-status.is-progress{
  color:#1e3a8a;
  background:#dbeafe;
  border-color:#bfdbfe;
}
body.page-magazyn .mag-phase-status.is-pending{
  color:#374151;
  background:#f3f4f6;
  border-color:#e5e7eb;
}
body.page-magazyn .mag-status-line{
  margin:0;
  color:#1f2937;
}
body.page-magazyn{
  overflow-x:hidden;
}
body.page-magazyn main,
body.page-magazyn .card,
body.page-magazyn .mag-hero,
body.page-magazyn .mag-section{
  min-width:0;
  max-width:100%;
}
body.page-magazyn .mag-tabs-wrap{
  padding:10px;
  overflow:hidden;
}
body.page-magazyn .mag-tabs{
  display:flex;
  gap:8px;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:thin;
  max-width:100%;
  padding-bottom:2px;
}
body.page-magazyn .mag-tab{
  appearance:none;
  -webkit-appearance:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
  border:1px solid #cfd8e3;
  background:#eef2f7;
  color:#1f2937;
  border-radius:10px;
  padding:8px 12px;
  font-size:14px;
  font-weight:700;
  white-space:nowrap;
  cursor:pointer;
}
body.page-magazyn .mag-tab:hover{
  background:#e5ebf3;
}
body.page-magazyn .mag-tab.is-active{
  background:#0f1a2e;
  color:#fff;
  border-color:#0f1a2e;
}
body.page-magazyn .mag-subtabs{
  margin-top:8px;
  display:flex;
  gap:8px;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  padding-bottom:2px;
}
body.page-magazyn .mag-subtab{
  appearance:none;
  -webkit-appearance:none;
  border:1px solid #cfd8e3;
  background:#f5f7fb;
  color:#1f2937;
  border-radius:10px;
  padding:7px 11px;
  font-size:13px;
  font-weight:700;
  white-space:nowrap;
  cursor:pointer;
}
body.page-magazyn .mag-subtab:hover{
  background:#ebf0f7;
}
body.page-magazyn .mag-subtab.is-active{
  background:#0f1a2e;
  color:#fff;
  border-color:#0f1a2e;
}
body.page-magazyn .mag-panel[hidden]{
  display:none !important;
}
body.page-magazyn .mag-actions-row{
  margin-top:10px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
body.page-magazyn .mag-headline-row .mag-actions-row .input-search{
  min-width:220px;
}
body.page-magazyn .mag-material-form{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
  margin-top:8px;
}
body.page-magazyn .mag-material-form .field-full{
  grid-column:1 / -1;
}
body.page-magazyn .mag-material-image-row{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}
body.page-magazyn .mag-material-image-preview{
  margin-top:8px;
  min-height:84px;
  border:1px dashed #cbd5e1;
  border-radius:10px;
  background:#f8fafc;
  padding:10px;
  display:flex;
  align-items:center;
  gap:10px;
}
body.page-magazyn .mag-material-thumb{
  width:44px;
  height:44px;
  border:1px solid #cbd5e1;
  border-radius:8px;
  object-fit:cover;
  background:#fff;
  display:block;
  transition:transform .2s ease, box-shadow .2s ease;
}
body.page-magazyn .mag-material-thumb.is-preview{
  width:64px;
  height:64px;
}
body.page-magazyn .mag-material-thumb-empty{
  width:44px;
  height:44px;
  border:1px dashed #cbd5e1;
  border-radius:8px;
  background:#f8fafc;
  color:#64748b;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
body.page-magazyn .mag-material-thumb-empty svg{
  width:18px;
  height:18px;
  pointer-events:none;
}
body.page-magazyn .mag-material-thumb-empty.is-preview{
  width:64px;
  height:64px;
}
body.page-magazyn .mag-material-preview-trigger{
  margin:0;
  padding:0;
  border:0;
  background:transparent;
  color:inherit;
  font:inherit;
  text-align:left;
  cursor:pointer;
}
body.page-magazyn .mag-material-photo-btn{
  margin:0;
  padding:0;
  border:0;
  background:transparent;
  color:inherit;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
@media (hover:hover){
  body.page-magazyn .mag-material-preview-trigger:hover strong{
    text-decoration:underline;
  }
  body.page-magazyn .mag-material-photo-cell.is-clickable .mag-material-photo-btn:hover .mag-material-thumb{
    transform:scale(2.05);
    box-shadow:0 12px 25px rgba(15,23,42,.28);
    position:relative;
    z-index:2;
  }
}
body.page-magazyn .mag-ai-tools{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
}
body.page-magazyn .mag-ai-box{
  margin-top:8px;
  border:1px solid #c7d2fe;
  border-radius:10px;
  background:#eef2ff;
  padding:10px;
}
body.page-magazyn .mag-ai-box h3{
  margin:0 0 6px;
  font-size:15px;
}
body.page-magazyn .mag-ai-box p{
  margin:4px 0;
}
body.page-magazyn .mag-doc-form{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
  margin-top:8px;
}
body.page-magazyn .mag-doc-form .field-full{
  grid-column:1 / -1;
}
body.page-magazyn .mag-loc-grid{
  margin-top:10px;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
body.page-magazyn .mag-loc-card{
  min-width:0;
  border:1px solid #d4dde8;
  border-radius:11px;
  background:#f9fbfd;
  padding:10px;
}
body.page-magazyn .mag-loc-card h3{
  margin:0 0 8px;
  font-size:17px;
}
body.page-magazyn .mag-loc-card .mag-table-wrap{
  margin-top:0;
}
body.page-magazyn .mag-loc-card .mag-table-wrap .table{
  min-width:0;
  width:100%;
  table-layout:auto;
}
body.page-magazyn .mag-loc-card .mag-table-wrap .table th,
body.page-magazyn .mag-loc-card .mag-table-wrap .table td{
  white-space:normal;
  word-break:break-word;
}
body.page-magazyn .mag-loc-card .mag-table-wrap .table th:nth-child(3),
body.page-magazyn .mag-loc-card .mag-table-wrap .table td:nth-child(3){
  width:1%;
  white-space:nowrap;
}
body.page-magazyn .mag-loc-card .action-cell{
  text-align:right;
  white-space:normal;
  display:flex;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:6px;
}
body.page-magazyn .mag-check-inline label{
  display:flex;
  gap:8px;
  align-items:center;
}
body.page-magazyn .mag-check-inline input[type='checkbox']{
  width:18px;
  height:18px;
}
body.page-magazyn .mag-table-wrap{
  margin-top:10px;
  display:block;
  width:100%;
  max-width:100%;
  min-width:0;
  overflow-x:auto;
  overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
  border:1px solid var(--border);
  border-radius:10px;
  background:#fff;
}
body.page-magazyn .mag-table-wrap .table{
  min-width:980px;
}
body.page-magazyn #issuesTable{
  min-width:1180px;
}
body.page-magazyn .mag-sort-btn{
  appearance:none;
  -webkit-appearance:none;
  border:0;
  background:transparent;
  padding:0;
  margin:0;
  width:100%;
  display:inline-flex;
  align-items:center;
  justify-content:flex-start;
  gap:6px;
  font:inherit;
  font-weight:700;
  color:inherit;
  cursor:pointer;
}
body.page-magazyn .mag-sort-caret{
  display:inline-flex;
  flex-direction:column;
  line-height:1;
  font-size:10px;
  color:#94a3b8;
}
body.page-magazyn .mag-sort-btn.is-asc .mag-sort-caret .up,
body.page-magazyn .mag-sort-btn.is-desc .mag-sort-caret .down{
  color:#0f1a2e;
}
body.page-magazyn .mag-stock-actions{
  text-align:right;
  white-space:nowrap;
}
body.page-magazyn td.mag-material-actions{
  text-align:right;
  white-space:nowrap;
  vertical-align:middle;
}
body.page-magazyn .mag-material-photo-cell{
  text-align:center;
  vertical-align:middle;
  white-space:nowrap;
  position:relative;
  overflow:visible;
}
body.page-magazyn .mag-material-actions .mag-icon-btn + .mag-icon-btn,
body.page-magazyn .mag-material-actions .btn + .btn{
  margin-left:6px;
}
body.page-magazyn .mag-material-actions .btn{
  min-height:34px;
  padding:6px 10px;
  font-size:13px;
}
body.page-magazyn .mag-worker-return-actions{
  display:flex;
  justify-content:flex-end;
  align-items:center;
  gap:8px;
  white-space:nowrap;
}
body.page-magazyn .mag-worker-return-actions input[type="number"]{
  width:110px;
  min-width:90px;
}
body.page-magazyn .mag-stock-qr-btn{
  min-height:34px;
  padding:6px 10px;
  font-size:13px;
}
body.page-magazyn .mag-stock-pz-btn{
  min-height:34px;
  padding:6px 10px;
  font-size:13px;
}
body.page-magazyn .mag-stock-pager{
  margin-top:0;
  padding:12px 14px;
  border-top:1px solid #e2e8f0;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:26px;
  flex-wrap:wrap;
  background:#fff;
  text-align:center;
}
body.page-magazyn .mag-stock-pager-info{
  font-size:15px;
  display:flex;
  align-items:center;
  justify-content:center;
  line-height:1;
  color:#2f2f2f;
  letter-spacing:.2px;
}
body.page-magazyn .mag-stock-pager-controls{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  flex-wrap:nowrap;
}
body.page-magazyn .mag-stock-pager-controls label{
  font-size:15px;
  line-height:1;
  color:#3a3a3a;
  white-space:nowrap;
}
body.page-magazyn .mag-stock-pager-controls select{
  min-width:96px;
  height:46px;
  border:2px solid #aeb1b6;
  border-radius:9px;
  background-color:#fff;
  font-size:15px;
  color:#2f2f2f;
  padding:0 34px 0 12px;
}
body.page-magazyn #docPager .mag-stock-pager-controls{
  flex-wrap:wrap;
}
body.page-magazyn .mag-stock-pager-nav{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}
body.page-magazyn .mag-stock-pager-btn{
  width:42px;
  height:42px;
  border:0;
  border-radius:50%;
  background:transparent;
  color:#9aa0a6;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0;
  cursor:pointer;
  transition:color .2s ease, background-color .2s ease;
}
body.page-magazyn .mag-stock-pager-btn svg{
  width:28px;
  height:28px;
  pointer-events:none;
}
body.page-magazyn .mag-stock-pager-btn:disabled{
  opacity:.35;
  cursor:not-allowed;
}
@media (hover:hover){
  body.page-magazyn .mag-stock-pager-btn:hover:not(:disabled){
    color:#4b5563;
    background:#f1f5f9;
  }
}
body.page-magazyn.mag-modal-open{
  overflow:hidden;
}
body.page-magazyn .mag-qr-modal{
  position:fixed;
  inset:0;
  z-index:1200;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
}
body.page-magazyn .mag-qr-modal.hidden{
  display:none !important;
}
body.page-magazyn .mag-qr-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(11,18,32,.45);
}
body.page-magazyn .mag-qr-generator{
  position:relative;
  z-index:1;
  width:min(1200px,calc(100vw - 36px));
  max-height:calc(100vh - 36px);
  overflow:auto;
  margin-top:0;
  border:1px solid #d4dde8;
  border-radius:11px;
  background:#f9fbfd;
  padding:10px;
  box-shadow:0 20px 45px rgba(15,23,42,.25);
}
body.page-magazyn .mag-material-preview-modal{
  width:min(860px,calc(100vw - 36px));
}
body.page-magazyn .mag-material-preview-body{
  display:grid;
  gap:14px;
}
body.page-magazyn .mag-material-preview-body .mag-table-wrap{
  margin-top:0;
  overflow-x:hidden;
}
body.page-magazyn .mag-material-preview-body .mag-table-wrap .table{
  min-width:0;
  width:100%;
  table-layout:fixed;
}
body.page-magazyn .mag-material-preview-name{
  margin:0;
  font-size:22px;
  line-height:1.15;
}
body.page-magazyn .mag-material-preview-grid{
  display:grid;
  grid-template-columns:minmax(170px,220px) minmax(0,1fr);
  gap:16px;
  align-items:start;
}
body.page-magazyn .mag-material-preview-photo{
  border:1px solid #d4dde8;
  border-radius:10px;
  background:#fff;
  min-height:180px;
  padding:10px;
  display:grid;
  place-items:center;
  gap:8px;
}
body.page-magazyn .mag-material-preview-photo img{
  max-width:100%;
  max-height:220px;
  border-radius:8px;
  object-fit:contain;
}
body.page-magazyn .mag-material-preview-table{
  margin:0;
}
body.page-magazyn .mag-material-preview-table th{
  width:210px;
  color:#334155;
  font-weight:700;
  background:#f8fbff;
  vertical-align:top;
}
body.page-magazyn .mag-material-preview-table td{
  vertical-align:top;
  overflow-wrap:anywhere;
}
body.page-magazyn .mag-material-preview-table code{
  font-size:12px;
}
body.page-magazyn .mag-material-preview-link{
  margin:0;
}
body.page-magazyn .mag-material-preview-link a{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin-top:10px;
}
body.page-magazyn .mag-qr-generator h3{
  margin:0 0 10px;
  font-size:17px;
}
body.page-magazyn .mag-qr-modal-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:8px;
}
body.page-magazyn .mag-qr-modal-head h3{
  margin:0;
}
body.page-magazyn .mag-qr-controls{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:10px;
  align-items:end;
}
body.page-magazyn .mag-qr-preview{
  margin-top:10px;
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(8cm,1fr));
  gap:10px;
  justify-items:center;
}
body.page-magazyn .mag-qr-label{
  width:8cm;
  min-height:5cm;
  box-sizing:border-box;
  overflow:hidden;
  border:1px solid #cbd5e1;
  border-radius:10px;
  background:#fff;
  padding:4px 5px;
  text-align:center;
  display:grid;
  align-content:start;
  row-gap:2px;
}
body.page-magazyn .mag-qr-main-img{
  width:2.2cm;
  height:2.2cm;
  object-fit:contain;
  justify-self:center;
}
body.page-magazyn .mag-code128-img{
  width:100%;
  height:.95cm;
  object-fit:contain;
  justify-self:center;
}
body.page-magazyn .mag-qr-name{
  font-weight:700;
  font-size:11px;
  line-height:1.1;
}
body.page-magazyn .mag-qr-code{
  font-size:9.5px;
  line-height:1;
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;
  color:#334155;
}
body.page-magazyn .mag-qr-unit{
  font-size:9px;
  line-height:1.1;
  color:#64748b;
}
body.page-magazyn .mag-qr-notes{
  color:#334155;
  word-break:break-word;
  overflow:hidden;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:2;
  line-clamp:2;
}
@media (max-width:760px){
  body.page-magazyn .mag-qr-modal{
    padding:10px;
  }
  body.page-magazyn .mag-qr-generator{
    width:100%;
    max-height:calc(100vh - 20px);
    border-radius:10px;
  }
  body.page-magazyn .mag-material-preview-grid{
    grid-template-columns:1fr;
  }
  body.page-magazyn .mag-material-preview-photo{
    min-height:140px;
  }
  body.page-magazyn .mag-material-preview-table th{
    width:42%;
  }
  body.page-magazyn .mag-qr-modal-head{
    align-items:flex-start;
  }
  body.page-magazyn .mag-stock-pager{
    gap:12px;
    padding:10px;
  }
  body.page-magazyn .mag-stock-pager-controls{
    width:100%;
    justify-content:center;
  }
  body.page-magazyn #docPager .mag-stock-pager-controls{
    gap:10px;
  }
  body.page-magazyn .mag-stock-pager-info{
    width:100%;
    text-align:center;
  }
}
body.page-magazyn .mag-scan-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  align-items:start;
}
body.page-magazyn .mag-scan-box{
  border:1px solid #d4dde8;
  border-radius:11px;
  background:#f9fbfd;
  padding:10px;
  display:grid;
  gap:8px;
  align-content:start;
}
body.page-magazyn .mag-scan-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
  align-items:center;
}
body.page-magazyn .mag-scan-row .btn{
  min-height:var(--fld-h);
  height:var(--fld-h);
  padding:0 14px;
  white-space:nowrap;
  align-self:center;
}
body.page-magazyn .mag-scan-box .mag-actions-row{
  align-items:center;
}
body.page-magazyn .mag-scan-box .mag-actions-row .btn{
  min-height:42px;
  padding:9px 14px;
  flex:0 0 auto;
  max-width:100%;
  min-width:0;
}
body.page-magazyn .mag-video-wrap{
  position:fixed;
  inset:0;
  z-index:1200;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:16px;
  border:0;
  border-radius:0;
  overflow:hidden;
  background:rgba(2,6,23,.72);
  backdrop-filter:blur(2px);
}
body.page-magazyn .mag-video-wrap.hidden{
  display:none !important;
}
body.page-magazyn .mag-video-wrap video{
  width:min(92vw,640px);
  max-height:74vh;
  display:block;
  border:1px solid #cbd5e1;
  border-radius:12px;
  background:#0b1220;
  box-shadow:0 18px 40px rgba(2,6,23,.45);
}
body.page-magazyn #btnStopCamera:not(.hidden){
  position:fixed;
  top:calc(env(safe-area-inset-top, 0px) + 16px);
  right:16px;
  z-index:1210;
  min-height:40px;
  padding:8px 12px;
}
body.page-magazyn.mag-scan-active{
  overflow:hidden;
}
body.page-magazyn .mag-match-box{
  border:1px solid #bfdbfe;
  background:#eff6ff;
  border-radius:10px;
  padding:10px;
}
body.page-magazyn .mag-match-box h3{
  margin:0 0 8px;
  font-size:16px;
}
body.page-magazyn .mag-match-box p{
  margin:4px 0;
}
body.page-magazyn .mag-match-list{
  margin:6px 0 0;
  padding-left:18px;
}
body.page-magazyn .mag-match-list li{
  margin:3px 0;
}
body.page-magazyn .mag-worker-availability{
  margin:8px 0 2px;
  padding:10px;
  border:1px solid #cbd5e1;
  border-radius:10px;
  background:#f8fafc;
}
body.page-magazyn .mag-worker-availability p{
  margin:4px 0;
}
body.page-magazyn .mag-worker-availability-qty{
  font-weight:800;
  font-size:18px;
}
body.page-magazyn .mag-worker-availability-hint{
  color:#334155;
}
body.page-magazyn .mag-match-box.is-worker-simple{
  border-color:#c7d2fe;
  background:linear-gradient(180deg,#f8fbff 0%,#eef4ff 100%);
}
body.page-magazyn .mag-match-box.is-worker-simple .mag-worker-quick-name{
  margin:0 0 8px;
  font-size:20px;
  line-height:1.2;
  font-weight:800;
  color:#0f172a;
}
body.page-magazyn .mag-match-box.is-worker-simple .mag-worker-quick-name span{
  font-size:17px;
  font-weight:700;
  color:#475569;
}
body.page-magazyn .mag-match-box.is-worker-simple .mag-worker-quick-qty{
  margin:8px 0;
  padding:10px 12px;
  border-radius:10px;
  border:1px solid #86efac;
  background:#ecfdf5;
}
body.page-magazyn .mag-match-box.is-worker-simple .mag-worker-quick-qty.is-empty{
  border-color:#fecaca;
  background:#fef2f2;
}
body.page-magazyn .mag-match-box.is-worker-simple .mag-worker-quick-qty span{
  display:block;
  font-size:13px;
  color:#334155;
}
body.page-magazyn .mag-match-box.is-worker-simple .mag-worker-quick-qty strong{
  display:block;
  margin-top:2px;
  font-size:34px;
  line-height:1;
  font-weight:900;
  color:#065f46;
}
body.page-magazyn .mag-match-box.is-worker-simple .mag-worker-quick-qty.is-empty strong{
  color:#991b1b;
}
body.page-magazyn .mag-match-box.is-worker-simple .mag-worker-quick-meta{
  margin:6px 0 0;
  font-size:15px;
  color:#1e293b;
}
body.page-magazyn .mag-match-box.is-worker-simple .mag-worker-quick-pick-label{
  display:block;
  margin:8px 0 4px;
  font-size:13px;
  color:#334155;
  font-weight:700;
}
body.page-magazyn .mag-match-box.is-worker-simple .mag-worker-quick-pick{
  width:100%;
}
body.page-magazyn .mag-match-box.is-worker-simple .mag-worker-quick-hint{
  margin:8px 0 0;
  font-size:13px;
  color:#b45309;
  font-weight:700;
}
body.page-magazyn .mag-match-box.is-worker-simple .mag-worker-quick-hint.is-alert{
  color:#991b1b;
}
body.page-magazyn .mag-feedback-form{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
body.page-magazyn .mag-feedback-form .field-full{
  grid-column:1 / -1;
}
body.page-magazyn .mag-inline-msg{
  margin:10px 0 0;
  padding:8px 10px;
  border-radius:9px;
  background:#e2e8f0;
  color:#1e293b;
}
body.page-magazyn .mag-inline-msg.is-error{
  background:#fee2e2;
  color:#991b1b;
}
body.page-magazyn .mag-feedback-list{
  margin-top:10px;
  display:grid;
  gap:10px;
}
body.page-magazyn .mag-empty{
  margin:0;
  padding:10px 12px;
  border:1px dashed #cbd5e1;
  border-radius:10px;
  color:#475569;
  background:#f8fafc;
}
body.page-magazyn .mag-feedback-item{
  border:1px solid #d4dde8;
  border-radius:11px;
  background:#f9fbfd;
  padding:10px 11px;
  margin-left:calc(var(--reply-level, 0) * 26px);
  position:relative;
}
body.page-magazyn .mag-feedback-item.is-reply{
  background:#ffffff;
  border-left:3px solid #94a3b8;
  padding-left:14px;
}
body.page-magazyn .mag-feedback-item.is-reply::before{
  content:"";
  position:absolute;
  left:-14px;
  top:-1px;
  bottom:-1px;
  width:2px;
  border-radius:2px;
  background:#dbe4ef;
}
body.page-magazyn .mag-feedback-item.is-reply::after{
  content:"";
  position:absolute;
  left:-14px;
  top:18px;
  width:12px;
  height:2px;
  border-radius:2px;
  background:#dbe4ef;
}
body.page-magazyn .mag-feedback-top{
  display:flex;
  align-items:center;
  gap:8px;
}
body.page-magazyn .mag-feedback-title{
  font-size:15px;
  margin-right:auto;
}
body.page-magazyn .mag-feedback-meta{
  margin:8px 0 0;
  color:#64748b;
  font-size:12px;
}
body.page-magazyn .mag-feedback-body{
  margin:8px 0 0;
  line-height:1.45;
  color:#0f172a;
  white-space:pre-wrap;
}
body.page-magazyn .mag-reply-wrap{
  margin-top:10px;
  padding:9px;
  border:1px dashed #cbd5e1;
  border-radius:10px;
  background:#f8fafc;
}
body.page-magazyn .mag-reply-wrap label{
  display:block;
  margin-bottom:6px;
  font-size:12px;
  color:#334155;
  font-weight:700;
}
body.page-magazyn .mag-reply-wrap textarea{
  min-height:72px;
}
body.page-magazyn .mag-reply-controls{
  margin-top:8px;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto auto;
  gap:8px;
}
body.page-magazyn .mag-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:2px 8px;
  border-radius:999px;
  border:1px solid #d1d5db;
  font-size:12px;
  font-weight:700;
  background:#f3f4f6;
  color:#374151;
}
body.page-magazyn .mag-chip.is-low{
  color:#991b1b;
  background:#fee2e2;
  border-color:#fecaca;
}
body.page-magazyn .mag-chip.is-idea{
  color:#1e3a8a;
  background:#dbeafe;
  border-color:#bfdbfe;
}
body.page-magazyn .mag-chip.is-comment{
  color:#4338ca;
  background:#e0e7ff;
  border-color:#c7d2fe;
}
body.page-magazyn .mag-chip.is-reply{
  color:#0f766e;
  background:#ccfbf1;
  border-color:#99f6e4;
}
body.page-magazyn tr.mag-row-low td{
  background:#fff7ed;
}

/* Strona: view.html (podgląd raportu robót) */
body.page-view-report .thumbs{display:flex;flex-wrap:wrap;gap:10px;margin-top:0}
body.page-view-report .thumb{
  display:block;
  position:relative;
  width:140px;
  height:100px;
  border:1px solid var(--border);
  border-radius:8px;
  overflow:hidden;
  background:#fff;
}
body.page-view-report .thumb img{width:100%;height:100%;object-fit:cover;display:block}
body.page-view-report main{
  min-width:0;
  overflow-x:clip;
}
body.page-view-report .card{
  width:100%;
  max-width:100%;
  min-width:0;
}
body .soft-card{
  background:linear-gradient(180deg,#fcfcfd 0%,#f3f4f6 100%);
  border-color:rgba(100,116,139,.22);
  box-shadow:0 10px 24px rgba(15,23,42,.06);
}
body.page-view-report .soft-card h3,
body.page-fiber-view .soft-card h3{
  color:#1f2937;
  margin-bottom:12px;
}
.preview-meta-grid{
  gap:10px;
  margin-bottom:10px;
}
.report-meta-grid{
  display:grid;
  grid-template-columns:minmax(170px,220px) minmax(0,1fr);
  gap:10px;
}
.preview-meta-grid > .preview-meta-item{
  padding:10px 12px;
  border:1px solid rgba(100,116,139,.2);
  border-radius:10px;
  background:#f8fafc;
  margin-bottom:0;
}
.preview-meta-grid > .preview-meta-item:nth-child(even){
  background:#f3f4f6;
}
.preview-note-box{
  padding:10px 12px;
  border:1px solid rgba(100,116,139,.2);
  border-radius:10px;
  background:#f8fafc;
}
body.page-view-report .preview-meta-place{
  background:#f8fafc;
}
body.page-view-report .preview-place{
  display:grid;
  gap:4px;
}
body.page-view-report .preview-place-line{
  margin:0;
  line-height:1.32;
  overflow-wrap:anywhere;
  word-break:break-word;
}
body.page-view-report .preview-place-key{
  display:inline-block;
  min-width:104px;
  color:#64748b;
  margin-right:6px;
}
body.page-view-report .preview-place-val{
  color:#111827;
}
.preview-history-list{
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  gap:8px;
}
.preview-history-list li{
  padding:8px 10px;
  border:1px solid rgba(100,116,139,.18);
  border-radius:8px;
  background:#f8fafc;
}
body.page-fiber-view .fiber-meta-card .preview-meta-grid{margin-bottom:0}
body.page-fiber-view .fiber-stash-card{
  margin-bottom:12px;
}
body.page-fiber-view .fiber-stash-card:last-child{
  margin-bottom:0;
}
body.page-fiber-view .fiber-stash-card h4{
  margin:0 0 10px;
}
body.page-fiber-view .fiber-stash-card .stash-meta > div{
  padding:10px 12px;
  border:1px solid rgba(100,116,139,.18);
  border-radius:10px;
  background:#f8fafc;
}
.preview-breakword{
  overflow-wrap:anywhere;
  word-break:break-word;
}
/* PDF/druk: nagłówek arkusza dla podglądów */
.pdf-sheet-header{
  display:none;
  margin:0 0 14px;
  padding:10px 12px;
  border:1px solid rgba(100,116,139,.22);
  border-radius:10px;
  background:#f8fafc;
}
.pdf-brand{
  display:flex;
  align-items:center;
  gap:12px;
}
.pdf-logo{
  width:44px;
  height:44px;
  object-fit:contain;
}
.pdf-brand h2{
  margin:0 0 4px;
  font-size:18px;
}
@media print{
  @page{
    size:A4;
    margin:12mm;
  }
  html,body{
    background:#fff !important;
  }
  header.topbar,
  footer.foot,
  #msg,
  #backBtn,
  #editBtn,
  #btnCsv,
  #btnXls,
  #pdfBtn,
  #printBtn,
  #historyToggleBtn,
  #fiberHistoryToggleBtn{
    display:none !important;
  }
  body.page-view-report .pdf-sheet-header,
  body.page-fiber-view .pdf-sheet-header{
    display:block;
  }
  main{
    max-width:none !important;
    margin:0 !important;
    padding:0 !important;
  }
  .card{
    box-shadow:none !important;
    break-inside:avoid;
    page-break-inside:avoid;
    margin-bottom:10px;
  }
  .table,
  body.page-view-report .table,
  body.page-fiber-view .table{
    min-width:0 !important;
    width:100% !important;
  }
  .table-scroll{
    overflow:visible !important;
  }
}
body.page-view-report #tbl_inst th:nth-child(2),
body.page-view-report #tbl_inst td:nth-child(2),
body.page-view-report #tbl_bud th:nth-child(2),
body.page-view-report #tbl_bud td:nth-child(2){
  width:68px;
  min-width:68px;
  white-space:nowrap;
}
body.page-view-report #tbl_inst th:nth-child(3),
body.page-view-report #tbl_inst td:nth-child(3),
body.page-view-report #tbl_bud th:nth-child(3),
body.page-view-report #tbl_bud td:nth-child(3){
  width:84px;
  min-width:84px;
  white-space:nowrap;
  font-variant-numeric:tabular-nums;
}
/* Strony: listy i podgląd (spójne okna tabel) */
body.page-report-list{--table-min-w:960px}
body.page-fiber-list{--table-min-w:960px}
body.page-view-report{--table-min-w:940px}
body.page-fiber-view{--table-min-w:900px}
body.page-users{--table-min-w:1180px}
body.page-report-list .card,
body.page-fiber-list .card,
body.page-report-list .toolbar,
body.page-fiber-list .toolbar,
body.page-report-list .table-scroll,
body.page-fiber-list .table-scroll{
  width:100%;
}
body.page-report-list .table,
body.page-fiber-list .table,
body.page-view-report .table,
body.page-fiber-view .table,
body.page-users .table{
  width:100%;
  min-width:var(--table-min-w);
}
body.page-report-list .table th:last-child,
body.page-fiber-list .table th:last-child,
body.page-report-list .table td.actions-cell,
body.page-fiber-list .table td.actions-cell{
  text-align:right;
}
body.page-report-list .table td.actions-cell .row-actions,
body.page-fiber-list .table td.actions-cell .row-actions{
  justify-content:flex-end;
}
/* Strona: zapasy2.html (nowy zaciąg) */
body.page-zapasy2 .pos-list{display:flex;flex-direction:column;gap:12px}
body.page-zapasy2 .pos-card{border:1px solid var(--border);border-radius:12px;padding:12px;background:#fff}
body.page-zapasy2 .pos-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}
body.page-zapasy2 .pos-title{font-weight:700}
body.page-zapasy2 .gps-row{display:flex;gap:8px;align-items:center}
body.page-zapasy2 .gps-row .btn{white-space:nowrap}
body.page-zapasy2 .dropzone-sm{border:1px dashed #cbd5e1;border-radius:10px;padding:10px;background:#fafafa;cursor:pointer}
body.page-zapasy2 .dropzone-sm.drag{background:#eef6ff;border-color:#93c5fd}
body.page-zapasy2 .thumbs{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
body.page-zapasy2 .thumb{
  width:110px;
  height:80px;
  position:relative;
  border:1px solid #e5e7eb;
  border-radius:8px;
  overflow:hidden;
  background:#fff;
}
body.page-zapasy2 .thumb img{width:100%;height:100%;object-fit:cover}
body.page-zapasy2 .thumb .rm{position:absolute;top:4px;right:4px;font-size:11px}
body.page-zapasy2 .pos-insert{display:flex;align-items:center;justify-content:center}
body.page-zapasy2 .pos-insert .btn{width:100%}
body.page-zapasy2 .item-full{grid-column:1 / -1}
body.page-zapasy2 .is-auto-field[readonly]{
  background:#eef2f6;
  border-color:#cbd5e1;
  color:#334155;
  font-weight:600;
  cursor:default;
}
body.page-zapasy2 .is-auto-field[readonly]:focus{
  box-shadow:none;
}
body.page-zapasy2 input.is-auto-field[readonly]::-webkit-outer-spin-button,
body.page-zapasy2 input.is-auto-field[readonly]::-webkit-inner-spin-button{
  -webkit-appearance:none;
  margin:0;
}

/* Strona: users.html (zarządzanie użytkownikami) */
body.page-users .users-actions .btn{
  min-height:32px;
  padding:6px 10px;
  font-size:12px;
  border-radius:8px;
}
body.page-users .users-actions .btn-key{
  min-width:34px;
  padding:6px;
  font-size:14px;
  line-height:1;
}
body.page-users .table td.users-cell-actions .users-actions{
  justify-content:flex-end;
}

/* Strona: fiber_view.html (podgląd zaciągu) */
body.page-fiber-view .gal{display:flex;flex-wrap:wrap;gap:8px}
body.page-fiber-view .gal a{
  display:block;
  width:140px;
  height:100px;
  border:1px solid #e5e7eb;
  border-radius:8px;
  overflow:hidden;
  background:#fff;
}
body.page-fiber-view .gal img{width:100%;height:100%;object-fit:cover}
body.page-fiber-view #lok{
  display:grid;
  gap:2px;
}
body.page-fiber-view .location-line{
  margin:0;
  line-height:1.3;
  overflow-wrap:anywhere;
  word-break:break-word;
}
body.page-fiber-view .location-gps{
  font-variant-numeric:tabular-nums;
  color:#334155;
}
body.page-fiber-view .gps-map-links{
  display:inline-flex;
  flex-wrap:wrap;
  gap:6px;
  margin-left:8px;
  vertical-align:middle;
}
body.page-fiber-view .gps-map-link{
  display:inline-flex;
  align-items:center;
  padding:2px 8px;
  border:1px solid #cbd5e1;
  border-radius:999px;
  background:#f8fafc;
  color:#0f172a;
  font-size:11px;
  line-height:1.25;
}
body.page-fiber-view .gps-map-link:hover{
  background:#eef2f7;
}
body.page-fiber-view .meta-label{
  color:var(--muted);
  font-size:12px;
  margin-right:4px;
}
body.page-fiber-view .stash-text{
  display:grid;
  gap:3px;
}
body.page-fiber-view .stash-line{
  margin:0;
  line-height:1.3;
  overflow-wrap:anywhere;
  word-break:break-word;
}
body.page-fiber-view .stash-line-title{
  font-weight:700;
  color:#111827;
}
body.page-fiber-view .stash-line-gps{
  font-variant-numeric:tabular-nums;
}
body.page-fiber-view .stash-meta{
  display:grid;
  grid-template-columns:minmax(0,2fr) minmax(260px,1fr);
  gap:16px;
  align-items:stretch;
}
body.page-fiber-view .stash-side{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  align-items:stretch;
  align-content:stretch;
  height:100%;
}
body.page-fiber-view .stash-side > div{
  height:100%;
}
body.page-view-report .btn-print-soft,
body.page-fiber-view .btn-print-soft{
  background-color:#e5e7eb;
  border-color:#cbd5e1;
  color:#0f172a;
  box-shadow:0 1px 2px rgba(15,23,42,.12);
}
body.page-view-report .btn-print-soft:focus-visible,
body.page-fiber-view .btn-print-soft:focus-visible{
  background-color:#dbe1e8;
  border-color:#b9c4d3;
  box-shadow:0 6px 14px rgba(15,23,42,.18);
}
body.page-protocol-list .protocol-toolbar{
  width:100%;
  max-width:100%;
  grid-template-columns:minmax(0,1.7fr) minmax(0,1.1fr) minmax(0,0.8fr) minmax(0,1.1fr) minmax(0,0.9fr) minmax(0,0.9fr) minmax(0,0.9fr) auto auto;
}
body.page-protocol-list .protocol-toolbar > *,
body.page-protocol-contractors .protocol-toolbar > *,
body.page-protocol-executors .protocol-toolbar > *{
  min-width:0;
}
body.page-protocol-list .protocol-toolbar .btn,
body.page-protocol-contractors .protocol-toolbar .btn,
body.page-protocol-executors .protocol-toolbar .btn{
  width:100%;
}
body.page-protocol-list .table .protocol-group-row,
body.page-protocol-list .table .protocol-group-row:nth-child(even){
  background:#edf2f9;
}
body.page-protocol-list .protocol-group-row td{
  border-top:2px solid #d0d9e6;
  border-bottom:1px solid #d0d9e6;
  padding:11px 12px;
}
body.page-protocol-list .protocol-group-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
body.page-protocol-list .protocol-group-head strong{
  font-size:14px;
}
body.page-protocol-contractors .protocol-dictionary-toolbar,
body.page-protocol-executors .protocol-dictionary-toolbar{
  width:100%;
  max-width:100%;
  grid-template-columns:minmax(0,1fr) auto auto auto;
}
body.page-protocol-form .protocol-picker-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
  align-items:center;
}
body.page-protocol-form .protocol-scope-tools{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
  align-items:center;
  margin:0 0 10px;
}
body.page-protocol-form .protocol-scope-tools .btn{
  white-space:nowrap;
}
body.page-protocol-form #contractorInfo,
body.page-protocol-form #executorInfo{
  margin-top:6px;
}
body.page-protocol-form .protocol-template-note{
  margin-top:10px;
  padding:10px 12px;
  border:1px solid rgba(15,23,42,.12);
  border-radius:10px;
  background:linear-gradient(180deg,#f8fafc 0%,#f1f5f9 100%);
  color:#1e293b;
  font-size:13px;
  line-height:1.45;
}
body.page-protocol-form #executorPersonInfo{
  margin-top:6px;
}
body.page-protocol-form .protocol-cpe-box{
  border:1px solid var(--border);
  border-radius:10px;
  padding:8px;
  background:#fff;
  overflow-x:auto;
}
body.page-protocol-form .protocol-cpe-table{
  margin:0 0 8px;
}
body.page-protocol-form .protocol-cpe-box.is-wide .protocol-cpe-table{
  min-width:980px;
}
body.page-protocol-form .protocol-cpe-table th,
body.page-protocol-form .protocol-cpe-table td{
  vertical-align:middle;
}
body.page-protocol-form .protocol-cpe-table .cpe-col-lp{
  width:50px;
  text-align:center;
}
body.page-protocol-form .protocol-cpe-table .cpe-col-actions{
  width:56px;
  text-align:center;
}
body.page-protocol-form .protocol-cpe-table .cpe-col-qty{
  width:92px;
}
body.page-protocol-form .protocol-cpe-table input{
  width:100%;
  min-width:0;
}
body.page-protocol-view .protocol-cpe-view-table{
  margin:0;
}
body.page-protocol-form .protocol-logo-grid{
  align-items:flex-start;
}
body.page-protocol-form .protocol-logo-grid .item{
  margin-bottom:0;
}
.protocol-logo-preview-wrap{
  margin-top:8px;
  min-height:88px;
  display:flex;
  align-items:center;
}
.protocol-logo-preview{
  max-width:220px;
  max-height:110px;
  width:auto;
  height:auto;
  object-fit:contain;
  border:1px solid var(--border);
  border-radius:8px;
  background:#fff;
  padding:6px;
}
body.page-protocol-view .protocol-view-logos{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
body.page-protocol-view .protocol-view-logo-box{
  padding:10px 12px;
  border:1px solid rgba(100,116,139,.2);
  border-radius:10px;
  background:#f8fafc;
}
@media (max-width:1200px){
  body.page-protocol-list .protocol-toolbar{
    grid-template-columns:repeat(4,minmax(0,1fr));
  }
  body.page-protocol-contractors .protocol-dictionary-toolbar,
  body.page-protocol-executors .protocol-dictionary-toolbar{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media (max-width:980px){
  body.page-protocol-list .protocol-toolbar{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  body.page-protocol-form .protocol-picker-row{
    grid-template-columns:1fr;
  }
  body.page-protocol-form .protocol-scope-tools{
    grid-template-columns:1fr;
  }
}

/* ========== 09 Responsive ========== */
/* Globalne breakpointy layoutu i komponentów */
@media (max-width:960px){
  .form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:900px){
  .toolbar{grid-template-columns:1fr 1fr auto}
}
@media (max-width:860px){
  body.page-protocol-list .protocol-toolbar{
    grid-template-columns:1fr 1fr;
  }
  body.page-protocol-list .protocol-toolbar > *{
    min-width:0;
  }
  body.page-protocol-view .protocol-view-logos{
    grid-template-columns:1fr;
  }
  body.page-protocol-contractors .protocol-dictionary-toolbar,
  body.page-protocol-executors .protocol-dictionary-toolbar{
    grid-template-columns:1fr;
  }
  .topbar .wrap{
    min-height:unset;
    display:grid;
    grid-template-columns:1fr auto;
    align-items:center;
  }
  .topbar h1{font-size:30px;gap:10px}
  .brand-logo,
  .brand-fallback{
    width:36px;
    height:36px;
  }
  body.nav-ready nav.nav{
    display:none;
    grid-column:1 / -1;
    border-top:1px solid var(--border);
    padding-top:10px;
    width:100%;
    grid-template-columns:repeat(2,minmax(0,1fr));
    align-items:stretch;
    gap:8px;
  }
  body.nav-ready .nav-toggle{display:inline-flex}
  body.nav-ready.is-nav-open nav.nav{display:grid}
  body.nav-ready nav.nav .btn{width:100%}
  .topbar .nav .btn-logout{
    margin-left:0;
    order:0;
  }

  body.page-report-form .mobile-action-bar,
  body.page-zapasy2 .mobile-action-bar{
    display:block;
    position:fixed;
    left:0;
    right:0;
    bottom:0;
    z-index:35;
    padding:10px 12px calc(env(safe-area-inset-bottom, 0px) + 10px);
    background:rgba(246,247,251,.96);
    border-top:1px solid var(--border);
    backdrop-filter:blur(8px);
  }
  body.page-report-form .mobile-action-bar .bar-inner,
  body.page-zapasy2 .mobile-action-bar .bar-inner{
    max-width:var(--page-max);
    margin:0 auto;
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:8px;
  }
  body.page-report-form .mobile-action-bar .btn,
  body.page-zapasy2 .mobile-action-bar .btn{
    width:100%;
    min-height:42px;
    padding:8px 10px;
    font-size:13px;
    border-radius:9px;
  }
  body.page-report-form main,
  body.page-zapasy2 main{
    padding-bottom:132px;
  }
}
@media (max-width:700px){
  body.page-report-form .form-grid{grid-template-columns:1fr}
  body.page-report-form .gps-row{flex-direction:column;align-items:stretch}
  body.page-report-form .gps-row .btn{width:100%}
  body.page-view-report .report-meta-grid{grid-template-columns:1fr}
  body.page-view-report .preview-place-key{min-width:0}
  body.page-view-report .grid-4{grid-template-columns:1fr}
  body.page-view-report .table-scroll{overflow-x:hidden}
  body.page-view-report .table{
    width:100%;
    min-width:0;
    table-layout:fixed;
  }
  body.page-view-report .table th,
  body.page-view-report .table td{
    white-space:normal;
    overflow-wrap:anywhere;
    word-break:break-word;
  }
  body.page-zapasy2 .gps-row{flex-direction:column;align-items:stretch}
  body.page-zapasy2 .gps-row .btn{width:100%}
  .grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}
  .table th,
  .table td{
    padding:8px 10px;
    font-size:13px;
  }
  .row-actions{gap:4px}
  .row-actions .btn,
  .table td.nowrap .btn{
    min-height:34px;
    padding:7px 10px;
    font-size:13px;
    border-radius:8px;
  }
  .table .row-actions{gap:5px}
  .table .row-actions{
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:thin;
    padding-block:4px;
  }
  body.page-report-list .table .row-actions,
  body.page-fiber-list .table .row-actions,
  body.page-users .table .row-actions{
    overflow:visible;
    flex-wrap:wrap;
    padding-block:0;
  }
  body.page-report-list .table .row-actions .btn,
  body.page-fiber-list .table .row-actions .btn,
  body.page-users .table .row-actions .btn{
    flex:1 1 calc(50% - 5px);
    min-width:0;
    min-height:40px;
    padding:8px 10px;
  }
  .table-scroll-hint{
    display:block;
    margin-top:6px;
    margin-left:2px;
    font-size:12px;
    line-height:1.25;
  }
  .table-scroll.is-scrollable.can-scroll-left.can-scroll-right{
    box-shadow:inset 12px 0 12px -12px rgba(15,23,42,.45), inset -12px 0 12px -12px rgba(15,23,42,.45);
  }
  .table-scroll.is-scrollable.can-scroll-left:not(.can-scroll-right){
    box-shadow:inset 12px 0 12px -12px rgba(15,23,42,.45);
  }
  .table-scroll.is-scrollable.can-scroll-right:not(.can-scroll-left){
    box-shadow:inset -12px 0 12px -12px rgba(15,23,42,.45);
  }
  .view-switch{display:flex}
  body.page-report-list.view-cards .table-scroll,
  body.page-fiber-list.view-cards .table-scroll{
    display:none;
  }
  body.page-report-list.view-cards .list-cards,
  body.page-fiber-list.view-cards .list-cards{
    display:grid;
  }
  .list-card-actions .btn{
    flex:1 1 calc(50% - 5px);
    min-width:0;
    min-height:40px;
    padding:8px 10px;
  }
  .list-card-actions .btn:last-child{
    flex-basis:100%;
  }

  body.page-users{--table-min-w:0}
  body.page-users .table-scroll{
    overflow:visible;
    border:0;
    background:transparent;
  }
  body.page-users #tbl{
    width:100%;
    min-width:0;
    border-collapse:separate;
    border-spacing:0 10px;
  }
  body.page-users #tbl thead{
    display:none;
  }
  body.page-users #tbl tbody{
    display:block;
  }
  body.page-users #tbl tr{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px 10px;
    padding:10px;
    border:1px solid var(--border);
    border-radius:12px;
    background:#fff;
    box-shadow:0 2px 8px rgba(15,23,42,.04);
  }
  body.page-users #tbl td{
    display:block;
    padding:0;
    border-bottom:0;
    min-width:0;
  }
  body.page-users #tbl td::before{
    content:attr(data-label);
    display:block;
    font-size:11px;
    color:var(--muted);
    margin-bottom:2px;
  }
  body.page-users #tbl td.users-cell-actions{
    grid-column:1 / -1;
  }
  body.page-users #tbl td.users-cell-actions::before{
    margin-bottom:6px;
  }
  body.page-users .users-actions{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:6px;
    width:100%;
  }
  body.page-users .users-actions .btn{
    width:100%;
    min-width:0;
  }
  body.page-users .users-actions .btn-key{
    grid-column:1 / -1;
    max-width:120px;
  }

  #instalacyjne .item,
  #budowlane .item{
    grid-template-columns:1fr;
    gap:8px;
    padding:10px;
    border:1px solid var(--border);
    border-radius:10px;
  }
  #instalacyjne .item .unit,
  #budowlane .item .unit{
    justify-self:start;
  }
}
@media (max-width:560px){
  body.page-report-list,
  body.page-fiber-list,
  body.page-view-report,
  body.page-fiber-view{--table-min-w:620px}
  body.page-users{--table-min-w:0}
  body.page-magazyn .mag-table-wrap .table{
    min-width:560px;
  }
  body.page-magazyn .mag-table-wrap .table th,
  body.page-magazyn .mag-table-wrap .table td{
    padding:8px 10px;
    font-size:13px;
  }
  body.page-fiber-view .stash-meta{grid-template-columns:1fr}
  body.page-fiber-view .stash-side{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .grid-2,
  .grid-4{grid-template-columns:1fr}
  main{margin:16px auto;padding:0 12px 28px}
  .card{padding:12px;border-radius:10px;margin-bottom:14px}
  .topbar h1{font-size:26px}
  .brand-logo,
  .brand-fallback{
    width:32px;
    height:32px;
    border-radius:9px;
  }
  .toolbar{grid-template-columns:1fr}
  .toolbar > *{
    width:100%;
    max-width:100%;
    min-width:0;
  }
  .toolbar input[type="date"]{
    display:block;
    width:100%;
    max-width:100%;
    min-width:0;
    inline-size:100%;
    min-inline-size:0;
    max-inline-size:100%;
  }
  .toolbar input[type="date"]::-webkit-datetime-edit,
  .toolbar input[type="date"]::-webkit-date-and-time-value{
    padding:0;
    min-width:0;
    text-align:left;
  }
  body.page-report-form .form-grid .field,
  body.page-zapasy2 .grid-2 > .item{
    min-width:0;
  }
  body.page-report-form input[type="date"],
  body.page-zapasy2 input[type="date"]{
    display:block;
    width:100%;
    max-width:100%;
    min-width:0;
    inline-size:100%;
    min-inline-size:0;
    max-inline-size:100%;
    margin:0;
    padding:8px 10px;
    padding-right:10px;
    line-height:1.2;
    height:var(--fld-h);
    min-height:var(--fld-h);
    box-sizing:border-box;
    overflow:hidden;
  }
  body.page-report-form input[type="date"]::-webkit-datetime-edit,
  body.page-zapasy2 input[type="date"]::-webkit-datetime-edit,
  body.page-report-form input[type="date"]::-webkit-date-and-time-value,
  body.page-zapasy2 input[type="date"]::-webkit-date-and-time-value{
    padding:0;
    min-width:0;
    text-align:left;
  }
  body.page-report-list .toolbar,
  body.page-fiber-list .toolbar{
    display:flex;
    flex-direction:column;
    align-items:stretch;
  }
  body.page-report-list .toolbar > *,
  body.page-fiber-list .toolbar > *{
    width:100%;
    min-width:0;
    max-width:100%;
  }
  body.page-report-list .toolbar input[type="date"],
  body.page-fiber-list .toolbar input[type="date"]{
    margin:0;
    padding:8px 10px;
    padding-right:10px;
    line-height:1.2;
    height:var(--fld-h);
    min-height:var(--fld-h);
    box-sizing:border-box;
    overflow:hidden;
  }
  body.page-report-list .toolbar .btn,
  body.page-fiber-list .toolbar .btn{
    align-self:flex-start;
  }
  @supports (-webkit-touch-callout:none){
    body.page-report-form input[type="date"],
    body.page-zapasy2 input[type="date"]{
      width:-webkit-fill-available;
      max-width:100%;
      min-width:0;
      -webkit-appearance:auto;
      appearance:auto;
    }
    body.page-report-form input[type="date"]::-webkit-date-and-time-value,
    body.page-zapasy2 input[type="date"]::-webkit-date-and-time-value{
      text-align:left;
    }
    body.page-report-form input[type="date"]::-webkit-calendar-picker-indicator,
    body.page-zapasy2 input[type="date"]::-webkit-calendar-picker-indicator{
      margin:0;
      padding:0;
    }
    body.page-report-list .toolbar input[type="date"],
    body.page-fiber-list .toolbar input[type="date"]{
      width:-webkit-fill-available;
      max-width:100%;
      min-width:0;
      -webkit-appearance:auto;
      appearance:auto;
    }
    body.page-report-list .toolbar input[type="date"]::-webkit-date-and-time-value,
    body.page-fiber-list .toolbar input[type="date"]::-webkit-date-and-time-value{
      text-align:left;
    }
    body.page-report-list .toolbar input[type="date"]::-webkit-calendar-picker-indicator,
    body.page-fiber-list .toolbar input[type="date"]::-webkit-calendar-picker-indicator{
      margin:0;
      padding:0;
    }
  }
  .toolbar .btn{width:auto;justify-self:start}
  .toolbar-inline{gap:6px}
  .toolbar-inline .input-search{
    max-width:none;
    flex:1 1 100%;
  }
  .table{
    min-width:520px;
  }
  .login-logo,
  .login-logo-fallback{
    width:min(210px,78%);
    height:52px;
  }
  .table th,
  .table td{padding:7px 9px}
  .table .row-actions{gap:4px}
}
@media (max-width:900px) and (min-width:561px){
  body.page-report-list,
  body.page-fiber-list,
  body.page-view-report,
  body.page-fiber-view{--table-min-w:760px}
  body.page-users{--table-min-w:980px}
  body.page-fiber-view .stash-meta{grid-template-columns:1fr}
  body.page-fiber-view .stash-side{grid-template-columns:1fr 1fr}
}
@media (max-width:980px){
  body.page-magazyn.mag-worker-mode #magStatusSection{
    border:1px solid #cbd5e1;
    background:linear-gradient(180deg,#f8fafc 0%,#f1f5f9 100%);
  }
  body.page-magazyn.mag-worker-mode #magStatusSection #magUserInfo{
    margin:0;
    font-size:14px;
    font-weight:700;
    color:#0f172a;
  }
  body.page-magazyn.mag-worker-mode #scanOperationsSection{
    border:1px solid #bfdbfe;
    background:linear-gradient(180deg,#f8fbff 0%,#eef5ff 100%);
  }
  body.page-magazyn.mag-worker-mode #scanOperationsSection > h2{
    color:#1d4ed8;
  }
  body.page-magazyn.mag-worker-mode #workerReturnSection{
    border:1px solid #fcd9a1;
    background:linear-gradient(180deg,#fffaf0 0%,#fff3dd 100%);
  }
  body.page-magazyn.mag-worker-mode #workerReturnSection > h2{
    color:#b45309;
  }
  body.page-magazyn.mag-worker-mode #scanTeamStockSection{
    border:1px solid #b7e3cc;
    background:linear-gradient(180deg,#f4fdf8 0%,#e9f9f0 100%);
  }
  body.page-magazyn.mag-worker-mode #scanTeamStockSection > h2{
    color:#047857;
  }
  body.page-magazyn.mag-worker-mode #scanEventsSection{
    display:none !important;
  }
  body.page-magazyn .mag-headline-row{
    flex-direction:column;
    align-items:flex-start;
  }
  body.page-magazyn .mag-headline-row .mag-actions-row{
    width:100%;
  }
  body.page-magazyn .mag-headline-row .mag-actions-row .input-search{
    min-width:0;
    flex:1 1 100%;
  }
  body.page-magazyn .mag-doc-grid{
    grid-template-columns:1fr;
  }
  body.page-magazyn .mag-loc-grid{
    grid-template-columns:1fr;
  }
  body.page-magazyn .mag-material-form{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  body.page-magazyn .mag-doc-form{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  body.page-magazyn .mag-qr-controls{
    grid-template-columns:1fr;
  }
  body.page-magazyn .mag-scan-grid{
    grid-template-columns:1fr;
  }
  body.page-magazyn .mag-table-wrap .table{
    min-width:680px;
  }
  body.page-magazyn .mag-table-wrap .table.mag-mobile-cards{
    min-width:0;
    display:block;
    border-collapse:separate;
  }
  body.page-magazyn .mag-table-wrap .table.mag-mobile-cards thead{
    display:none;
  }
  body.page-magazyn .mag-table-wrap .table.mag-mobile-cards tbody{
    display:block;
  }
  body.page-magazyn .mag-table-wrap .table.mag-mobile-cards tbody tr{
    display:block;
    border:1px solid #d4dde8;
    border-radius:11px;
    background:#f9fbfd;
    padding:10px;
    margin:0 0 10px;
  }
  body.page-magazyn .mag-table-wrap .table.mag-mobile-cards tbody tr.mag-empty-row{
    display:block;
    border:0;
    background:transparent;
    padding:0;
    margin:0;
  }
  body.page-magazyn .mag-table-wrap .table.mag-mobile-cards tbody tr.mag-empty-row td{
    display:block;
    padding:10px;
  }
  body.page-magazyn .mag-table-wrap .table.mag-mobile-cards tbody td{
    display:grid;
    grid-template-columns:minmax(96px,120px) minmax(0,1fr);
    gap:8px;
    padding:6px 0;
    border:0;
  }
  body.page-magazyn .mag-table-wrap .table.mag-mobile-cards tbody td::before{
    content:attr(data-label);
    font-size:12px;
    font-weight:700;
    color:#64748b;
  }
  body.page-magazyn .mag-table-wrap .table.mag-mobile-cards .mag-worker-return-actions{
    justify-content:flex-start;
    flex-wrap:wrap;
    gap:8px;
  }
  body.page-magazyn .mag-table-wrap .table.mag-mobile-cards .mag-worker-return-actions input[type="number"]{
    width:120px;
    min-width:110px;
  }
  body.page-magazyn .mag-scan-box .mag-actions-row .btn{
    flex:1 1 220px;
  }
  body.page-magazyn .mag-worker-return-actions{
    justify-content:flex-start;
    flex-wrap:wrap;
  }
  body.page-magazyn .mag-feedback-form{
    grid-template-columns:1fr;
  }
  body.page-magazyn .mag-feedback-item{
    margin-left:calc(var(--reply-level, 0) * 14px);
  }
  body.page-magazyn .mag-feedback-item.is-reply::before{
    left:-10px;
  }
  body.page-magazyn .mag-feedback-item.is-reply::after{
    left:-10px;
    width:8px;
  }
  body.page-magazyn .mag-reply-controls{
    grid-template-columns:1fr;
  }
}
@media (max-width:800px){
  body.page-home .grid{grid-template-columns:1fr}
}
@media (max-width:420px){
  body.page-report-list,
  body.page-fiber-list,
  body.page-view-report,
  body.page-fiber-view{--table-min-w:560px}
  body.page-users{--table-min-w:0}
  body.page-report-list .table .row-actions .btn,
  body.page-fiber-list .table .row-actions .btn,
  body.page-users .table .row-actions .btn{
    flex:1 1 100%;
  }
  .table{min-width:480px}
  body.nav-ready nav.nav{grid-template-columns:1fr}
  body.page-report-form .mobile-action-bar .bar-inner,
  body.page-zapasy2 .mobile-action-bar .bar-inner{
    gap:6px;
  }
  body.page-report-form .mobile-action-bar .btn,
  body.page-zapasy2 .mobile-action-bar .btn{
    min-height:40px;
    padding:7px 8px;
    font-size:12px;
  }
}
@media (max-width:375px){
  .wrap,.container{padding:0 10px}
  .topbar .wrap{
    padding-top:10px;
    padding-bottom:10px;
    gap:8px;
  }
  .topbar h1{font-size:22px}
  .brand-logo,
  .brand-fallback{
    width:28px;
    height:28px;
    border-radius:8px;
  }
  .nav-toggle{
    width:40px;
    height:40px;
    border-radius:9px;
  }
  body.nav-ready nav.nav{padding-top:8px}
  body.nav-ready nav.nav .btn{
    min-height:36px;
    font-size:13px;
    border-radius:8px;
  }
  main{padding:0 10px 24px}
  .card{
    padding:10px;
    border-radius:9px;
    margin-bottom:12px;
  }
  .actions{gap:8px}
  .table{min-width:440px}
  .table th,.table td{padding:6px 8px;font-size:12px}
  .table .row-actions{gap:4px}
  .row-actions .btn{
    min-height:32px;
    padding:6px 9px;
    font-size:12px;
  }
  .login-page{padding:12px 8px}
  .login-card{padding:16px 14px}
  .login-logo,
  .login-logo-fallback{
    width:min(190px,82%);
    height:46px;
    min-width:120px;
  }
  body.page-magazyn .mag-phase-head{
    flex-direction:column;
    align-items:flex-start;
  }
  body.page-magazyn .mag-feedback-top{
    flex-wrap:wrap;
  }
  body.page-magazyn .mag-feedback-top .btn{
    width:100%;
  }
  body.page-magazyn .mag-material-form{
    grid-template-columns:1fr;
  }
  body.page-magazyn .mag-doc-form{
    grid-template-columns:1fr;
  }
  body.page-magazyn .mag-scan-row{
    grid-template-columns:1fr;
  }
  body.page-magazyn .mag-scan-row .btn{
    width:100%;
  }
  body.page-magazyn .mag-scan-box .mag-actions-row .btn{
    width:100%;
    flex:1 1 100%;
  }
  body.page-magazyn .mag-match-box.is-worker-simple .mag-worker-quick-name{
    font-size:18px;
  }
  body.page-magazyn .mag-match-box.is-worker-simple .mag-worker-quick-qty strong{
    font-size:30px;
  }
}

@media print{
  body.page-protocol-view{
    background:#fff;
  }
  body.page-protocol-view .topbar,
  body.page-protocol-view .foot,
  body.page-protocol-view #msg,
  body.page-protocol-view #historyCard{
    display:none !important;
  }
  body.page-protocol-view main{
    max-width:190mm;
    margin:0 auto;
    padding:0;
  }
  body.page-protocol-view .card{
    box-shadow:none;
    border:1px solid #111;
    border-radius:0;
    page-break-inside:avoid;
  }
  body.page-protocol-view .table th,
  body.page-protocol-view .table td{
    font-size:12px;
    border-color:#111;
  }
}

@media (hover:hover){
  body.page-view-report .btn-print-soft:hover,
  body.page-fiber-view .btn-print-soft:hover{
    background-color:#dbe1e8;
    border-color:#b9c4d3;
    box-shadow:0 6px 14px rgba(15,23,42,.18);
  }
}

/* ========== 10 Dostępność I Ruch ========== */
@media (prefers-reduced-motion:reduce){
  *{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
}
