/* FERA SKLADISTE — izgled (Faza 1). Desktop layout: lijevi izbornik + sadrzaj. */
:root {
  --g: #12734e; --gd: #0d5a3c; --gt: #e9f4ee;
  --o: #ef7d2a; --od: #d96716;
  --bg: #eef2f0; --card: #fff; --ink: #16211c; --mut: #64756c; --line: #e2e9e4;
  --amber-i: #9a6410; --amber-b: #fbf1dd; --red-i: #b23528; --red-b: #fbe9e6;
  --blue-i: #2a5f9e; --blue-b: #e8f0f8;
}
* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  color: var(--ink); background: var(--bg); -webkit-font-smoothing: antialiased; font-size: 14px;
}
#app { display: flex; min-height: 100vh; }

/* ── Lijevi izbornik ── */
.side { width: 210px; flex: none; background: linear-gradient(180deg, var(--g), var(--gd)); color: #fff; padding: 16px 12px; display: flex; flex-direction: column; gap: 4px; position: sticky; top: 0; height: 100vh; }
.brand { display: flex; align-items: center; gap: 10px; padding: 2px 8px 16px; }
.brand .lg { width: 38px; height: 38px; border-radius: 10px; background: linear-gradient(145deg, #f6923d, var(--o)); flex: none; display: grid; place-items: center; box-shadow: 0 4px 12px -3px rgba(0,0,0,.45); font-size: 18px; overflow: hidden; }
.brand .lg img { width: 100%; height: 100%; object-fit: cover; display: block; }
.brand b { font-size: 14.5px; line-height: 1.15; letter-spacing: .02em; }
.brand small { display: block; font-size: 10px; opacity: .75; font-weight: 600; }
.nav { display: flex; flex-direction: column; gap: 2px; font-size: 13.5px; }
.nav a { color: rgba(255,255,255,.84); padding: 9px 11px; border-radius: 9px; text-decoration: none; display: flex; gap: 10px; align-items: center; cursor: pointer; }
.nav a:hover { background: rgba(255,255,255,.09); }
.nav a i { width: 15px; height: 15px; border-radius: 4px; background: rgba(255,255,255,.35); flex: none; }
.nav a.on { background: rgba(255,255,255,.17); color: #fff; font-weight: 700; }
.nav a.on i { background: var(--o); }
.nav a.uskoro { opacity: .45; cursor: default; }
.nav a .fazica { margin-left: auto; font-size: 9px; background: rgba(255,255,255,.18); padding: 2px 6px; border-radius: 6px; letter-spacing: .04em; }
.who { margin-top: auto; font-size: 11.5px; opacity: .85; padding: 10px 8px 4px; border-top: 1px solid rgba(255,255,255,.18); display: flex; justify-content: space-between; align-items: center; gap: 6px; }
.who button { background: rgba(255,255,255,.14); color: #fff; border: none; border-radius: 7px; padding: 4px 9px; font-size: 11px; cursor: pointer; }

/* ── Sadrzaj ── */
.main { flex: 1; min-width: 0; padding: 22px 26px 40px; max-width: 1120px; }
.ph { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 16px; }
.ph h2 { margin: 0; font-size: 21px; letter-spacing: -.01em; }
.ph .sub { font-size: 12.5px; color: var(--mut); }

.btn { background: var(--g); color: #fff; border: none; border-radius: 10px; padding: 10px 16px; font-size: 13.5px; font-weight: 700; font-family: inherit; cursor: pointer; }
.btn:hover { background: var(--gd); }
.btn.o { background: var(--o); } .btn.o:hover { background: var(--od); }
.btn.gh { background: #fff; color: var(--gd); border: 1.5px solid var(--g); }
.btn.danger { background: #fff; color: var(--red-i); border: 1.5px solid #d98b7f; }
.btn:disabled { opacity: .5; cursor: default; }
.btn.sm { padding: 6px 11px; font-size: 12px; border-radius: 8px; }

.grid2 { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 12px; }
.row { display: flex; gap: 10px; flex-wrap: wrap; } .row > * { flex: 1; min-width: 160px; }
.num { font-variant-numeric: tabular-nums; }
.mut { color: var(--mut); } .sm { font-size: 12px; }

.stat { background: var(--card); border: 1px solid var(--line); border-radius: 13px; padding: 12px 14px; }
.stat small { display: block; font-size: 10.5px; text-transform: uppercase; letter-spacing: .06em; color: var(--mut); font-weight: 700; margin-bottom: 3px; }
.stat b { font-size: 21px; font-variant-numeric: tabular-nums; }
.stat.ok b { color: var(--gd); } .stat.warn b { color: var(--amber-i); } .stat.bad b { color: var(--red-i); }

.card { background: var(--card); border: 1px solid var(--line); border-radius: 13px; padding: 14px 16px; }
.li { background: var(--card); border: 1px solid var(--line); border-radius: 11px; padding: 11px 14px; display: flex; align-items: center; gap: 12px; margin-bottom: 8px; }
.li .tx { flex: 1; min-width: 0; }
.li .tx b { font-size: 13.5px; display: block; }
.li .tx small { font-size: 11.5px; color: var(--mut); }
.li.neaktivan { opacity: .55; }

.pill { display: inline-block; padding: 3px 10px; border-radius: 999px; font-size: 11px; font-weight: 700; white-space: nowrap; }
.pill.koop { background: var(--gt); color: var(--gd); }
.pill.dob { background: #fdeee0; color: var(--od); }
.pill.ok { background: var(--gt); color: var(--gd); }
.pill.hold { background: var(--amber-b); color: var(--amber-i); }
.pill.rej { background: var(--red-b); color: var(--red-i); }
.pill.open { background: var(--blue-b); color: var(--blue-i); }
.pill.gray { background: #eef0ec; color: #556; }

label { display: block; font-size: 10.5px; letter-spacing: .07em; text-transform: uppercase; color: var(--mut); font-weight: 700; margin: 10px 0 4px; }
input, select, textarea { width: 100%; background: #fff; border: 1px solid var(--line); border-radius: 9px; padding: 9px 12px; font-size: 13.5px; font-family: inherit; color: var(--ink); }
input:focus, select:focus, textarea:focus { outline: 2px solid var(--g); outline-offset: 0; border-color: var(--g); }

.alert { border-radius: 10px; padding: 10px 14px; font-size: 13px; margin: 10px 0; }
.alert.ok { background: var(--gt); color: var(--gd); }
.alert.err { background: var(--red-b); color: var(--red-i); }

.meter { height: 8px; border-radius: 4px; background: #e6ece8; overflow: hidden; flex: 1; }
.meter i { display: block; height: 100%; background: var(--g); border-radius: 4px; }
.bar { display: flex; align-items: center; gap: 10px; font-size: 12.5px; }

/* dvostruka polja "AI ocitao | Glavno" (identicna logika kao mobilni ulaz) */
.ai-grid { display: grid; grid-template-columns: 1fr 92px 112px; gap: 6px 8px; align-items: center; }
.ai-grid .h { font-size: 10px; text-transform: uppercase; letter-spacing: .06em; color: var(--mut); font-weight: 700; text-align: right; }
.ai-grid .naz { font-size: 13px; }
.ai-grid input { text-align: right; }
.ai-grid .aip { background: #f4f6f5; font-weight: 700; color: #556; }

.tabs { display: flex; gap: 6px; flex-wrap: wrap; }
.tabs b { padding: 7px 14px; border-radius: 999px; font-size: 12px; font-weight: 700; background: #e4ebe7; color: var(--mut); cursor: pointer; }
.tabs b.on { background: var(--g); color: #fff; }

.uskoro-box { border: 2px dashed var(--line); border-radius: 14px; padding: 34px 20px; text-align: center; color: var(--mut); background: rgba(255,255,255,.5); }
.uskoro-box b { display: block; font-size: 16px; color: var(--ink); margin-bottom: 6px; }

/* ── MOBITEL (kao mockup: gornja mini traka + donja traka s ikonama) ── */
.m-top, .m-bottom, .m-vise-pozadina { display: none; }

@media (max-width: 860px) {
  .side { display: none; }
  #app { flex-direction: column; }

  .m-top {
    display: flex; align-items: center; gap: 10px;
    background: linear-gradient(90deg, var(--g), var(--gd)); color: #fff;
    padding: 10px 14px; position: sticky; top: 0; z-index: 30;
  }
  .m-top .lg { width: 32px; height: 32px; border-radius: 9px; overflow: hidden; flex: none; }
  .m-top .lg img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .m-top b { font-size: 14px; letter-spacing: .02em; }
  .m-top b small { font-weight: 600; opacity: .75; font-size: 10.5px; margin-left: 4px; }
  .m-top .tko { margin-left: auto; font-size: 11.5px; background: rgba(255,255,255,.16); padding: 4px 10px; border-radius: 999px; }

  .m-bottom {
    display: flex; position: fixed; left: 0; right: 0; bottom: 0; z-index: 40;
    background: #fff; border-top: 1px solid var(--line);
    box-shadow: 0 -6px 18px -8px rgba(14,30,22,.25);
    padding: 4px 4px calc(4px + env(safe-area-inset-bottom));
  }
  .m-bottom a {
    flex: 1; display: flex; flex-direction: column; align-items: center; gap: 2px;
    padding: 7px 2px 5px; font-size: 10.5px; font-weight: 700; color: var(--mut);
    border-radius: 10px; cursor: pointer; -webkit-tap-highlight-color: transparent;
  }
  .m-bottom a .ik { font-size: 19px; line-height: 1; }
  .m-bottom a.on { color: var(--gd); background: var(--gt); }

  .m-vise-pozadina {
    display: block; position: fixed; inset: 0; z-index: 50; background: rgba(10,20,15,.45);
  }
  .m-vise {
    position: absolute; left: 10px; right: 10px; bottom: 68px;
    background: #fff; border-radius: 16px; padding: 10px;
    box-shadow: 0 24px 50px -16px rgba(5,20,12,.5);
  }
  .m-vise .naslov { display: block; font-size: 11px; text-transform: uppercase; letter-spacing: .07em; color: var(--mut); padding: 4px 10px 8px; }
  .m-vise a { display: block; padding: 12px 12px; border-radius: 10px; font-size: 14.5px; font-weight: 600; color: var(--ink); cursor: pointer; }
  .m-vise a.on { background: var(--gt); color: var(--gd); }
  .m-vise a:active { background: var(--gt); }
  .m-vise a.odjava { color: var(--red-i); border-top: 1px solid var(--line); border-radius: 0 0 10px 10px; margin-top: 4px; }

  /* sadrzaj: jedan stupac, prostor za donju traku, veci ciljevi za prst */
  .main { padding: 14px 12px calc(84px + env(safe-area-inset-bottom)); max-width: 100%; }
  .ph { margin-bottom: 12px; }
  .ph h2 { font-size: 18.5px; }
  .row > * { min-width: 100%; }            /* polja jedno ispod drugog */
  .row > [style*="flex:none"] { min-width: 0; } /* gumbi ostaju u redu */
  .btn { padding: 12px 16px; }              /* veci dodir */
  input, select, textarea { padding: 12px 12px; font-size: 15px; } /* 15px+ = iOS ne zumira */
  .tabs { overflow-x: auto; flex-wrap: nowrap; padding-bottom: 2px; }
  .tabs b { white-space: nowrap; }
  .grid2 { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .ai-grid { grid-template-columns: 1fr 76px 96px; }
  .ai-grid input { padding: 10px 8px; }
  .stat b { font-size: 18px; }
  .li { flex-wrap: wrap; }
  .li .tx { min-width: 100%; order: -1; } /* tekst preko cijele sirine, gumbi u redu ispod */
  .li .pill:first-child { order: -2; }
  .uskoro-box img.prazno { width: 100px; height: 100px; }
}

/* ispis naljepnice: na papir ide SAMO naljepnica */
@media print {
  body * { visibility: hidden; }
  .naljepnica-print, .naljepnica-print * { visibility: visible; }
  .naljepnica-print { position: fixed; left: 0; top: 0; width: 100mm; border: 1px solid #000 !important; border-radius: 0 !important; }
}

/* prijava — ilustracija skladista preko cijelog ekrana + kartica lijevo */
.login-wrap {
  min-height: 100vh; width: 100%; display: flex; align-items: center;
  padding: 24px 5vw;
  background: #0f5f41 url('../assets/login-ilustracija.png') center right / cover no-repeat;
}
@media (max-width: 760px) { .login-wrap { justify-content: center; padding: 20px; } }
.login {
  background: rgba(255,255,255,.96); backdrop-filter: blur(4px);
  border: 1px solid rgba(255,255,255,.6); border-radius: 20px; padding: 30px 28px;
  width: min(390px, 94vw); box-shadow: 0 30px 70px -24px rgba(5,25,16,.65);
}
.login .brand2 { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.login .lg { width: 52px; height: 52px; border-radius: 14px; background: linear-gradient(145deg, #f6923d, var(--o)); display: grid; place-items: center; font-size: 24px; overflow: hidden; flex: none; box-shadow: 0 8px 18px -6px rgba(180,90,20,.55); }
.login .lg img { width: 100%; height: 100%; object-fit: cover; display: block; }
.login h1 { margin: 0; font-size: 20px; letter-spacing: -.01em; }
.login h1 small { display: block; font-size: 11px; color: var(--mut); font-weight: 600; margin-top: 2px; }

/* prazna stanja s ilustracijom */
.uskoro-box img.prazno { width: 130px; height: 130px; object-fit: contain; display: block; margin: 0 auto 8px; }
