*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg:#ffffff;--bg2:#f5f7fa;--bg3:#eef1f6;
  --text:#1a1a2e;--text2:#4a5568;--text3:#94a3b8;
  --border:#e2e8f0;--border2:#cbd5e1;
  --blue:#1d4ed8;--blue-bg:#eff6ff;
  --green:#15803d;--green-bg:#f0fdf4;
  --red:#dc2626;--gold:#b45309;--purple:#7c3aed;--purple-bg:#f5f3ff;
  --radius:6px;--radius-lg:10px;
  --shadow:0 1px 4px rgba(0,0,0,.08);
  --card:#ffffff;--accent:#1d4ed8;--hover:#f1f5f9;
}
@media(prefers-color-scheme:dark){:root{
  --bg:#111827;--bg2:#1f2937;--bg3:#374151;
  --text:#f1f5f9;--text2:#94a3b8;--text3:#64748b;
  --border:#374151;--border2:#4b5563;
  --blue:#60a5fa;--blue-bg:#1e3a5f;
  --green:#4ade80;--green-bg:#14532d;
  --red:#f87171;--gold:#fbbf24;--purple:#a78bfa;--purple-bg:#2e1065;
  --shadow:0 1px 4px rgba(0,0,0,.4);
  --card:#1e293b;--accent:#60a5fa;--hover:#1f2937;
}}
body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;font-size:15px;min-height:100vh;}
input,select,button{font-family:inherit;font-size:inherit;color:inherit;}
input{background:transparent;border:none;outline:none;width:100%;}
input:focus{background:var(--bg3);border-radius:3px;padding:0 3px;}
select{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:2px 4px;outline:none;}

/* ── Layout ── */
.wrap{padding:10px 14px;max-width:1400px;margin:0 auto;}
.top{display:flex;gap:10px;align-items:flex-start;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--border);}
.logo-area{flex-shrink:0;width:80px;}
.logo-box{width:80px;height:50px;border:1.5px dashed var(--border2);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;position:relative;background:var(--bg2);}
.logo-box img{max-width:100%;max-height:100%;object-fit:contain;display:none;}
.logo-box span{font-size:10px;color:var(--text3);text-align:center;}
.logo-box input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;}
.proj-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:5px;flex:1;}
.fi{display:flex;flex-direction:column;gap:2px;}
.fi label{font-size:12px;color:var(--text2);font-weight:500;}
.fi input{border:1px solid var(--border);border-radius:var(--radius);padding:4px 6px;background:var(--bg2);}
.fi input:focus{border-color:var(--blue);background:var(--bg);}

