:root{
  --teal:#3fa697; --teal-d:#34897c; --teal-l:#e7f4f1; --strip:#5cc4b3;
  --top:#2b2b2b; --top2:#222;
  --orange:#f5851f; --orange-d:#e0760f;
  --bg:#eef1f3; --panel:#ffffff; --panel2:#f5f6f7; --line:#d8dde1; --line2:#e6e9ec;
  --txt:#23282d; --muted:#6b7480; --danger:#d8453b; --ok:#16a34a; --warn:#ea580c;
  --radius:6px;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:"Segoe UI",system-ui,Arial,sans-serif;background:var(--bg);color:var(--txt);font-size:15px}
.boot{padding:40px;text-align:center;color:var(--muted)}

button{font-family:inherit;font-size:14px;cursor:pointer;border:1px solid var(--teal-d);border-radius:var(--radius);padding:9px 16px;background:var(--teal);color:#fff;transition:.12s;font-weight:600}
button:hover{background:var(--teal-d)}
button.ghost{background:#fff;border:1px solid var(--line);color:var(--txt);font-weight:500}
button.ghost:hover{background:var(--panel2)}
button.danger{background:var(--danger);border-color:#b5362e}
button.warn{background:var(--orange);border-color:var(--orange-d)}
button:disabled{opacity:.45;cursor:not-allowed}
button.pomoc{background:var(--orange);border-color:var(--orange-d);font-weight:700;letter-spacing:.5px}

input,select,textarea{font-family:inherit;font-size:14px;width:100%;padding:9px 11px;border-radius:var(--radius);border:1px solid var(--line);background:#fff;color:var(--txt)}
input:focus,select:focus,textarea:focus{outline:2px solid var(--teal)}
input:disabled,select:disabled,textarea:disabled{background:#f1f3f4;color:#666}
label{display:block;font-size:12px;color:var(--muted);margin:8px 0 3px;font-weight:600}
a{color:var(--teal-d)}
table{width:100%;border-collapse:collapse;background:#fff}
th,td{text-align:left;padding:9px 12px;border-bottom:1px solid var(--line2);font-size:13px}
th{color:var(--muted);font-weight:700;background:var(--panel2)}
.row{display:flex;gap:14px;flex-wrap:wrap}
.col{flex:1;min-width:0}
.card{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:16px;margin-bottom:14px}
.card h3{margin:0 0 12px;font-size:15px}
.card b{color:var(--teal-d)}
.muted{color:var(--muted)} .small{font-size:12px}
.tag{display:inline-block;padding:2px 10px;border-radius:999px;font-size:12px;font-weight:700;color:#fff}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.flex-between{display:flex;align-items:center;justify-content:space-between;gap:10px}
.hr{height:1px;background:var(--line2);margin:14px 0}
.empty{color:var(--muted);text-align:center;padding:30px}

/* ---------- Login ---------- */
.login-wrap{display:flex;align-items:center;justify-content:center;height:100vh;padding:20px;
  background:linear-gradient(135deg,#2b2b2b 0%,#34897c 100%)}
.login-box{width:380px;max-width:100%;background:#fff;border-radius:12px;padding:30px;box-shadow:0 18px 50px rgba(0,0,0,.35)}
.login-box h1{font-size:22px;margin:0 0 2px;color:var(--teal-d)}
.login-box .sub{color:var(--muted);font-size:13px;margin-bottom:20px}
.login-box button{width:100%;margin-top:16px;padding:12px}
.err{background:#fde8e6;color:#9b2620;padding:9px 12px;border-radius:6px;font-size:13px;margin-top:10px;border:1px solid #f5c6c0}
.ok-box{background:#e7f4f1;color:#1f6b5e;padding:9px 12px;border-radius:6px;font-size:13px;margin-top:10px;border:1px solid #b6e0d7}
.code-chip{font-family:"Consolas",monospace;font-weight:700;letter-spacing:2px;background:#fff5e6;border:1px solid #f0c98a;color:#9a5b00;padding:2px 8px;border-radius:5px}

/* ---------- SWD top bar ---------- */
.swd-top{display:flex;align-items:center;justify-content:space-between;background:var(--top);color:#fff;
  padding:0 18px;height:58px;border-bottom:4px solid var(--strip)}
.swd-top .seg{display:flex;align-items:center;gap:10px;font-size:13px}
.swd-top .user-ic{width:34px;height:34px;border-radius:50%;border:2px solid #777;display:flex;align-items:center;justify-content:center;font-size:16px;color:#bbb}
.swd-top .zlecenie{color:#7ddccb}
.swd-top .zlecenie .amb{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:#3a3a3a;margin-right:8px}
.swd-top .statuspill{display:flex;align-items:center;gap:8px;color:#9ad9cd}
.swd-top .statuspill .dot{width:18px;height:18px;border-radius:50%;border:2px solid var(--strip)}
.swd-top button{background:transparent;border:1px solid #555;color:#ddd;padding:6px 12px}
.swd-top button:hover{background:#3a3a3a}
.swd-top .clock{font-variant-numeric:tabular-nums;color:#9aa3ab}

/* ---------- SWD tab bar ---------- */
.swd-tabbar{display:flex;align-items:stretch;background:#fff;border-bottom:1px solid var(--line);height:74px}
.zrm-box{min-width:200px;padding:8px 18px;border-right:1px solid var(--line);border-bottom:3px solid var(--teal);
  display:flex;flex-direction:column;justify-content:center;text-align:center}
.zrm-box .kod{font-weight:700;font-size:17px;color:var(--teal-d)}
.zrm-box .st{font-size:13px;color:var(--txt);margin-top:2px}
.swd-tab{min-width:120px;padding:8px 18px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  cursor:pointer;border-right:1px solid var(--line2);color:#444;font-size:13px;background:#fff}
.swd-tab .ic{font-size:20px;line-height:1}
.swd-tab:hover{background:var(--panel2)}
.swd-tab.active{background:#fff;border-bottom:3px solid var(--teal);color:var(--teal-d);font-weight:700;margin-bottom:-1px}
.swd-spacer{flex:1}
.swd-tabbar .pomoc{align-self:center;margin:0 16px;padding:14px 26px}

/* ---------- Standard topbar (admin/dyspozytor) ---------- */
.top{display:flex;align-items:center;justify-content:space-between;padding:0 18px;height:56px;background:var(--top);color:#fff;border-bottom:4px solid var(--strip)}
.top .brand{font-weight:700;letter-spacing:.5px}
.top .brand small{font-weight:400;color:#9aa3ab;margin-left:8px}
.top .who{display:flex;align-items:center;gap:14px;font-size:13px}
.top .clock{font-variant-numeric:tabular-nums;color:#9aa3ab}
.top button{background:transparent;border:1px solid #555;color:#ddd}
.top button:hover{background:#3a3a3a}
.tabs{display:flex;gap:0;background:#fff;border-bottom:1px solid var(--line);flex-wrap:wrap}
.tabs button{background:#fff;color:#444;border:none;border-right:1px solid var(--line2);border-radius:0;padding:14px 22px;font-weight:600}
.tabs button.active{color:var(--teal-d);border-bottom:3px solid var(--teal);margin-bottom:-1px}
.tabs button:hover{background:var(--panel2)}
.wrap{padding:18px;max-width:1400px;margin:0 auto}

/* ---------- ZRM grid (dispatcher) ---------- */
.zrm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}
.zrm-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:14px;border-left:5px solid var(--line)}
.zrm-card .kod{font-weight:700;font-size:16px}
.zrm-card .meta{color:var(--muted);font-size:12px;margin:2px 0 10px}
.zrm-card .stat{display:flex;align-items:center;justify-content:space-between;gap:8px}
.zrm-card .since{font-size:11px;color:var(--muted);margin-top:6px}
.zrm-card.overdue{box-shadow:0 0 0 2px rgba(216,69,59,.5)}

/* ---------- Tablet: statusy SWD ---------- */
.tablet{max-width:1500px;margin:0 auto;padding:18px 22px}
.status-group-title{font-size:15px;font-weight:800;color:#333;margin:18px 0 8px;text-transform:uppercase;letter-spacing:.5px}
.status-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.status-tile{padding:26px 14px;border-radius:6px;font-weight:700;font-size:16px;text-align:center;line-height:1.25;
  background:#f3f4f5;border:1px solid var(--line);color:#3a3f44;cursor:pointer;transition:.1s}
.status-tile:hover:not(:disabled){background:#e9ebed}
.status-tile.active{background:var(--teal);border-color:var(--teal-d);color:#fff}
.status-tile.active::after{content:" ✔"}
.status-tile:disabled{background:#fafbfb;color:#c2c7cc;cursor:not-allowed;border-color:var(--line2)}
.status-restore{margin-top:22px;display:flex;justify-content:flex-end}
.status-restore button{background:#f3f4f5;color:#3a3f44;border:1px solid var(--line);padding:22px 30px;font-weight:700}

/* ---------- KMCR editor ---------- */
.kmcr-layout{display:flex;gap:0;min-height:calc(100vh - 140px)}
.kmcr-nav{width:230px;border-right:1px solid var(--line);background:#fff;padding:14px 12px;flex-shrink:0}
.kmcr-nav .lbl{font-weight:800;color:var(--teal-d);margin-bottom:10px}
.kmcr-nav button{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:#fff;border:1px solid var(--line);
  color:#444;margin-bottom:8px;padding:12px 12px;font-weight:600}
.kmcr-nav button .rom{color:var(--teal-d);font-weight:800;min-width:26px}
.kmcr-nav button.active{background:var(--teal);border-color:var(--teal-d);color:#fff}
.kmcr-nav button.active .rom{color:#fff}
.kmcr-main{flex:1;padding:18px 22px;min-width:0;background:var(--bg)}
.kmcr-bottomnav{display:flex;align-items:center;justify-content:space-between;background:#fff;border-top:1px solid var(--line);padding:12px 22px}
.kmcr-bottomnav .nav-arrow{display:flex;align-items:center;gap:12px;color:var(--teal-d);font-weight:700;font-size:13px;cursor:pointer}
.kmcr-bottomnav .nav-arrow .sq{width:46px;height:46px;border-radius:6px;background:#eef4f3;border:1px solid var(--teal);display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--teal-d)}
.kmcr-bottomnav .nav-arrow.disabled{opacity:.3;pointer-events:none}

.kzw-sec{border:1px solid var(--line);border-radius:8px;margin-bottom:12px;overflow:hidden;background:#fff}
.kzw-sec>.h{background:var(--panel2);padding:11px 16px;font-weight:700;font-size:14px;color:var(--teal-d);border-bottom:1px solid var(--line2)}
.kzw-sec>.b{padding:14px 16px}
.kv{display:grid;grid-template-columns:220px 1fr;gap:7px 16px;font-size:13px}
.kv .k{color:var(--muted);font-weight:600}
.timeline{font-size:12px}
.timeline div{padding:4px 0;border-bottom:1px dashed var(--line2)}

/* big status banner (kierownik zlecenie quick view) */
.status-big{padding:18px;border-radius:8px;text-align:center;margin-bottom:14px;color:#fff}
.status-big .lbl{font-size:13px;opacity:.9}
.status-big .val{font-size:24px;font-weight:800;margin-top:4px}

/* ---------- Modal ---------- */
.modal-bg{position:fixed;inset:0;background:rgba(20,25,30,.55);display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}
.modal{background:#fff;border-radius:10px;padding:22px;width:560px;max-width:100%;max-height:90vh;overflow:auto;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.modal h2{margin:0 0 14px;font-size:18px;color:var(--teal-d)}
.modal .actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}

/* ---------- Toast ---------- */
#toasts{position:fixed;right:18px;bottom:18px;z-index:200;display:flex;flex-direction:column;gap:8px}
.toast{background:#fff;border:1px solid var(--line);border-left:4px solid var(--teal);padding:12px 16px;border-radius:6px;min-width:240px;max-width:360px;box-shadow:0 8px 24px rgba(0,0,0,.2);animation:slidein .2s}
.toast.ok{border-left-color:var(--ok)} .toast.err{border-left-color:var(--danger)} .toast.warn{border-left-color:var(--orange)}
@keyframes slidein{from{transform:translateX(40px);opacity:0}to{transform:none;opacity:1}}

/* ---------- Alert wezwanie ---------- */
.alert-call{position:fixed;inset:0;background:rgba(216,69,59,.85);z-index:300;display:flex;align-items:center;justify-content:center;padding:20px;animation:flash 1s infinite}
@keyframes flash{0%,100%{background:rgba(216,69,59,.85)}50%{background:rgba(185,54,46,.92)}}
.alert-call .box{background:#fff;border-radius:12px;padding:26px;width:580px;max-width:100%}
.alert-call h2{margin:0 0 6px;color:var(--danger)}
.badge-list{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}

@media(max-width:760px){
  .status-grid{grid-template-columns:1fr 1fr}
  .kv{grid-template-columns:1fr}.grid2,.grid3{grid-template-columns:1fr}
  .kmcr-layout{flex-direction:column}.kmcr-nav{width:auto;border-right:none;border-bottom:1px solid var(--line);display:flex;gap:8px;overflow-x:auto}
  .kmcr-nav button{margin-bottom:0;white-space:nowrap}.kmcr-nav .lbl{display:none}
  .swd-tab{min-width:90px}
}
