*{box-sizing:border-box;margin:0;padding:0}:root{--primary:#3b82f6;--primary-dark:#1d4ed8;--danger:#ef4444;--success:#22c55e;--warning:#f59e0b;--bg:#f1f5f9;--surface:#fff;--border:#e2e8f0;--text:#1e293b;--text-muted:#64748b;--nav-height:64px;--header-height:56px}@media (prefers-color-scheme:dark){:root{--bg:#0f172a;--surface:#1e293b;--border:#334155;--text:#f1f5f9;--text-muted:#94a3b8}}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:system-ui,-apple-system,sans-serif;font-size:16px}#root{flex-direction:column;max-width:480px;min-height:100svh;margin:0 auto;display:flex}.app{flex-direction:column;min-height:100svh;display:flex}.app-header{z-index:10;height:var(--header-height);background:var(--primary);align-items:center;padding:0 16px;display:flex;position:sticky;top:0}.app-header h1{color:#fff;letter-spacing:-.3px;font-size:20px;font-weight:700}.app-main{padding-bottom:var(--nav-height);flex:1;overflow-y:auto}.bottom-nav{width:100%;max-width:480px;height:var(--nav-height);background:var(--surface);border-top:1px solid var(--border);z-index:10;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.bottom-nav a{color:var(--text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;font-size:11px;text-decoration:none;transition:color .15s;display:flex}.bottom-nav a.active{color:var(--primary)}.nav-icon{font-size:22px}.page{padding:16px}.page-title{margin-bottom:16px;font-size:18px;font-weight:600}.search-input{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);border-radius:10px;outline:none;margin-bottom:16px;padding:10px 14px;font-size:15px}.search-input:focus{border-color:var(--primary)}.category-section{margin-bottom:20px}.category-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:8px;font-size:13px;font-weight:600}.item-list{flex-direction:column;gap:8px;list-style:none;display:flex}.item-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;justify-content:space-between;align-items:center;gap:8px;padding:12px 14px;display:flex}.item-card.selectable{cursor:pointer}.item-card.selectable:active{background:var(--bg)}.item-info{flex-direction:column;gap:2px;display:flex}.item-name{font-size:15px;font-weight:500}.item-date{color:var(--text-muted);font-size:12px}.item-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.item-qty{color:var(--primary);font-size:14px;font-weight:600}.badge{border-radius:20px;padding:2px 7px;font-size:11px;font-weight:600}.badge-soon{color:#92400e;background:#fef3c7}.badge-expired{color:#991b1b;background:#fee2e2}.form{flex-direction:column;gap:14px;display:flex}.form-label{flex-direction:column;gap:6px;font-size:14px;font-weight:500;display:flex}.form-input{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:10px;outline:none;width:100%;padding:10px 12px;font-size:15px}.form-input:focus{border-color:var(--primary)}.form-row{gap:12px;display:flex}.hint{color:var(--text-muted);font-size:12px}.btn{cursor:pointer;border:none;border-radius:10px;flex:1;padding:12px 20px;font-size:15px;font-weight:600;transition:opacity .15s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-secondary{background:var(--border);color:var(--text)}.selected-item{background:var(--bg);border-radius:10px;flex-direction:column;gap:4px;padding:12px 14px;font-size:14px;display:flex}.loading,.empty{text-align:center;color:var(--text-muted);padding:40px 0}.error{color:var(--danger);font-size:14px}.barcode-row{gap:8px;display:flex}.btn-scan{border:1px solid var(--border);background:var(--surface);cursor:pointer;border-radius:10px;flex-shrink:0;padding:10px 14px;font-size:20px}.btn-scan:active{background:var(--bg)}.scanner-overlay{z-index:100;background:#000000b3;align-items:flex-end;display:flex;position:fixed;inset:0}.scanner-modal{background:var(--surface);border-radius:20px 20px 0 0;width:100%;max-width:480px;margin:0 auto;overflow:hidden}.scanner-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px;font-weight:600;display:flex}.scanner-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:4px 8px;font-size:18px}.scanner-viewport{background:#000;position:relative}.scanner-video{object-fit:cover;width:100%;max-height:280px;display:block}.scanner-crosshair{border:2px solid var(--primary);border-radius:8px;width:200px;height:120px;margin:auto;position:absolute;inset:0;box-shadow:0 0 0 9999px #0006}.favorites-section{margin-bottom:20px}.favorites-list{flex-wrap:wrap;gap:8px;display:flex}.fav-chip{background:var(--surface);border:1px solid var(--border);cursor:pointer;color:var(--text);border-radius:20px;padding:6px 14px;font-size:13px;transition:background .15s}.fav-chip:active{background:var(--primary);color:#fff;border-color:var(--primary)}.log-list{flex-direction:column;gap:8px;list-style:none;display:flex}.log-item{background:var(--surface);border:1px solid var(--border);border-radius:12px;justify-content:space-between;align-items:center;gap:8px;padding:12px 14px;display:flex}.log-left{flex-direction:column;gap:4px;display:flex}.log-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;display:flex}.log-action{font-size:12px;font-weight:600}.log-add{color:#16a34a}.log-remove{color:#dc2626}