/* ── Toolbar ── */
.toolbar{display:flex;align-items:center;gap:5px;margin-bottom:10px;flex-wrap:wrap;padding:6px 10px;background:var(--bg2);border-radius:var(--radius-lg);border:1px solid var(--border);}
.scheme-tabs{display:flex;align-items:center;gap:0;border-right:1px solid var(--border);padding-right:8px;margin-right:3px;}
.stab{padding:4px 11px;font-size:14px;cursor:pointer;border:none;background:none;color:var(--text2);border-radius:var(--radius);white-space:nowrap;}
.stab.on{background:var(--bg);color:var(--text);font-weight:600;box-shadow:var(--shadow);}
.stab-add{padding:4px 7px;font-size:14px;cursor:pointer;border:none;background:none;color:var(--text3);}
.vt{display:flex;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;}
.vt button{border:none;background:transparent;padding:4px 11px;font-size:14px;cursor:pointer;color:var(--text2);}
.vt button.on{background:var(--bg);color:var(--text);font-weight:600;}
.mc{display:flex;align-items:center;gap:5px;font-size:14px;color:var(--text2);padding:0 4px;}
.mc input[type=range]{width:70px;accent-color:var(--blue);}
.mc .mv{font-weight:600;color:var(--text);min-width:30px;}
.sp{flex:1;}
.btn{padding:4px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);cursor:pointer;font-size:14px;color:var(--text2);white-space:nowrap;transition:.15s;}
.btn:hover{background:var(--bg3);border-color:var(--border2);}
.btn.on{background:var(--blue-bg);border-color:var(--blue);color:var(--blue);font-weight:600;}
.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue);}
.btn-primary:hover{opacity:.88;}
.btn-primary:disabled{opacity:.5;cursor:not-allowed;}
.btn-ai{background:var(--purple-bg);border-color:var(--purple);color:var(--purple);}
.btn-ai:hover{opacity:.88;}
.btn-ai.on{background:var(--purple);color:#fff;}
/* ── 智能定价 CSS ── */
.btn-price{background:#fff7ed;border-color:#f97316;color:#ea580c;}
.btn-price:hover{background:#ffedd5;}
/* ── 模板系统 CSS ── */
.btn-tpl{background:#f0fdf4;border-color:#22c55e;color:var(--green);}
.btn-tpl:hover{background:var(--green-bg);}
.tpl-modal{max-width:860px;width:95vw;max-height:88vh;display:flex;flex-direction:column;}
.tpl-tabs{display:flex;gap:4px;margin-bottom:12px;border-bottom:1px solid var(--border);padding-bottom:8px;}
.tpl-tab{padding:5px 14px;border-radius:var(--radius);border:1px solid transparent;cursor:pointer;font-size:14px;font-weight:600;color:var(--text2);background:none;}
.tpl-tab.active{background:var(--green);color:#fff;border-color:var(--green);}
.tpl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;overflow-y:auto;flex:1;padding-right:4px;}
.tpl-card{border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:14px;cursor:pointer;transition:all .15s;position:relative;}
.tpl-card:hover{border-color:var(--green);box-shadow:0 2px 12px rgba(34,197,94,.15);transform:translateY(-1px);}
.tpl-card.selected{border-color:var(--green);background:#f0fdf4;}
.tpl-card-icon{font-size:28px;margin-bottom:4px;}
.tpl-card-name{font-weight:700;font-size:15px;color:var(--text);margin-bottom:3px;}
.tpl-card-desc{font-size:13px;color:var(--text2);line-height:1.5;margin-bottom:8px;}
.tpl-card-meta{display:flex;gap:6px;flex-wrap:wrap;}
.tpl-tag{font-size:10px;padding:2px 7px;border-radius:8px;background:var(--bg2);color:var(--text2);border:1px solid var(--border);}
.tpl-card-stats{font-size:10px;color:var(--text3);margin-top:6px;}
.tpl-card-del{position:absolute;top:8px;right:8px;background:none;border:none;cursor:pointer;color:var(--text3);font-size:14px;padding:2px 5px;border-radius:4px;}
.tpl-card-del:hover{background:#fee2e2;color:var(--red);}
.tpl-preview{border:1px solid var(--border);border-radius:var(--radius);padding:12px;margin-top:10px;font-size:11px;background:var(--bg2);}
.tpl-preview-title{font-weight:700;margin-bottom:8px;color:var(--text);}
.tpl-preview-cats{display:flex;flex-wrap:wrap;gap:6px;}
.tpl-preview-cat{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:4px 8px;}
/* 套用参数弹窗 */
.tpl-apply-modal{max-width:420px;width:95vw;}
.tpl-apply-param{display:flex;flex-direction:column;gap:12px;padding:12px 0;}
.tpl-apply-row{display:flex;align-items:center;justify-content:space-between;gap:12px;}
.tpl-apply-row label{font-size:12px;color:var(--text2);font-weight:600;white-space:nowrap;}
.tpl-apply-row input{flex:1;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;background:var(--bg);}
.tpl-apply-hint{font-size:11px;color:var(--text3);padding:8px;background:var(--bg2);border-radius:var(--radius);}
.tpl-apply-actions{display:flex;gap:8px;justify-content:flex-end;padding-top:10px;}
.price-hint{position:absolute;z-index:999;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 4px 20px rgba(0,0,0,.15);padding:10px 12px;min-width:200px;font-size:11px;}
.price-hint-title{font-weight:700;color:var(--text);margin-bottom:4px;display:flex;align-items:center;justify-content:space-between;}
.price-hint-row{display:flex;justify-content:space-between;gap:16px;color:var(--text2);margin-bottom:3px;}
.price-hint-row b{color:var(--text);font-weight:600;}
.price-hint-apply{margin-top:8px;width:100%;padding:5px;background:var(--green);color:#fff;border:none;border-radius:var(--radius);cursor:pointer;font-size:11px;font-weight:600;}
.price-hint-apply:hover{opacity:.88;}
.price-hint-trend{font-size:10px;margin-left:4px;}
.price-hint-badge{font-size:9px;padding:1px 5px;border-radius:8px;background:#fef3c7;color:#92400e;font-weight:600;}
/* batch pricing modal */
.bp-modal{max-width:780px;width:95vw;max-height:85vh;display:flex;flex-direction:column;}
.bp-table{flex:1;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius);}
.bp-table table{width:100%;border-collapse:collapse;font-size:12px;}
.bp-table th{background:var(--bg2);padding:7px 10px;text-align:left;font-weight:600;position:sticky;top:0;border-bottom:1px solid var(--border);}
.bp-table td{padding:6px 10px;border-bottom:1px solid var(--border2);}
.bp-table tr:hover td{background:var(--bg2);}
.bp-diff-up{color:var(--green);font-weight:600;}
.bp-diff-down{color:var(--red);font-weight:600;}
.bp-diff-same{color:var(--text3);}
.bp-actions{display:flex;gap:8px;padding-top:12px;justify-content:flex-end;}
.bp-summary{font-size:11px;color:var(--text2);padding:8px 0;border-top:1px solid var(--border);margin-top:8px;}
.bp-no-data{padding:20px;text-align:center;color:var(--text3);font-size:12px;}
.btn-stats{background:var(--green-bg);border-color:var(--green);color:var(--green);}
.btn-stats:hover{opacity:.88;}
.bdg{display:inline-flex;align-items:center;justify-content:center;background:var(--blue);color:#fff;border-radius:50%;width:14px;height:14px;font-size:9px;margin-left:3px;font-weight:600;}
.user-badge{display:flex;align-items:center;gap:4px;padding:3px 8px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);font-size:13px;cursor:pointer;white-space:nowrap;}
.user-badge .avatar{width:20px;height:20px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;}

/* ── Main area ── */
.main-layout{display:flex;gap:10px;align-items:flex-start;}
.content{flex:1;min-width:0;}
.rpanel{width:240px;flex-shrink:0;display:none;position:sticky;top:10px;}

/* ── Category ── */
.cat-block{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:8px;box-shadow:var(--shadow);}
.cat-block.cat-dragging{opacity:0.45;border:2px dashed var(--accent);}
.cat-block.cat-drag-over{border:2px solid var(--accent);box-shadow:0 0 0 3px rgba(59,130,246,0.18);}
.cat-drag-handle{cursor:grab;color:var(--text3);font-size:16px;line-height:1;padding:0 2px;user-select:none;opacity:0.5;}
.cat-drag-handle:hover{opacity:1;color:var(--accent);}
.cat-drag-handle:active{cursor:grabbing;}
.row-drag-handle{cursor:grab;color:var(--text3);font-size:13px;padding:0 3px;user-select:none;opacity:0.35;display:inline-block;}
.row-drag-handle:hover{opacity:1;color:var(--accent);}
.row-drag-handle:active{cursor:grabbing;}
tr.row-dragging td{background:var(--bg2);opacity:0.45;}
tr.row-drag-over td{border-top:2px solid var(--accent);}
.cat-head{display:flex;align-items:center;gap:6px;padding:6px 10px;background:var(--bg2);border-bottom:1px solid var(--border);}
.cat-name-input{flex:1;border:none;background:transparent;font-size:14px;font-weight:600;color:var(--text);outline:none;}
.cat-name-input:focus{background:var(--bg3);border-radius:3px;padding:1px 4px;}
.cat-name-text{flex:1;font-size:14px;font-weight:600;}
.cat-stat{font-size:12px;color:var(--text2);white-space:nowrap;}
.xbtn{background:none;border:none;cursor:pointer;color:var(--text3);padding:0 3px;font-size:13px;line-height:1;border-radius:3px;}
.xbtn:hover{color:var(--red);background:var(--bg3);}

/* ── Table ── */
.tbl-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;font-size:13.5px;}
th{font-size:12px;color:var(--text2);font-weight:600;padding:5px 6px;text-align:left;border-bottom:1px solid var(--border);background:var(--bg2);white-space:nowrap;}
td{padding:3px 6px;border-bottom:1px solid var(--border);vertical-align:middle;}
tr:last-child td{border-bottom:none;}
tr:hover td{background:var(--blue-bg);}
.nr{text-align:right;}
.ca{text-align:right;font-weight:600;color:var(--blue);}
.qa{text-align:right;font-weight:600;color:var(--green);}
.add-row-btn{width:100%;padding:5px 10px;border:none;background:transparent;font-size:13px;color:var(--text3);cursor:pointer;text-align:left;}
.add-row-btn:hover{background:var(--bg2);color:var(--text2);}
.add-cat-btn{width:100%;padding:8px;border:1.5px dashed var(--border2);border-radius:var(--radius-lg);background:transparent;font-size:14px;color:var(--text2);cursor:pointer;margin-bottom:8px;transition:.15s;}
.add-cat-btn:hover{background:var(--bg2);border-color:var(--blue);color:var(--blue);}
/* ── 内陪核算 ── */
.neipei-block{margin-top:12px;border:1.5px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;}
.neipei-head{display:flex;align-items:center;gap:8px;padding:6px 10px;background:linear-gradient(90deg,#7c3aed22,transparent);border-bottom:1px solid var(--border);}
.neipei-head .np-title{font-weight:700;font-size:13px;color:var(--purple);flex:1;}
.neipei-head .np-total{font-size:12px;color:var(--text2);}
.neipei-collapse{background:none;border:none;cursor:pointer;font-size:14px;color:var(--text3);}
.neipei-sub{font-size:10px;color:var(--text3);background:var(--bg2);padding:3px 10px;border-bottom:1px solid var(--border);}
.np-add-row{width:100%;padding:6px;border:none;border-top:1px dashed var(--border2);background:transparent;font-size:11px;color:var(--text2);cursor:pointer;}
.np-add-row:hover{background:var(--bg2);color:var(--purple);}

/* ── Summary bar ── */
.summary{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:10px;padding:10px 14px;background:var(--bg2);border-radius:var(--radius-lg);border:1px solid var(--border);}
.sum-item{text-align:center;}
.sum-lbl{font-size:10px;color:var(--text2);}
.sum-val{font-size:15px;font-weight:700;margin-top:2px;}

/* ── Image button ── */
.img-btn{padding:2px 6px;border:1px solid var(--border);border-radius:var(--radius);font-size:10px;cursor:pointer;background:var(--bg);color:var(--text3);white-space:nowrap;}
.img-btn.has{border-color:var(--blue);color:var(--blue);background:var(--blue-bg);font-weight:600;}
.img-btn:hover{background:var(--bg3);}

/* ── Right Panel ── */
.rp-box{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg);box-shadow:var(--shadow);}
.rp-tabs{display:flex;border-bottom:1px solid var(--border);background:var(--bg2);}
.rptab{flex:1;padding:6px 4px;text-align:center;font-size:11px;cursor:pointer;border:none;background:transparent;color:var(--text2);border-bottom:2px solid transparent;}
.rptab.on{color:var(--text);font-weight:600;border-bottom-color:var(--blue);}
.rptab.ai-tab.on{border-bottom-color:var(--purple);}
.rp-body{overflow-y:auto;max-height:580px;}
.rp-sect{padding:8px;}
.rp-sect label{font-size:10px;color:var(--text2);font-weight:600;display:block;margin-bottom:3px;}
.rp-sect input{border:1px solid var(--border);border-radius:var(--radius);padding:4px 6px;width:100%;background:var(--bg2);margin-bottom:4px;}
.rp-sect input:focus{border-color:var(--blue);background:var(--bg);}
.rp-save-btn{width:100%;padding:6px;background:var(--blue);color:#fff;border:none;border-radius:var(--radius);cursor:pointer;font-size:12px;margin-top:2px;}
.rp-save-btn:hover{opacity:.88;}
.logo-upload{width:100%;height:54px;border:1.5px dashed var(--border2);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;position:relative;background:var(--bg2);margin-bottom:4px;}
.logo-upload img{max-width:100%;max-height:100%;object-fit:contain;}
.logo-upload span{font-size:10px;color:var(--text3);}
.logo-upload input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;}

/* ── Lib panel ── */
.lib-search{padding:6px 8px;border-bottom:1px solid var(--border);}
.lib-search input{border:1px solid var(--border);border-radius:var(--radius);padding:4px 7px;background:var(--bg2);width:100%;font-size:11px;}
.lib-search input:focus{border-color:var(--blue);}
.lib-cat-hdr{font-size:9px;font-weight:700;color:var(--text2);padding:5px 8px 2px;text-transform:uppercase;letter-spacing:.06em;background:var(--bg2);}
.lib-item{display:flex;align-items:center;padding:4px 8px;cursor:pointer;gap:4px;border-bottom:1px solid var(--border);}
.lib-item:hover{background:var(--blue-bg);}
.lib-item .lin{flex:1;font-size:11px;color:var(--text);}
.lib-item .lip{font-size:10px;color:var(--text2);}
.le-row{display:flex;align-items:center;padding:3px 6px;border-bottom:1px solid var(--border);gap:3px;}
.le-row:hover{background:var(--bg2);}
.le-row input{border:none;background:transparent;outline:none;font-size:11px;padding:0;}
.le-nm{flex:1;}.le-ut{width:26px;}.le-pr{width:44px;text-align:right;}
.le-add-area{padding:8px;border-top:1px solid var(--border);background:var(--bg2);}
.le-add-area input{border:1px solid var(--border);border-radius:var(--radius);padding:3px 6px;background:var(--bg);font-size:11px;margin-bottom:4px;width:100%;}
.le-add-row{display:flex;gap:4px;margin-bottom:4px;}
.le-add-row input{flex:1;}
.le-add-row input.sm{width:36px;flex:none;}
.le-btns{display:flex;gap:4px;}
.le-btns button{flex:1;padding:5px;border-radius:var(--radius);cursor:pointer;font-size:11px;}

/* ── Att panel ── */
.att-grid{display:flex;flex-wrap:wrap;gap:6px;padding:8px;}
.att-thumb{width:60px;text-align:center;}
.att-thumb img{width:60px;height:60px;object-fit:cover;border-radius:var(--radius);border:1px solid var(--border);display:block;}
.att-thumb .aname{font-size:9px;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:60px;margin-top:2px;}
.att-thumb .adel{display:block;width:16px;height:16px;background:var(--red);color:#fff;border:none;border-radius:50%;font-size:9px;cursor:pointer;margin:0 auto 2px;line-height:16px;text-align:center;}
.att-add-btn{display:flex;align-items:center;justify-content:center;width:60px;height:60px;border:1.5px dashed var(--border2);border-radius:var(--radius);cursor:pointer;position:relative;background:var(--bg2);}
.att-add-btn span{font-size:22px;color:var(--text3);}
.att-add-btn input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;}

/* ── AI Panel ── */
.ai-panel{padding:8px;}
.ai-textarea{width:100%;border:1px solid var(--border);border-radius:var(--radius);padding:6px 8px;background:var(--bg2);font-size:11px;resize:vertical;min-height:80px;font-family:inherit;color:var(--text);}
.ai-textarea:focus{border-color:var(--purple);outline:none;background:var(--bg);}
.ai-run-btn{width:100%;padding:7px;background:var(--purple);color:#fff;border:none;border-radius:var(--radius);cursor:pointer;font-size:12px;margin-top:6px;display:flex;align-items:center;justify-content:center;gap:5px;}
.ai-run-btn:disabled{opacity:.55;cursor:not-allowed;}
/* ── 图片识别区 ── */
.ai-img-zone{border:1.5px dashed var(--border2);border-radius:var(--radius-lg);padding:10px;margin-bottom:8px;cursor:pointer;position:relative;transition:.15s;}
.ai-img-zone:hover{border-color:var(--purple);background:var(--purple-bg);}
.ai-img-zone.has-img{border-style:solid;border-color:var(--purple);background:var(--purple-bg);}
.ai-img-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;}
.ai-img-placeholder{text-align:center;font-size:11px;color:var(--text3);pointer-events:none;}
.ai-img-placeholder span{font-size:20px;display:block;margin-bottom:4px;}
.ai-img-grid{display:flex;flex-wrap:wrap;gap:5px;pointer-events:none;align-items:flex-start;}
.ai-img-thumb{position:relative;width:52px;height:52px;pointer-events:all;}
.ai-img-thumb img{width:52px;height:52px;object-fit:cover;border-radius:var(--radius);border:1px solid var(--border);}
.ai-img-thumb .ai-img-del{position:absolute;top:-4px;right:-4px;background:var(--red);color:#fff;border:none;border-radius:50%;width:16px;height:16px;font-size:9px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1;}
.ai-img-add{width:52px;height:52px;border:1.5px dashed var(--border2);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;cursor:pointer;background:var(--bg2);color:var(--text3);font-size:18px;flex-shrink:0;position:relative;pointer-events:all;}
.ai-img-add input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;}
/* 模式切换 */
.ai-mode-bar{display:flex;gap:5px;margin-bottom:8px;}
.ai-mode-btn{flex:1;padding:5px 4px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:11px;cursor:pointer;background:var(--bg);color:var(--text2);transition:.15s;text-align:center;line-height:1.4;}
.ai-mode-btn.active{border-color:var(--purple);background:var(--purple-bg);color:var(--purple);font-weight:600;}
.ai-mode-btn:hover:not(.active){background:var(--bg2);}
.ai-model-bar{display:flex;gap:4px;margin-bottom:8px;flex-wrap:wrap;}
.ai-model-btn{flex:1;min-width:0;padding:4px 3px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:10px;cursor:pointer;background:var(--bg);color:var(--text2);transition:.15s;text-align:center;line-height:1.5;white-space:nowrap;}
.ai-model-btn.active{border-color:var(--purple);background:var(--purple-bg);color:var(--purple);font-weight:600;}
.ai-model-btn:hover:not(.active){background:var(--bg2);}
.ai-model-tag{display:inline-block;font-size:9px;padding:1px 4px;border-radius:3px;margin-top:1px;}
.ai-model-tag.best{background:#fff3cd;color:#856404;}
.ai-model-tag.fast{background:#d1e7dd;color:#0f5132;}
.ai-model-tag.smart{background:#cff4fc;color:#055160;}
/* 描述结果 */
.ai-desc-result{margin-top:8px;border:1px solid var(--border);border-radius:var(--radius);padding:8px;background:var(--bg2);font-size:11px;line-height:1.7;color:var(--text);white-space:pre-wrap;max-height:200px;overflow-y:auto;}
.ai-desc-actions{display:flex;gap:5px;margin-top:6px;}
.ai-desc-use-btn{flex:1;padding:5px;background:var(--purple);color:#fff;border:none;border-radius:var(--radius);cursor:pointer;font-size:11px;font-weight:600;}
.ai-desc-use-btn:hover{opacity:.88;}
.ai-desc-copy-btn{padding:5px 10px;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;font-size:11px;background:var(--bg);color:var(--text2);}
.ai-section-lbl{font-size:12px;font-weight:600;color:var(--text2);margin-bottom:4px;display:flex;align-items:center;gap:4px;}
.ai-result{margin-top:8px;border-top:1px solid var(--border);padding-top:8px;}
.ai-item{display:flex;align-items:center;padding:3px 4px;border-bottom:1px solid var(--border);gap:4px;font-size:11px;}
.ai-item:last-child{border-bottom:none;}
.ai-item .ai-chk{flex-shrink:0;accent-color:var(--purple);}
.ai-item .ai-nm{flex:1;color:var(--text);}
.ai-item .ai-pr{color:var(--text2);font-size:10px;white-space:nowrap;}
.ai-tips{font-size:10px;color:var(--text3);padding:4px 0;line-height:1.6;}
.ai-spin{display:inline-block;width:13px;height:13px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;}
/* ── AI 对话模式 ── */
.ai-chat-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.ai-chat-reset{font-size:10px;padding:3px 8px;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;background:var(--bg);color:var(--text2);}
.ai-chat-reset:hover{background:var(--bg2);}
.ai-chat-history{max-height:210px;overflow-y:auto;margin-bottom:8px;display:flex;flex-direction:column;gap:5px;}
.ai-chat-turn-user{background:var(--purple-bg);border:1px solid var(--purple);border-radius:var(--radius);padding:5px 8px;font-size:11px;color:var(--purple);text-align:right;word-break:break-all;}
.ai-chat-turn-ai{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:5px 8px;font-size:11px;color:var(--text);word-break:break-all;}
.ai-chat-ai-meta{font-size:10px;color:var(--green);margin-top:3px;font-weight:500;}
.ai-chat-input-row{display:flex;gap:5px;align-items:flex-end;}
.ai-chat-ta{flex:1;border:1px solid var(--border);border-radius:var(--radius);padding:6px 8px;background:var(--bg2);font-size:11px;resize:none;min-height:44px;max-height:80px;font-family:inherit;color:var(--text);}
.ai-chat-ta:focus{border-color:var(--purple);outline:none;background:var(--bg);}
.ai-chat-send{padding:6px 10px;background:var(--purple);color:#fff;border:none;border-radius:var(--radius);cursor:pointer;font-size:11px;flex-shrink:0;min-height:44px;line-height:1.3;}
.ai-chat-send:disabled{opacity:.55;cursor:not-allowed;}
/* 紧凑图片条 */
.ai-imgs-strip{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px;padding:6px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);}
.ai-imgs-strip-item{display:flex;flex-direction:column;align-items:center;gap:2px;}
.ai-imgs-strip-thumb{width:34px;height:34px;object-fit:cover;border-radius:var(--radius);border:1px solid var(--border);}
.ai-imgs-strip-lbl{font-size:8px;color:var(--text3);text-align:center;max-width:40px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
/* 图片类型标注 */
.ai-img-wrap{display:flex;flex-direction:column;width:52px;gap:2px;flex-shrink:0;}
.ai-img-label{font-size:9px;text-align:center;color:var(--text2);cursor:pointer;padding:1px 2px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);user-select:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ai-img-label:hover{background:var(--purple-bg);color:var(--purple);border-color:var(--purple);}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── History modal ── */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:10000;display:flex;align-items:center;justify-content:center;}
.modal-box{background:var(--bg);border-radius:var(--radius-lg);border:1px solid var(--border);padding:16px;width:520px;max-height:82vh;display:flex;flex-direction:column;box-shadow:0 8px 32px rgba(0,0,0,.2);}
.modal-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.modal-hdr h3{font-size:14px;font-weight:700;}
.modal-body{overflow-y:auto;flex:1;}
.hist-filter{display:flex;gap:5px;margin-bottom:8px;}
.hist-filter input,.hist-filter select{border:1px solid var(--border);border-radius:var(--radius);padding:4px 7px;background:var(--bg2);font-size:11px;outline:none;}
.hist-filter input{flex:1;}
.hist-filter input:focus,.hist-filter select:focus{border-color:var(--blue);}
.hist-item{padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:5px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:.15s;}
.hist-item:hover{background:var(--bg2);border-color:var(--border2);}
.hist-name{font-size:12px;font-weight:600;}
.hist-sub{font-size:10px;color:var(--text2);}
.hist-user{font-size:10px;color:var(--blue);font-weight:600;margin-top:2px;}
.hist-val{font-size:13px;font-weight:700;color:var(--green);text-align:right;}
.hist-del{padding:2px 6px;font-size:10px;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;background:transparent;color:var(--text3);margin-left:6px;}
.hist-del:hover{background:var(--red);border-color:var(--red);color:#fff;}

/* ── Status Tags ── */
.status-tag{display:inline-flex;align-items:center;padding:2px 7px;border-radius:10px;font-size:9px;font-weight:700;cursor:pointer;border:1px solid transparent;white-space:nowrap;transition:.15s;}
.status-tag:hover{opacity:.8;}
.st-draft{background:#f1f5f9;color:#64748b;border-color:#e2e8f0;}
.st-sent{background:#eff6ff;color:var(--blue);border-color:#bfdbfe;}
.st-negotiating{background:#fef9c3;color:#b45309;border-color:#fde68a;}
.st-won{background:#f0fdf4;color:#15803d;border-color:#bbf7d0;}
.st-lost{background:#fef2f2;color:var(--red);border-color:#fecaca;}
.status-menu{position:absolute;right:0;top:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px rgba(0,0,0,.15);z-index:200;min-width:100px;padding:3px 0;}
.status-menu button{display:block;width:100%;padding:5px 10px;border:none;background:none;cursor:pointer;font-size:11px;text-align:left;color:var(--text);}
.status-menu button:hover{background:var(--bg2);}
.hist-right{display:flex;align-items:center;gap:6px;flex-shrink:0;position:relative;}

/* ── PDF Preview Modal ── */
.pdf-modal{width:720px;max-width:96vw;max-height:92vh;}
.pdf-toolbar{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border);margin-bottom:10px;}
.pdf-download-btn{padding:6px 16px;background:#e11d48;color:#fff;border:none;border-radius:var(--radius);cursor:pointer;font-size:12px;font-weight:600;}
.pdf-download-btn:hover{opacity:.88;}
.pdf-preview{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:auto;max-height:calc(92vh - 120px);}
/* Quote document styles: see inline  inside buildQuoteDocHTML() */

/* ── Enhanced stats ── */
.stats-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:12px;}
.st-tab{flex:1;padding:6px;text-align:center;font-size:11px;cursor:pointer;border:none;background:transparent;color:var(--text2);border-bottom:2px solid transparent;}
.st-tab.on{color:var(--text);font-weight:600;border-bottom-color:var(--blue);}
.conv-table{width:100%;border-collapse:collapse;font-size:11px;}
.conv-table th{font-size:12px;color:var(--text2);font-weight:600;padding:5px 8px;border-bottom:1px solid var(--border);text-align:left;background:var(--bg2);}
.conv-table th.r{text-align:right;}
.conv-table td{padding:5px 8px;border-bottom:1px solid var(--border);}
.conv-table td.r{text-align:right;}
.conv-table tr:last-child td{border-bottom:none;}
.rate-pill{display:inline-block;padding:1px 6px;border-radius:10px;font-size:10px;font-weight:700;}
.rate-hi{background:var(--green-bg);color:var(--green);}
.rate-mid{background:#fef9c3;color:#b45309;}
.rate-lo{background:var(--bg3);color:var(--text2);}
.rate-none{color:var(--text3);font-size:10px;}
.margin-bar{display:flex;align-items:center;gap:6px;}
.mb-fill{height:12px;border-radius:2px;background:var(--blue);min-width:2px;}
.mb-val{font-size:10px;font-weight:600;white-space:nowrap;}

/* ── Stats modal ── */
.stats-modal{width:680px;max-width:96vw;}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px;}
.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px 14px;text-align:center;}
.stat-card .sc-val{font-size:22px;font-weight:800;color:var(--blue);margin-bottom:2px;}
.stat-card .sc-lbl{font-size:10px;color:var(--text2);}
.stats-section{margin-bottom:14px;}
.stats-section h4{font-size:12px;font-weight:700;color:var(--text2);margin-bottom:8px;border-bottom:1px solid var(--border);padding-bottom:4px;}
.bar-row{display:flex;align-items:center;gap:8px;margin-bottom:5px;font-size:11px;}
.bar-row .br-lbl{width:70px;text-align:right;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0;}
.bar-row .br-bar{flex:1;height:14px;background:var(--bg3);border-radius:3px;overflow:hidden;}
.bar-row .br-fill{height:100%;background:var(--blue);border-radius:3px;transition:.4s;}
.bar-row .br-val{width:65px;text-align:right;font-weight:600;color:var(--text);flex-shrink:0;}
.month-chart{display:flex;align-items:flex-end;gap:4px;height:80px;padding:0 4px;}
.month-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;}
.month-bar{width:100%;background:var(--blue);border-radius:2px 2px 0 0;min-height:2px;transition:.4s;}
.month-label{font-size:9px;color:var(--text3);white-space:nowrap;}
.stats-empty{text-align:center;padding:30px;color:var(--text3);font-size:12px;}

/* ── Login modal ── */
.login-modal{width:340px;}
.login-title{font-size:16px;font-weight:700;margin-bottom:4px;}
.login-sub{font-size:11px;color:var(--text2);margin-bottom:14px;}
.login-team{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px;}
.login-member{padding:5px 12px;border:1.5px solid var(--border);border-radius:20px;font-size:12px;cursor:pointer;transition:.15s;}
.login-member:hover{border-color:var(--blue);color:var(--blue);}
.login-member.on{border-color:var(--blue);background:var(--blue-bg);color:var(--blue);font-weight:600;}
.login-or{text-align:center;font-size:10px;color:var(--text3);margin:8px 0;}
.login-input{border:1px solid var(--border);border-radius:var(--radius);padding:7px 10px;width:100%;background:var(--bg2);font-size:12px;margin-bottom:10px;}
.login-input:focus{border-color:var(--blue);outline:none;background:var(--bg);}
.login-btn{width:100%;padding:9px;background:var(--blue);color:#fff;border:none;border-radius:var(--radius);cursor:pointer;font-size:13px;font-weight:600;}
.login-btn:hover{opacity:.88;}

/* ── Image modal ── */
.imgm-bg{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:2000;display:flex;align-items:center;justify-content:center;}
.imgm-box{background:var(--bg);border-radius:var(--radius-lg);border:1px solid var(--border);padding:16px;width:540px;max-height:82vh;display:flex;flex-direction:column;gap:10px;}
.imgm-hdr{display:flex;justify-content:space-between;align-items:center;}
.imgm-hdr h3{font-size:13px;font-weight:600;}
.img-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:6px;overflow-y:auto;max-height:380px;}
.ig-cell{position:relative;}
.ig-cell img{width:100%;height:95px;object-fit:cover;border-radius:var(--radius);border:1px solid var(--border);}
.ig-del{position:absolute;top:3px;right:3px;background:rgba(220,38,38,.9);border:none;border-radius:50%;width:18px;height:18px;color:#fff;cursor:pointer;font-size:10px;display:flex;align-items:center;justify-content:center;}
.ig-add{display:flex;align-items:center;justify-content:center;height:95px;border:1.5px dashed var(--border2);border-radius:var(--radius);cursor:pointer;position:relative;background:var(--bg2);}
.ig-add span{font-size:24px;color:var(--text3);}
.ig-add input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;}

/* ── Role Badge ── */
.role-badge{display:inline-flex;align-items:center;padding:1px 6px;border-radius:10px;font-size:9px;font-weight:700;margin-left:4px;}
.role-admin{background:#fef9c3;color:#b45309;border:1px solid #fde68a;}
.role-sales{background:var(--bg3);color:var(--text2);border:1px solid var(--border);}
.cost-hidden{color:var(--text3);font-style:italic;font-size:10px;}
/* ── Version History ── */
.ver-item{padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:4px;}
.ver-item.is-final{border-color:var(--green);background:var(--green-bg);}
.ver-header{display:flex;align-items:center;gap:6px;margin-bottom:4px;}
.ver-num{font-size:11px;font-weight:700;color:var(--text);}
.ver-badge{padding:1px 7px;border-radius:10px;font-size:9px;font-weight:700;}
.vb-final{background:var(--green-bg);color:var(--green);border:1px solid var(--green);}
.vb-current{background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue);}
.ver-sub{font-size:10px;color:var(--text2);}
.ver-actions{display:flex;gap:5px;margin-top:6px;}
.ver-btn{padding:3px 9px;font-size:10px;border-radius:var(--radius);cursor:pointer;border:1px solid var(--border);background:var(--bg);color:var(--text2);}
.ver-btn:hover{background:var(--bg3);}
.ver-btn.primary{background:var(--blue);color:#fff;border-color:var(--blue);}
.ver-btn.green{background:var(--green);color:#fff;border-color:var(--green);}
.hist-ver{font-size:10px;font-weight:700;color:var(--text3);margin-left:4px;}
.hist-final-badge{font-size:9px;background:var(--green-bg);color:var(--green);border:1px solid var(--green);padding:1px 5px;border-radius:10px;margin-left:4px;font-weight:700;}

/* ── Toast ── */
.toast{position:fixed;bottom:20px;right:20px;padding:9px 16px;border-radius:var(--radius-lg);font-size:12px;font-weight:600;z-index:9999;box-shadow:0 4px 16px rgba(0,0,0,.2);transition:.3s;color:#fff;}
.toast.ok{background:#15803d;}
.toast.err{background:#dc2626;}
.toast.warn{background:#b45309;}


/* ── 租户登录界面 ────────────────────────────── */
#login-screen{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;align-items:center;justify-content:center;}
#login-screen.hidden{display:none;}
.login-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:40px 36px;width:360px;box-shadow:0 8px 40px rgba(0,0,0,.12);}
.login-logo{font-size:22px;font-weight:700;color:var(--text);margin-bottom:4px;}
.login-sub{font-size:13px;color:var(--text2);margin-bottom:28px;}
.login-field{margin-bottom:16px;}
.login-field label{display:block;font-size:12px;color:var(--text2);margin-bottom:4px;font-weight:500;}
.login-field input{width:100%;box-sizing:border-box;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:14px;outline:none;transition:.15s;}
.login-field input:focus{border-color:var(--blue);}
.login-btn{width:100%;padding:11px;background:var(--blue);color:#fff;border:none;border-radius:var(--radius);font-size:14px;font-weight:600;cursor:pointer;margin-top:8px;transition:.15s;}
.login-btn:hover{opacity:.9;}
.login-btn:disabled{opacity:.5;cursor:not-allowed;}
.login-err{font-size:12px;color:#e53;margin-top:10px;min-height:16px;}
.login-ver{font-size:11px;color:var(--text3);margin-top:20px;text-align:center;}

/* ── AI 暂存预览弹窗 ── */
.ai-staging-cat-hdr{display:flex;align-items:center;gap:6px;padding:7px 0 4px;font-size:12px;font-weight:700;color:var(--text);border-bottom:1px solid var(--border);margin-bottom:4px;cursor:pointer;user-select:none;}
.ai-staging-cat-hdr:hover{color:var(--blue);}
.ai-staging-item{display:grid;grid-template-columns:20px 1fr 60px 40px 70px;gap:5px;align-items:center;padding:5px 4px;border-radius:var(--radius);font-size:12px;}
.ai-staging-item:hover{background:var(--bg2);}
.ai-staging-item.unchecked{opacity:.45;}
.ai-staging-item input[type=checkbox]{width:14px;height:14px;accent-color:var(--purple);cursor:pointer;}
.ai-staging-item-name{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ai-staging-item-qty{border:1px solid var(--border);border-radius:3px;padding:2px 4px;text-align:right;width:100%;background:var(--bg2);color:var(--text);}
.ai-staging-item-unit{color:var(--text3);text-align:center;}
.ai-staging-item-price{color:var(--green);text-align:right;font-weight:600;}
/* v34.5.10: 点击遮罩自动关闭弹窗，防止按钮卡死 */
.modal-bg>div:first-child{cursor:default;}

