*{box-sizing:border-box}body{color:#1a1a1a;background:#f5f6f8;margin:0;font-family:-apple-system,Segoe UI,Roboto,sans-serif}a{color:#1b6ef3;text-decoration:none}button{cursor:pointer}.layout{max-width:960px;margin:0 auto;padding:24px}.nav{background:#fff;border-bottom:1px solid #e5e7eb;align-items:center;gap:16px;padding:12px 24px;display:flex}.nav .spacer{flex:1}.card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px}.scan-top{margin-top:16px}.scan-top--split{grid-template-columns:minmax(0,1.4fr) minmax(320px,1fr);align-items:start;gap:16px;display:grid}.scan-top__image{margin:0}.scan-top__side{flex-direction:column;gap:16px;min-width:0;display:flex}.scan-top__side>.card{margin-top:0!important}@media (width<=1100px){.scan-top--split{grid-template-columns:1fr}}.row{align-items:center;gap:12px;display:flex}input,button{background:#fff;border:1px solid #d0d5dc;border-radius:6px;padding:8px 12px;font-size:14px}button.primary{color:#fff;background:#1b6ef3;border-color:#1b6ef3}table{border-collapse:collapse;width:100%}th,td{text-align:left;border-bottom:1px solid #eee;padding:8px 12px;font-size:14px}.error{color:#b91c1c}.spinner{border:2px solid #d0d5dc;border-top-color:#1b6ef3;border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.lasso-overlay{z-index:100;background:#0000008c;justify-content:center;align-items:flex-start;padding:24px;display:flex;position:fixed;inset:0;overflow:auto}.lasso-modal{background:#f5f6f8;border-radius:10px;width:min(1100px,100%);padding:14px;box-shadow:0 10px 40px #0000004d}.lasso-head{border-bottom:1px solid #e5e7eb;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:10px;padding-bottom:10px;display:flex}.lasso-head__title{align-items:baseline;gap:10px;min-width:0;display:flex}.lasso-head__title h3{color:#111827;margin:0;font-size:15px}.lasso-head__file{color:#6b7280;text-overflow:ellipsis;white-space:nowrap;max-width:280px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:12px;overflow:hidden}.lasso-canvas-wrap{background:#111;border-radius:8px;justify-content:center;max-height:65vh;display:flex;position:relative;overflow:hidden}.lasso-canvas{cursor:crosshair;touch-action:none;width:auto;max-width:100%;height:auto;max-height:65vh;display:block}.lasso-hints{color:#4b5563;background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex-wrap:wrap;align-items:center;gap:6px 14px;margin-top:8px;padding:8px 10px;font-size:12px;display:flex}.lasso-hints span{white-space:nowrap;align-items:center;gap:4px;display:inline-flex}.lasso-kbd{color:#1f2937;background:#f3f4f6;border:1px solid #d1d5db;border-bottom-width:2px;border-radius:5px;justify-content:center;align-items:center;min-width:22px;height:22px;padding:0 6px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:11px;line-height:1;display:inline-flex}.lasso-footer{background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex-wrap:wrap;align-items:center;gap:8px;margin-top:10px;padding:10px 12px;display:flex}.lasso-footer__spacer{flex:1}.lasso-masks{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.lasso-mask{appearance:none;color:#374151;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:999px;align-items:center;gap:8px;padding:4px 10px 4px 4px;font-size:12px;transition:border-color .15s,box-shadow .15s,background .15s;display:inline-flex}.lasso-mask:hover{background:#f9fafb}.lasso-mask__thumb{background:repeating-conic-gradient(#eef0f3 0 25%, #fff 0 50%) 50% / 8px 8px;border-radius:999px;flex:none;justify-content:center;align-items:center;width:28px;height:28px;display:flex;overflow:hidden}.lasso-mask__thumb img{object-fit:contain;width:100%;height:100%}.lasso-mask__thumb-empty{color:#cbd5e1;font-size:14px}.lasso-mask__body{align-items:baseline;gap:6px;display:inline-flex}.lasso-mask__idx{font-family:ui-monospace,SFMono-Regular,monospace;font-weight:600}.lasso-mask__pts{color:#9ca3af;align-items:center;gap:3px;font-size:11px;display:inline-flex}.lasso-mask__ok{color:#059669;padding-right:4px;font-weight:700}.lasso-mask--done{color:#065f46;background:#ecfdf5;border-color:#a7f3d0}.lasso-mask--done .lasso-mask__pts{color:#059669}.lasso-mask--active{color:#92400e;background:#fffbeb;border-color:#f59e0b;box-shadow:0 0 0 2px #f59e0b33}.lasso-mask--active .lasso-mask__pts{color:#b45309}.details-head{border-bottom:1px solid #eef0f3;flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:14px;padding-bottom:12px;display:flex}.details-title{color:#111827;letter-spacing:-.01em;align-items:baseline;gap:8px;font-size:15px;font-weight:600;display:flex}.details-title__hint{color:#9ca3af;letter-spacing:0;font-size:12px;font-weight:400}.seg{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;gap:2px;padding:3px;display:inline-flex}.seg__btn{appearance:none;color:#4b5563;cursor:pointer;background:0 0;border:0;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;transition:background .15s,color .15s;display:inline-flex}.seg__btn:hover{color:#111827}.seg__btn--active{color:#111827;background:#fff;font-weight:600;box-shadow:0 1px 2px #0f172a14}.seg__count{color:#6b7280;background:#fff;border:1px solid #e5e7eb;border-radius:999px;justify-content:center;align-items:center;min-width:20px;height:18px;padding:0 6px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:11px;line-height:1;display:inline-flex}.seg__btn--active .seg__count{color:#1d4ed8;background:#eff6ff;border-color:#bfdbfe}.details-foot{border-top:1px solid #eef0f3;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:14px;padding-top:12px;display:flex}.details-foot__count{color:#6b7280;font-size:13px}.pager{align-items:center;gap:6px;display:inline-flex}.pager__btn{appearance:none;color:#374151;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;padding:0;font-size:14px;line-height:1;display:inline-flex}.pager__btn:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db}.pager__btn:disabled{color:#d1d5db;cursor:not-allowed}.pager__info{color:#6b7280;text-align:center;min-width:88px;padding:0 6px;font-size:13px}.pred-list{flex-direction:column;gap:8px;display:flex}.pred-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;grid-template-columns:72px minmax(0,1fr) minmax(0,1.15fr);align-items:stretch;gap:18px;height:112px;padding:12px 14px;transition:border-color .15s,box-shadow .15s;display:grid;overflow:hidden}.pred-card:hover{border-color:#c7d2fe;box-shadow:0 2px 10px #1b6ef30f}.pred-card__id{flex-direction:column;justify-content:center;align-items:center;gap:6px;display:flex}.pred-id-badge{color:#1f2937;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:999px;justify-content:center;align-items:center;min-width:44px;height:40px;padding:0 10px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:13px;font-weight:600;display:inline-flex}.pred-id-shelf{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;font-size:11px}.pred-card__main{flex-direction:column;justify-content:center;gap:8px;min-width:0;display:flex}.pred-sku-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.pred-sku{word-break:break-all;font-family:ui-monospace,SFMono-Regular,monospace;font-size:16px;font-weight:700}.pred-sku--ok{color:#047857}.pred-sku--unk{color:#b91c1c}.pred-sku--shelf{color:#1d4ed8}.pred-sku--empty{color:#b45309}.pred-pill{letter-spacing:.5px;text-transform:uppercase;border-radius:999px;padding:3px 8px;font-size:10px;font-weight:600;line-height:1}.pred-pill--ok{color:#065f46;background:#d1fae5}.pred-pill--unk{color:#991b1b;background:#fee2e2}.pred-pill--shelf{color:#1d4ed8;background:#dbeafe}.pred-pill--empty{color:#92400e;background:#fef3c7}.pred-conf{align-items:center;gap:8px;display:flex}.pred-conf__label{color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;min-width:32px;font-size:10px}.pred-conf__bar{background:#f3f4f6;border-radius:3px;flex:1;height:6px;overflow:hidden}.pred-conf__fill{background:linear-gradient(90deg,#34d399,#059669);border-radius:3px;height:100%;transition:width .3s}.pred-conf__fill--unk{background:linear-gradient(90deg,#f87171,#dc2626)}.pred-conf__fill--shelf{background:linear-gradient(90deg,#60a5fa,#2563eb)}.pred-conf__fill--empty{background:linear-gradient(90deg,#fbbf24,#d97706)}.pred-conf__value{text-align:right;color:#1f2937;min-width:48px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:12px;font-weight:600}.pred-meta{color:#9ca3af;flex-wrap:wrap;gap:14px;font-size:11px;display:flex}.pred-meta code{color:#6b7280;font-family:ui-monospace,SFMono-Regular,monospace}.pred-matches{flex-direction:column;justify-content:center;gap:5px;min-width:0;display:flex}.pred-matches__label{color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;font-size:10px}.pred-match{grid-template-columns:minmax(60px,auto) minmax(0,1fr) 46px;align-items:center;gap:8px;display:grid}.pred-match__sku{text-overflow:ellipsis;white-space:nowrap;color:#374151;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:4px;max-width:140px;padding:2px 6px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:11px;overflow:hidden}.pred-match__sku--win{color:#065f46;background:#d1fae5;border-color:#a7f3d0;font-weight:600}.pred-match__bar{background:#f3f4f6;border-radius:2px;height:4px;overflow:hidden}.pred-match__fill{background:#cbd5e1;border-radius:2px;height:100%;transition:width .3s}.pred-match__fill--win{background:#10b981}.pred-match__score{color:#4b5563;text-align:right;font-family:ui-monospace,SFMono-Regular,monospace;font-size:11px}.pred-no-matches{color:#9ca3af;font-size:12px;font-style:italic}.pred-stats{flex-direction:column;justify-content:center;gap:6px;display:flex}.pred-stat{grid-template-columns:minmax(72px,auto) 1fr;align-items:baseline;gap:10px;display:grid}.pred-stat__label{color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;font-size:10px}.pred-stat__value{color:#1f2937;font-family:ui-monospace,SFMono-Regular,monospace;font-size:12px;font-weight:600}.pred-stat__value--muted{color:#9ca3af;font-weight:400}.pred-empty{color:#6b7280;border:1px dashed #e5e7eb;border-radius:8px;justify-content:center;align-items:center;padding:40px 16px;font-size:13px;display:flex}@media (width<=720px){.pred-card{grid-template-columns:56px 1fr;height:auto;min-height:112px}.pred-matches,.pred-stats{border-top:1px dashed #e5e7eb;grid-column:1/-1;padding-top:8px}}.cat-toolbar{background:#fff;border:1px solid #e5e7eb;border-radius:10px;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:14px;padding:12px 14px;display:flex}.cat-toolbar__search{background:#fafafa;border:1px solid #e5e7eb;border-radius:8px;flex:1;min-width:200px;padding:8px 12px;font-size:14px}.cat-toolbar__search:focus{background:#fff;border-color:#bfdbfe;outline:none}.cat-add{background:#fff;border:1px solid #e5e7eb;border-radius:10px;gap:10px;margin-bottom:14px;padding:16px;display:grid}.cat-add__head{justify-content:space-between;align-items:center;gap:8px;display:flex}.cat-add__title{color:#111827;margin:0;font-size:14px;font-weight:600}.cat-add__row{flex-wrap:wrap;gap:10px;display:flex}.cat-add__row input{flex:1;min-width:160px}.cat-add__hint{color:#9ca3af;font-size:12px}.cat-list{flex-direction:column;gap:12px;display:flex}.sku-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;align-items:stretch;gap:20px;padding:16px;transition:border-color .15s,box-shadow .15s;display:flex}.sku-card:hover{border-color:#c7d2fe;box-shadow:0 2px 14px #1b6ef30f}.sku-card__left{border-right:1px solid #eef0f3;flex-direction:column;flex:none;gap:14px;width:260px;padding-right:20px;display:flex}.sku-card__right{flex:1;align-items:center;min-width:0;display:flex}.sku-card__head{align-items:flex-start;gap:12px;display:flex}.sku-card__icon{color:#3730a3;letter-spacing:-.02em;background:#eef2ff;border-radius:10px;flex:none;justify-content:center;align-items:center;width:44px;height:44px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:17px;font-weight:700;display:flex}.sku-card__icon--comp{color:#991b1b;background:#fee2e2}.sku-card__meta{flex:1;min-width:0}.sku-card__title{color:#111827;overflow-wrap:anywhere;font-size:15px;font-weight:600;line-height:1.35}.sku-card__sub{color:#6b7280;flex-wrap:wrap;align-items:center;gap:8px;margin-top:6px;font-size:12px;display:flex}.sku-card__code{color:#374151;background:#f3f4f6;border-radius:4px;padding:1px 6px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:11px}.sku-card__count{color:#4b5563;font-size:11px}.sku-card__actions{flex-wrap:wrap;gap:6px;margin-top:auto;display:flex}.sku-card__actions button{color:#374151;background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:6px 10px;font-size:12px}.sku-card__actions button:hover{background:#f9fafb;border-color:#d1d5db}.sku-card__actions button.danger{color:#b91c1c}.sku-card__actions button.danger:hover{background:#fef2f2;border-color:#fecaca}@media (width<=720px){.sku-card{flex-direction:column;gap:14px}.sku-card__left{border-bottom:1px solid #eef0f3;border-right:0;width:auto;padding-bottom:14px;padding-right:0}}.crop-strip{scrollbar-width:thin;gap:8px;width:100%;padding:2px 2px 8px;display:flex;overflow:auto hidden}.crop-strip::-webkit-scrollbar{height:8px}.crop-strip::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.crop-strip::-webkit-scrollbar-track{background:0 0}.crop-strip__empty{color:#9ca3af;align-items:center;padding:0 4px;font-size:13px;font-style:italic;display:flex}.crop-strip__err{color:#b91c1c;align-items:center;padding:0 4px;font-size:13px;display:flex}.crop-tile{background:repeating-conic-gradient(#eef0f3 0 25%, #fff 0 50%) 50% / 16px 16px;border:1px solid #e5e7eb;border-radius:10px;flex:none;width:96px;height:96px;padding:0;position:relative;overflow:hidden}.crop-tile img{object-fit:contain;width:100%;height:100%;display:block}.crop-tile__placeholder{color:#9ca3af;background:#f9fafb;justify-content:center;align-items:center;font-size:11px;display:flex;position:absolute;inset:0}.crop-tile__del{color:#fff;cursor:pointer;opacity:0;background:#111111a6;border:0;border-radius:999px;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-size:11px;line-height:1;transition:opacity .15s,transform .15s,background .15s;display:inline-flex;position:absolute;top:4px;right:4px;transform:scale(.85)}.crop-tile:hover .crop-tile__del,.crop-tile:focus-within .crop-tile__del{opacity:1;transform:scale(1)}.crop-tile__del:hover{background:#dc2626}.crop-tile__edit{color:#fff;cursor:pointer;opacity:0;background:#111111a6;border:0;border-radius:999px;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-size:12px;line-height:1;transition:opacity .15s,transform .15s,background .15s;display:inline-flex;position:absolute;top:4px;right:30px;transform:scale(.85)}.crop-tile:hover .crop-tile__edit,.crop-tile:focus-within .crop-tile__edit{opacity:1;transform:scale(1)}.crop-tile__edit:hover{background:#1b6ef3}.crop-editor .crop-editor__canvas-wrap{background:repeating-conic-gradient(#e5e7eb 0% 25%,#f3f4f6 0% 50%) 50%/20px 20px;border-radius:8px;justify-content:center;align-items:center;height:65vh;padding:12px;display:flex;position:relative;overflow:auto}.crop-editor__canvas{touch-action:none;cursor:none;image-rendering:pixelated;background:0 0;flex:none;margin:auto}.crop-editor__zoom{align-items:center;gap:2px;margin-left:12px;display:inline-flex}.crop-editor__zoom button{min-width:28px;padding:4px 8px}.crop-editor__zoom-val{font-variant-numeric:tabular-nums;text-align:center;min-width:56px}.crop-editor__cursor{pointer-events:none;mix-blend-mode:difference;border:1px solid #fff;border-radius:50%;position:fixed;transform:translate(-50%,-50%);box-shadow:0 0 0 1px #000000bf,inset 0 0 0 1px #000000bf}.crop-editor__brush{color:#374151;align-items:center;gap:8px;font-size:13px;display:inline-flex}.crop-editor__brush input[type=range]{width:140px}.crop-editor__brush-val{text-align:right;font-variant-numeric:tabular-nums;color:#6b7280;min-width:42px}.crop-tile--skel{background:linear-gradient(90deg,#f3f4f6 0%,#eef0f3 50%,#f3f4f6 100%) 0 0/200% 100%;border-color:#eef0f3;animation:1.2s ease-in-out infinite crop-skel}@keyframes crop-skel{0%{background-position:200% 0}to{background-position:-200% 0}}.crop-tile--add{color:#4b5563;cursor:pointer;background:#fafafa;border:1px dashed #cbd5e1;flex-direction:column;justify-content:center;align-items:center;gap:4px;transition:background .15s,border-color .15s,color .15s;display:flex}.crop-tile--add:hover{color:#1b6ef3;background:#eff6ff;border-color:#1b6ef3}.crop-tile__plus{font-size:24px;font-weight:400;line-height:1}.crop-tile__add-label{font-size:11px}.cat-empty{text-align:center;color:#6b7280;background:#fff;border:1px dashed #e5e7eb;border-radius:10px;padding:48px 24px}.cat-empty__title{color:#374151;margin-bottom:4px;font-size:15px;font-weight:600}.cat-empty__hint{color:#6b7280;font-size:13px}.mselect{min-width:240px;display:inline-block;position:relative}.mselect__btn{appearance:none;color:#1f2937;cursor:pointer;text-align:left;background:#fff;border:1px solid #d0d5dc;border-radius:8px;align-items:center;gap:10px;width:100%;padding:8px 10px 8px 12px;font-size:14px;line-height:1.2;transition:border-color .15s,box-shadow .15s,background .15s;display:flex}.mselect__btn:hover:not(:disabled){border-color:#bfdbfe}.mselect__btn:focus-visible,.mselect--open .mselect__btn{border-color:#1b6ef3;outline:none;box-shadow:0 0 0 3px #1b6ef326}.mselect__btn:disabled{color:#9ca3af;cursor:not-allowed;background:#f9fafb}.mselect__value{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.mselect__value--placeholder{color:#9ca3af}.mselect__meta{color:#6b7280;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:999px;flex:none;padding:1px 6px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:11px}.mselect__chev{color:#6b7280;flex:none;width:16px;height:16px;transition:transform .15s}.mselect--open .mselect__chev{color:#1b6ef3;transform:rotate(180deg)}.mselect__panel{z-index:20;background:#fff;border:1px solid #e5e7eb;border-radius:10px;flex-direction:column;gap:6px;max-height:320px;padding:6px;display:flex;position:absolute;top:calc(100% + 4px);left:0;right:0;box-shadow:0 10px 30px #0f172a1f}.mselect__search{color:#1f2937;background:#fafafa;border:1px solid #e5e7eb;border-radius:7px;width:100%;padding:7px 10px;font-size:13px}.mselect__search:focus{background:#fff;border-color:#bfdbfe;outline:none}.mselect__list{scrollbar-width:thin;flex:auto;min-height:0;margin:0;padding:2px;list-style:none;overflow-y:auto}.mselect__list::-webkit-scrollbar{width:8px}.mselect__list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.mselect__item{cursor:pointer;color:#1f2937;border-radius:7px;align-items:center;gap:10px;padding:8px 10px;font-size:13px;display:flex}.mselect__item:hover,.mselect__item--active{background:#f3f4f6}.mselect__item--selected{color:#1d4ed8;background:#eff6ff}.mselect__item--selected:hover,.mselect__item--selected.mselect__item--active{background:#dbeafe}.mselect__item-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:500;overflow:hidden}.mselect__item-meta{color:#6b7280;flex:none;font-family:ui-monospace,SFMono-Regular,monospace;font-size:11px}.mselect__item--selected .mselect__item-meta{color:#1d4ed8}.mselect__item-check{color:#1d4ed8;opacity:0;flex:none;width:14px;height:14px;transition:opacity .1s}.mselect__item--selected .mselect__item-check{opacity:1}.mselect__empty{text-align:center;color:#9ca3af;padding:16px;font-size:12px;font-style:italic}
