/* Mobile-first UI */
:root {
  --bg: #ffffff;
  --fg: #111;
  --muted: #6b7280;
  --border: #e5e7eb;
  --brand: #0a7;
  --danger: #b00020;
}

*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--fg);font:16px system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}
h1{font-size:22px;margin:0}
.app-header{padding:12px 16px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg);z-index:5}

.controls, .actions{display:flex;gap:8px;align-items:center;padding:10px 12px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.controls input[type=search]{flex:1;border:1px solid var(--border);border-radius:10px;padding:10px 12px}
select{border:1px solid var(--border);border-radius:10px;padding:10px 12px;background:#fff}
button, .fileBtn{border:1px solid var(--border);background:#f9fafb;border-radius:10px;padding:10px 12px}
button.secondary, .fileBtn.secondary{background:#fff}
button.danger{background:#fff;border-color:#f5c2c7;color:var(--danger)}
button#addBtn{background:var(--fg);color:#fff;border-color:var(--fg)}
button.link{border:none;background:transparent;color:var(--brand);padding:8px 12px}
button.strong{font-weight:700}
.small{padding:6px 8px;font-size:12px}
main{padding:6px 0 24px}
.list{list-style:none;margin:0;padding:0}
.row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-bottom:1px solid var(--border)}
.left{flex:1;min-width:0}
.name{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.meta{color:var(--muted);font-size:12px;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.right{text-align:right}
.qty{font-size:18px;font-weight:800}
.status{font-size:12px;color:var(--muted)}
.actions-inline{display:flex;gap:6px;margin-left:6px}
.empty{text-align:center;color:var(--muted);margin-top:24px}

.thumb{width:44px;height:44px;border-radius:8px;object-fit:cover;background:#f3f4f6;border:1px solid var(--border)}
.groupHeader{background:#f8fafc;color:#111;font-weight:700;padding:8px 12px;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}

.modal{position:fixed;inset:0;background:rgba(0,0,0,.2);display:flex;justify-content:center;align-items:flex-end}
.modal.hidden{display:none}
.sheet{width:100%;max-width:560px;background:#fff;border-top-left-radius:14px;border-top-right-radius:14px;box-shadow:0 -10px 30px rgba(0,0,0,.15)}
.sheet-full{max-width:none;height:90vh;display:flex;flex-direction:column}
.sheet-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);padding:8px 12px}
.sheet-body{padding:12px 14px;display:flex;flex-direction:column;gap:10px}
label{display:flex;flex-direction:column;gap:6px}
textarea{border:1px solid var(--border);border-radius:10px;padding:10px 12px;resize:vertical}
input[type=text], input[type=number]{border:1px solid var(--border);border-radius:10px;padding:10px 12px}
.row .row{gap:12px}
.row label{flex:1}
.row.space{justify-content:space-between;align-items:center}
.flex{flex:1}

.photoRow{display:flex;gap:12px;align-items:center}
.photoBtns{display:flex;gap:8px;flex-wrap:wrap}
.photoPreview{width:72px;height:72px;border-radius:10px;object-fit:cover;background:#f3f4f6;border:1px solid var(--border)}

.placeQtyList{display:flex;flex-direction:column;gap:8px}
.placeRow{display:flex;gap:10px;align-items:center}
.placeRow .placeName{flex:1}
.placeRow input{width:110px}

.placesCard{border:1px solid var(--border);border-radius:12px;padding:10px}

.muted{color:var(--muted)}

.scannerBody{position:relative;height:70vh;background:#000;display:flex;justify-content:center;align-items:center}
#video{max-width:100%;max-height:100%;border-radius:8px}
#overlay{position:absolute;inset:0;pointer-events:none}
.hint{position:fixed;left:12px;right:12px;bottom:12px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:12px 14px;box-shadow:0 10px 30px rgba(0,0,0,.12)}
.ios-share{display:inline-block;border:1px solid var(--border);border-radius:6px;padding:2px 6px;margin:0 4px}
