body{color:#222;-webkit-font-smoothing:antialiased;background:#f5f6fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px}#root{flex-direction:column;height:100vh;display:flex}.sidebar{background:#fff;border-right:1px solid #e0e3ea;flex-direction:column;flex-shrink:0;width:200px;display:flex;overflow-y:auto}.sidebar-title{text-transform:uppercase;letter-spacing:.8px;color:#888;border-bottom:1px solid #e0e3ea;padding:14px 16px 10px;font-size:11px;font-weight:700}.sidebar ul{padding:6px 0;list-style:none}.sidebar-item{text-align:left;cursor:pointer;color:#444;background:0 0;border:none;border-radius:0;width:100%;padding:9px 16px;font-size:13px;transition:background .15s;display:block}.sidebar-item:hover{background:#f0f2f8}.sidebar-item.active{color:#1a2744;background:#e8edfd;border-left:3px solid #3b5bdb;font-weight:600}.fields-panel{width:100%}.section-tabs{border-bottom:2px solid #e0e3ea;flex-wrap:wrap;gap:4px;margin-bottom:0;padding:12px 0 0;display:flex}.section-tab{color:#667;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:4px 4px 0 0;margin-bottom:-2px;padding:6px 14px;font-size:12px;font-weight:600;transition:color .15s,border-color .15s,background .15s}.section-tab:hover{color:#1a2744;background:#f0f2f8}.section-tab.active{color:#3b5bdb;background:#f0f2f8;border-bottom-color:#3b5bdb}.section-tab-count{color:#3b5bdb;vertical-align:middle;background:#e8edfd;border-radius:10px;margin-left:5px;padding:1px 6px;font-size:10px;font-weight:700;display:inline-block}.section-tab.active .section-tab-count{color:#fff;background:#3b5bdb}.matrix-section-tabs{background:#fff;border-bottom:2px solid #e0e3ea;margin-bottom:0;padding:0}.panel-title-row{justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.panel-title{color:#1a2744;align-items:baseline;gap:10px;margin:0;font-size:22px;font-weight:600;display:flex}.source-toggle{flex-shrink:0;align-items:center;gap:6px;display:flex}.source-toggle-label{text-transform:uppercase;letter-spacing:.5px;color:#aaa;font-size:11px;font-weight:700}.source-tab{color:#666;cursor:pointer;background:0 0;border:1px solid #c8d0e8;border-radius:4px;padding:4px 14px;font-size:12px;font-weight:700;transition:background .15s,color .15s,border-color .15s}.source-tab:hover{color:#1a2744;background:#f0f2f8;border-color:#3b5bdb}.source-tab.active{color:#fff;background:#3b5bdb;border-color:#3b5bdb}.panel-product-id{color:#888;background:#f0f2f8;border-radius:4px;padding:2px 8px;font-family:ui-monospace,Consolas,monospace;font-size:13px;font-weight:400}.empty-msg{color:#888;font-style:italic}.detection-rules{background:#fff;border:1px solid #e0e3ea;border-radius:8px;margin-bottom:24px;overflow:hidden}.detection-rules-title{text-transform:uppercase;letter-spacing:.5px;color:#555;background:#f8f9fc;border-bottom:1px solid #e0e3ea;justify-content:space-between;align-items:center;padding:9px 16px;font-size:11px;font-weight:700;display:flex}.detection-rules-body{flex-wrap:wrap;gap:0;display:flex}.detection-rule-row{border-right:1px solid #f0f2f8;align-items:center;gap:8px;min-width:180px;padding:8px 20px;display:flex}.detection-rule-row:last-child{border-right:none}.detection-rule-label{color:#888;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;font-size:11px;font-weight:600}.detection-rule-value{color:#1a2744;background:#eef1fb;border-radius:4px;padding:2px 8px;font-family:ui-monospace,Consolas,monospace;font-size:12px}.detection-cond-set{border-top:1px solid #f0f2f8}.detection-cond-set:first-child{border-top:none}.detection-cond-or{letter-spacing:.8px;text-transform:uppercase;color:#a0a8c0;align-items:center;gap:10px;padding:6px 16px;font-size:10px;font-weight:700;display:flex}.detection-cond-or:before,.detection-cond-or:after{content:"";background:#e0e3ea;flex:1;height:1px}.section-block{background:#fff;border:1px solid #e0e3ea;border-radius:8px;margin-bottom:28px;overflow:visible}.section-header{background:#f8f9fc;border-bottom:1px solid #e0e3ea;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.section-header h3{text-transform:uppercase;letter-spacing:.5px;color:#555;font-size:13px;font-weight:700}.btn-add{color:#fff;cursor:pointer;background:#3b5bdb;border:none;border-radius:4px;padding:4px 10px;font-size:12px}.btn-add:hover{background:#2f4abf}.add-form{background:#f0f4ff;border-bottom:1px solid #d0d8f0;flex-wrap:wrap;gap:8px;padding:10px 16px;display:flex}.add-form input{border:1px solid #c8d0e8;border-radius:4px;flex:1;min-width:120px;padding:6px 10px;font-size:13px}.btn-save{color:#fff;cursor:pointer;background:#2e7d32;border:none;border-radius:4px;padding:6px 14px;font-size:13px}.btn-save:hover{background:#1b5e20}.btn-save:disabled{cursor:not-allowed;opacity:.7;background:#a5c9a8}.fields-table{border-collapse:separate;border-spacing:0;width:100%;font-size:13px}.fields-table th{z-index:1;text-align:left;text-transform:uppercase;letter-spacing:.5px;color:#888;background:#f8f9fc;border-bottom:1px solid #e0e3ea;padding:8px 16px;font-size:11px;font-weight:700;position:sticky;top:0}.fields-table td{vertical-align:middle;border-bottom:1px solid #f0f2f8;padding:8px 16px}.fields-table tr:last-child td{border-bottom:none}.fields-table tbody tr:hover{background:#fafbff}.key-cell{color:#555;font-family:ui-monospace,Consolas,monospace;font-size:12px}.source-badge{color:#e65100;background:#fff3e0;border:1px solid #ffcc80;border-radius:10px;padding:2px 7px;font-size:11px;font-weight:600;display:inline-block}.custom-row{background:#f5fff5}.custom-row:hover{background:#edfaed!important}.btn-remove{color:#c0392b;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:16px;line-height:1}.btn-remove:hover{color:#922b21}.app-loading,.app-error{color:#555;justify-content:center;align-items:center;gap:12px;height:100vh;font-size:16px;display:flex}.app-error{color:#c0392b}.header-actions{align-items:center;gap:12px;margin-left:auto;display:flex}.save-msg{color:#2e7d32;background:#e8f5e9;border-radius:4px;padding:4px 10px;font-size:13px}.save-msg.error{color:#c62828;background:#fdecea}.unsaved-badge{color:#856404;white-space:nowrap;background:#fff3cd;border:1px solid #ffc107;border-radius:12px;padding:3px 10px;font-size:12px;font-weight:600}.changes-panel{background:#fff;border-left:1px solid #e0e3ea;flex-direction:column;flex-shrink:0;width:220px;display:flex;overflow:hidden}.changes-panel-header{color:#5d4037;text-transform:uppercase;letter-spacing:.4px;background:#fff8e1;border-bottom:1px solid #ffe082;flex-shrink:0;padding:10px 14px;font-size:12px;font-weight:700}.changes-list{flex:1;margin:0;padding:6px 0;list-style:none;overflow-y:auto}.change-item{color:#333;border-bottom:1px solid #f5f5f5;align-items:flex-start;gap:6px;padding:5px 10px 5px 14px;font-size:12px;line-height:1.4;display:flex}.change-item:last-child{border-bottom:none}.change-desc{flex:1}.btn-revert-change{color:#aaa;cursor:pointer;background:0 0;border:none;flex-shrink:0;margin-top:1px;padding:0 2px;font-size:13px;line-height:1}.btn-revert-change:hover:not(:disabled){color:#c62828}.btn-revert-change:disabled{color:#ccc;cursor:default}.changes-panel-footer{border-top:1px solid #e0e3ea;flex-direction:column;flex-shrink:0;gap:6px;padding:10px 14px;display:flex}.sidebar-footer{border-top:1px solid #e0e3ea;margin-top:auto;padding:12px}.btn-add-product{color:#fff;cursor:pointer;background:#1a2744;border:none;border-radius:5px;width:100%;padding:8px;font-size:12px}.btn-add-product:hover{background:#2f4abf}.section-empty{color:#aaa;padding:10px 16px;font-size:13px;font-style:italic}.modal-overlay{z-index:1000;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:10px;flex-direction:column;width:680px;max-width:95vw;display:flex;box-shadow:0 8px 32px #0000002e}.modal-header{border-bottom:1px solid #e0e3ea;justify-content:space-between;align-items:center;padding:18px 24px 14px;display:flex}.modal-header h3{color:#1a2744;margin:0;font-size:16px;font-weight:700}.modal-close{color:#888;cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:20px;line-height:1}.modal-close:hover{color:#333}.modal-body{padding:20px 24px}.modal-footer{border-top:1px solid #e0e3ea;justify-content:flex-end;gap:10px;padding:14px 24px 18px;display:flex}.add-product-form{grid-template-columns:1fr 1fr;gap:12px;display:grid}.add-product-form label{color:#666;flex-direction:column;gap:4px;font-size:12px;font-weight:600;display:flex}.add-product-form input,.add-product-form select{border:1px solid #c8d0e8;border-radius:4px;padding:7px 10px;font-size:13px}.add-product-actions{grid-column:1/-1;gap:10px;margin-top:4px;display:flex}.cond-sets-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.cond-sets-title{color:#666;font-size:12px;font-weight:600}.btn-add-cond{color:#3b5bdb;cursor:pointer;background:0 0;border:1px solid #c8d0e8;border-radius:4px;padding:3px 10px;font-size:11px}.btn-add-cond:hover{background:#eef1fb}.cond-set-group{margin-bottom:6px}.cond-set-or{color:#aaa;text-transform:uppercase;letter-spacing:.5px;text-align:center;margin:4px 0;font-size:10px;font-weight:700}.cond-set-row{background:#f8f9fc;border:1px solid #e0e3ea;border-radius:6px;grid-template-columns:1fr 1fr 1fr auto;align-items:end;gap:8px;padding:10px 12px;display:grid}.cond-set-row label{color:#666;flex-direction:column;gap:4px;font-size:11px;font-weight:600;display:flex}.cond-set-row input{border:1px solid #c8d0e8;border-radius:4px;padding:6px 8px;font-size:12px}.btn-remove-cond{color:#aaa;cursor:pointer;background:0 0;border:none;align-self:center;margin-top:14px;padding:0 4px;font-size:18px;line-height:1}.btn-remove-cond:hover{color:#c62828}.btn-cancel{color:#444;cursor:pointer;background:#e0e3ea;border:none;border-radius:4px;padding:6px 14px;font-size:13px}.btn-cancel:hover{background:#c8cdd8}.groups-toggle{color:#666;cursor:pointer;text-transform:uppercase;letter-spacing:.5px;background:0 0;border:1px solid #c8d0e8;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:700}.groups-toggle:hover,.groups-toggle.active{color:#fff;background:#3b5bdb;border-color:#3b5bdb}.groups-info{color:#777;background:#f8f9fc;border:1px solid #e0e3ea;border-radius:6px;margin-bottom:20px;padding:10px 14px;font-size:12px;line-height:1.6}.groups-info code{color:#1a2744;background:#eef1fb;border-radius:3px;padding:1px 5px;font-size:11px}.group-members-row{flex-wrap:wrap;gap:6px;padding:10px 16px 12px;display:flex}.group-member-badge{color:#1a2744;background:#eef1fb;border:1px solid #d0d8f0;border-radius:6px;align-items:center;gap:5px;padding:3px 10px;font-size:12px;display:inline-flex}.group-member-badge code{color:#888;font-size:11px}.group-edit-panel{padding:14px 16px}.group-edit-header{margin-bottom:12px}.group-edit-header label{color:#666;flex-direction:column;gap:4px;max-width:260px;font-size:12px;font-weight:600;display:flex}.group-members-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:6px;margin-bottom:14px;display:grid}.member-checkbox{cursor:pointer;color:#555;background:#fff;border:1px solid #e0e3ea;border-radius:6px;align-items:center;gap:6px;padding:6px 10px;font-size:12px;transition:border-color .15s,background .15s;display:flex}.member-checkbox.checked{color:#1a2744;background:#eef1fb;border-color:#3b5bdb}.member-checkbox input{flex-shrink:0;width:auto}.member-checkbox code{color:#aaa;margin-left:auto;font-size:10px}.member-checkbox.checked code{color:#3b5bdb}.group-edit-actions{gap:8px;display:flex}.sidebar-row{align-items:center;display:flex}.sidebar-row .sidebar-item{flex:1}.sidebar-row-actions{flex-shrink:0;gap:2px;padding-right:6px;display:none}.sidebar-row:hover .sidebar-row-actions,.sidebar-row.active-row .sidebar-row-actions{display:flex}.sidebar-action-btn{cursor:pointer;color:#666;background:0 0;border:none;border-radius:3px;padding:3px 4px;font-size:12px;line-height:1}.sidebar-action-btn:hover{color:#1a2744;background:#e0e3ea}.sidebar-action-btn.delete:hover{color:#c62828;background:#fdecea}.row-editing td{background:#f0f4ff;padding:4px 8px}.inline-input{background:#fff;border:1px solid #3b5bdb;border-radius:4px;width:100%;padding:4px 8px;font-size:13px}.key-input{font-family:ui-monospace,Consolas,monospace;font-size:12px}.source-input{max-width:80px}.row-actions{white-space:nowrap}.btn-edit{color:#888;cursor:pointer;opacity:0;background:0 0;border:none;padding:0 4px;font-size:13px;line-height:1;transition:opacity .15s}tr:hover .btn-edit{opacity:1}.btn-edit:hover{color:#3b5bdb}.btn-save-inline{color:#2e7d32;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:16px;font-weight:700}.btn-cancel-inline{color:#c0392b;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:14px;font-weight:700}input:disabled{color:#888;cursor:not-allowed;background:#f0f2f8}.inherit-label{grid-column:1/-1}.inherit-hint{color:#3b5bdb;margin-top:2px;font-size:11px;font-weight:400;display:block}.version-picker{align-items:center;gap:8px;display:flex}.version-label{text-transform:uppercase;letter-spacing:.5px;color:#aaa;font-size:11px;font-weight:700}.version-select{color:#1a2744;cursor:pointer;background:#fff;border:1px solid #c8d0e8;border-radius:4px;max-width:200px;padding:4px 8px;font-size:13px}.version-select:focus{border-color:#3b5bdb;outline:none}.version-dropdown{position:relative}.version-dropdown-trigger{color:#fff;cursor:pointer;white-space:nowrap;text-align:left;background:#ffffff1f;border:1px solid #ffffff59;border-radius:4px;align-items:center;gap:6px;width:200px;padding:4px 9px;font-size:12px;display:flex}.version-dropdown-trigger:hover{background:#ffffff38}.version-dropdown-trigger.open{background:#ffffff38;border-color:#ffffffb3}.version-dropdown-trigger:disabled{opacity:.6;cursor:not-allowed}.version-dropdown-label{text-overflow:ellipsis;text-align:left;flex:1;min-width:0;overflow:hidden}.version-filename{opacity:.65;font-size:11px}.version-dropdown-menu{z-index:200;background:#fff;border:1px solid #dde1ec;border-radius:6px;width:200px;position:absolute;top:calc(100% + 4px);left:0;overflow:hidden;box-shadow:0 4px 16px #0000001f}.version-dropdown-item{color:#1a2744;cursor:pointer;justify-content:space-between;align-items:center;gap:6px;padding:8px 10px;font-size:13px;display:flex}.version-dropdown-item:hover{background:#f0f4ff}.version-dropdown-item.active{color:#3b5bdb;background:#eef1fd;font-weight:600}.version-dropdown-item span{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.version-delete-btn{color:#bbb;cursor:pointer;background:0 0;border:none;border-radius:3px;flex-shrink:0;padding:0 2px;font-size:15px;line-height:1}.version-delete-btn:hover{color:#c62828;background:#fdecea}.version-dropdown-empty{color:#aaa;padding:10px 12px;font-size:12px;font-style:italic}.version-switching-indicator{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:12px;height:12px;animation:.6s linear infinite spin;display:inline-block}.btn-upload,.btn-download{color:#fff;cursor:pointer;background:#ffffff1f;border:1px solid #ffffff59;border-radius:4px;padding:4px 10px;font-size:12px}.btn-upload:hover,.btn-download:hover{background:#ffffff38;border-color:#ffffffb3}.btn-delete-version{color:#c62828;cursor:pointer;background:0 0;border:1px solid #e0b0b0;border-radius:4px;padding:4px 8px;font-size:12px}.btn-delete-version:hover{background:#fdecea}.upload-modal{width:520px}.upload-modal .modal-header{justify-content:flex-start;gap:12px}.upload-modal .modal-header .modal-close{margin-left:auto}.modal-header-icon{color:#3b5bdb;background:#eef1fd;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.modal-subtitle{color:#888;margin:2px 0 0;font-size:12px}.upload-form{flex-direction:column;gap:16px;display:flex}.upload-form label{color:#555;flex-direction:column;gap:5px;font-size:12px;font-weight:600;display:flex}.upload-form input[type=text]{border:1px solid #c8d0e8;border-radius:6px;padding:8px 11px;font-size:13px;transition:border-color .15s,box-shadow .15s}.upload-form input[type=text]:focus{border-color:#3b5bdb;outline:none;box-shadow:0 0 0 3px #3b5bdb1a}.field-hint{color:#999;font-size:11px;font-weight:400}.upload-dropzone{cursor:pointer;border:2px dashed #c8d0e8;border-radius:8px;justify-content:center;align-items:center;min-height:110px;transition:border-color .15s,background .15s,box-shadow .15s;display:flex}.upload-dropzone:hover,.upload-dropzone.dragging{background:#f0f4ff;border-color:#3b5bdb;box-shadow:0 0 0 3px #3b5bdb14}.upload-dropzone.has-file{cursor:default;background:#f5f7ff;border-color:#3b5bdb}.upload-dropzone input[type=file]{display:none}.dropzone-empty{flex-direction:column;align-items:center;gap:6px;padding:20px;display:flex}.dropzone-text{color:#555;font-size:13px}.dropzone-text u{color:#3b5bdb}.dropzone-hint{color:#aaa;font-size:11px}.upload-file-info{align-items:center;gap:12px;width:100%;padding:14px 16px;display:flex}.file-icon{flex-shrink:0}.file-meta{flex-direction:column;flex:1;min-width:0;display:flex}.file-name{color:#1a2744;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.file-size{color:#888;margin-top:2px;font-size:11px}.file-clear{color:#888;cursor:pointer;background:0 0;border:1px solid #dde1ec;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:14px;line-height:1;display:flex}.file-clear:hover{color:#c62828;background:#fdecea;border-color:#e57373}.upload-error-box{color:#c62828;background:#fff5f5;border:1px solid #fcc;border-radius:6px;align-items:center;gap:8px;padding:9px 12px;font-size:12px;display:flex}.spinner{vertical-align:middle;border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:12px;height:12px;margin-right:4px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.view-toggle{border:1px solid #fff3;border-radius:6px;gap:0;display:flex;overflow:hidden}.view-tab{cursor:pointer;color:#ffffff8c;background:0 0;border:none;border-right:1px solid #ffffff26;padding:5px 14px;font-size:12px;font-weight:600}.view-tab:last-child{border-right:none}.view-tab.active{color:#fff;background:#ffffff2e}.view-tab:not(.active):hover{color:#ffffffd9;background:#ffffff1a}.field-matrix-outer{flex-direction:column;flex:1;min-height:0;padding-bottom:24px;display:flex}.matrix-pt-filter{border-bottom:1px solid #e8eaf0;flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:4px;padding:8px 0 6px;display:flex}.matrix-pt-filter-label{color:#64748b;margin-right:2px;font-size:12px;font-weight:600}.matrix-pt-chip{color:#475569;cursor:pointer;white-space:nowrap;background:#f1f5f9;border:1px solid #cbd5e1;border-radius:10px;padding:2px 8px;font-size:11px}.matrix-pt-chip.active{color:#fff;background:#3b5bdb;border-color:#3b5bdb}.matrix-pt-chip.inactive{color:#cbd5e1;background:#f8fafc;border-color:#e2e8f0}.matrix-toolbar{align-items:center;gap:16px;margin-bottom:12px;display:flex}.matrix-search-wrap{align-items:center;display:inline-flex;position:relative}.matrix-search{border:1px solid #c8d0e8;border-radius:4px;width:240px;padding:6px 28px 6px 10px;font-size:13px}.matrix-search:focus{border-color:#3b5bdb;outline:none}.matrix-search-clear{color:#aaa;cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:16px;line-height:1;position:absolute;right:6px}.matrix-search-clear:hover{color:#333}.matrix-filter-count{color:#3b5bdb;background:#eef1fb;border-radius:10px;padding:3px 8px;font-size:12px;font-weight:600}.matrix-hint{color:#999;font-size:12px;font-style:italic}.filter-highlight{color:#333;background:#fff3a0;border-radius:2px;padding:0 1px}.field-matrix-scroll{background:#fff;border:1px solid #e0e3ea;border-radius:8px;flex:1;overflow:auto}.matrix-table{border-collapse:collapse;white-space:nowrap;font-size:12px}.matrix-th{z-index:2;text-transform:uppercase;letter-spacing:.4px;color:#888;vertical-align:bottom;background:#f8f9fc;border-bottom:2px solid #e0e3ea;padding:6px 8px;font-size:11px;font-weight:700;position:sticky;top:0}.matrix-label-col{z-index:3;background:inherit;min-width:160px;max-width:200px;position:sticky;left:0}thead .matrix-label-col,thead .matrix-key-col{z-index:5;background:#f8f9fc}tbody .matrix-label-col,tbody .matrix-key-col{background:#fff}.matrix-key-col{z-index:3;background:inherit;min-width:150px;max-width:180px;position:sticky;left:160px;box-shadow:2px 0 4px #0000000a}.matrix-src-col{text-align:center;width:48px;min-width:48px}.matrix-pt-col{vertical-align:bottom;text-align:center;width:36px;min-width:36px;max-width:36px;height:130px;padding:0 0 6px}.matrix-pt-label{writing-mode:vertical-lr;white-space:nowrap;color:#555;text-overflow:ellipsis;max-height:120px;margin:0 auto;font-size:11px;font-weight:600;display:block;overflow:hidden;transform:rotate(180deg)}.matrix-section-row td{text-transform:uppercase;letter-spacing:.5px;color:#3b5bdb;background:#f0f4ff;border-top:2px solid #d0d8f0;border-bottom:1px solid #d0d8f0;padding:6px 12px;font-size:11px;font-weight:700;position:sticky;left:0}.matrix-field-row:hover .matrix-label-col,.matrix-field-row:hover .matrix-key-col,.matrix-field-row:hover{background:#fafbff}.matrix-field-row:not(:last-child) td{border-bottom:1px solid #f0f2f8}.matrix-td{vertical-align:middle;background:#fff;padding:5px 8px}.matrix-label{color:#333;font-size:12px}.matrix-key code{color:#555;text-overflow:ellipsis;white-space:nowrap;max-width:170px;font-family:ui-monospace,Consolas,monospace;font-size:11px;display:block;overflow:hidden}.matrix-cell{text-align:center;padding:4px 2px}.matrix-cell.cell-on{background:#f0f4ff}.matrix-cell.cell-global.cell-on{background:#eef8f0}.matrix-cell.cell-dirty{background:#fffde7}.matrix-cell.cell-dirty .matrix-checkbox{outline-offset:1px;accent-color:#f59f00;border-radius:2px;outline:2px solid #f59f00}.matrix-checkbox{cursor:pointer;accent-color:#3b5bdb;width:14px;height:14px}.matrix-label-wrap{justify-content:space-between;align-items:center;gap:4px;display:flex}.matrix-row-actions{flex-shrink:0;gap:2px;display:none}.matrix-field-row:hover .matrix-row-actions{display:flex}.matrix-row-btn{cursor:pointer;color:#888;background:0 0;border:none;border-radius:3px;padding:2px 3px;font-size:11px;line-height:1}.matrix-row-btn:hover{color:#1a2744;background:#e0e3ea}.matrix-row-btn.delete:hover{color:#c62828;background:#fdecea}.matrix-add-btn{color:#fff;cursor:pointer;background:#3b5bdb;border:none;border-radius:4px;flex-shrink:0;padding:2px 8px;font-size:11px;font-weight:700}.matrix-add-btn:hover{background:#2f4abf}.matrix-add-row td{background:#f0f4ff;padding:4px 6px}.matrix-add-row .inline-input{background:#fff;border:1px solid #3b5bdb;border-radius:4px;width:100%;padding:3px 6px;font-size:12px}.matrix-add-row .key-input{font-family:ui-monospace,Consolas,monospace}.matrix-add-row .source-input{max-width:44px}.matrix-add-actions-row td{background:#f0f4ff;border-bottom:2px solid #d0d8f0;padding:0}.matrix-all-col{text-align:center;width:36px;min-width:36px}.matrix-cond-col{text-align:center;width:54px;min-width:54px}.cond-toggle{color:#aaa;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #c8d0e8;border-radius:8px;padding:2px 5px;font-size:10px;font-weight:600}.cond-toggle:hover{color:#3b5bdb;background:#eef1fb;border-color:#3b5bdb}.cond-toggle.active{color:#2e7d32;background:#e8f5e9;border-color:#a5d6a7}.cond-toggle.active:hover{color:#c62828;background:#fdecea;border-color:#ef9a9a}.cond-badge{color:#2e7d32;white-space:nowrap;background:#e8f5e9;border:1px solid #a5d6a7;border-radius:8px;padding:2px 6px;font-size:10px;font-weight:600;display:inline-block}.diff-panel{max-width:960px;padding:24px}.diff-toolbar{background:#fff;border:1px solid #e0e3ea;border-radius:10px;align-items:flex-end;gap:12px;margin-bottom:20px;padding:20px 24px;display:flex}.diff-version-select{flex-direction:column;flex:1;gap:5px;display:flex}.diff-version-label{text-transform:uppercase;letter-spacing:.6px;color:#888;font-size:11px;font-weight:700}.diff-select{color:#222;cursor:pointer;background:#f8f9fc;border:1px solid #d0d4df;border-radius:6px;min-width:200px;padding:7px 10px;font-size:13px}.diff-select:focus{border-color:#3b5bdb;outline:none}.diff-vs{color:#aab;flex-shrink:0;padding-bottom:8px;font-size:12px;font-weight:700}.diff-compare-btn{flex-shrink:0;align-self:flex-end}.diff-results{background:#fff;border:1px solid #e0e3ea;border-radius:10px;overflow:hidden}.diff-results-header{background:#f8f9fc;border-bottom:1px solid #e0e3ea;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding:14px 20px;display:flex}.diff-results-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.diff-results-title{color:#444;font-size:13px;font-weight:600}.diff-version-pill{border-radius:4px;padding:2px 8px;font-size:12px;font-weight:700;display:inline-block}.diff-version-pill.version-a{color:#2b4dbf;background:#e8edfd}.diff-version-pill.version-b{color:#1a7a3c;background:#e6f7ee}.diff-summary-badges{gap:6px;display:flex}.diff-no-changes{color:#2d9a4e;align-items:center;gap:6px;font-size:12px;font-weight:600;display:flex}.diff-section{border-bottom:1px solid #eef0f5}.diff-section:last-child{border-bottom:none}.diff-section-header{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:11px 20px;transition:background .12s;display:flex}.diff-section-header:hover{background:#f5f6fa}.diff-section-chevron{color:#888;flex-shrink:0;width:12px;font-size:11px}.diff-section-name{color:#333;flex:1;font-size:13px;font-weight:600}.diff-section-badges{gap:4px;display:flex}.diff-badge{border-radius:10px;padding:2px 7px;font-size:11px;font-weight:700;display:inline-block}.diff-badge.added{color:#1a7a3c;background:#e6f7ee}.diff-badge.removed{color:#b91c1c;background:#fdecea}.diff-badge.changed{color:#b45309;background:#fff4e5}.diff-section-body{padding:4px 0 8px}.diff-row{flex-wrap:wrap;align-items:flex-start;gap:8px;padding:7px 20px 7px 40px;font-size:13px;display:flex}.diff-row-added{background:#f4fbf6}.diff-row-removed{background:#fdf4f4}.diff-row-changed{background:#fffbf2}.diff-row-icon{flex-shrink:0;width:14px;margin-left:-18px;font-size:13px;font-weight:700}.diff-row-added .diff-row-icon{color:#1a7a3c}.diff-row-removed .diff-row-icon{color:#b91c1c}.diff-row-changed .diff-row-icon{color:#b45309}.diff-row-label{color:#222;font-weight:600}.diff-row-key{color:#666;background:#f0f2f8;border-radius:3px;padding:1px 5px;font-size:11px}.diff-row-src{color:#3b5bdb;background:#e8edfd;border-radius:3px;padding:1px 5px;font-size:11px}.diff-rule-summary{color:#666;font-size:11px;font-style:italic}.diff-field-changes{flex-direction:column;gap:4px;width:100%;margin-top:4px;display:flex}.diff-field-change{flex-wrap:wrap;align-items:center;gap:6px;font-size:12px;display:flex}.diff-field-name{color:#888;text-transform:uppercase;letter-spacing:.4px;min-width:80px;font-size:11px;font-weight:700}.diff-value{overflow-wrap:anywhere;border-radius:3px;max-width:320px;padding:2px 6px;font-size:12px}.diff-value-from{color:#b91c1c;opacity:.85;background:#fdecea;text-decoration:line-through}.diff-value-to{color:#1a7a3c;background:#e6f7ee}.diff-arrow{color:#aab;font-size:12px}.pt-tokens{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.pt-token{border-radius:10px;padding:2px 7px;font-size:11px;font-weight:600;display:inline-block}.pt-token.pt-kept{color:#555;background:#f0f2f8}.pt-token.pt-added{color:#1a7a3c;background:#e6f7ee;border:1px solid #b7e5c8}.pt-token.pt-removed{color:#b91c1c;opacity:.8;background:#fdecea;border:1px solid #f5c6c6;text-decoration:line-through}.btn-promote{color:#3b5bdb;cursor:pointer;white-space:nowrap;background:#e8edfd;border:1px solid #c0ccf5;border-radius:6px;align-items:center;gap:5px;padding:6px 12px;font-size:12px;font-weight:700;transition:background .15s,border-color .15s;display:inline-flex}.btn-promote:hover{background:#d4dcfb;border-color:#3b5bdb}.promote-direction{background:#f8f9fc;border:1px solid #e0e3ea;border-radius:8px;justify-content:center;align-items:center;gap:14px;margin-bottom:14px;padding:20px;display:flex}.promote-arrow{align-items:center;display:flex}.promote-warning{color:#555;font-size:13px;line-height:1.5}.promote-msg{border-radius:6px;margin-bottom:12px;padding:10px 14px;font-size:13px;font-weight:600}.promote-msg.ok{color:#1a7a3c;background:#e6f7ee;border:1px solid #b7e5c8}.promote-msg.error{color:#b91c1c;background:#fdecea;border:1px solid #f5c6c6}.diff-empty{color:#aab;text-align:center;flex-direction:column;align-items:center;gap:12px;padding:60px 20px;font-size:13px;display:flex}.diff-empty strong{color:#555}.qa-panel{flex-direction:column;gap:20px;max-width:1100px;padding:24px;display:flex;overflow-y:auto}.qa-card{background:#fff;border:1px solid #e0e3ea;border-radius:10px;padding:24px}.qa-card-title{color:#1a2744;align-items:center;gap:10px;margin-bottom:16px;font-size:14px;font-weight:700;display:flex}.qa-step-badge{color:#fff;background:#3b5bdb;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;font-weight:700;display:inline-flex}.qa-result-meta{color:#94a3b8;margin-left:6px;font-size:11px;font-weight:400}.qa-fg{margin-bottom:12px}.qa-fg-label{color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:11px;font-weight:700;display:block}.qa-input-row{gap:10px;display:flex}.qa-input{border:1.5px solid #e0e3ea;border-radius:7px;outline:none;flex:1;padding:9px 13px;font-size:13px;transition:border-color .15s}.qa-input:focus{border-color:#3b5bdb}.qa-url-hint{color:#94a3b8;margin-top:8px;font-size:12px;line-height:1.5}.qa-textarea{resize:vertical;border:1.5px solid #e0e3ea;border-radius:7px;outline:none;width:100%;min-height:100px;padding:10px 12px;font-family:monospace;font-size:12px}.qa-textarea:focus{border-color:#3b5bdb}.qa-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:7px;align-items:center;gap:6px;padding:9px 18px;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.qa-btn:disabled{opacity:.5;cursor:not-allowed}.qa-btn-primary{color:#fff;background:#3b5bdb}.qa-btn-primary:not(:disabled):hover{background:#2f4ac0}.qa-btn-success{color:#fff;background:#10b981}.qa-btn-success:hover{background:#059669}.qa-action-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.qa-no-page-hint{color:#94a3b8;font-size:12px;font-style:italic}.qa-sbar{border-radius:8px;align-items:flex-start;gap:10px;margin-top:12px;padding:12px 16px;font-size:13px;display:flex}.qa-sbar-loading{color:#92400e;background:#fef9c3}.qa-sbar-error{color:#991b1b;background:#fee2e2}.qa-sbar-success{color:#065f46;background:#d1fae5}.qa-sbar-info{color:#1e40af;background:#dbeafe}.qa-status-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;margin-top:1px;font-size:10px;font-weight:700;display:inline-flex}.qa-icon-success{color:#fff;background:#10b981}.qa-icon-error{color:#fff;background:#ef4444}.qa-icon-info{color:#fff;background:#3b82f6}.qa-spinner{border:2px solid #00000026;border-top-color:#92400e;border-radius:50%;flex-shrink:0;width:14px;height:14px;margin-top:2px;animation:.8s linear infinite qa-spin;display:inline-block}@keyframes qa-spin{to{transform:rotate(360deg)}}.qa-fallback{background:#f8f9fc;border:1.5px solid #e0e3ea;border-radius:10px;margin-top:16px;overflow:hidden}.qa-fallback-tabs{border-bottom:1.5px solid #e0e3ea;display:flex}.qa-ftab{cursor:pointer;color:#64748b;background:0 0;border:none;border-bottom:2px solid #0000;padding:9px 18px;font-size:12px;font-weight:600}.qa-ftab.active{color:#3b5bdb;border-bottom-color:#3b5bdb}.qa-ftab:hover{background:#f1f5f9}.qa-fallback-body{padding:18px}.qa-fallback-desc{color:#475569;margin-bottom:12px;font-size:13px}.qa-step-list{counter-reset:qa-steps;margin-top:8px;list-style:none}.qa-step-list li{counter-increment:qa-steps;color:#475569;padding:5px 0 5px 30px;font-size:13px;position:relative}.qa-step-list li:before{content:counter(qa-steps);color:#fff;background:#3b5bdb;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:10px;font-weight:700;display:flex;position:absolute;top:5px;left:0}.qa-bookmarklet-link{color:#fff;cursor:grab;background:#f59e0b;border:2px dashed #d97706;border-radius:7px;padding:6px 14px;font-size:12px;font-weight:700;text-decoration:none;display:inline-block}.qa-bookmarklet-link:hover{background:#d97706}.qa-product-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;display:grid}.qa-product-chip{cursor:pointer;color:#475569;text-align:left;background:#f8f9fc;border:1.5px solid #e0e3ea;border-radius:8px;flex-direction:column;align-items:flex-start;gap:2px;padding:10px 14px;font-size:13px;font-weight:600;transition:all .15s;display:flex}.qa-product-chip:hover{color:#1d4ed8;background:#eff6ff;border-color:#93c5fd}.qa-product-chip.selected{color:#1d4ed8;background:#eff6ff;border-color:#3b5bdb}.qa-product-id{color:#94a3b8;font-family:monospace;font-size:10px;font-weight:400}.qa-product-chip.selected .qa-product-id{color:#93c5fd}.qa-stats{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px;margin-bottom:18px;display:grid}.qa-stat{text-align:center;border-radius:10px;padding:16px}.qa-stat-total{background:#f1f5f9}.qa-stat-pass{background:#d1fae5}.qa-stat-fail{background:#fee2e2}.qa-stat-cov{background:#dbeafe}.qa-stat-number{font-size:28px;font-weight:800;line-height:1}.qa-stat-label{text-transform:uppercase;letter-spacing:.05em;opacity:.7;margin-top:5px;font-size:10px;font-weight:700}.qa-stat-total .qa-stat-number{color:#334155}.qa-stat-pass .qa-stat-number{color:#065f46}.qa-stat-fail .qa-stat-number{color:#991b1b}.qa-stat-cov .qa-stat-number{color:#1e40af}.qa-progress-label{color:#64748b;justify-content:space-between;margin-bottom:6px;font-size:12px;display:flex}.qa-progress-pct{font-weight:700}.qa-progress-bar{background:#e0e3ea;border-radius:3px;height:6px;margin-bottom:20px;overflow:hidden}.qa-progress-fill{background:linear-gradient(90deg,#3b5bdb,#10b981);height:100%;transition:width .5s}.qa-toolbar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;display:flex}.qa-filter-btn{cursor:pointer;color:#475569;background:#fff;border:1.5px solid #e0e3ea;border-radius:20px;padding:5px 13px;font-size:12px;font-weight:600;transition:all .15s}.qa-filter-btn.active{color:#1d4ed8;background:#eff6ff;border-color:#3b5bdb}.qa-filter-btn:hover{border-color:#93c5fd}.qa-toolbar-spacer{flex:1}.qa-search{border:1.5px solid #e0e3ea;border-radius:7px;outline:none;width:200px;padding:6px 12px;font-size:12px}.qa-search:focus{border-color:#3b5bdb}.qa-section-tabs{border-bottom:2px solid #e0e3ea;gap:2px;margin-bottom:14px;display:flex;overflow-x:auto}.qa-section-tab{cursor:pointer;color:#64748b;white-space:nowrap;background:0 0;border:none;border-radius:7px 7px 0 0;padding:6px 14px;font-size:12px;font-weight:600}.qa-section-tab.active{color:#3b5bdb;border-bottom:2px solid #3b5bdb;margin-bottom:-2px}.qa-section-tab:hover{background:#f8f9fc}.qa-table-wrap{overflow-x:auto}.qa-table{border-collapse:collapse;width:100%;font-size:13px}.qa-table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:#64748b;z-index:1;background:#f8f9fc;border-bottom:2px solid #e0e3ea;padding:9px 13px;font-size:11px;font-weight:700;position:sticky;top:0}.qa-table td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:8px 13px}.qa-section-hdr td{text-transform:uppercase;letter-spacing:.07em;color:#94a3b8;background:#f8f9fc;border-bottom:1px solid #e0e3ea;padding:10px 13px 4px;font-size:11px;font-weight:700}.qa-section-count{opacity:.7;margin-left:4px;font-weight:400}.qa-data-row:hover td{background:#f8f9fc}.qa-no-rows{text-align:center;color:#94a3b8;padding:28px}.qa-badge{white-space:nowrap;border-radius:20px;align-items:center;padding:2px 8px;font-size:11px;font-weight:700;display:inline-flex}.qa-badge-pass{color:#065f46;background:#d1fae5}.qa-badge-fail{color:#991b1b;background:#fee2e2}.qa-badge-ath{color:#1e40af;background:#dbeafe}.qa-badge-fi{color:#5b21b6;background:#ede9fe}.qa-badge-how{color:#92400e;background:#fef9c3;font-size:10px}.qa-value{color:#0f172a;text-overflow:ellipsis;white-space:nowrap;max-width:180px;font-family:monospace;font-size:12px;display:inline-block;overflow:hidden}.qa-dim{color:#cbd5e1;font-size:12px}.mapping-col-header,.xpath-cell{width:55%}.xpath-value{color:#334155;white-space:pre-wrap;word-break:break-all;font-family:monospace;font-size:11px;display:block}.xpath-empty{color:#cbd5e1;font-size:12px}.xpath-config-select{color:#334155;cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:4px;padding:3px 6px;font-size:12px}.detection-allotment-row{flex-wrap:wrap;gap:16px;margin-bottom:16px;display:flex}.detection-allotment-row .detection-rules{flex:1;min-width:200px;margin-bottom:0}.allotment-info{background:#f8faff;border:1px solid #e0e3ea;border-radius:6px;flex:1;min-width:200px;padding:10px 14px}.allotment-tags{flex-wrap:wrap;gap:4px;display:flex}.allotment-badge{color:#3730a3;background:#e0e7ff;border-radius:10px;padding:2px 7px;font-size:11px;font-weight:500;display:inline-block}.allotment-badge.element{color:#166534;background:#dcfce7}.allotment-badge.multi-leg{color:#92400e;vertical-align:middle;background:#fef3c7;margin-left:6px;font-size:10px;font-weight:400}.legacy-indicator-row{justify-content:flex-end;padding-bottom:2px}.legacy-badge{color:#9a3412;vertical-align:middle;cursor:default;text-transform:uppercase;letter-spacing:.04em;background:#fff7ed;border:1px solid #fed7aa;border-radius:4px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:500;display:inline-block}*{box-sizing:border-box;margin:0;padding:0}body{color:#222;background:#f5f6fa;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app-layout{flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-header{color:#fff;background:#1a2744;flex-shrink:0;align-items:center;gap:24px;padding:10px 24px;display:flex}.app-header h1{letter-spacing:.3px;white-space:nowrap;font-size:18px;font-weight:600}.app-body{flex:1;display:flex;overflow:hidden}.app-main{flex-direction:column;flex:1;min-height:0;padding:24px 28px;display:flex;overflow-y:auto}
