:root{
  --bg:#0B0B0D; --bg2:#15151A; --card:#1C1C22; --line:#2A2A33;
  --gold:#D9B25A; --gold-soft:#E7CD8F; --text:#F3EFE6; --muted:#9A958A;
  --green:#3FB27A; --red:#E5604D; --amber:#E0A53A;
  --r:16px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;}
body{min-height:100vh}
.hidden{display:none !important}

#topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:8px;
  padding:calc(env(safe-area-inset-top) + 10px) 12px 10px;background:var(--bg);
  border-bottom:1px solid var(--line)}
#title{flex:1;text-align:center;font-weight:700;letter-spacing:.3px;color:var(--gold)}
.icon-btn{width:42px;height:42px;border:1px solid var(--line);background:var(--card);
  color:var(--text);border-radius:12px;font-size:22px;line-height:1}
.icon-btn:active{background:var(--bg2)}

#app{padding:16px;max-width:560px;margin:0 auto;
  padding-bottom:calc(env(safe-area-inset-bottom) + 24px)}

h1,h2{margin:0 0 12px}
h1{font-size:24px;color:var(--gold)}
h2{font-size:19px}
.muted{color:var(--muted)}
.center{text-align:center}
.row{display:flex;gap:10px}
.row>*{flex:1}
.spacer{height:14px}

