*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #F5F4F0;--surface: #FFFFFF;--border: #E2E0D8;--border2: #C8C5BB;--text: #1A1916;--muted: #6B6860;--hint: #9E9B93;--accent: #E84B4B;--accent-dk: #C93D3D;--green: #3B6D11;--green-bg: #EAF3DE;--amber: #854F0B;--amber-bg: #FAEEDA;--red: #A32D2D;--red-bg: #FCEBEB;--blue: #185FA5;--blue-bg: #E6F1FB;--radius: 8px;--radius-lg: 12px;--mono: "IBM Plex Mono", monospace;--sans: "IBM Plex Sans", system-ui, sans-serif}body{font-family:var(--sans);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}.app{display:flex;flex-direction:column;min-height:100vh}.header{background:var(--surface);border-bottom:1px solid var(--border);padding:0 2rem;display:flex;align-items:center;justify-content:space-between;height:56px}.logo{display:flex;align-items:center;gap:10px;font-weight:600;font-size:15px}.logo-ps{background:#df0067;color:#fff;width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}.logo-mv{background:var(--accent);color:#fff;width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}.logo-arrow{color:var(--hint);font-size:18px}.layout{display:flex;flex:1}.sidebar{width:220px;background:var(--surface);border-right:1px solid var(--border);padding:1.5rem 0;flex-shrink:0}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 1.5rem;font-size:13px;color:var(--muted);cursor:pointer;border-left:3px solid transparent;transition:all .12s}.nav-item:hover{color:var(--text);background:var(--bg)}.nav-item.active{color:var(--text);font-weight:600;border-left-color:var(--accent);background:var(--bg)}.nav-icon{font-size:16px}.main{flex:1;padding:2rem;overflow-y:auto;max-width:1200px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;margin-bottom:1.25rem}.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.card-title{font-size:14px;font-weight:600;color:var(--text)}.stats{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:1.25rem}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.875rem 1rem}.stat-label{font-size:11px;color:var(--muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.04em}.stat-val{font-size:22px;font-weight:600}.stat-val.blue{color:var(--blue)}.stat-val.green{color:var(--green)}.stat-val.amber{color:var(--amber)}.stat-val.red{color:var(--red)}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-family:var(--sans);font-weight:500;border:1px solid var(--border2);border-radius:var(--radius);background:var(--surface);color:var(--text);cursor:pointer;white-space:nowrap}.btn:hover{background:var(--bg)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:hover{background:var(--accent-dk);border-color:var(--accent-dk)}.btn.success{background:var(--green);border-color:var(--green);color:#fff}.btn.success:hover{background:#27500a}.btn.sm{padding:4px 10px;font-size:12px}.btn-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column;gap:5px}.form-group.full{grid-column:1 / -1}.form-label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.form-input{padding:8px 10px;font-size:13px;font-family:var(--mono);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text)}.form-input:focus{outline:none;border-color:var(--border2)}.form-select{padding:8px 10px;font-size:13px;font-family:var(--sans);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text)}.form-select:focus{outline:none;border-color:var(--border2)}.form-check{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer}.save-row{display:flex;justify-content:flex-end;gap:8px;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}th{text-align:left;padding:8px 12px;font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);white-space:nowrap}td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg)}.mono{font-family:var(--mono);font-size:12px;color:var(--muted)}.badge{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600}.badge.synced{background:var(--green-bg);color:var(--green)}.badge.pending{background:var(--amber-bg);color:var(--amber)}.badge.error{background:var(--red-bg);color:var(--red)}.badge.new{background:var(--blue-bg);color:var(--blue)}.badge.skipped{background:var(--bg);color:var(--hint);border:1px solid var(--border)}.badge.matched{background:var(--green-bg);color:var(--green)}.badge.unmatched{background:var(--red-bg);color:var(--red)}.drop-zone{border:2px dashed var(--border2);border-radius:var(--radius-lg);padding:2.5rem 2rem;text-align:center;cursor:pointer;background:var(--bg);transition:all .15s}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--accent);background:#fff5f5}.drop-icon{font-size:40px;margin-bottom:.75rem}.drop-title{font-size:15px;font-weight:600;margin-bottom:4px}.drop-sub{font-size:12px;color:var(--muted)}.ean-pills{display:flex;flex-wrap:wrap;gap:5px;margin-top:.75rem;max-height:180px;overflow-y:auto}.ean-pill{font-family:var(--mono);font-size:11px;padding:3px 8px;border-radius:4px;border:1px solid var(--border);color:var(--muted)}.ean-pill.matched{background:var(--green-bg);border-color:#c0dd97;color:var(--green)}.ean-pill.unmatched{background:var(--red-bg);border-color:#f7c1c1;color:var(--red)}.progress-bar{height:5px;background:var(--bg);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .3s}.alert{padding:.75rem 1rem;border-radius:var(--radius);font-size:13px;margin-bottom:1rem;border:1px solid}.alert.success{background:var(--green-bg);color:var(--green);border-color:#c0dd97}.alert.error{background:var(--red-bg);color:var(--red);border-color:#f7c1c1}.alert.info{background:var(--blue-bg);color:var(--blue);border-color:#b5d4f4}.toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.search{padding:7px 10px;font-size:13px;font-family:var(--sans);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);width:200px}.search:focus{outline:none;border-color:var(--border2)}.log-entry{display:flex;align-items:flex-start;gap:10px;padding:9px 0;border-bottom:1px solid var(--border);font-size:13px}.log-entry:last-child{border-bottom:none}.log-time{font-family:var(--mono);font-size:11px;color:var(--hint);min-width:80px;margin-top:1px}.log-msg{flex:1;line-height:1.4}.log-empty{padding:1rem 0;font-size:13px;color:var(--muted)}.thumb{width:34px;height:34px;border-radius:6px;background:var(--bg);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--hint);flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.spin{display:inline-block;animation:spin .8s linear infinite}.ean-summary{display:flex;gap:1.5rem;flex-wrap:wrap;margin-top:.75rem;font-size:13px}.ean-summary b{color:var(--text)}
