:root{--bg: #f4f6f8;--card: #ffffff;--ink: #1c2430;--muted: #6b7785;--line: #dde3ea;--brand: #0d5e8c;--brand-dark: #094663;--ok: #1b8a4b;--warn: #b9770b;--bad: #c0392b}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,Segoe UI,Microsoft JhengHei,Roboto,sans-serif;background:var(--bg);color:var(--ink);line-height:1.45}.app{max-width:860px;margin:0 auto;padding:24px 18px 64px}.app-header{display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid var(--brand);padding-bottom:14px;margin-bottom:18px}.app-header h1{margin:0;font-size:22px;color:var(--brand-dark)}.subtitle{margin:2px 0 0;color:var(--muted);font-size:13px}.loading,.fatal{padding:40px;text-align:center;color:var(--muted)}.fatal{color:var(--bad)}.restored-note{background:#eef6fb;border:1px solid #cfe6f3;color:var(--brand-dark);padding:8px 12px;border-radius:8px;font-size:13px;margin-bottom:14px}.module{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:18px 20px;margin-bottom:18px}.module h2{margin:0 0 4px;font-size:17px;color:var(--brand-dark)}.module-sub{margin:0 0 14px;color:var(--muted);font-size:13px}.step-bar{display:flex;align-items:center;gap:12px;margin-bottom:14px;font-weight:600;color:var(--brand-dark)}.step-bar .muted{font-weight:400;flex:1}.type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;margin-bottom:18px}.type-card{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1.5px solid var(--line);border-radius:10px;cursor:pointer;background:#fafcfe;transition:all .12s}.type-card.checked{border-color:var(--brand);background:#eef6fb}.type-card span{font-weight:500}.field{padding:12px 0;border-bottom:1px dashed var(--line)}.field:last-child{border-bottom:none}.field-label{display:flex;flex-wrap:wrap;align-items:baseline;gap:6px;margin-bottom:6px}.qid{font-family:ui-monospace,monospace;font-size:12px;color:var(--brand);font-weight:700}.q-en-primary{font-weight:600}.req{color:var(--bad);font-weight:700}.badge{font-size:11px;padding:1px 6px;border-radius:10px;font-weight:600}.badge-compliance{background:#fdecea;color:var(--bad)}.badge-reval{background:#fff4e0;color:var(--warn)}.field input[type=text],.field input[type=number],.field input[type=date],.field select{width:100%;padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-size:14px;background:#fff}.field-error input,.field-error select{border-color:var(--bad);background:#fff8f7}.radio-row{display:flex;gap:18px}.radio,.checkbox{display:inline-flex;align-items:center;gap:6px;font-size:14px}.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:6px 14px}.file-field{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.filename{font-size:13px;color:var(--brand-dark)}.hint{font-size:12px;color:var(--muted);margin-top:4px}.err{font-size:12px;color:var(--bad);margin-top:4px;font-weight:600}button{font:inherit;cursor:pointer;border-radius:8px}.btn-primary{background:var(--brand);color:#fff;border:none;padding:11px 20px;font-weight:600;font-size:15px}.btn-primary:disabled{background:#9bb6c6;cursor:not-allowed}.btn-secondary{background:#fff;border:1px solid var(--line);padding:11px 18px}.btn-ghost{background:transparent;border:1px solid var(--line);padding:6px 12px;font-size:13px;color:var(--muted)}.actions{display:flex;gap:12px;margin-top:8px}.block-summary,.block-note{background:#fdecea;border:1px solid #f5c6c0;color:var(--bad);padding:12px 14px;border-radius:8px;margin-bottom:14px;font-size:14px}.block-note ul{margin:8px 0 0;padding-left:20px}.status-banner{display:flex;align-items:center;gap:16px;padding:18px 20px;border-radius:10px;margin-bottom:16px}.status-score{font-size:40px;font-weight:800}.status-label{font-size:18px;font-weight:700}.status-approved{background:#e7f6ec;color:var(--ok)}.status-conditional{background:#fff4e0;color:var(--warn)}.status-rejected{background:#fdecea;color:var(--bad)}.summary-table{width:100%;border-collapse:collapse;margin:8px 0 16px}.summary-table th,.summary-table td{text-align:left;padding:10px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:top}.summary-table th{color:var(--muted);font-size:12px;text-transform:uppercase;width:150px;white-space:nowrap}.chips{display:inline-flex;flex-wrap:wrap;gap:6px}.chip{background:#e8eef3;color:var(--brand-dark);border-radius:999px;padding:3px 10px;font-size:12.5px;font-weight:600}.flags-note{background:#fff4e0;border:1px solid #f3d79a;color:#8a5a00;padding:12px 14px;border-radius:8px;margin-bottom:14px;font-size:14px}.flags-note ul{margin:8px 0 0;padding-left:20px}.flags-note .flag-high{color:var(--bad)}.flags-note .flag-med{color:#8a5a00}.submit-state{margin:14px 0;font-size:14px;font-weight:600;color:var(--brand-dark)}.muted{color:var(--muted);font-weight:400}.json-view{background:#0f1b24;color:#c8e1f0;padding:16px;border-radius:10px;overflow:auto;font-size:12.5px;max-height:420px}.app-footer{margin-top:24px;text-align:center;color:var(--muted);font-size:12px}.app-footer code{background:#eef2f6;padding:1px 5px;border-radius:4px}.admin-gate{max-width:420px;text-align:center}.admin-gate form{display:flex;gap:8px;margin-top:16px}.admin-gate input{flex:1}.admin-actions{display:flex;gap:8px;align-items:center}.filters{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px;margin-bottom:16px;display:flex;flex-direction:column;gap:14px}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-label{font-size:12px;text-transform:uppercase;color:var(--muted);font-weight:700}.chip-btn{border:1px solid var(--line);cursor:pointer;background:#eef2f6}.chip-on{background:var(--brand);color:#fff;border-color:var(--brand)}.vendor-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:14px}.vendor-card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px;font-size:13.5px}.vendor-head{display:flex;justify-content:space-between;gap:8px;align-items:flex-start;margin-bottom:8px}.vendor-row{display:flex;gap:8px;padding:3px 0;border-top:1px solid #f0f3f6}.vendor-row>span:first-child{color:var(--muted);min-width:96px;font-size:12px;text-transform:uppercase}.vendor-row .flag-text{color:var(--bad)}.doc-link{display:inline-block;margin-right:10px;color:var(--brand)}.empty{text-align:center;color:var(--muted);padding:40px}.admin{max-width:1080px}.tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--line)}.tab{background:transparent;border:none;border-bottom:3px solid transparent;padding:8px 16px;font-size:15px;font-weight:600;color:var(--muted);border-radius:0}.tab-on{color:var(--brand-dark);border-bottom-color:var(--brand)}.rfq-toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.rfq-toolbar input[type=text]{padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-size:14px}.rfq-table{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden;font-size:13.5px}.rfq-table th{text-align:left;padding:10px;background:#eef2f6;color:var(--muted);font-size:12px;text-transform:uppercase}.rfq-table td{padding:9px 10px;border-top:1px solid #f0f3f6}.rfq-table tbody tr{cursor:pointer}.rfq-table tbody tr:hover{background:#f2f8fc}.status{font-size:12px;font-weight:700;padding:2px 9px;border-radius:999px;background:#e8eef3;color:var(--brand-dark)}.status-won{background:#e7f6ec;color:var(--ok)}.status-lost,.status-no-bid{background:#fdecea;color:var(--bad)}.status-quoting,.status-quoted{background:#fff4e0;color:var(--warn)}.chip-dg{background:#fdecea;color:var(--bad)}.chip-warn{background:#fff4e0;color:var(--warn)}.chip-ok{background:#e7f6ec;color:var(--ok)}.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:10px 14px}.form-field{display:flex;flex-direction:column;gap:4px}.form-field input,.form-field select{padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-size:14px;background:#fff;width:100%}.form-wide{grid-column:1 / -1}.money-pair{display:flex;gap:6px}.money-pair select{width:84px;flex:none}.cargo-flags{display:flex;gap:16px;align-items:center;flex-wrap:wrap;margin-top:12px}.cargo-flags .mini{width:110px;padding:6px 8px;border:1px solid var(--line);border-radius:8px;font-size:13px}.saved-note{color:var(--ok);font-weight:600;font-size:13px}.won-note{color:var(--ok);font-weight:600}.lost-note{color:var(--bad);font-weight:600}.quote-line,.recall-row,.capable-row{display:flex;gap:12px;align-items:flex-start;padding:10px 0;border-top:1px solid #f0f3f6;font-size:13.5px}.recall-main{flex:1}.recall-sub{color:var(--muted);font-size:12.5px;margin-top:2px}.recall-row.stale{opacity:.55}.score-badge{flex:none;width:38px;height:38px;border-radius:10px;background:var(--brand);color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center}.stale .score-badge{background:#9aa7b2}.recall-breakdown{margin-top:4px;font-size:12.5px}.recall-breakdown summary{cursor:pointer;color:var(--brand)}.bk-line{display:grid;grid-template-columns:160px 110px 1fr;gap:8px;padding:2px 0 2px 14px}.row-actions{display:flex;gap:4px;flex:none}.capable-row{align-items:center}.capable-row>strong{min-width:180px}.quote-form{background:#f7fafc;border:1px solid var(--line);border-radius:10px;padding:14px;margin-top:10px}.bk-edit{display:grid;grid-template-columns:180px 120px 1fr 36px;gap:8px;margin:6px 0}.bk-edit input{padding:7px 9px;border:1px solid var(--line);border-radius:8px;font-size:13px}.paste-box{width:100%;margin-top:10px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;font:inherit;font-size:13.5px;resize:vertical;background:#fff}.inbox-card{font-size:13.5px}.inbox-card.inbox-done{opacity:.55}.inbox-head{display:flex;gap:6px;align-items:center;margin-bottom:8px;flex-wrap:wrap}.inbox-subject{margin-bottom:4px}.chip-class-customer_rfq{background:#e7f6ec;color:var(--ok)}.chip-class-vendor_quote{background:#eef6fb;color:var(--brand-dark)}.chip-class-rate_sheet{background:#f3e8fd;color:#6b21a8}.chip-class-other{background:#eef2f6;color:var(--muted)}.inbox-extract{background:#f7fafc;border:1px solid var(--line);border-radius:10px;padding:8px 12px;margin-top:8px}.inbox-attach{display:flex;gap:8px;align-items:center;padding:8px 0 4px;flex-wrap:wrap}.inbox-attach select{flex:1;min-width:220px;padding:7px 9px;border:1px solid var(--line);border-radius:8px;font-size:13px;background:#fff}.inbox-raw{white-space:pre-wrap;background:#f0f3f6;border-radius:8px;padding:10px;font-size:12px;max-height:200px;overflow:auto}
