:root{
  --primary:#1a73e8; --accent:#29a3ec; --bg:#f1f5f9; --card:#fff; --text:#0f172a;
  --muted:#64748b; --line:#e2e8f0; --ok:#16a34a; --warn:#d97706; --danger:#dc2626;
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--font);font-size:15px}
button{font-family:inherit;cursor:pointer}
a{color:var(--primary)}
.hidden{display:none!important}

/* brend */
.brand{display:flex;align-items:center;gap:10px}
.brand svg{width:34px;height:34px;border-radius:8px;display:block}
.brand .bt{font-weight:700;font-size:19px;color:#0f172a;letter-spacing:-.3px}
.brand .bt small{font-weight:600;color:var(--muted);font-size:13px;margin-left:6px}

/* login */
#gate{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:linear-gradient(135deg,#1a73e8,#29a3ec)}
.lcard{background:#fff;border-radius:18px;padding:34px 30px;width:100%;max-width:380px;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.lcard .brand{justify-content:center;margin-bottom:6px}
.lcard h1{font-size:18px;margin:14px 0 4px;text-align:center}
.lcard p.sub{color:var(--muted);text-align:center;margin:0 0 20px;font-size:13.5px}
.field{margin-bottom:13px}
.field label{display:block;font-size:12.5px;color:var(--muted);margin-bottom:5px;font-weight:600}
input,select,textarea{width:100%;padding:10px 12px;border:1.5px solid var(--line);border-radius:9px;font-size:14.5px;font-family:inherit;outline:none;background:#fff;color:var(--text)}
input:focus,select:focus,textarea:focus{border-color:var(--primary)}
textarea{resize:vertical;min-height:64px}
.btn{background:var(--primary);color:#fff;border:none;padding:11px 18px;border-radius:9px;font-weight:600;font-size:14.5px}
.btn:hover{filter:brightness(1.05)}
.btn.full{width:100%}
.btn.ghost{background:#fff;color:var(--text);border:1.5px solid var(--line)}
.btn.sm{padding:6px 11px;font-size:13px;border-radius:7px}
.btn.warn{background:var(--warn)} .btn.danger{background:var(--danger)} .btn.ok{background:var(--ok)}
.err{color:var(--danger);font-size:13px;margin-top:8px}

/* app shell */
header.top{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30;
  display:flex;align-items:center;gap:16px;padding:10px 18px;flex-wrap:wrap}
header.top .sp{flex:1}
header .who{color:var(--muted);font-size:13px}
.tabs{display:flex;gap:6px;background:#fff;border-bottom:1px solid var(--line);padding:0 14px;position:sticky;top:55px;z-index:20}
.tab{padding:12px 16px;border:none;background:none;font-weight:600;color:var(--muted);border-bottom:3px solid transparent;font-size:14.5px}
.tab.active{color:var(--primary);border-bottom-color:var(--primary)}
main{max-width:1180px;margin:0 auto;padding:18px}

/* dashboard */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px;margin-bottom:18px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:15px 17px}
.kpi .n{font-size:28px;font-weight:800;line-height:1}
.kpi .l{color:var(--muted);font-size:13px;margin-top:6px}
.kpi.warn .n{color:var(--warn)} .kpi.alert .n{color:var(--danger)}

/* toolbar */
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px}
.toolbar .grow{flex:1;min-width:160px}
.seg{display:flex;gap:0;border:1.5px solid var(--line);border-radius:9px;overflow:hidden;background:#fff}
.seg button{border:none;background:#fff;padding:8px 12px;font-size:13px;color:var(--muted);font-weight:600}
.seg button.active{background:var(--primary);color:#fff}

/* table/list */
.panel{background:var(--card);border:1px solid var(--line);border-radius:13px;overflow:hidden}
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:top}
th{background:#f8fafc;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.4px;position:sticky;top:0}
tr.row:hover{background:#f8fafc;cursor:pointer}
.bnum{font-weight:700;color:var(--primary);white-space:nowrap}
.empty{padding:34px;text-align:center;color:var(--muted)}
.muted{color:var(--muted)} .nowrap{white-space:nowrap}

/* badge */
.badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:11.5px;font-weight:700;white-space:nowrap}
.b-otvoren{background:#dbeafe;color:#1d4ed8}
.b-u_radu{background:#fef3c7;color:#92400e}
.b-resen{background:#dcfce7;color:#166534}
.b-razveden,.b-arhiviran{background:#e2e8f0;color:#475569}
.b-primljeno{background:#dbeafe;color:#1d4ed8}
.b-dodeljeno{background:#fef3c7;color:#92400e}
.b-zavedeno{background:#dcfce7;color:#166534}
.b-preuzeto{background:#e2e8f0;color:#475569}

/* modal */
.ov{position:fixed;inset:0;background:rgba(15,23,42,.5);display:flex;align-items:flex-start;justify-content:center;padding:30px 16px;z-index:50;overflow:auto}
.modal{background:#fff;border-radius:16px;width:100%;max-width:620px;box-shadow:0 24px 70px rgba(0,0,0,.3)}
.modal .mh{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--line)}
.modal .mh h3{margin:0;font-size:16px;flex:1}
.modal .mb{padding:18px 20px}
.modal .mf{padding:14px 20px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end}
.x{border:none;background:none;font-size:22px;color:var(--muted);line-height:1}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid2 .full{grid-column:1/3}
@media(max-width:560px){.grid2{grid-template-columns:1fr}.grid2 .full{grid-column:auto}}

/* akti list */
.akt{border:1px solid var(--line);border-radius:11px;padding:12px 14px;margin-bottom:10px;background:#fff}
.akt .ah{display:flex;gap:8px;align-items:center;margin-bottom:5px}
.scanlink{font-size:12.5px}
#toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);background:#0f172a;color:#fff;padding:11px 18px;border-radius:10px;font-size:14px;z-index:80;box-shadow:0 10px 30px rgba(0,0,0,.3)}

/* onboarding = isti centriran layout kao login */
#onboard{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#1a73e8,#29a3ec)}
#onboard .lcard{max-width:440px}
/* header: naziv firme + uloga chip */
.firmaName{font-weight:700;color:#0f172a;font-size:15px;margin-left:4px}
.chip{display:inline-block;padding:2px 9px;border-radius:999px;font-size:11px;font-weight:700;background:#dbeafe;color:#1d4ed8;text-transform:uppercase;letter-spacing:.4px}
.modal.wide{max-width:780px}
h4{font-size:14.5px}
/* profil meni (gornji desni ugao) */
.profile{position:relative}
.profBtn{display:flex;align-items:center;gap:5px;background:#fff;border:1.5px solid var(--line);border-radius:999px;padding:4px 8px 4px 4px}
.profBtn:hover{border-color:var(--primary)}
.avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;font-weight:700;font-size:12px;display:flex;align-items:center;justify-content:center}
.pcaret{color:var(--muted);font-size:11px}
.profMenu{position:absolute;right:0;top:46px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 14px 40px rgba(0,0,0,.18);min-width:250px;padding:6px;z-index:60}
.pm-head{padding:9px 11px 10px}
.pm-name{font-weight:700;font-size:13.5px;word-break:break-all}
.pm-firma{color:var(--muted);font-size:12px;margin-top:2px}
.pm-item{display:block;width:100%;text-align:left;border:none;background:none;padding:9px 11px;border-radius:8px;font-size:14px;color:var(--text);cursor:pointer}
.pm-item:hover{background:#f1f5f9}
.pm-item.danger{color:var(--danger)}
.pm-sep{height:1px;background:var(--line);margin:5px 4px}