/* Karty / przyciski menu */
.grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:8px}
.tile{background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:20px 14px;text-align:center;font-weight:700;font-size:16px}
.tile .ico{font-size:30px;display:block;margin-bottom:8px}
.tile.wide{grid-column:1/3}
.tile:active{background:var(--bg2);border-color:var(--gold)}
.tile.gold{background:linear-gradient(160deg,#2a2417,#1c1c22);border-color:var(--gold)}
.tile.gold .ico{color:var(--gold)}

button.btn{width:100%;padding:16px;border-radius:14px;border:1px solid var(--line);
  background:var(--card);color:var(--text);font-size:17px;font-weight:700}
button.btn:active{transform:translateY(1px)}
button.btn.primary{background:var(--gold);color:#1a1407;border-color:var(--gold)}
button.btn.green{background:var(--green);color:#06210f;border-color:var(--green)}
button.btn.ghost{background:transparent}
button.btn.danger{background:transparent;color:var(--red);border-color:var(--red)}
button.btn[disabled]{opacity:.5}

label{display:block;margin:14px 0 6px;font-size:14px;color:var(--muted)}
input,select{width:100%;padding:15px;border-radius:12px;border:1px solid var(--line);
  background:var(--bg2);color:var(--text);font-size:17px}
input:focus,select:focus{outline:none;border-color:var(--gold)}
.price-in{font-size:26px;font-weight:800;text-align:center;letter-spacing:.5px}

/* Lista pozycji */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:12px;margin-bottom:10px;display:flex;gap:12px;align-items:center}
.thumb{width:60px;height:60px;border-radius:10px;object-fit:cover;background:var(--bg2);
  flex:none;border:1px solid var(--line)}
.thumb.ph{display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--muted)}
.card .meta{flex:1;min-width:0}
.card .meta .nm{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card .meta .sub{color:var(--muted);font-size:13px;margin-top:2px}
.price{font-weight:800;color:var(--gold);white-space:nowrap}
.qty-badge{font-size:12px;padding:2px 8px;border-radius:20px;background:var(--bg2);
  border:1px solid var(--line);color:var(--muted)}
.qty-badge.low{color:var(--amber);border-color:var(--amber)}
.qty-badge.zero{color:var(--red);border-color:var(--red)}

/* Zdjęcie */
.photo-box{width:100%;aspect-ratio:1/1;max-height:46vh;border-radius:var(--r);
  border:1px dashed var(--line);background:var(--bg2);display:flex;align-items:center;
  justify-content:center;overflow:hidden;color:var(--muted);text-align:center}
.photo-box img{width:100%;height:100%;object-fit:cover}

/* Wynik weryfikacji */
.verdict{border-radius:var(--r);padding:14px;margin-top:14px;border:1px solid var(--line);
  background:var(--card)}
.verdict.ok{border-color:var(--green);background:rgba(63,178,122,.10)}
.verdict.mismatch,.verdict.unsure{border-color:var(--amber);background:rgba(224,165,58,.10)}
.verdict.unknown{border-color:var(--line)}
.verdict .vt{font-weight:800;font-size:16px;margin-bottom:4px}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.chip{padding:9px 12px;border-radius:20px;border:1px solid var(--line);background:var(--bg2);
  font-size:14px}
.chip.sel{border-color:var(--gold);color:var(--gold)}

/* PIN */
.pin-dots{display:flex;gap:12px;justify-content:center;margin:18px 0}
.pin-dots .d{width:14px;height:14px;border-radius:50%;border:2px solid var(--muted)}
.pin-dots .d.on{background:var(--gold);border-color:var(--gold)}
.keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px}
.key{padding:18px;font-size:24px;font-weight:700;text-align:center;border-radius:14px;
  background:var(--card);border:1px solid var(--line)}
.key:active{background:var(--bg2)}
.key.ok{background:var(--gold);color:#1a1407}

/* Tabela raportu */
table{width:100%;border-collapse:collapse;margin-top:10px}
th,td{padding:11px 8px;text-align:left;border-bottom:1px solid var(--line);font-size:15px}
th{color:var(--muted);font-weight:600;font-size:13px}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
tr.total td{font-weight:800;color:var(--gold);border-top:2px solid var(--line)}

.stat{display:flex;gap:10px;margin:8px 0 4px}
.stat .box{flex:1;background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:14px;text-align:center}
.stat .box .big{font-size:24px;font-weight:800;color:var(--gold)}
.stat .box .lbl{font-size:12px;color:var(--muted);margin-top:2px}

.list-row{display:flex;justify-content:space-between;gap:8px;padding:11px 4px;
  border-bottom:1px solid var(--line);align-items:center}
.list-row .amt{font-weight:700;color:var(--gold)}
.list-row .amt.neg{color:var(--red)}
.tag{font-size:11px;padding:2px 7px;border-radius:10px;border:1px solid var(--line);color:var(--muted)}
.tag.ret{color:var(--red);border-color:var(--red)}

.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%);z-index:50;
  background:var(--gold);color:#1a1407;padding:13px 20px;border-radius:30px;font-weight:700;
  box-shadow:0 8px 30px rgba(0,0,0,.5);max-width:90vw;text-align:center}
.toast.err{background:var(--red);color:#fff}

.brand{text-align:center;padding:18px 0 6px}
.brand .sun{font-size:40px}
.brand .nm{font-weight:800;letter-spacing:1px;color:var(--gold);margin-top:4px}
.brand .sub{color:var(--muted);font-size:13px;letter-spacing:3px;text-transform:uppercase}

/* Ekran „Dziś" */
.daybar{display:flex;align-items:center;justify-content:space-between;
  background:linear-gradient(160deg,#2a2417,#1c1c22);border:1px solid var(--gold);
  border-radius:var(--r);padding:16px;margin-bottom:14px}
.daybar .lbl{font-size:12px;color:var(--muted);letter-spacing:1px}
.daybar .big{font-size:30px;font-weight:800;color:var(--gold);margin-top:2px}
.daybar .cnt{font-size:22px;font-weight:800;color:var(--text);text-align:right;line-height:1}
.daybar .cnt span{display:block;font-size:11px;color:var(--muted);font-weight:600}

.menu-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.mini{flex:1 1 30%;min-width:30%;padding:12px 8px;border-radius:12px;border:1px solid var(--line);
  background:var(--card);color:var(--text);font-weight:600;font-size:14px}
.mini:active{background:var(--bg2)}

/* Wiersz pozycji sprzedaży */
.irow{display:flex;flex-wrap:wrap;align-items:center;gap:8px;background:var(--card);
  border:1px solid var(--line);border-radius:12px;padding:10px;margin-bottom:8px}
.irow .ig{flex:1 1 90px;font-size:20px;font-weight:700;text-align:center;padding:12px}
.irow .rmrow{flex:0 0 44px;height:46px;border-radius:10px;border:1px solid var(--line);
  background:var(--bg2);color:var(--red);font-size:16px}
.seg{display:flex;flex:1 1 100%;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.seg button{flex:1;padding:11px 6px;background:var(--bg2);color:var(--muted);border:none;
  font-size:14px;font-weight:600}
.seg button.on{background:var(--gold);color:#1a1407}
.chk{display:flex;align-items:center;gap:6px;margin:0;color:var(--muted);font-size:14px;flex:1 1 100%}
.chk input{width:20px;height:20px;flex:0 0 20px}

.total-bar{margin:16px 0 10px;padding:14px;border-radius:12px;background:var(--bg2);
  border:1px solid var(--line);font-size:18px;text-align:center}
.total-bar b{color:var(--gold);font-size:22px}
.disc-info{display:block;margin-top:4px;font-size:13px;color:var(--green)}

/* Plakietka „nieprzeczytane" */
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--red);
  margin-left:5px;vertical-align:middle}

/* Komunikator */
.chat-wrap{display:flex;flex-direction:column;gap:8px;max-height:64vh;overflow-y:auto;padding:6px 2px 10px}
.chat-empty{text-align:center;padding:30px 0}
.msg{display:flex}
.msg.me{justify-content:flex-end}
.bubble{max-width:82%;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:9px 12px}
.msg.me .bubble{background:#2a2417;border-color:var(--gold)}
.bubble .who{font-size:12px;color:var(--gold);font-weight:700;margin-bottom:2px}
.bubble .body{white-space:pre-wrap;word-break:break-word;font-size:15px;line-height:1.35}
.bubble .when{font-size:11px;color:var(--muted);margin-top:3px;text-align:right}
.composer{position:sticky;bottom:0;display:flex;gap:8px;background:var(--bg);
  padding:10px 0 calc(env(safe-area-inset-bottom) + 6px)}
.composer input{flex:1}
.composer .btn{width:auto;margin:0;flex:0 0 auto;padding:0 18px}

/* Uprawnienia (panel właściciela) */
.perms{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.perm{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:0;
  background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px 14px}
.perm span{display:flex;flex-direction:column}
.perm b{font-weight:600;color:var(--text);font-size:15px}
.perm small{color:var(--muted);font-size:12px;margin-top:1px}
.perm input{width:26px;height:26px;flex:0 0 26px;accent-color:var(--gold)}

/* Rozpoznawanie AI w sprzedaży */
.ai-head{margin:12px 0 6px;font-size:13px;color:var(--gold);font-weight:600}
.ai-match{display:flex;align-items:center;gap:10px;background:var(--card);border:1px solid var(--line);
  border-radius:12px;padding:9px;margin-bottom:7px}
.ai-match:active{border-color:var(--gold);background:var(--bg2)}
.ai-match .meta{flex:1;min-width:0}

/* Historia */
.hist-date{margin:16px 0 8px;font-size:13px;color:var(--muted);font-weight:600;
  border-bottom:1px solid var(--line);padding-bottom:4px}
.thumb.zoom{cursor:pointer}

/* Powiększenie zdjęcia (lightbox) */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.92);display:flex;
  align-items:center;justify-content:center;padding:16px}
.lightbox img{max-width:100%;max-height:100%;border-radius:10px}
.lb-close{position:absolute;top:calc(env(safe-area-inset-top) + 12px);right:16px;width:42px;height:42px;
  border-radius:50%;background:rgba(255,255,255,.15);color:#fff;font-size:22px;display:flex;
  align-items:center;justify-content:center}

/* Drzewo grup */
.grp-main{display:flex;justify-content:space-between;align-items:center;margin:14px 0 6px;
  font-weight:600;color:var(--gold);font-size:15px}
.grp-main .lnk{background:none;border:none;color:var(--muted);font-size:16px;padding:4px 10px}
.card.sub{margin-left:10px}
