:root{color-scheme:light;--ink: #17202a;--muted: #66717e;--line: #dce2e8;--surface: #ffffff;--soft: #f5f7fa;--accent: #0f766e;--accent-strong: #0b5f59;--danger: #a33b49;--warning: #8a5a14;--shadow: 0 16px 40px rgba(23, 32, 42, .08);font-family:Microsoft YaHei,PingFang SC,Arial,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--soft);color:var(--ink);overflow:hidden}button,input,select,textarea{font:inherit}button{color:inherit}h1,h2,h3,p{margin-top:0}.app-shell{display:grid;grid-template-columns:248px minmax(0,1fr);height:100vh;min-height:100vh;overflow:hidden}.sidebar{position:sticky;top:0;display:flex;flex-direction:column;gap:22px;height:100vh;min-height:100vh;overflow:hidden;padding:24px;background:#10201e;color:#f7fbfa}.brand{display:flex;align-items:center;gap:12px}.brand svg{width:42px;height:42px;padding:9px;border-radius:8px;background:#e8f5f3;color:var(--accent-strong)}.brand strong,.brand span{display:block}.brand span,.sidebar-card span,.sidebar-card small{color:#b9cbc8}.nav{display:grid;gap:8px;overflow-y:auto;padding-right:2px}.nav-item{display:flex;align-items:center;gap:10px;min-height:42px;border:0;border-radius:8px;padding:0 13px;background:transparent;color:#cbdad8;text-align:left;cursor:pointer}.nav-item:hover,.nav-item.active{background:#ffffff1f;color:#fff}.sidebar-card{margin-top:auto;flex-shrink:0;padding:16px;border:1px solid rgba(255,255,255,.16);border-radius:8px;background:#ffffff14}.user-name{display:block;margin:6px 0;font-size:22px}.logout-button{width:100%;min-height:36px;margin-top:14px;border:1px solid rgba(255,255,255,.18);border-radius:8px;background:#ffffff14;color:#f7fbfa;cursor:pointer}.workspace{min-width:0;height:100vh;overflow-y:auto;padding:28px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:24px}.eyebrow{margin-bottom:6px;color:var(--accent);font-size:13px;font-weight:700}h1{margin-bottom:0;font-size:30px;letter-spacing:0}h2{margin-bottom:0;font-size:18px}h3{margin:20px 0 12px;font-size:16px}.topbar-actions{display:flex;align-items:center;gap:12px}.search{display:flex;align-items:center;gap:10px;min-width:320px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.search input{width:100%;min-width:0;border:0;outline:0}.primary-button,.secondary-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;border:1px solid transparent;border-radius:8px;padding:0 15px;cursor:pointer;white-space:nowrap}.primary-button{background:var(--accent);color:#fff}.primary-button:hover{background:var(--accent-strong)}.secondary-button{border-color:var(--line);background:#fff;color:var(--ink)}.compact{min-height:34px;padding:0 10px}.danger-text{color:var(--danger)}.link-button{border:0;background:transparent;color:var(--accent-strong);cursor:pointer;font-weight:700}.view-stack{display:grid;gap:18px}.split-view{display:grid;grid-template-columns:minmax(460px,.95fr) minmax(560px,1.2fr);gap:18px;align-items:start}.metrics{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}.summary-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.metric,.panel,.summary-strip article{border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow)}.metric{position:relative;min-height:112px;padding:18px}.metric span{color:var(--muted);font-size:13px}.metric strong{display:block;margin-top:13px;padding-right:38px;font-size:24px;overflow-wrap:anywhere}.demo-guide{display:grid;gap:8px;color:#334155;line-height:1.7}.demo-guide p{margin:0}.summary-strip article{padding:16px}.summary-strip span{color:var(--muted);font-size:13px}.summary-strip strong{display:block;margin-top:8px;font-size:24px;overflow-wrap:anywhere}.metric-icon{position:absolute;right:16px;top:16px;display:grid;place-items:center;width:36px;height:36px;border-radius:8px;background:#e8f5f3;color:var(--accent-strong)}.panel{min-width:0;padding:18px}.detail-anchor{scroll-margin-top:18px}.split-view>.panel:nth-child(2),.detail-anchor>.panel{box-shadow:0 10px 28px #17202a0f}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.panel-actions,.dialog-actions,.row-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px;margin-top:16px}.document-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.print-tip{color:#64748b;font-size:12px}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:8px;background:var(--surface)}table{width:100%;min-width:860px;border-collapse:collapse}th,td{padding:12px 14px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}th{background:#fbfcfd;color:var(--muted);font-size:13px}td small{display:block;margin-top:5px;color:var(--muted);line-height:1.45}.disabled-row{opacity:.62;background:#f8fafc}.badge{display:inline-flex;align-items:center;min-height:26px;border-radius:999px;padding:0 9px;font-size:12px;font-weight:700}.badge.success{background:#e8f5f3;color:var(--accent-strong)}.badge.warning{background:#fff1dc;color:var(--warning)}.badge.danger{background:#fdecef;color:var(--danger)}.detail-grid,.record-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.detail-grid div,.record-grid article,.score-preview{display:grid;gap:6px;padding:12px;border:1px solid var(--line);border-radius:8px;background:#fbfcfd}.detail-grid span,.record-grid span{color:var(--muted);font-size:13px}.record-grid strong,.detail-grid strong{overflow-wrap:anywhere}.receipt-editor{gap:12px}.receipt-editor .payment-method-editor{padding:10px}.receipt-settings-grid{grid-template-columns:minmax(150px,.8fr) minmax(260px,1.4fr) minmax(220px,1.2fr) minmax(160px,.8fr) minmax(170px,.9fr);align-items:end;margin-bottom:0}.receipt-settings-grid .wide-field{min-width:0}.notice{margin:14px 0 0;padding:10px 12px;border-radius:8px;background:#fff1dc;color:var(--warning)}.notice.danger,.form-error{background:#fdecef;color:var(--danger)}.notice.success{background:#e8f5f3;color:var(--accent-strong)}.approval-box{display:grid;gap:12px;padding:14px;border:1px solid var(--line);border-radius:8px;background:#fbfcfd}.approval-box textarea{min-height:76px}.login-screen{min-height:100vh;display:grid;place-items:center;padding:28px;background:linear-gradient(135deg,#10201e,#f5f7fa 62%)}.login-panel{width:min(480px,100%);display:grid;gap:16px;padding:28px;border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow)}.login-panel div strong,.login-panel div span{display:block}.login-panel div strong{font-size:22px}.login-panel div span,.login-panel small{margin-top:6px;color:var(--muted)}.form-grid,.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}label{display:grid;gap:7px;color:var(--muted);font-size:13px}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:8px;padding:10px 12px;background:#fff;color:var(--ink)}input.field-error,select.field-error,textarea.field-error{border-color:var(--danger);box-shadow:0 0 0 3px #a33b491f}.field-error-text{color:var(--danger);font-size:12px;line-height:1.45}textarea{min-height:92px;resize:vertical}.full{grid-column:1 / -1}.modal-backdrop{position:fixed;inset:0;z-index:30;display:grid;place-items:center;padding:18px;background:#0f1c1a7a}.dialog-card{width:min(920px,calc(100vw - 36px));max-height:calc(100vh - 36px);overflow:auto;padding:22px;border-radius:10px;background:var(--surface);box-shadow:0 24px 80px #0000003d}.dialog-header,.line-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.line-header{margin:18px 0 10px}.icon-button{display:grid;place-items:center;width:36px;height:36px;border:1px solid var(--line);border-radius:8px;background:#fff;cursor:pointer}.upload-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.file-button{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:40px;border:1px solid var(--line);border-radius:8px;padding:0 12px;background:#fff;color:var(--ink);cursor:pointer;overflow:hidden}.file-button input{position:absolute;inset:0;opacity:0;cursor:pointer}.thumb{width:100%;max-height:150px;border:1px solid var(--line);border-radius:8px;object-fit:contain}.clickable-thumb{cursor:zoom-in;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}.clickable-thumb:hover,.clickable-thumb:focus-visible{border-color:var(--accent);box-shadow:0 0 0 3px #1d6f6124;outline:none}.clickable-thumb:active{transform:scale(.99)}.image-preview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(88px,1fr));gap:8px;margin-top:8px}.image-preview-grid .thumb{height:96px;max-height:96px;background:#fff}.image-preview-backdrop{position:fixed;inset:0;z-index:60;display:grid;place-items:center;padding:24px;background:#0b1412b8}.image-preview-modal{position:relative;display:grid;place-items:center;max-width:94vw;max-height:90vh}.image-preview-modal img{max-width:90vw;max-height:85vh;border-radius:8px;background:#fff;box-shadow:0 24px 64px #00000059;object-fit:contain}.image-preview-close{position:absolute;top:-14px;right:-14px;z-index:1;display:grid;place-items:center;width:34px;height:34px;border:1px solid var(--line);border-radius:999px;background:var(--surface);color:var(--text);cursor:pointer}.muted-text{color:var(--muted);font-size:.9rem}.item-editor{display:grid;grid-template-columns:2fr .7fr .9fr 1fr;gap:10px;margin-bottom:10px;padding:12px;border:1px solid var(--line);border-radius:8px;background:#fbfcfd}.total-line{margin-top:12px;text-align:right;font-size:18px}.hidden-input,.print-only{display:none}.signature-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;margin-top:18px}.signature-grid div{min-height:76px;border:1px solid var(--line);border-radius:8px;padding:10px;color:var(--muted)}.empty-panel{padding:28px;border:1px dashed var(--line);border-radius:8px;color:var(--muted);text-align:center}.table-empty{padding:28px 16px;color:var(--muted);text-align:center;background:#f8fafc}.document-print-area h1{margin:0 0 18px;text-align:center;font-size:28px;letter-spacing:.08em}.print-hint{margin:-8px 0 14px;color:#64748b;font-size:11px;text-align:center}.print-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 18px;margin:12px 0}.print-meta p,.print-totals p{margin:0 0 8px}.document-head{display:grid;grid-template-columns:minmax(0,1fr) 220px;gap:24px;align-items:start;margin:10px 0 18px}.document-customer{margin:0 0 8px;padding-bottom:10px;border-bottom:1px solid #111827;font-size:18px}.document-recipient p,.document-meta-box p{margin:0 0 8px;line-height:1.7}.document-bottom-grid{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:24px;margin-top:18px;align-items:start}.document-bottom-grid p,.issuer-block{margin:0 0 8px;line-height:1.75}.document-bottom-grid span,.issuer-block span,.print-meta span{display:block}.print-amount{display:flex;align-items:baseline;justify-content:space-between;margin:18px 0;border-top:2px solid #111827;border-bottom:2px solid #111827;padding:12px 0}.print-amount strong{font-size:24px}.print-table{width:100%;border-collapse:collapse;table-layout:fixed}.print-table th,.print-table td{border:1px solid #111827;padding:7px;vertical-align:top}.print-table small{display:block;margin-top:4px;color:#4b5563}.print-table .col-item{width:34%}.print-table .col-qty{width:8%}.print-table .col-money{width:14%}.print-table .col-tax{width:13%}.tax-rate{white-space:nowrap}.print-totals{margin-top:12px;text-align:right}.receipt-print{color:#111827}.receipt-print h1{margin-bottom:26px;letter-spacing:.08em}.receipt-head{display:grid;grid-template-columns:minmax(0,1fr) 220px;gap:24px;align-items:start;margin:10px 0 26px}.receipt-customer,.receipt-meta{margin:0;line-height:1.8}.receipt-customer{border-bottom:1px solid #111827;padding-bottom:10px;font-size:18px;text-align:left}.receipt-meta{text-align:left;font-size:12px}.receipt-amount{width:min(420px,100%);margin:18px auto 26px;border-top:2px solid #111827;border-bottom:2px solid #111827;padding:12px 8px;text-align:center}.receipt-amount span{display:block;margin-bottom:6px;font-size:13px}.receipt-amount strong{font-size:30px;letter-spacing:0}.receipt-body{margin:0 0 18px;text-align:left;line-height:1.9}.receipt-body p{margin:0 0 8px}.receipt-tax{width:min(360px,100%);margin:18px 0 24px;border-top:1px solid #111827;border-bottom:1px solid #111827}.receipt-tax div{display:grid;grid-template-columns:1fr auto;gap:16px;padding:7px 0;border-bottom:1px solid #d1d5db}.receipt-tax div:last-child{border-bottom:0}.receipt-footer{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:28px;align-items:end;margin-top:26px}.receipt-footer p{margin:0;line-height:1.8}.receipt-issuer{justify-self:end;text-align:left}.receipt-issuer span{display:block}@media(max-width:1280px){.metrics{grid-template-columns:repeat(3,minmax(0,1fr))}.split-view{grid-template-columns:1fr}}@media(max-width:920px){body{overflow:auto}.app-shell{grid-template-columns:1fr;height:auto;min-height:100vh;overflow:visible}.sidebar{position:static;height:auto;min-height:0;overflow:visible}.workspace{height:auto;overflow:visible}.nav,.metrics,.detail-grid,.record-grid,.form-grid,.settings-grid,.item-editor{grid-template-columns:1fr}.topbar,.topbar-actions{align-items:stretch;flex-direction:column}.search{min-width:0}}@media print{@page{size:A4;margin:12mm}.no-print{display:none!important}html,body{width:210mm;min-height:297mm;margin:0;background:#fff;-webkit-print-color-adjust:exact;print-color-adjust:exact}body *{visibility:hidden}.split-view>.panel:first-child,.topbar,.sidebar,.panel-header,.approval-box,.dialog-actions,.panel-actions,.row-actions,.no-print{display:none}.workspace,.app-shell,.split-view,.panel,.print-document.is-printing{display:block;visibility:visible;padding:0;box-shadow:none;border:0;background:#fff}.print-document.is-printing *{visibility:visible}.panel>:not(.print-document.is-printing),.detail-anchor>.panel>:not(.print-document.is-printing){display:none}.print-document:not(.is-printing){display:none;visibility:hidden}.table-wrap{width:100%;overflow:visible}table{width:100%;min-width:0;table-layout:fixed;border-collapse:collapse;font-size:10px}th,td{padding:5px;overflow-wrap:anywhere;word-break:break-word}td small{display:block;overflow-wrap:anywhere}.print-only{font-size:12px}.document-print-area{width:100%;max-width:186mm;margin:0 auto;page-break-after:avoid}.print-table{font-size:11px}.print-table th,.print-table td{padding:6px}.print-meta{grid-template-columns:repeat(2,minmax(0,1fr))}.receipt-print{text-align:left}.receipt-print h1,.receipt-amount{text-align:center}.receipt-head,.receipt-footer{break-inside:avoid}}
