:root{--bg: #f4f7fb;--panel: #ffffff;--line: #d8e0eb;--ink: #172033;--muted: #667085;--blue: #2563eb;--green: #16845b;--amber: #b76e00;--red: #c0392b}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink);font-family:Inter,PingFang SC,Microsoft YaHei,Arial,sans-serif}button{font:inherit;cursor:pointer}.app{min-height:100vh;display:grid;grid-template-columns:72px minmax(0,1fr)}.sidebar{background:#101827;padding:16px 10px;display:grid;align-content:start;justify-items:center;gap:12px}.brand,.sidebar button{width:44px;height:44px;border:0;border-radius:8px;display:grid;place-items:center}.brand{background:#e7f0ff;color:#123b77;font-weight:900}.sidebar button{color:#dbeafe;background:#172235}.sidebar button.active{background:#2563eb;color:#fff}.workspace{padding:20px;display:grid;gap:14px}.topbar,.status-tabs,.panel-head,.detail-hero{display:flex;align-items:center;justify-content:space-between;gap:16px}h1,h2,h3,h4,p{margin:0}.topbar p,.detail-hero p,.detail-hero span,.order-card span,.order-card small,.summary-grid span,.section-grid p{color:var(--muted)}.actions{display:flex;gap:10px}.actions button,.detail-hero button,.status-tabs button{min-height:38px;border-radius:8px;border:1px solid var(--line);background:#fff;padding:0 12px;display:inline-flex;align-items:center;gap:7px;font-weight:700}.ghost{background:#fff!important;color:var(--ink);border-color:var(--line)!important}.primary{background:var(--blue)!important;color:#fff;border-color:var(--blue)!important}.status-tabs{background:#fff;border:1px solid var(--line);border-radius:8px;padding:8px;justify-content:flex-start;overflow-x:auto}.status-tabs button.active{color:var(--blue);background:#eef4ff;border-color:#bfdbfe}.status-tabs strong{min-width:22px;min-height:22px;border-radius:999px;display:grid;place-items:center;background:#edf2f7}.order-list,.detail,.table-card,.report-panel{background:var(--panel);border:1px solid var(--line);border-radius:8px;overflow:hidden}.page-panel{min-height:calc(100vh - 176px)}.panel-head,.detail-hero{padding:14px;border-bottom:1px solid var(--line)}.order-grid{padding:12px;display:grid;grid-template-columns:repeat(auto-fill,minmax(430px,1fr));gap:10px}.order-card{width:100%;text-align:left;border:1px solid var(--line);border-radius:8px;background:#fff;padding:10px;display:grid;grid-template-columns:58px minmax(0,1fr);gap:10px}.order-card:hover{background:#f3f7ff}.part-thumb{width:58px;height:58px;border:1px solid var(--line);border-radius:8px;background:linear-gradient(135deg,rgba(37,99,235,.12),transparent 48%),repeating-linear-gradient(45deg,#eef2f7,#eef2f7 9px,#f8fafc 9px,#f8fafc 18px);display:grid;place-items:center;color:#475569;font-size:12px;font-weight:900}.part-thumb.large{width:86px;height:86px;font-size:15px}.order-card-main{display:grid;gap:7px}.order-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.order-card h3{font-size:15px}.order-card em{flex:0 0 auto;border-radius:999px;padding:3px 8px;font-style:normal;font-size:12px;font-weight:800;background:#eef2ff;color:#3340a0}.order-card em.danger{background:#fee2e2;color:var(--red)}.order-card em.warn{background:#fff7df;color:var(--amber)}.order-card em.prepare{background:#e0f2fe;color:#0369a1}.order-card em.good{background:#e6f7ef;color:var(--green)}.flag-row,.tag-row{display:flex;flex-wrap:wrap;gap:5px;margin-top:5px}.flag-row span,.tag-row span{min-height:20px;border-radius:999px;padding:2px 7px;background:#eef4ff;color:var(--blue);font-size:11px;font-weight:800}.tag-row span{background:#f1f5f9;color:#475569}.order-facts{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}.order-facts div{display:grid;gap:1px}.order-facts span{color:var(--muted);font-size:11px;font-weight:650}.order-facts strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.detail{min-height:680px}.detail-hero{position:relative;padding:18px 22px 18px 172px;background:linear-gradient(180deg,#fff,#f8fbff)}.back-button{position:absolute;left:14px;top:14px}.eyebrow{display:block;color:var(--blue)!important;font-size:12px;font-weight:850;margin-bottom:6px}.detail-hero h2{font-size:22px}.detail-status-stack{min-width:120px;display:grid;justify-items:end;gap:7px}.detail-status-stack em{border-radius:999px;padding:4px 9px;font-style:normal;font-size:12px;font-weight:850;background:#eef2ff;color:#3340a0}.detail-status-stack em.danger{background:#fee2e2;color:var(--red)}.detail-status-stack em.warn{background:#fff7df;color:var(--amber)}.detail-status-stack em.prepare{background:#e0f2fe;color:#0369a1}.detail-status-stack em.good{background:#e6f7ef;color:var(--green)}.detail-status-stack strong{font-size:13px}.detail-tabs{display:flex;gap:2px;padding:0 16px;border-bottom:1px solid var(--line);background:#fff;overflow-x:auto}.detail-tabs button{border:0;border-bottom:3px solid transparent;background:transparent;min-height:48px;padding:0 12px;color:var(--muted);font-weight:760}.detail-tabs button.active{color:var(--blue);border-bottom-color:var(--blue)}.detail-content{padding:18px 20px 22px}.content-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.wide{grid-column:1 / -1}.info-block{border:1px solid var(--line);border-radius:8px;background:#fff;padding:14px;display:grid;gap:10px}.gate-score{min-height:70px;padding:14px;border:1px solid var(--line);border-radius:8px;display:grid;gap:4px}.gate-score strong{font-size:24px}.gate-score span{color:var(--muted);font-weight:700}.gate-score.blocked{background:#fff6f3;border-color:#ffd6cf}.gate-score.blocked strong{color:var(--red)}.gate-score.prepare{background:#eff6ff;border-color:#bfdbfe}.gate-score.prepare strong{color:#0369a1}.gate-score.allowed{background:#f0fdf7;border-color:#c8f0dc}.gate-score.allowed strong{color:var(--green)}.gate-score.checking{background:#fffaf0;border-color:#fde68a}.gate-score.checking strong{color:var(--amber)}.kv-grid,.focus-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.focus-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.kv-grid div,.focus-grid div{min-height:58px;padding:10px;border:1px solid var(--line);border-radius:8px;background:#f8fafc;display:grid;align-content:center;gap:4px}.kv-grid span,.focus-grid span{color:var(--muted);font-size:12px;font-weight:650}.kv-grid strong,.focus-grid strong{font-size:13px}.action-list{display:grid;gap:10px}.action-list div{display:grid;grid-template-columns:28px minmax(0,1fr);gap:10px;align-items:start;padding:10px;border:1px solid var(--line);border-radius:8px;background:#f8fafc}.action-list div strong,.action-list div p{grid-column:2}.action-list div>span{grid-row:1 / 3}.action-list div>span{width:24px;height:24px;border-radius:999px;display:grid;place-items:center;background:#eef4ff;color:var(--blue);font-size:12px;font-weight:900}.action-list p,.info-block p{color:var(--muted);line-height:1.5}.mes-context,.inspection-tab{display:grid;gap:14px}.requirement-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.requirement-grid article{padding:12px;border:1px solid var(--line);border-radius:8px;background:#f8fafc;display:grid;gap:6px}.chip-row,.attachment-row,.report-status-strip,.actions-row{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.requirement-chip,.attachment-pill,.mini-pill,.status-badge{min-height:24px;border-radius:999px;padding:3px 9px;display:inline-flex;align-items:center;background:#eef4ff;color:var(--blue);font-size:12px;font-weight:800}.attachment-pill,.mini-pill{background:#f1f5f9;color:#475569}.status-badge.danger{background:#fee2e2;color:var(--red)}.status-badge.warn{background:#fff7df;color:var(--amber)}.status-badge.prepare{background:#e0f2fe;color:#0369a1}.status-badge.good{background:#e6f7ef;color:var(--green)}.summary-strip,.qc-result-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.summary-strip div,.qc-result-grid div{min-height:58px;border:1px solid var(--line);border-radius:8px;background:#f8fafc;padding:10px;display:grid;align-content:center;gap:3px}.summary-strip span,.qc-result-grid span,.attachment-card span,.report-preview span,.muted{color:var(--muted);font-size:12px;font-weight:650}.issue-note{padding:12px;border:1px solid #fde68a;border-radius:8px;background:#fffbeb;line-height:1.55;color:#713f12}.row-between{display:flex;justify-content:space-between;align-items:center;gap:12px}.qc-part-list{display:grid;gap:10px}.qc-part-card{display:grid;grid-template-columns:86px minmax(0,1fr);gap:12px;border:1px solid var(--line);border-radius:8px;background:#f8fafc;padding:12px}.qc-part-main,.qc-part-head{display:grid;gap:10px}.qc-part-head{grid-template-columns:minmax(0,1fr) auto;align-items:start}.qc-part-head p{color:var(--muted);font-size:12px;margin-top:3px}.qc-part-facts,.qc-note-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.qc-note-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.qc-part-facts div,.qc-note-grid div{border:1px solid var(--line);border-radius:8px;background:#fff;padding:9px;display:grid;gap:3px}.qc-part-facts span,.qc-note-grid span{color:var(--muted);font-size:11px;font-weight:700}.qc-part-facts strong,.qc-note-grid strong{font-size:12px}.attachment-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.attachment-card{min-height:82px;border:1px solid var(--line);border-radius:8px;background:#f8fafc;padding:10px;display:grid;gap:5px}.attachment-card em{color:var(--blue);font-style:normal;font-size:12px;font-weight:850}.gauge-page{background:var(--panel);border:1px solid var(--line);border-radius:8px;overflow:hidden}.gauge-head{align-items:flex-start}.gauge-head p{margin-top:4px;color:var(--muted)}.gauge-stat-grid{padding:12px;border-bottom:1px solid var(--line);display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;background:#f8fafc}.gauge-stat-grid div{min-height:72px;border:1px solid var(--line);border-radius:8px;background:#fff;padding:12px;display:grid;align-content:center;gap:4px}.gauge-stat-grid span{color:var(--muted);font-size:12px;font-weight:750}.gauge-stat-grid strong{font-size:24px}.gauge-layout{padding:14px;display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:14px;align-items:start}.gauge-table td small{display:block;margin-top:4px;color:var(--muted);font-size:12px}.gauge-side{display:grid;gap:14px}.rule-list{display:grid;gap:10px}.rule-list div{border:1px solid var(--line);border-radius:8px;background:#f8fafc;padding:10px;display:grid;gap:4px}.rule-list p{color:var(--muted);font-size:12px;line-height:1.45}.gauge-chip-cloud{display:flex;flex-wrap:wrap;gap:8px}.gauge-chip-cloud span{min-height:24px;border-radius:999px;padding:3px 9px;background:#f1f5f9;color:#475569;font-size:12px;font-weight:800}.online-qc-head{min-height:78px;padding:14px 16px;border:1px solid var(--line);border-radius:8px;background:#fff;display:flex;align-items:center;justify-content:space-between;gap:16px}.online-qc{display:grid;gap:14px}.drawing-recognition{border:1px solid var(--line);border-radius:8px;background:#fff;overflow:hidden}.recognition-head{padding:14px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:16px}.recognition-head h3{font-size:15px}.recognition-head p{color:var(--muted);margin-top:4px;font-size:13px}.recognition-actions{display:flex;align-items:center;gap:8px;flex:0 0 auto}.upload-drawing-btn{min-height:38px;border-radius:8px;border:1px solid var(--line);background:#fff;padding:0 12px;display:inline-flex;align-items:center;font-weight:800;cursor:pointer}.upload-drawing-btn.secondary{background:#f8fafc;color:#334155}.upload-drawing-btn input{display:none}.upload-drawing-btn.disabled,button:disabled{opacity:.55;cursor:not-allowed}.cnc-error{margin:12px 14px 0;padding:10px 12px;border:1px solid #ffc8c0;border-radius:8px;background:#fff6f3;color:var(--red);font-size:13px}.cnc-feedback-message{margin:10px 14px 0;padding:9px 12px;border:1px solid #bfdbfe;border-radius:8px;background:#eff6ff;color:#1d4ed8;font-size:13px;font-weight:750}.cnc-compare-strip{margin:10px 14px 0;border:1px solid #dbeafe;border-radius:8px;background:#f8fbff;padding:8px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr)) auto minmax(220px,1.3fr);gap:8px;align-items:stretch}.cnc-compare-strip div{border:1px solid var(--line);border-radius:7px;background:#fff;padding:7px 9px;display:grid;gap:2px}.cnc-compare-strip span{color:var(--muted);font-size:11px;font-weight:800}.cnc-compare-strip strong{font-size:18px}.cnc-compare-strip p{color:#1e40af;font-size:12px;line-height:1.45;font-weight:750;align-self:center}.compare-switch{display:inline-grid!important;grid-template-columns:repeat(2,minmax(56px,auto));gap:4px!important;padding:4px!important;align-self:center}.compare-switch button{min-height:30px;border:1px solid var(--line);border-radius:6px;background:#f8fafc;padding:0 10px;font-size:12px;font-weight:850}.compare-switch button.active{border-color:#93c5fd;background:#eff6ff;color:var(--blue)}.recognition-body{display:grid;grid-template-columns:minmax(0,1.9fr) minmax(360px,.85fr);gap:12px;padding:10px;background:#f8fafc;align-items:start}.review-summary-strip{padding:10px 14px;border-bottom:1px solid var(--line);display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;background:#fff}.review-summary-strip div{border:1px solid var(--line);border-radius:8px;background:#f8fafc;padding:8px 10px;display:grid;gap:2px}.review-summary-strip span{color:var(--muted);font-size:12px;font-weight:750}.review-summary-strip strong{font-size:18px}.drawing-reviewer{border:1px solid var(--line);border-radius:8px;background:#fff;overflow:hidden;display:grid;grid-template-rows:auto minmax(640px,calc(100vh - 280px))}.drawing-toolbar{min-height:36px;border-bottom:1px solid var(--line);padding:5px 8px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;background:#fff}.drawing-toolbar button{min-height:28px;border-radius:8px;border:1px solid var(--line);padding:0 8px;font-size:11px;font-weight:800}.bubble-mode-control{border:1px solid var(--line);border-radius:8px;background:#f8fafc;padding:2px;display:inline-grid;grid-template-columns:repeat(3,minmax(42px,auto));gap:2px}.bubble-mode-control button{min-height:24px;border:1px solid transparent;border-radius:6px;background:transparent;padding:0 8px;color:var(--muted);font-size:11px}.bubble-mode-control button.active{border-color:#bfdbfe;background:#fff;color:var(--blue);box-shadow:0 1px 4px #0f172a14}.drawing-toolbar span{margin-left:auto;color:var(--muted);font-size:11px;font-weight:750;max-width:44%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:right}.drawing-image-wrap{position:relative;min-height:640px;height:calc(100vh - 280px);border:0;border-radius:0;background:linear-gradient(90deg,rgba(148,163,184,.15) 1px,transparent 1px),linear-gradient(rgba(148,163,184,.15) 1px,transparent 1px),#eef2f7;background-size:24px 24px;overflow:hidden;display:grid;place-items:center;padding:8px}.drawing-canvas{position:relative;width:100%;height:100%;transform-origin:center center;transition:transform .18s ease;display:grid;place-items:center}.drawing-canvas img{width:100%;height:100%;object-fit:contain;display:block;filter:contrast(1.08) saturate(.92)}.drawing-empty{min-height:640px;height:calc(100vh - 280px);border:1px dashed #cbd5e1;border-radius:8px;background:#f8fafc;display:grid;place-items:center;align-content:center;gap:6px;color:var(--muted);text-align:center}.drawing-empty strong{color:var(--ink)}.cnc-balloon-dot{position:absolute;transform:translate(-50%,-50%);width:20px;height:20px;border-radius:50%;display:grid;place-items:center;color:#fff;background:var(--amber);border:2px solid rgba(255,255,255,.95);box-shadow:0 2px 7px #0f172a3d;font-size:9px;font-weight:900;cursor:pointer;opacity:.82;z-index:3;padding:0}.cnc-balloon-dot.accepted{background:var(--green)}.cnc-balloon-dot.excluded{background:#64748b;opacity:.38}.cnc-balloon-dot.review{background:var(--amber)}.cnc-balloon-dot.dot{width:8px;height:8px;border:1px solid #ffffff;color:transparent;box-shadow:0 1px 4px #0f172a33}.cnc-balloon-dot.focused,.cnc-balloon-dot.active{width:24px;height:24px;opacity:1;z-index:8;outline:3px solid rgba(37,99,235,.2);background:var(--blue);font-size:10px}.cnc-balloon-dot.dot.focused,.cnc-balloon-dot.dot.active{color:#fff}.candidate-crosshair{position:absolute;left:50%;top:50%;width:46px;height:46px;transform:translate(-50%,-50%);pointer-events:none;z-index:7}.candidate-crosshair:before,.candidate-crosshair:after{content:"";position:absolute;background:#2563ebd1;box-shadow:0 0 0 2px #ffffffc7}.candidate-crosshair:before{left:50%;top:0;bottom:0;width:1px}.candidate-crosshair:after{top:50%;left:0;right:0;height:1px}.candidate-list{max-height:360px;overflow:auto;display:grid;align-content:start;gap:8px;padding-right:2px}.candidate-list.compact{max-height:340px}.candidate-review-panel{display:grid;gap:12px;align-content:start}.active-candidate-card{border:1px solid var(--line);border-radius:8px;background:#fff;overflow:hidden}.active-candidate-head{padding:12px;border-bottom:1px solid var(--line);display:grid;grid-template-columns:40px minmax(0,1fr) auto;gap:10px;align-items:start}.active-candidate-head h4{font-size:15px;line-height:1.35}.active-candidate-head p{margin-top:3px;color:var(--muted);font-size:12px}.candidate-balloon{width:28px;height:28px;border-radius:999px;display:grid;place-items:center;background:#eef4ff;color:var(--blue);font-weight:900}.candidate-balloon.large{width:36px;height:36px;font-size:16px}.candidate-review-note{margin:0 12px 8px;border:1px solid #fde68a;border-radius:8px;background:#fffbeb;padding:8px 10px;color:#713f12;font-size:12px;line-height:1.45;font-weight:750}.candidate-local-preview{margin:0 12px 8px;border:1px dashed #cbd5e1;border-radius:8px;background:#f8fafc;display:grid;grid-template-rows:auto auto;gap:6px;text-align:center;color:var(--muted);font-size:12px;overflow:hidden}.local-preview-canvas{position:relative;min-height:104px;max-height:168px;overflow:hidden;background:linear-gradient(90deg,rgba(148,163,184,.14) 1px,transparent 1px),linear-gradient(rgba(148,163,184,.14) 1px,transparent 1px),#fff;background-size:20px 20px}.local-preview-canvas img{position:absolute;max-width:none;object-fit:fill;filter:contrast(1.12)}.local-preview-badge{position:absolute;left:8px;top:8px;z-index:5;min-height:22px;border-radius:999px;padding:2px 8px;display:inline-flex;align-items:center;background:#2563ebeb;color:#fff;border:1px solid rgba(255,255,255,.9);box-shadow:0 1px 5px #0f172a33;font-size:12px;font-weight:900}.local-crosshair{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:42px;height:42px;pointer-events:none;z-index:4}.local-crosshair:before,.local-crosshair:after{content:"";position:absolute;background:#2563ebd9;box-shadow:0 0 0 1px #ffffffbf}.local-crosshair:before{left:50%;top:0;bottom:0;width:1px}.local-crosshair:after{top:50%;left:0;right:0;height:1px}.local-crosshair{border:1px solid rgba(37,99,235,.55);border-radius:50%;background:#2563eb14}.candidate-local-preview p{padding:0 10px 8px;line-height:1.45}.review-actions{padding:10px 12px;border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.review-actions button{min-height:34px}.candidate-feedback-box{border-top:1px solid var(--line);padding:8px 12px;display:grid;gap:8px;background:#fbfdff}.candidate-feedback-box.collapsed{padding-bottom:8px}.feedback-collapse-toggle,.feedback-title-row{display:flex;justify-content:space-between;gap:8px;align-items:center}.feedback-collapse-toggle{width:100%;min-height:32px;border:1px solid var(--line);border-radius:8px;background:#fff;padding:0 10px;text-align:left}.feedback-collapse-toggle span{color:var(--blue);font-size:11px;font-weight:850}.feedback-title-row strong{font-size:13px}.feedback-title-row span,.feedback-upload-row span{color:var(--muted);font-size:11px;font-weight:750}.candidate-feedback-box textarea{min-height:72px}.feedback-screenshot-preview{border:1px solid var(--line);border-radius:8px;background:#fff;padding:8px;display:grid;grid-template-columns:64px minmax(0,1fr) auto;gap:8px;align-items:center}.feedback-screenshot-preview img{width:64px;height:48px;border:1px solid #dbe3ee;border-radius:6px;object-fit:cover}.feedback-screenshot-preview span,.feedback-paste-hint{color:var(--muted);font-size:11px;font-weight:750}.feedback-screenshot-preview button{min-height:30px;border-radius:8px;border:1px solid var(--line);padding:0 10px;font-size:12px;font-weight:850}.feedback-paste-hint{border:1px dashed #cbd5e1;border-radius:8px;background:#f8fafc;padding:8px}.feedback-upload-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:8px;align-items:center}.feedback-upload-row .upload-drawing-btn{min-height:32px;font-size:12px}.candidate-filterbar{border:1px solid var(--line);border-radius:8px;background:#fff;padding:6px;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:4px}.candidate-filterbar button{min-height:30px;border:1px solid transparent;border-radius:7px;background:transparent;color:var(--muted);font-size:12px;font-weight:850}.candidate-filterbar button.active{border-color:#bfdbfe;background:#eef4ff;color:var(--blue)}.confidence{color:var(--green);font-size:12px;font-weight:900}.confidence.low{color:var(--amber)}.candidate-empty{min-height:140px;border:1px dashed #cbd5e1;border-radius:8px;background:#f8fafc;display:grid;place-items:center;align-content:center;gap:6px;color:var(--muted);text-align:center}.candidate-empty.compact-empty{min-height:72px}.candidate-row{width:100%;min-height:58px;border:1px solid var(--line);border-radius:8px;background:#fff;padding:8px;display:grid;grid-template-columns:30px minmax(0,1fr) 44px;align-items:center;gap:8px;text-align:left}.candidate-row:hover,.candidate-row.hovered,.candidate-row.active{border-color:#93c5fd;background:#f3f7ff}.candidate-row.hovered{box-shadow:0 0 0 2px #93c5fd47}.candidate-row.excluded{opacity:.58}.rule-page{background:var(--panel);border:1px solid var(--line);border-radius:8px;overflow:hidden}.rule-summary-grid{padding:12px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;border-bottom:1px solid var(--line)}.rule-summary-grid div,.rule-preview-box{border:1px solid var(--line);border-radius:8px;background:#f8fafc;padding:10px;display:grid;gap:4px}.rule-summary-grid span,.rule-feedback-card span,.rule-draft-card span,.rule-preview-box span{color:var(--muted);font-size:11px;font-weight:750}.rule-summary-grid strong{font-size:22px}.rule-layout{padding:12px;display:grid;grid-template-columns:minmax(280px,.8fr) minmax(420px,1.2fr) minmax(280px,.8fr);gap:12px;align-items:start}.rule-suggestion-panel,.rule-feedback-panel,.rule-draft-panel{min-height:520px;border:1px solid var(--line);border-radius:8px;background:#fff;padding:10px;display:grid;align-content:start;gap:10px}.rule-suggestion-list,.rule-feedback-list,.rule-draft-list{display:grid;gap:8px;max-height:calc(100vh - 330px);overflow:auto}.rule-suggestion-card,.rule-feedback-card,.rule-draft-card{border:1px solid var(--line);border-radius:8px;background:#fff;padding:10px;text-align:left;display:grid;gap:7px}.rule-suggestion-card{grid-template-columns:minmax(0,1fr) auto}.rule-suggestion-card.active{border-color:#93c5fd;background:#f3f7ff}.rule-suggestion-card strong,.rule-feedback-card strong,.rule-draft-card strong,.rule-preview-box strong{font-size:13px}.rule-suggestion-card span,.rule-suggestion-card p,.rule-feedback-card p,.rule-draft-card p,.rule-preview-box p{color:var(--muted);font-size:12px;line-height:1.45}.rule-suggestion-card p{grid-column:1 / -1}.rule-suggestion-card em,.rule-draft-card em{color:var(--blue);font-size:11px;font-style:normal;font-weight:850}.rule-suggestion-card em.danger{color:var(--red)}.wide-action{width:100%;min-height:38px;border-radius:8px;border:1px solid var(--blue)}.feedback-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.feedback-card-meta{display:flex;flex-wrap:wrap;gap:6px}.feedback-card-meta span{max-width:100%;border-radius:999px;background:#eef2f7;padding:4px 7px}.rule-feedback-card code{border:1px solid #e2e8f0;border-radius:6px;background:#f8fafc;padding:6px;color:#334155;font-size:12px;white-space:normal}.rule-feedback-card a{color:var(--blue);font-size:12px;font-weight:850}.rule-draft-card{background:#fbfdff}.rule-draft-card.approved{border-color:#b7e4cf;background:#f4fbf7}.rule-draft-meta,.rule-draft-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.rule-draft-actions button{min-height:34px;border-radius:8px;border:1px solid var(--line);padding:0 10px;font-size:12px;font-weight:850}.rule-draft-actions button:disabled{cursor:not-allowed;opacity:.62}@media(max-width:1280px){.rule-layout{grid-template-columns:1fr}.rule-suggestion-list,.rule-feedback-list,.rule-draft-list{max-height:none}}.candidate-row strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.candidate-row small{display:block;margin-top:3px;color:var(--muted);font-size:11px}.candidate-row em{border-radius:999px;padding:3px 7px;background:#fff7df;color:var(--amber);font-style:normal;font-size:11px;font-weight:900;text-align:center}.candidate-row.accepted em{background:#e6f7ef;color:var(--green)}.candidate-row.excluded em{background:#f1f5f9;color:#64748b}.candidate-empty strong{color:var(--ink)}.mini-pill.warn{background:#fff7df;color:var(--amber)}.qc-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.qc-summary-grid label,.signature-grid label{color:var(--muted);font-size:12px;font-weight:750;display:grid;gap:5px}input,select,textarea{width:100%;min-height:34px;border:1px solid var(--line);border-radius:8px;background:#fff;padding:6px 8px;color:var(--ink);font:inherit;font-size:12px}textarea{min-height:86px;resize:vertical}.table-box{border:1px solid var(--line);border-radius:8px;background:#fff;overflow:hidden}.table-box h3{padding:12px 14px;border-bottom:1px solid var(--line)}.table-title-row{padding:12px 14px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:12px}.table-title-row h3{padding:0;border:0}.table-title-row p{margin-top:4px;color:var(--muted);font-size:12px}.measure-inputs{display:grid;grid-template-columns:repeat(4,minmax(52px,1fr));gap:5px}.result-select.ok{color:var(--green)}.result-select.ng{color:var(--red)}.result-select.pending{color:var(--amber)}.inspection-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.document-check-table input{min-width:160px}.report-preview{display:grid;grid-template-columns:minmax(0,1.5fr) repeat(2,minmax(0,1fr));gap:10px}.report-preview div{border:1px solid var(--line);border-radius:8px;background:#f8fafc;padding:10px;display:grid;gap:4px}.signature-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.danger{background:var(--red)!important;border:1px solid var(--red)!important;color:#fff;border-radius:8px;min-height:38px;padding:0 12px;font-weight:800}table{width:100%;border-collapse:collapse}th,td{padding:10px;border-bottom:1px solid var(--line);text-align:left;font-size:13px}th{color:var(--muted);background:#f8fafc}@media(max-width:1100px){.content-grid,.inspection-grid,.gauge-layout,.recognition-body{grid-template-columns:1fr}.focus-grid,.qc-summary-grid,.attachment-grid,.gauge-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.app{grid-template-columns:52px minmax(0,1fr)}.workspace{padding:10px}.topbar,.detail-hero,.online-qc-head,.recognition-head,.recognition-actions,.row-between{align-items:stretch;flex-direction:column}.detail-hero{padding-left:14px;padding-top:62px}.order-grid,.order-facts,.kv-grid,.focus-grid,.qc-summary-grid,.qc-result-grid,.qc-part-facts,.qc-note-grid,.attachment-grid,.signature-grid,.report-preview,.gauge-stat-grid,.qc-part-card{grid-template-columns:1fr}.candidate-item{grid-template-columns:18px 32px minmax(0,1fr)}}.empty,.error{margin:14px;padding:14px;border-radius:8px}.empty{background:#f8fafc;color:var(--muted)}.error{border:1px solid #ffc8c0;background:#fff6f3;color:var(--red)}
