:root{--bg: #f7f7f5;--surface: #ffffff;--border: #e5e5e2;--text: #1a1a1a;--muted: #6b6b68;--primary: #c96342;--primary-hover: #b55533;--success: #2f7a4b;--success-bg: #e8f3ec;--error: #b3261e;--error-bg: #fdecea;--warn: #a36800;--warn-bg: #fdf3dc;--radius: 10px;--shadow: 0 1px 2px rgba(0,0,0,.04), 0 2px 4px rgba(0,0,0,.03);--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}.page{max-width:880px;margin:0 auto;padding:48px 20px 80px}.hero{text-align:center;margin-bottom:40px}.hero h1{font-size:32px;font-weight:600;margin:0 0 8px;letter-spacing:-.02em}.hero .sub{color:var(--muted);margin:0;font-size:15px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px 28px;margin-bottom:20px;box-shadow:var(--shadow);transition:opacity .2s}.card[aria-disabled=true]{opacity:.55;pointer-events:none}.card h2{font-size:17px;font-weight:600;margin:0 0 18px;display:flex;align-items:center;gap:10px}.card-header-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}.card-header-row h2{margin:0}.generate-row{margin-top:18px;padding-top:18px;border-top:1px solid var(--border);display:flex;align-items:center;gap:14px;flex-wrap:wrap}.gen-hint{margin:0;font-size:13px;color:var(--muted);flex:1;min-width:200px}.gen-hint.warn{color:var(--error)}.gen-hint.ready{color:var(--success)}.step{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--text);color:#fff;border-radius:50%;font-size:12px;font-weight:600}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:40px 20px;text-align:center;cursor:pointer;transition:all .15s;background:#fafaf8}.drop-zone:hover,.drop-zone.dragging{border-color:var(--primary);background:#fef6f2}.drop-zone p{margin:6px 0}.icon-lg{width:40px;height:40px;color:var(--muted);margin-bottom:8px}.file-info{margin-top:16px;padding:12px 16px;background:var(--success-bg);border:1px solid #c6e4d1;border-radius:8px;display:flex;align-items:center;gap:10px;font-size:14px}.file-info .name{font-weight:600}.file-info .size{color:var(--muted)}.grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:500}label em{font-style:normal;color:var(--muted);font-weight:400}input[type=text],select{font-family:var(--font);font-size:14px;padding:9px 12px;border:1px solid var(--border);border-radius:7px;background:#fff;transition:border-color .15s,box-shadow .15s;width:100%}input:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #c9634226}input.invalid{border-color:var(--error)}.multiselect{position:relative}.multiselect-btn{font-family:var(--font);font-size:14px;padding:9px 12px;border:1px solid var(--border);border-radius:7px;background:#fff;width:100%;text-align:left;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px;transition:border-color .15s,box-shadow .15s}.multiselect-btn:hover{border-color:#cfcfca}.multiselect-btn:focus,.multiselect.open .multiselect-btn{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #c9634226}.multiselect-btn .caret-icon{width:16px;height:16px;flex-shrink:0;color:var(--muted);transition:transform .15s}.multiselect.open .caret-icon{transform:rotate(180deg)}#companyBtnLabel{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left}#companyBtnLabel.has-selection{color:var(--text)}.multiselect-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px #00000014;z-index:20;max-height:320px;overflow:hidden;display:flex;flex-direction:column}.multiselect-menu-actions{display:flex;gap:12px;padding:8px 12px;border-bottom:1px solid var(--border);background:#fafaf8}.link-btn{background:none;border:none;color:var(--primary);font-size:12.5px;cursor:pointer;padding:0;font-family:var(--font);font-weight:500}.link-btn:hover{text-decoration:underline}.multiselect-options{overflow-y:auto;padding:4px 0}.multiselect-option{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;gap:10px;padding:8px 14px;cursor:pointer;font-size:14px;font-weight:400}.multiselect-option:hover{background:#fafaf8}.multiselect-option input[type=checkbox]{margin:0;cursor:pointer;width:15px;height:15px;accent-color:var(--primary)}.multiselect-option .company-code{font-family:SF Mono,Monaco,Consolas,monospace;font-size:13.5px}.actions{display:flex;gap:10px;flex-wrap:wrap}.btn{font-family:var(--font);font-size:14px;font-weight:500;padding:9px 18px;border-radius:7px;cursor:pointer;border:1px solid transparent;transition:all .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-ghost{background:#fff;border-color:var(--border);color:var(--text)}.btn-ghost:hover:not(:disabled){background:#f0f0ee}.btn-sm{font-size:13px;padding:6px 12px}.status{margin-top:16px;padding:14px 16px;border-radius:8px;font-size:13.5px;line-height:1.55;white-space:pre-wrap}.status.success{background:var(--success-bg);border:1px solid #c6e4d1;color:var(--success)}.status.error{background:var(--error-bg);border:1px solid #f5c6c2;color:var(--error)}.status.warn{background:var(--warn-bg);border:1px solid #f3d9a3;color:var(--warn)}.status.info{background:#eaf2fb;border:1px solid #c9dbf4;color:#1c5ba3}.status h3{margin:0 0 6px;font-size:14px;font-weight:600}.status ul{margin:6px 0 0 18px;padding:0}.status li{margin-bottom:4px}.preview-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}.preview-header h2{margin:0;font-size:17px;font-weight:600}.preview-table-wrap{border:1px solid var(--border);border-radius:8px;overflow:hidden;max-height:400px;overflow-y:auto}.preview-table{width:100%;border-collapse:collapse;font-size:11.5px;table-layout:fixed}.preview-table thead th{background:#fafaf8;text-align:left;padding:8px 6px;font-weight:600;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:1;font-size:11px;text-transform:uppercase;letter-spacing:.02em;color:var(--muted)}.preview-table tbody td{padding:6px;border-bottom:1px solid #f0f0ee;word-break:break-word;overflow-wrap:anywhere;vertical-align:top;line-height:1.35}.preview-table tbody tr:hover{background:#fafaf8}.preview-table th.c-pos,.preview-table td.c-pos{width:32px;text-align:right;color:var(--muted)}.preview-table th.c-item,.preview-table td.c-item{width:70px;font-family:SF Mono,Monaco,Consolas,monospace;font-size:11px}.preview-table th.c-de,.preview-table td.c-de,.preview-table th.c-en,.preview-table td.c-en,.preview-table th.c-local,.preview-table td.c-local{width:auto}.preview-table th.c-ean,.preview-table td.c-ean{width:92px;font-family:SF Mono,Monaco,Consolas,monospace;font-size:10.5px}.preview-table th.c-unit,.preview-table td.c-unit{width:38px;text-align:center}.preview-table th.c-cuou,.preview-table td.c-cuou{width:72px;text-align:right;font-variant-numeric:tabular-nums}.preview-table th.c-price,.preview-table td.c-price{width:80px;text-align:right;font-variant-numeric:tabular-nums}.preview-table th.c-origin,.preview-table td.c-origin{width:42px;text-align:center}.preview-table th.c-avail,.preview-table td.c-avail{width:44px;text-align:right}.preview-table th.c-cust,.preview-table td.c-cust{width:52px;text-align:center;font-family:SF Mono,Monaco,Consolas,monospace;font-size:11px}.lang-note{margin-top:8px!important;display:inline-block;padding:2px 8px;background:#f0f0ee;border-radius:10px;font-size:11px;letter-spacing:.03em;color:var(--muted)}.toggle-warning{display:block;margin-top:6px!important;padding:4px 10px;background:var(--warn-bg);border-left:3px solid var(--warn);color:var(--warn)!important;border-radius:4px;font-weight:500;font-size:11.5px!important;line-height:1.45!important}.preview-table td.c-pos,.preview-table td.c-item,.preview-table td.c-ean,.preview-table td.c-unit,.preview-table td.c-cuou,.preview-table td.c-price,.preview-table td.c-origin,.preview-table td.c-avail,.preview-table td.c-cust{white-space:nowrap;word-break:keep-all;overflow-wrap:normal;overflow:hidden;text-overflow:ellipsis}td.invalid-cell{background:#fdecea;color:var(--error)}td.invalid-cell.na-cell:after{content:" #N/A";font-size:.85em;opacity:.6}td.warn-cell{background:#fdf3dc}.full-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a1a1a8c;z-index:900;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .15s ease-out;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.full-modal-inner{background:var(--surface);border-radius:var(--radius);box-shadow:0 10px 40px #00000040;width:100%;max-width:1600px;height:100%;max-height:calc(100vh - 48px);display:flex;flex-direction:column;overflow:hidden}.full-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);gap:16px;flex-wrap:wrap}.full-modal-header h2{margin:0;font-size:17px;font-weight:600}.full-modal-controls{display:flex;gap:10px;align-items:center}.search-input{font-family:var(--font);font-size:13px;padding:7px 11px;border:1px solid var(--border);border-radius:6px;background:#fff;width:220px}.search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #c9634226}.full-modal-body{flex:1;overflow:auto;padding:0 20px 20px}.full-table{width:100%;border-collapse:collapse;font-size:12px}.full-table thead th{background:#fafaf8;text-align:left;padding:8px 10px;font-weight:600;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:1;white-space:nowrap;font-size:11px;text-transform:uppercase;letter-spacing:.02em;color:var(--muted)}.full-table tbody td{padding:6px 10px;border-bottom:1px solid #f0f0ee;white-space:nowrap;max-width:280px;overflow:hidden;text-overflow:ellipsis;vertical-align:top}.full-table tbody tr:hover{background:#fafaf8}.full-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;padding-right:24px;position:sticky;top:0}.full-table th.sortable:hover{background:#f0f0ee;color:var(--text)}.full-table th.sortable .sort-arrow{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:10px;opacity:.35;transition:opacity .15s}.full-table th.sortable:hover .sort-arrow{opacity:.7}.full-table th.sortable.sorted{color:var(--primary);background:#fef6f2}.full-table th.sortable.sorted .sort-arrow{opacity:1;font-size:12px;color:var(--primary)}.error-toggle{display:inline-flex;flex-direction:row;align-items:center;gap:6px;padding:6px 10px;background:var(--error-bg);border:1px solid #f5c6c2;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;color:var(--error);-webkit-user-select:none;user-select:none}.error-toggle:hover{background:#fbdcd9}.error-toggle input[type=checkbox]{margin:0;cursor:pointer;accent-color:var(--error);width:14px;height:14px}.error-toggle span{white-space:nowrap}.template-note{margin-top:14px;margin-bottom:0;padding-top:12px;border-top:1px dashed var(--border)}.template-link{color:var(--primary);text-decoration:none;font-weight:500}.template-link:hover{text-decoration:underline}footer{margin-top:32px;text-align:center}.muted{color:var(--muted)}.small{font-size:12.5px}.hidden{display:none!important}code{background:#f0f0ee;padding:1px 5px;border-radius:3px;font-size:.9em;font-family:SF Mono,Monaco,Consolas,monospace}@media(max-width:600px){.grid{grid-template-columns:1fr}.page{padding:32px 14px 60px}.card{padding:20px}.hero h1{font-size:26px}.preview-table{font-size:10.5px}.preview-table th,.preview-table td{padding:5px 3px}.full-modal{padding:0}.full-modal-inner{border-radius:0;max-height:100vh}.search-input{width:140px}}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a1a1a8c;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .15s ease-out}.loading-box{background:var(--surface);border-radius:var(--radius);padding:28px 40px;text-align:center;box-shadow:0 10px 40px #0003;max-width:360px}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;margin:0 auto 16px;animation:spin .7s linear infinite}.loading-msg{font-size:15px;font-weight:500;margin:0 0 4px;color:var(--text)}.loading-sub{font-size:13px;color:var(--muted);margin:0}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.tabs{display:flex;gap:2px;background:var(--surface);border:1px solid var(--border);padding:4px;border-radius:var(--radius);margin-bottom:20px;box-shadow:var(--shadow)}.tab{flex:1;padding:10px 16px;border-radius:7px;text-align:center;cursor:pointer;background:transparent;border:none;font-family:var(--font);font-size:14px;font-weight:500;color:var(--muted);transition:all .15s}.tab.active{background:var(--bg);color:var(--text);box-shadow:inset 0 0 0 1px var(--border)}.tab:hover:not(.active){color:var(--text)}.tab-panel{display:none}.tab-panel.active{display:block}.supplier-banner{background:#eaf2fb;border:1px solid #c9dbf4;border-radius:8px;padding:12px 14px;margin-bottom:14px;display:flex;align-items:center;gap:12px}.supplier-banner .icon{width:36px;height:36px;border-radius:50%;background:#1c5ba3;color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0;letter-spacing:.02em}.supplier-banner .info{flex:1;min-width:0}.supplier-banner .label{font-size:11px;color:#1c5ba3;font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}.supplier-banner .name{font-size:15px;font-weight:600;color:#0c447c;line-height:1.3}.supplier-banner .meta{font-size:12.5px;color:var(--muted);margin-top:2px}.lang-pick{display:inline-flex;gap:2px;background:var(--bg);border:1px solid var(--border);padding:3px;border-radius:7px;width:fit-content}.lang-btn{border:none;background:transparent;padding:5px 14px;border-radius:5px;font-size:13px;cursor:pointer;color:var(--muted);font-family:var(--font);font-weight:500}.lang-btn.active{background:var(--surface);color:var(--text);box-shadow:0 1px 2px #0000000a}.toggle-row{display:flex;flex-direction:column;gap:10px;padding:12px;background:var(--bg);border-radius:8px}.tgl{display:grid;grid-template-columns:auto auto 1fr;align-items:start;gap:10px;padding:6px 8px;cursor:pointer;border-radius:6px;flex-direction:row;font-weight:400}.tgl:hover{background:#00000008}.tgl input[type=checkbox]{position:absolute;opacity:0;pointer-events:none}.tgl-sw{width:34px;height:20px;border-radius:10px;background:#c9c9c4;position:relative;flex-shrink:0;transition:background .15s;margin-top:2px}.tgl-sw:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 2px #00000026;transition:transform .15s}.tgl input[type=checkbox]:checked~.tgl-sw{background:var(--success)}.tgl input[type=checkbox]:checked~.tgl-sw:after{transform:translate(14px)}.tgl-label{font-size:14px;font-weight:500;line-height:1.4}.tgl-label small{display:block;color:var(--muted);font-size:12.5px;font-weight:400;margin-top:2px;line-height:1.45}.hdr-modal{margin-top:12px;padding:14px;background:#fbf8f1;border:1px solid #e4d9be;border-radius:8px}.hdr-modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.hdr-modal-head h3{margin:0;font-size:14px;font-weight:600}.hdr-close{background:transparent;border:none;color:var(--muted);font-size:16px;cursor:pointer;padding:2px 6px;border-radius:4px}.hdr-close:hover{background:#0000000f}.hdr-box{background:#fff;border:1px solid var(--border);border-radius:6px;padding:10px 12px;font-family:SF Mono,Monaco,Consolas,monospace;font-size:12px;line-height:1.6;margin:0 0 10px;overflow-x:auto;white-space:pre}.hdr-box .req{background:#fff3d6;font-weight:600;padding:1px 5px;border-radius:3px;color:#855000}.preview-table td.status-cell{white-space:normal;line-height:1.35}.status-pill{display:inline-block;padding:2px 7px;border-radius:4px;font-size:10.5px;font-weight:500;white-space:nowrap}.status-pill.pill-open{background:#eaf4ea;color:#2a6b38}.status-pill.pill-nopu{background:#fce6d0;color:#8a4f16}.status-pill.pill-p1145{background:#fcdede;color:#96231c}.status-pill.pill-p2ponly{background:#e6e5f9;color:#453d8a}.status-pill.pill-none{color:var(--muted);background:transparent}.preview-table td.price-updated{background:#eaf4ea}.preview-table td.price-fallback{background:#fcdede}.p2p-legend{display:flex;gap:16px;flex-wrap:wrap;font-size:11.5px;color:var(--muted);margin-top:10px}.p2p-legend span{display:inline-flex;align-items:center;gap:5px}.p2p-legend .sw{width:12px;height:12px;border-radius:2px;display:inline-block}.p2p-legend .sw-updated{background:#eaf4ea}.p2p-legend .sw-fallback{background:#fcdede}.p2p-legend .sw-nopu{background:#fce6d0}.options-card{background:var(--bg);border:1px dashed var(--border);box-shadow:none}.options-title{font-size:13px!important;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 12px!important}.preview-controls{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.status-filter{font-family:var(--font);font-size:13px;padding:6px 10px;border:1px solid var(--border);border-radius:6px;background:#fff;cursor:pointer;min-width:180px}.status-filter:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #c9634226}
