:root{--bg:#f4f6f5;--surface:#fff;--surface-2:#eef3f1;--ink:#17211d;--muted:#66736d;--line:#d8e0dc;--green:#16784c;--green-soft:#e2f3eb;--red:#b93b3b;--red-soft:#f8e8e5;--amber:#a86512;--amber-soft:#fbefd7;--blue:#2f66a2;--blue-soft:#e5eef8;--teal:#0d6f73;--shadow:0 18px 60px #1e2b2514}*{box-sizing:border-box}body{background:var(--bg);color:var(--ink);letter-spacing:0;margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif}button{font:inherit}.app-shell{grid-template-columns:248px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{color:#f7fbf9;background:#14231e;flex-direction:column;gap:28px;height:100vh;padding:24px 18px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:12px;display:flex}.brand-mark{color:#14231e;background:#eff7f2;border-radius:8px;place-items:center;width:42px;height:42px;font-weight:800;display:grid}.brand strong,.brand span{display:block}.brand span{color:#b9c7c1;margin-top:3px;font-size:12px}.nav{gap:8px;display:grid}.nav-item{color:#c9d6d1;cursor:pointer;text-align:left;background:0 0;border:0;border-radius:8px;align-items:center;gap:10px;padding:12px;display:flex}.nav-item:hover,.nav-item.active{color:#fff;background:#203730}.icon{color:#95d5bd;place-items:center;width:22px;height:22px;display:grid}.sidebar-card{background:#ffffff0f;border:1px solid #ffffff1f;border-radius:8px;margin-top:auto;padding:16px}.sidebar-card strong,.sidebar-card small,.sidebar-card span{display:block}.sidebar-card strong{margin:10px 0 3px;font-size:28px}.sidebar-card small{color:#b9c7c1}.main{min-width:0;padding:28px}.topbar{justify-content:space-between;align-items:flex-start;gap:18px;min-height:64px;margin-bottom:22px;display:flex}h1,h2,p{margin:0}h1{font-size:28px;line-height:1.2}h2{font-size:18px;line-height:1.3}.topbar p{color:var(--muted);margin-top:8px}.operator{white-space:nowrap;color:var(--muted);align-items:center;gap:10px;display:flex}.ghost-btn,.icon-btn{border:1px solid var(--line);background:var(--surface);width:36px;height:36px;color:var(--ink);cursor:pointer;border-radius:8px}.ghost-btn:hover,.icon-btn:hover{border-color:#9fb2aa}.view{display:none}.view.active{display:block}.metric-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.create-customer-panel{margin-bottom:16px}.create-form{justify-content:space-between;align-items:center;gap:12px;display:flex}.create-copy{gap:6px;min-width:0;display:grid}.create-copy strong{font-size:15px}.create-copy span{color:var(--muted);font-size:13px}.create-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.upload-button{border:1px solid var(--line);cursor:pointer;background:#fff;border-radius:8px;justify-content:center;align-items:center;height:40px;padding:0 14px;font-weight:700;display:inline-flex}.upload-button:hover{border-color:#9fb2aa}.upload-button.busy,.upload-button.disabled,.primary-btn:disabled,.input:disabled,.select:disabled{cursor:wait;opacity:.68}.upload-button.disabled,.primary-btn:disabled,.input:disabled,.select:disabled{cursor:not-allowed}.qc-json-upload{background:var(--blue-soft);color:var(--blue);border-color:#c9d9ea}.qc-folder-upload{background:var(--green-soft);color:var(--green);border-color:#c4dfd1}.qc-batch-upload{background:var(--amber-soft);color:var(--amber);border-color:#efd8ab}.upload-button input{opacity:0;pointer-events:none;position:absolute}.metric,.panel,.battle-card{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:8px}.metric{min-height:130px;padding:18px}.metric span,.metric small,.muted{color:var(--muted)}.metric strong{margin:14px 0 10px;font-size:34px;line-height:1;display:block}.metric.danger{border-top:4px solid var(--red)}.metric.amber{border-top:4px solid var(--amber)}.metric.blue{border-top:4px solid var(--blue)}.metric.green{border-top:4px solid var(--green)}.two-col{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px;margin-top:16px;display:grid}.quality-layout{grid-template-columns:minmax(0,.95fr) minmax(0,1fr) minmax(0,1.15fr);gap:16px;width:100%;min-width:0;margin-top:16px;display:grid}.panel{min-width:0;padding:18px}.panel-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.pill{border-radius:999px;align-items:center;height:24px;padding:0 9px;font-size:12px;font-weight:700;display:inline-flex}.pill.red{color:var(--red);background:var(--red-soft)}.pill.amber{color:var(--amber);background:var(--amber-soft)}.pill.blue{color:var(--blue);background:var(--blue-soft)}.pill.green{color:var(--green);background:var(--green-soft)}.task-list,#customerList,.quote-list,.qc-steps,.qc-queue{gap:10px;display:grid}.task,.customer-row,.quote,.step,.qc-case{border:1px solid var(--line);background:#fbfcfb;border-radius:8px;padding:12px}.task,.customer-row,.qc-case{text-align:left;cursor:pointer;width:100%}.task:hover,.customer-row:hover,.customer-row.active,.qc-case:hover,.qc-case.active{background:#f4faf7;border-color:#8da59a}.task-top,.customer-row-top{justify-content:space-between;align-items:center;gap:12px;display:flex}.task strong,.customer-row strong{font-size:15px;display:block}.task p,.customer-row p{color:var(--muted);margin-top:8px;font-size:13px;line-height:1.45}.customer-layout{grid-template-columns:minmax(280px,300px) minmax(0,1fr);gap:16px;width:100%;min-width:0;display:grid}.customer-list,.customer-rail{align-self:start;min-width:0}.customer-main{gap:16px;min-width:0;display:grid}.customer-search-row{grid-template-columns:minmax(0,1fr) auto;gap:10px;margin-bottom:14px;display:grid}.customer-search-row .input{width:100%;min-width:0}.customer-row{background:#fff;gap:8px;display:grid}.customer-row.active{background:#eef7f2}.customer-row p{margin-top:0}.customer-row small{color:var(--muted);line-height:1.35}.mini-progress{background:#edf1ef;border-radius:999px;height:4px;overflow:hidden}.mini-progress span{border-radius:inherit;background:var(--blue);height:100%;display:block}.customer-workspace{border:1px solid var(--line);width:100%;min-width:0;max-width:100%;box-shadow:var(--shadow);background:#fff;border-radius:8px;gap:0;overflow:hidden}.customer-summary{border-bottom:1px solid var(--line);justify-content:space-between;align-items:flex-start;gap:18px;padding:22px 24px;display:flex}.customer-summary h2{font-size:24px}.customer-summary p{color:var(--muted);margin-top:8px}.summary-tags{text-align:right;justify-items:end;gap:8px;min-width:220px;display:grid}.summary-tags strong{color:var(--green)}.customer-facts{border-bottom:1px solid var(--line);background:#f3f7fb;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px 18px;padding:12px 24px;display:grid}.customer-facts article{min-width:0}.customer-facts span,.field-stack span{color:var(--muted);margin-bottom:5px;font-size:12px;display:block}.customer-facts strong,.field-stack strong{overflow-wrap:anywhere;line-height:1.4;display:block}.strategy-band{color:#583a28;background:#fffaf0;border-bottom:1px solid #e8d8b8;padding:18px 24px 22px}.strategy-head,.work-head,.section-title-row{align-items:center;gap:10px;display:flex}.strategy-head{color:#7a421b;margin-bottom:12px}.target-icon{color:#d15b2f;font-weight:800}.strategy-band p,.strategy-band li{line-height:1.75}.strategy-band ol{margin:14px 0 0;padding-left:20px}.stage-section{border-bottom:1px solid var(--line);padding:22px 24px}.section-title-row{justify-content:space-between;margin-bottom:16px}.section-title-row>span{color:var(--muted);white-space:nowrap;font-size:13px}.stage-track{flex-wrap:wrap;gap:14px;min-width:0;display:flex;overflow-x:visible}.stage-pill{min-height:34px;color:var(--muted);white-space:nowrap;background:#eef2f0;border-radius:8px;flex:none;align-items:center;padding:0 14px;font-weight:800;display:inline-flex}.stage-pill.done{color:var(--green);background:#dff8e8}.stage-pill.current{box-shadow:inset 0 0 0 2px #16a34a38}.current-stage{border-bottom:1px solid var(--line);background:#f8fafb;padding:24px}.current-stage .section-title-row h2{margin-top:10px;font-size:26px}.stage-goal{border:1px solid var(--line);background:#fff;border-radius:8px;align-items:flex-start;gap:12px;padding:18px;display:flex}.stage-goal p{margin-top:8px;line-height:1.55}.square-icon{background:var(--blue-soft);width:28px;height:28px;color:var(--blue);border-radius:8px;flex:none;place-items:center;font-weight:800;display:grid}.square-icon.green{background:var(--green-soft);color:var(--green)}.square-icon.amber{background:var(--amber-soft);color:var(--amber)}.square-icon.blue{background:var(--blue-soft);color:var(--blue)}.customer-workgrid{background:#f8fafb;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;padding:22px 24px 24px;display:grid}.work-card{border:1px solid var(--line);background:#fff;border-radius:8px;min-width:0;overflow:hidden}.work-head{border-bottom:1px solid var(--line);min-height:64px;padding:14px 16px}.work-head h2{flex:1;min-width:0}.check-list{gap:10px;margin:0;padding:16px;list-style:none;display:grid}.check-list li{color:#284037;background:#eef9f2;border-radius:8px;align-items:flex-start;gap:10px;padding:12px;line-height:1.45;display:flex}.check-list li span{background:var(--green);color:#fff;border-radius:6px;flex:none;place-items:center;width:22px;height:22px;font-weight:900;display:grid}.script-preview{padding:18px 16px 0;line-height:1.7}.script-actions{gap:10px;padding:16px;display:flex}.script-actions .secondary-btn{flex:1}.field-stack{gap:12px;padding:16px;display:grid}.field-stack article{border:1px solid var(--line);background:#fbfcfb;border-radius:8px;min-width:0;padding:12px}.hero-band{color:#fff;min-height:156px;box-shadow:var(--shadow);background:#11342c;border-radius:8px;justify-content:space-between;align-items:flex-start;gap:18px;padding:22px;display:flex}.hero-band h2{margin-top:10px;font-size:30px}.hero-band p{color:#cee0d9;margin-top:12px;line-height:1.5}.eyebrow{color:#6f837b;text-transform:uppercase;font-size:12px;font-weight:800}.hero-band .eyebrow{color:#95d5bd}.rating-stack{justify-items:end;gap:8px;display:grid}.rating{background:#ffffff14;border:1px solid #ffffff3d;border-radius:8px;place-items:center;min-width:54px;height:54px;font-size:28px;font-weight:800;display:grid}.rating-stack small{color:#cee0d9}.battle-card{padding:18px}.battle-grid,.report-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.report-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.battle-grid article,.report-grid article{border:1px solid var(--line);background:#fbfcfb;border-radius:8px;min-height:96px;padding:12px}.battle-grid span,.report-grid span{color:var(--muted);margin-bottom:10px;font-size:13px;display:block}.battle-grid strong,.report-grid strong{overflow-wrap:anywhere;line-height:1.35}.script-box{background:#f0f6f3;border:1px solid #d4e4dc;border-radius:8px;margin-top:14px;padding:16px}.script-head{color:var(--muted);justify-content:space-between;align-items:center;gap:12px;display:flex}.script-head div{gap:8px;display:flex}.script-box p{margin-top:12px;font-size:17px;line-height:1.7}.tabs{border-bottom:1px solid var(--line);gap:8px;padding-bottom:10px;display:flex;overflow-x:auto}.tab{border:1px solid var(--line);white-space:nowrap;cursor:pointer;background:#fbfcfb;border-radius:8px;padding:9px 12px}.tab.active{color:#fff;background:#183b33;border-color:#183b33}.tab-body{min-height:260px;padding-top:16px}.insight-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.insight{border:1px solid var(--line);background:#fbfcfb;border-radius:8px;padding:14px}.insight span{color:var(--muted);margin-bottom:8px;font-size:13px;display:block}.insight p,.insight li{color:#26352f;line-height:1.55}.insight ul{margin:0;padding-left:18px}.control-row{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;display:flex}.select,.input{border:1px solid var(--line);background:#fff;border-radius:8px;height:40px;padding:0 10px}.primary-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#183b33;border:0;border-radius:8px;height:40px;padding:0 14px;font-weight:700}.primary-btn:hover{background:#245248}.primary-btn:disabled:hover{background:#183b33}.secondary-btn{border:1px solid var(--line);min-height:40px;color:var(--ink);cursor:pointer;background:#fff;border-radius:8px;padding:0 14px;font-weight:700}.secondary-btn:hover{border-color:#9fb2aa}.upload-status{overflow-wrap:anywhere;border-radius:999px;width:fit-content;max-width:100%;padding:6px 10px;font-size:12px;font-weight:700}.upload-status.idle,.upload-status.selected{color:var(--blue);background:var(--blue-soft)}.upload-status.uploading{color:var(--amber);background:var(--amber-soft)}.upload-status.success{color:var(--green);background:var(--green-soft)}.upload-status.review{color:var(--amber);background:var(--amber-soft)}.upload-status.failed{color:var(--red);background:var(--red-soft)}.resume-review-head{justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:16px;display:flex}.resume-review-head h2{margin-top:8px}.resume-review-head p{color:var(--muted);margin-top:8px}.resume-review-layout{grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:16px;display:grid}.resume-text{white-space:pre-wrap;word-break:break-word;border:1px solid var(--line);color:#26352f;background:#fbfcfb;border-radius:8px;min-height:420px;max-height:620px;margin:0;padding:14px;font:13px/1.65 ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;overflow:auto}.empty-state{justify-items:start;gap:12px;display:grid}.empty-state p{color:var(--muted)}.qc-runner,.qc-report{min-width:0;min-height:540px}.qc-report{overflow:hidden}.qc-intro{justify-content:space-between;align-items:center;gap:18px;display:flex}.qc-intro h2{margin-top:8px}.qc-intro p{color:var(--muted);margin-top:8px}.qc-intro .control-row{justify-content:flex-end;margin-bottom:0}.qc-status-strip{color:#183b33;background:#edf8f2;border:1px solid #b9d9cb;border-radius:8px;align-items:center;gap:10px;width:100%;margin-top:14px;padding:10px 12px;display:flex}.qc-status-strip strong{white-space:nowrap}.qc-status-strip small{min-width:0;color:var(--muted);overflow-wrap:anywhere}.status-dot{background:var(--green);border-radius:999px;flex:none;width:10px;height:10px}.status-dot.spinning{border:2px solid #b9d9cb;border-top-color:var(--green);background:0 0;animation:.9s linear infinite spin}.qc-upload-fields{grid-template-columns:minmax(180px,210px) minmax(140px,180px) minmax(88px,110px);gap:8px;min-width:min(100%,540px);display:grid}.qc-upload-fields .input{width:100%;min-width:0}.qc-upload-fields .amount-input{text-align:right}.qc-case-top{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.qc-case strong{overflow-wrap:anywhere;min-width:0;line-height:1.35;display:block}.qc-case .pill{flex:none}.qc-case p{color:var(--muted);margin-top:8px;font-size:13px;line-height:1.45}.qc-case small{color:var(--muted);margin-top:8px;display:block}.qc-target{background:var(--surface-2);border-radius:8px;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;padding:14px;display:flex}.qc-target>div{flex:auto;min-width:0}.qc-target strong{overflow-wrap:anywhere;margin-top:5px;line-height:1.35;display:block}.run-status-line{color:var(--teal);margin-top:6px;font-weight:700;display:block}.qc-target .primary-btn{flex:none;min-width:92px}.progress-track{background:#e0e7e3;border-radius:999px;height:10px;margin-bottom:14px;overflow:hidden}.progress-bar{background:var(--teal);width:0;height:100%;transition:width .3s}.step{color:var(--muted);justify-content:space-between;gap:12px;display:flex}.step.done{color:var(--green);background:var(--green-soft);border-color:#bdc}.step.running{color:var(--teal);background:#eef8f7;border-color:#9fcfd0}.step.running strong{color:var(--teal)}.step:not(.done):not(.running) strong{color:var(--muted)}@keyframes spin{to{transform:rotate(360deg)}}.report-link{color:#fff;cursor:pointer;background:#183b33;border:1px solid #183b33;border-radius:8px;width:100%;min-height:44px;margin-top:14px;font-weight:800}.hidden{display:none!important}.report-head{justify-content:space-between;align-items:flex-start;gap:14px;min-width:0;margin-bottom:16px;display:flex}.report-head>div{min-width:0}.report-head h2{overflow-wrap:anywhere;word-break:break-word;max-width:100%;margin-top:8px;font-size:clamp(22px,1.9vw,30px)}.report-head strong{text-align:right;white-space:nowrap;flex:none;font-size:clamp(24px,2.2vw,34px);line-height:1}.quote{margin-top:12px}.quote time,.quote span{color:var(--muted);font-size:12px}.quote p{overflow-wrap:anywhere;margin:8px 0;line-height:1.6}.quote strong{color:var(--red);overflow-wrap:anywhere}.qc-confirm{border-top:1px solid var(--line);margin-top:16px;padding-top:14px}.qc-confirm>span{color:var(--muted);margin-bottom:10px;font-size:13px;display:block}.qc-confirm div{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.confirm-btn{border:1px solid var(--line);min-height:38px;color:var(--ink);cursor:pointer;background:#fff;border-radius:8px;font-weight:700}.confirm-btn:hover,.confirm-btn.active{color:#fff;background:#183b33;border-color:#183b33}.toast{color:#fff;min-width:220px;max-width:min(360px,100vw - 48px);box-shadow:var(--shadow);opacity:0;pointer-events:none;background:#14231e;border-radius:8px;padding:12px 14px;transition:opacity .18s,transform .18s;position:fixed;bottom:24px;right:24px;transform:translateY(12px)}.toast.show{opacity:1;transform:translateY(0)}.modal{z-index:20;background:#0c18147a;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.modal-panel{border:1px solid var(--line);background:#fff;border-radius:8px;width:min(760px,100%);max-height:min(760px,100vh - 48px);overflow:auto;box-shadow:0 28px 80px #0c181447}.modal-head{z-index:1;border-bottom:1px solid var(--line);background:#fff;justify-content:space-between;align-items:flex-start;gap:16px;padding:18px;display:flex;position:sticky;top:0}.modal-head h2{margin-top:8px}.modal-body{padding:18px}.report-section{border:1px solid var(--line);background:#fbfcfb;border-radius:8px;margin-bottom:12px;padding:14px}.report-section span{color:var(--muted);margin-bottom:8px;font-size:13px;display:block}.report-section p,.report-section li{line-height:1.55}@media (max-width:1120px){.metric-grid,.battle-grid,.report-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.customer-facts{grid-template-columns:repeat(2,minmax(0,1fr));row-gap:14px}.customer-workgrid{grid-template-columns:1fr}.customer-summary{flex-direction:column}.summary-tags{text-align:left;justify-items:start;min-width:0}.two-col,.quality-layout,.resume-review-layout,.customer-layout{grid-template-columns:1fr}.qc-intro{flex-direction:column;align-items:stretch}.qc-intro .control-row{justify-content:flex-start}.qc-upload-fields{grid-template-columns:1fr;width:100%;min-width:0}}@media (max-width:760px){.app-shell{grid-template-columns:1fr}.sidebar{height:auto;padding:14px;position:static}.nav{grid-template-columns:repeat(4,minmax(0,1fr))}.nav-item{justify-content:center;padding:10px 8px}.nav-item span:last-child,.sidebar-card{display:none}.main{padding:18px 14px}.topbar{flex-direction:column}.operator{justify-content:space-between;width:100%}.metric-grid,.battle-grid,.report-grid,.insight-grid,.customer-facts,.customer-search-row{grid-template-columns:1fr}.customer-search-row .primary-btn{width:100%}.script-actions{flex-direction:column}.customer-summary,.customer-facts,.strategy-band,.stage-section,.current-stage,.customer-workgrid{padding-left:16px;padding-right:16px}.customer-summary h2,.current-stage .section-title-row h2{font-size:22px}.create-form,.resume-review-head{flex-direction:column;align-items:stretch}.create-actions,.create-actions .primary-btn,.upload-button{width:100%}.hero-band{flex-direction:column}.rating-stack{justify-items:start}.qc-target{flex-direction:column;align-items:stretch}.qc-target .primary-btn{width:100%}}
