:root{font-family:Inter,PingFang SC,Microsoft YaHei,system-ui,sans-serif;color:#172033;background:#f5f7fa;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;-webkit-font-smoothing:antialiased}button,input,textarea{font:inherit}button{cursor:pointer}.loading{min-height:100vh;display:grid;place-items:center;color:#667085}.app-shell{min-height:100vh;background:#f5f7fa}.topbar{height:72px;display:grid;grid-template-columns:minmax(300px,.92fr) minmax(520px,1.08fr) auto;align-items:center;gap:18px;padding:0 22px;border-bottom:1px solid #dde3eb;background:#fffffff0;position:sticky;top:0;z-index:20}.brand{display:flex;align-items:center;gap:12px}.brand svg{color:#0f9b8e}.brand h1{font-size:22px;line-height:1.2;margin:0;letter-spacing:0}.top-status{display:flex;justify-content:center;gap:18px;min-width:0}.save-status{display:flex;align-items:center;gap:10px;min-width:158px;flex:0 1 auto}.save-status svg{color:#12a389}.save-status strong{display:block;color:#0e9482;font-size:15px}.save-status span{color:#6a7485;font-size:12px;line-height:1.45}.overall-status{min-height:40px;display:grid;grid-template-columns:auto 86px auto;align-items:center;gap:9px;padding:0 13px;border:1px solid #d8f0ee;border-radius:8px;background:#f0fafa}.overall-status span{color:#667085;font-size:12px;white-space:nowrap}.overall-status strong{color:#0f9b8e;font-size:14px}.overall-status-bar{height:6px;background:#dce8ee;border-radius:999px;overflow:hidden}.overall-status-bar b{display:block;height:100%;border-radius:inherit;background:#0f9b8e;transition:width .25s ease}.export-ready svg,.export-ready strong{color:#11a36d}.actions{display:flex;gap:10px;align-items:center;justify-content:flex-end;min-width:max-content}.primary,.soft-btn,.icon-btn{border:1px solid #d8e0ea;background:#fff;color:#263349;min-height:38px;border-radius:7px;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 14px;flex:0 0 auto;white-space:nowrap}.primary{background:#0f9b8e;border-color:#0f9b8e;color:#fff;font-weight:700}.primary:hover{background:#0b887d}.primary:disabled{cursor:not-allowed;opacity:1;background:#d9e3ea;border-color:#d9e3ea;color:#667085}.primary.needs-attention{background:#f08a24;border-color:#f08a24}.primary.needs-attention:hover{background:#d97706}.soft-btn:hover{background:#f8fafc;border-color:#bfcedd}.soft-btn:disabled{cursor:not-allowed;color:#98a2b3;background:#f3f6f9;border-color:#e0e6ee}.soft-btn.compact{min-height:34px;padding-inline:11px;font-size:13px}.icon-btn{width:31px;height:31px;min-height:31px;padding:0}.danger,.danger-text{color:#d92d20}.workspace{display:grid;grid-template-columns:270px minmax(0,1fr) 360px;gap:14px;padding:14px}.sidebar,.audit-side{display:flex;flex-direction:column;gap:14px}.sidebar{position:sticky;top:86px;align-self:start}.steps{background:#fff;border:1px solid #e0e6ee;border-radius:8px;overflow:hidden}.step{width:100%;display:grid;grid-template-columns:36px 1fr 42px;align-items:center;gap:10px;padding:24px 16px;min-height:112px;border:0;border-bottom:1px solid #e6ebf2;background:#fff;text-align:left;color:#1f2937;position:relative}.step:last-child{border-bottom:0}.step.active:before{content:"";position:absolute;left:0;top:14px;bottom:14px;width:3px;background:#0f9b8e}.step-index{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:#e6edf3;color:#536172;font-weight:700}.step.active .step-index{background:#16b7ad;color:#fff}.step-body strong{display:block;font-size:14px;margin-bottom:14px}.progress-line{display:block;height:5px;background:#e7edf3;border-radius:999px;overflow:hidden}.progress-line span{display:block;height:100%;border-radius:inherit;background:#0f9b8e}.step:nth-child(2) .progress-line span{background:#1c75d8}.step:nth-child(3) .progress-line span{background:#f18b15}.step em{color:#637084;font-style:normal;font-size:13px}.storage-card,.hint-card,.panel{background:#fff;border:1px solid #e0e6ee;border-radius:8px}.storage-card,.hint-card{padding:18px}.storage-card{color:#536172}.storage-card svg{color:#64748b;margin-bottom:8px}.storage-card strong,.hint-card strong{display:block;color:#253044;margin-bottom:4px}.storage-card span,.hint-card p{color:#6a7485;font-size:13px}.storage-bar{height:5px;background:#e4ebf2;border-radius:999px;overflow:hidden;margin-top:14px}.storage-bar span{display:block;width:24%;height:100%;background:#0f9b8e}.hint-card{background:#effafa;border-color:#d8f0ee}.content{min-width:0;display:flex;flex-direction:column;gap:12px}.panel{overflow:hidden}.panel-title{min-height:52px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 18px;border-bottom:1px solid #e3e9f0}.panel-title h2,.audit-card h2,.image-audit h2,.final-panel h2{font-size:18px;margin:0;line-height:1.2}.panel-title span{color:#667085;font-size:13px}.sheet-title-left{display:flex;align-items:center;gap:12px;min-width:0}.uid-guide-btn{min-height:38px;border:2px solid #ef4444;border-radius:7px;padding:0 14px;background:#fff1f1;color:#d92d20;font-size:15px;font-weight:900;white-space:nowrap;box-shadow:0 8px 18px #d92d2029}.uid-guide-btn:hover{background:#d92d20;color:#fff}.main-form{min-height:565px}.form-grid{padding:22px 18px;display:grid;grid-template-columns:1fr 1fr;gap:20px 18px}.field{display:grid;grid-template-columns:118px minmax(0,1fr);align-items:center;gap:12px;position:relative}.field.full{grid-column:1 / -1}.field span{color:#344054;font-size:14px}.field b,.group-head b{color:#d92d20}.field input,.field textarea{width:100%;border:1px solid #d9e1ea;border-radius:6px;color:#1f2937;outline:none;background:#fff}.field input{height:42px;padding:0 14px}.field textarea{min-height:78px;resize:vertical;padding:12px 14px}.field input:focus,.field textarea:focus,.sheet input:focus,.note-input:focus{border-color:#0f9b8e;box-shadow:0 0 0 3px #0f9b8e1f}.attention-target{animation:attentionPulse 1.2s ease-in-out 2;outline:3px solid #f04438!important;outline-offset:3px}.sheet input.attention-target{box-shadow:inset 0 0 0 2px #f04438,0 0 0 4px #f044382e}.image-group.attention-target{border-color:#f04438;box-shadow:0 0 0 4px #f0443824}@keyframes attentionPulse{0%,to{outline-color:#f04438}50%{outline-color:#f59e0b}}.field em{position:absolute;right:12px;bottom:10px;color:#8a94a6;font-size:12px;font-style:normal;background:#fff}.sheet-panel{min-height:290px}.sheet-wrap{overflow:auto;max-height:390px}.sheet{border-collapse:collapse;width:100%;min-width:1360px;font-size:13px}.project-sheet-panel .sheet{min-width:1840px}.sheet th,.sheet td{border:1px solid #e1e7ee;height:42px;padding:0;background:#fff;position:relative}.sheet th{position:sticky;top:0;z-index:2;background:#f7f9fc;font-weight:700;color:#374151}.project-sheet-panel .sheet th:nth-child(2),.project-sheet-panel .sheet th:nth-child(3),.project-sheet-panel .sheet th:nth-child(4),.project-sheet-panel .sheet th:nth-child(5),.project-sheet-panel .sheet th:nth-child(6){background:#ffc400;color:#171717}.sheet tr.example-row td{height:auto;min-height:92px;padding:10px 8px;background:#e8f0ff;color:#172033;vertical-align:top;white-space:pre-wrap;line-height:1.55}.sheet tr.example-row .row-num{color:#1d4ed8;font-weight:800;vertical-align:middle}.example-cell{min-width:90px}.example-cell span{display:block}.example-action{width:72px;text-align:center;color:#667085!important;font-weight:700;vertical-align:middle!important}.sheet tr.incomplete-row td{background:#fff8f6}.sheet tr.incomplete-row td:first-child{color:#d92d20;font-weight:800}.row-num{width:44px;text-align:center;color:#667085;background:#f7f9fc!important}.sheet input{border:0;width:100%;height:41px;padding:0 10px;outline:none;color:#263349;background:transparent}.sheet tr:hover td{background:#fbfdff}.sheet td.selected-cell{background:#eef7ff!important;box-shadow:inset 0 0 0 1px #2f80ed}.sheet td.selected-cell input{color:#102a43}.sheet tr.incomplete-row:hover td{background:#fff3ef}.sheet-empty{height:72px!important;text-align:center;color:#98a2b3;background:#fbfdff!important}.guide-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:110;display:grid;place-items:center;padding:24px;background:#0f172a94;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.guide-dialog{position:relative;width:min(1180px,94vw);max-height:90vh;display:grid;grid-template-columns:260px minmax(0,1fr);overflow:hidden;border-radius:8px;border:1px solid rgba(255,255,255,.45);background:#fff;box-shadow:0 30px 80px #0f172a61}.guide-close{position:absolute;top:12px;right:12px;z-index:3;width:36px;height:36px;display:grid;place-items:center;border:1px solid #d8e0ea;border-radius:7px;background:#fff;color:#263349}.guide-side{display:grid;grid-template-rows:auto 1fr;gap:18px;padding:22px 18px;background:#0f9b8e;color:#fff}.guide-side>div{display:grid;gap:6px}.guide-side>div span{font-size:13px;opacity:.82}.guide-side>div strong{font-size:22px;line-height:1.25}.guide-side nav{display:grid;align-content:start;gap:9px}.guide-side nav button{min-height:42px;display:grid;grid-template-columns:26px 1fr;align-items:center;gap:9px;border:1px solid rgba(255,255,255,.22);border-radius:7px;padding:0 10px;background:#ffffff1a;color:#fff;text-align:left}.guide-side nav button.active{background:#fff;color:#0b766d}.guide-side nav em{width:24px;height:24px;display:grid;place-items:center;border-radius:50%;background:#fff3;font-style:normal;font-weight:800;font-size:12px}.guide-side nav button.active em{background:#0f9b8e;color:#fff}.guide-main{min-width:0;max-height:90vh;display:grid;grid-template-rows:auto minmax(0,1fr) auto auto;overflow:hidden}.guide-head{display:flex;justify-content:space-between;gap:18px;padding:22px 62px 16px 22px;border-bottom:1px solid #e3e9f0}.guide-head span{display:inline-flex;width:fit-content;margin-bottom:8px;padding:4px 9px;border-radius:999px;background:#effafa;color:#0f9b8e;font-size:12px;font-weight:800}.guide-head h2{margin:0;color:#172033;font-size:24px;line-height:1.2}.guide-head p{max-width:680px;margin:8px 0 0;color:#667085;line-height:1.65;font-size:14px}.guide-head>strong{flex:0 0 auto;align-self:start;color:#0f9b8e;font-size:15px}.guide-image{min-height:0;padding:18px 22px;overflow:auto;background:#f7f9fc}.guide-image img{display:block;width:100%;min-width:680px;border:1px solid #dfe7f0;border-radius:8px;background:#fff}.guide-points{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;padding:14px 22px;border-top:1px solid #e3e9f0;background:#fff}.guide-points div{min-height:38px;display:flex;align-items:center;gap:8px;padding:0 11px;border-radius:7px;background:#f1fbf5;color:#344054;font-size:13px}.guide-points svg{flex:0 0 auto;color:#079455}.guide-actions{display:flex;justify-content:space-between;gap:12px;padding:14px 22px;border-top:1px solid #e3e9f0;background:#fff}.uid-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:grid;place-items:center;padding:24px;background:#0f172a8a;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.uid-dialog{position:relative;width:min(920px,92vw);max-height:88vh;display:flex;flex-direction:column;overflow:hidden;border-radius:8px;border:1px solid rgba(255,255,255,.34);background:#0f172a;box-shadow:0 28px 70px #0f172a5c}.uid-dialog.show-qr{width:min(520px,92vw);background:#fff}.uid-close{position:absolute;top:12px;right:12px;z-index:2;width:36px;height:36px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.36);border-radius:7px;background:#0f172ab8;color:#fff}.uid-dialog.show-qr .uid-close{border-color:#d8e0ea;background:#fff;color:#172033}.uid-dialog-head{min-height:58px;display:flex;align-items:center;gap:10px;padding:0 64px 0 18px;color:#fff;background:#111827}.uid-dialog-head strong{font-size:17px}.uid-dialog-head span{color:#cbd5e1;font-size:13px}.uid-video{width:100%;max-height:calc(88vh - 58px);background:#000}.uid-qr-panel{display:grid;justify-items:center;gap:12px;padding:54px 30px 30px;text-align:center}.uid-qr-panel svg{color:#0f9b8e}.uid-qr-panel strong{color:#172033;font-size:22px}.uid-qr-panel img{width:min(360px,72vw);aspect-ratio:1;object-fit:contain;border:1px solid #e0e6ee;border-radius:8px;background:#fff}.uid-qr-panel span{color:#667085;font-size:13px}.image-panel{min-height:600px}.image-groups{display:grid;gap:0}.image-group{padding:18px;border-bottom:1px solid #e3e9f0}.image-group:last-child{border-bottom:0}.group-head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:14px}.group-head strong{display:block;font-size:16px}.group-head span{color:#667085;font-size:13px}.rule-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.rule-tags em{font-style:normal;font-size:12px;color:#177ddc;background:#eef6ff;border:1px solid #c9e4ff;border-radius:5px;padding:4px 8px}.upload-row{display:grid;grid-template-columns:220px minmax(0,1fr);gap:16px}.route-methods{display:grid;gap:14px}.route-note-tip{min-height:38px;display:flex;align-items:center;border:1px solid #b9dafc;border-radius:7px;padding:9px 12px;background:#eef6ff;color:#1d4ed8;font-size:13px;line-height:1.5}.route-method{border:1px solid #dfe8f2;border-radius:8px;background:#fbfdff;padding:14px}.route-method.complete{border-color:#bfe7d4;background:#f6fdf9}.route-method-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.route-method-head strong{display:block;font-size:15px}.route-method-head span{color:#667085;font-size:12px}.route-method-head em{font-style:normal;font-size:12px;color:#177ddc;background:#eef6ff;border:1px solid #c9e4ff;border-radius:5px;padding:4px 8px;white-space:nowrap}.route-method.complete .route-method-head em{color:#07884f;background:#eaf8f0;border-color:#c7ead8}.route-example{border:1px solid #d9e3ee;border-radius:7px;overflow:hidden;background:#fff;margin-bottom:12px}.route-example img{display:block;width:100%;max-height:130px;object-fit:contain;background:#fff}.route-upload-row{grid-template-columns:220px minmax(0,1fr)}.upload-zone{height:162px;border:1px dashed #74a9ff;border-radius:8px;display:grid;place-items:center;align-content:center;gap:5px;color:#177ddc;background:#f8fbff;position:relative}.upload-zone input{display:none}.upload-zone strong{color:#263349;font-size:13px}.upload-zone span,.upload-zone small{font-size:12px}.upload-zone.green{border-color:#7ccf9c;color:#17a05d;background:#f6fdf8}.upload-zone.teal{border-color:#71c9c3;color:#0f9b8e;background:#f3fbfa}.upload-zone.purple{border-color:#bba7ff;color:#7856d8;background:#fbf9ff}.zone-mark{position:absolute;right:10px;bottom:10px;opacity:.5}.thumb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(138px,1fr));gap:10px}.thumb{border:1px solid #dfe6ee;border-radius:7px;padding:8px;min-height:190px;position:relative;background:#fff}.thumb.passed{border-color:#cfeedd}.thumb.failed{border-color:#ffd2cc}.thumb img,.svg-preview{width:100%;aspect-ratio:16 / 10;object-fit:cover;border-radius:5px;background:#f1f5f9;border:1px solid #e5ebf2}.svg-preview{display:grid;place-items:center;color:#7856d8;font-weight:800}.thumb-delete{position:absolute;top:12px;right:12px;width:26px;height:26px;border:1px solid #f0c8c3;background:#fff;color:#d92d20;border-radius:6px;display:grid;place-items:center}.thumb-meta{margin-top:7px}.thumb-meta strong{display:block;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.thumb-meta span,.thumb small,.reject-reason{display:block;color:#667085;font-size:11px;margin-top:3px}.thumb small,.reject-reason{color:#d92d20;line-height:1.35}.reject-reason{padding:6px 7px;background:#fff0ee;border-radius:5px}.thumb-status,.status,.level{display:inline-flex;align-items:center;min-height:24px;border-radius:5px;padding:0 8px;font-size:12px;font-weight:700;margin-top:6px}.passed,.status.passed{color:#07884f;background:#eaf8f0}.failed,.status.failed{color:#d92d20;background:#fff0ee}.note-input{width:100%;height:30px;margin-top:7px;border:1px solid #dce4ed;border-radius:5px;padding:0 8px;outline:none;font-size:12px}.route-name-input{border-color:#9bd7cc;background:#fff}.route-name-help{display:block;margin-top:5px;color:#667085;font-size:11px;line-height:1.45}.empty-thumbs{min-height:162px;border:1px dashed #d8e0ea;border-radius:8px;display:grid;place-items:center;color:#98a2b3}.audit-side{position:sticky;top:86px;align-self:start}.audit-card,.image-audit,.package-ready{padding:18px}.missing{display:grid;gap:12px}.missing h3{color:#d92d20;font-size:18px;margin:0}.missing-row{display:grid;grid-template-columns:10px minmax(0,1fr) auto;gap:8px;align-items:center;min-height:30px;font-size:13px}.missing-row b{width:7px;height:7px;border-radius:50%;background:#f04438}.missing-row em{color:#667085;font-style:normal}.success-line{color:#07884f;display:flex;gap:8px;align-items:center;font-size:13px}.image-audit{display:grid;gap:10px}.image-audit h2{margin-bottom:4px}.image-audit div:not(:first-child){display:flex;justify-content:space-between;align-items:center;min-height:40px;padding:0 12px;border-radius:6px;background:#f6f8fb;color:#5a6678}.image-audit strong{color:#0f9b8e}.package-ready{display:grid;gap:9px;border-color:#ffd8ba;background:#fffaf5}.package-ready.ready{border-color:#bfecd3;background:#f1fbf5}.package-ready svg{color:#f08a24}.package-ready.ready svg{color:#079455}.package-ready span{color:#667085;font-size:13px}.simple-table{width:100%;border-collapse:collapse;font-size:13px}.recent-panel{overflow-x:auto}.recent-panel.embedded{margin:14px 18px 0;border:1px solid #dfe7f0;border-radius:7px;background:#fbfdff}.recent-panel .simple-table{min-width:640px}.simple-table th,.simple-table td{border-bottom:1px solid #e6ebf2;padding:11px 14px;text-align:left}.simple-table th{background:#f7f9fc;color:#475467;font-weight:700}.simple-table td{color:#344054}.level.错误{color:#d92d20;background:#fff0ee}.level.警告{color:#e07000;background:#fff5e8}.level.提示{color:#177ddc;background:#eef6ff}.footer-actions{display:flex;justify-content:space-between;gap:12px;padding:0 2px}.step-actions{display:flex;justify-content:space-between;gap:12px;padding:2px 0}.final-panel{padding:24px;display:grid;gap:20px}.final-panel p{margin:8px 0 0;color:#667085}.export-tree{background:#f7f9fc;border:1px solid #e0e6ee;border-radius:8px;padding:16px;display:grid;gap:8px;color:#475467}.export-tree strong{color:#172033}.final-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.final-grid div{border:1px solid #e0e6ee;border-radius:8px;padding:16px;display:grid;gap:5px}.final-grid strong{font-size:26px;color:#0f9b8e}.final-grid span,.check-list span{color:#667085}.check-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.check-list div{min-height:38px;display:flex;align-items:center;gap:8px;color:#07884f;background:#f1fbf5;border-radius:7px;padding:0 12px}.check-list strong{margin-left:auto;color:#172033}.primary.big{width:fit-content;min-height:46px;padding-inline:20px}.final-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.export-hint{margin:0;color:#667085;font-size:13px}.soft-btn.big{min-height:46px;padding-inline:20px;font-weight:700}@media(max-width:1180px){.topbar{grid-template-columns:1fr;height:auto;padding:14px}.top-status,.actions{justify-content:flex-start;flex-wrap:wrap}.workspace{grid-template-columns:1fr}.sidebar,.audit-side{position:static}.steps{display:grid;grid-template-columns:repeat(4,minmax(180px,1fr));overflow-x:auto}.step{border-bottom:0;border-right:1px solid #e6ebf2}.guide-dialog{grid-template-columns:1fr}.guide-side{grid-template-rows:auto auto;gap:12px}.guide-side nav{grid-template-columns:repeat(3,minmax(0,1fr))}.guide-main{max-height:calc(90vh - 198px)}.guide-points{grid-template-columns:1fr}}@media(max-width:760px){.brand h1{font-size:18px}.form-grid,.final-grid,.check-list,.upload-row{grid-template-columns:1fr}.steps{grid-template-columns:repeat(2,minmax(0,1fr));overflow:visible}.step{grid-template-columns:32px 1fr;min-height:128px;gap:8px;padding:18px 14px}.step em{grid-column:2}.field{grid-template-columns:1fr;gap:7px}.actions,.top-status,.step-actions,.footer-actions,.final-actions{flex-direction:column;align-items:stretch}.actions button,.step-actions button,.footer-actions button,.final-actions button{width:100%}.panel-title{align-items:stretch;flex-direction:column;padding:12px 14px}.sheet-title-left{align-items:flex-start;flex-direction:column;gap:8px}.uid-guide-btn{width:100%;white-space:normal}.uid-dialog-head{align-items:flex-start;flex-direction:column;gap:5px;padding:12px 58px 12px 14px}.guide-overlay{padding:10px}.guide-dialog{width:100%;max-height:94vh}.guide-side{padding:16px 12px}.guide-side>div strong{font-size:18px}.guide-side nav{grid-template-columns:1fr 1fr}.guide-side nav button{min-height:38px;font-size:12px}.guide-main{max-height:calc(94vh - 248px)}.guide-head{flex-direction:column;padding:16px 54px 12px 14px}.guide-head h2{font-size:20px}.guide-image{padding:12px 14px}.guide-image img{min-width:760px}.guide-points,.guide-actions{padding:12px 14px}.guide-actions{flex-direction:column}.guide-actions button{width:100%}.overall-status{grid-template-columns:auto minmax(70px,1fr) auto}}
