:root{color-scheme:light;font-family:Inter,Microsoft YaHei,PingFang SC,Arial,sans-serif;--bg: #f6f7f9;--surface: #ffffff;--surface-2: #eef3f6;--ink: #1c2730;--muted: #62707c;--line: #d9e0e6;--brand: #0f766e;--brand-2: #2563eb;--warn: #b45309;--danger: #b91c1c;--ok: #15803d;--radius: 8px}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink)}button,input,select,textarea{font:inherit}button{border:0}.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:#eef3f6}.login-card{width:min(420px,100%);display:grid;gap:14px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:24px;box-shadow:0 18px 60px #0f172a1f}.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:4px}.login-brand h1{margin:0;font-size:19px}.login-brand p{margin:4px 0 0;color:var(--muted);font-size:13px}.login-button{width:100%}.login-error{border:1px solid #fecaca;border-radius:6px;background:#fef2f2;color:var(--danger);padding:9px 10px;font-size:13px}.password-error{margin-top:12px}.rotate-90{transform:rotate(90deg)}.login-server{border:1px solid #fed7aa;border-radius:6px;background:#fff7ed;color:#9a3412;padding:8px 10px;font-size:12px}.login-server.connected{border-color:#bbf7d0;background:#f0fdf4;color:#166534}.login-hint,.login-users{display:flex;flex-wrap:wrap;gap:8px;color:var(--muted);font-size:12px}.login-hint strong{color:var(--ink)}.login-users span{border:1px solid var(--line);border-radius:999px;padding:4px 8px;background:#fbfcfd}.app{display:grid;grid-template-columns:260px minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;background:#18232e;color:#f8fafc;display:flex;flex-direction:column;padding:18px 14px}.brand{display:flex;gap:12px;align-items:center;padding:8px 10px 18px;border-bottom:1px solid rgba(255,255,255,.12)}.brand-mark{width:38px;height:38px;border-radius:8px;background:#f59e0b;color:#18232e;display:grid;place-items:center;font-weight:800}.brand strong{display:block;font-size:15px}.brand span{display:block;color:#b9c4cf;font-size:12px;margin-top:2px}.nav{overflow-y:auto;padding-top:14px}.nav button{width:100%;min-height:38px;display:flex;align-items:center;gap:10px;color:#cfdae5;background:transparent;border-radius:6px;padding:9px 10px;cursor:pointer;text-align:left}.nav button:hover,.nav button.active{background:#ffffff1a;color:#fff}.nav svg,.btn svg,.icon-button svg{flex:0 0 auto}.main{min-width:0;display:flex;flex-direction:column}.topbar{height:66px;background:var(--surface);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:4}.topbar h1{display:flex;align-items:center;gap:8px;font-size:19px;margin:0}.topbar p{margin:3px 0 0;color:var(--muted);font-size:13px}.topbar-actions{display:flex;align-items:center;gap:8px}.content{padding:22px 24px 36px}.section{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin-bottom:18px}.section-header,.row-between{display:flex;align-items:center;justify-content:space-between;gap:12px}.section-header{margin-bottom:14px}.section-header h2{font-size:17px;margin:0}.section-header p{margin:4px 0 0;color:var(--muted);font-size:13px}.grid{display:grid;gap:14px}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}.metric{border:1px solid var(--line);border-radius:var(--radius);background:#fbfcfd;padding:14px;min-height:104px;text-align:left;color:inherit}.metric.clickable{width:100%;cursor:pointer;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}.metric.clickable:hover,.metric.active{border-color:var(--brand);background:#f4fbf8;box-shadow:0 0 0 3px #0f766e1a}.metric .label{color:var(--muted);font-size:13px;display:flex;align-items:center;gap:7px}.metric strong{display:block;margin-top:10px;font-size:27px}.metric span{display:block;margin-top:7px;color:var(--muted);font-size:12px}.pipeline{display:grid;grid-template-columns:repeat(5,minmax(150px,1fr));gap:10px;overflow-x:auto;padding-bottom:2px}.stage{min-height:190px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:10px}.stage h3{margin:0 0 10px;font-size:13px;color:#334155}.mini-card,.record-card{width:100%;display:block;text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:7px;padding:10px;margin-bottom:8px}.mini-card strong,.record-card strong{display:block;font-size:13px}.mini-card.readonly{cursor:default}.mini-card span,.record-card span{color:var(--muted);font-size:12px}.toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.account-switcher{min-width:190px}.account-pill{min-height:38px;display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);border-radius:6px;background:#fbfcfd;padding:7px 10px;white-space:nowrap}.account-pill span{font-weight:700}.account-pill small{color:var(--muted)}.btn,.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:36px;border-radius:6px;padding:8px 12px;cursor:pointer;background:#e8eef3;color:#23313d}.btn.primary{background:var(--brand);color:#fff}.btn.blue{background:var(--brand-2);color:#fff}.btn.warn{background:#f59e0b;color:#211200}.btn.danger{background:var(--danger);color:#fff}.btn.ghost{background:transparent;border:1px solid var(--line)}.icon-button{width:36px;padding:0}.btn:disabled,.icon-button:disabled{background:#d6dee6;border-color:#d6dee6;color:#71808e;opacity:1;cursor:not-allowed}.badge{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:4px 9px;background:#e8eef3;color:#334155;font-size:12px;white-space:nowrap}.badge.ok{background:#dcfce7;color:var(--ok)}.badge.warn{background:#ffedd5;color:var(--warn)}.badge.danger{background:#fee2e2;color:var(--danger)}.badge.blue{background:#dbeafe;color:var(--brand-2)}table{width:100%;border-collapse:collapse}th,td{border-bottom:1px solid var(--line);padding:11px 9px;text-align:left;vertical-align:top;font-size:13px}th{color:var(--muted);font-weight:600;background:#fbfcfd}tr.clickable{cursor:pointer}tr.clickable:hover td{background:#f8fafc}.compact-cell{max-width:180px}.clamp-text{display:grid;gap:4px}.clamp-text span{display:-webkit-box;-webkit-line-clamp:var(--clamp-lines, 2);-webkit-box-orient:vertical;overflow:hidden;word-break:break-word;color:inherit;font-size:inherit;line-height:1.35}.clamp-text.expanded span{display:block;-webkit-line-clamp:unset;overflow:visible}.clamp-text button{justify-self:start;padding:0;background:transparent;color:var(--brand-2);font-size:12px}.split{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(360px,.9fr);gap:18px;align-items:start}.detail{position:sticky;top:88px}.detail-title{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:12px}.detail-title h3{margin:0;font-size:18px}.detail-title p{margin:5px 0 0;color:var(--muted);font-size:13px}.timeline{display:grid;gap:8px}.timeline-step{display:grid;grid-template-columns:24px 1fr;gap:9px;align-items:center;color:var(--muted);font-size:13px}.dot{width:18px;height:18px;border-radius:999px;border:2px solid #b8c3cc;display:grid;place-items:center;background:#fff}.timeline-step.done{color:var(--ink)}.timeline-step.done .dot{background:var(--brand);border-color:var(--brand);color:#fff}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.form-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.permission-add-form{border:1px solid var(--line);border-radius:var(--radius);background:#fbfcfd;padding:14px;margin-bottom:14px}.permission-list{display:grid;gap:12px}.permission-card{border:1px solid var(--line);border-radius:var(--radius);background:#fff;padding:14px}.permission-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.permission-card-head strong,.permission-card-head span{display:block}.permission-card-head span{margin-top:3px;color:var(--muted);font-size:12px}.permission-actions{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin:10px 0}.permission-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.permission-option{min-height:38px;display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:6px;background:#fbfcfd;padding:8px;font-size:13px}.permission-option input{width:15px;height:15px;flex:0 0 auto}.permission-option svg{color:var(--muted);flex:0 0 auto}.permission-option span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.customer-panel{border:1px solid var(--line);border-radius:var(--radius);background:#fbfcfd;padding:14px;margin-bottom:14px}.device-batch-panel{border:1px solid var(--line);border-radius:var(--radius);background:#fff;padding:14px}.device-form-list{display:grid;gap:12px}.device-form-card{border:1px solid var(--line);border-radius:7px;background:#fbfcfd;padding:12px}.device-form-card .row-between{margin-bottom:10px}.customer-picker{display:grid;gap:12px}.customer-results{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.customer-option{display:grid;gap:4px;min-height:62px;text-align:left;border:1px solid var(--line);border-radius:7px;background:#fff;padding:10px;cursor:pointer}.customer-option.active{border-color:var(--brand);background:#ecfdf5}.customer-option strong{font-size:13px}.customer-option span,.customer-summary span{color:var(--muted);font-size:12px}.customer-summary{display:grid;gap:4px;border-left:3px solid var(--brand);padding:8px 10px;background:#fff;border-radius:6px}.lookup-panel{display:grid;gap:12px;border:1px solid var(--line);border-radius:var(--radius);background:#fbfcfd;padding:14px;margin-bottom:14px}.device-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.device-summary div{border:1px solid var(--line);border-radius:7px;background:#fff;padding:10px;min-height:66px}.device-summary .summary-wide{grid-column:1 / -1;min-height:auto}.device-summary .important-summary{border-color:#facc15;background:#fefce8}.device-summary span{display:block;color:var(--muted);font-size:12px;margin-bottom:5px}.device-summary strong{display:block;font-size:13px;overflow-wrap:anywhere}.quote-overview{margin-bottom:10px}.query-summary{margin-top:10px}.query-result-head{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--line);border-radius:var(--radius);background:#fbfcfd;padding:10px 12px;margin-bottom:10px}.query-detail-row td{background:#f8fafc;padding:12px}.query-detail-panel{display:grid;gap:12px}.query-detail-card{border:1px solid var(--line);border-radius:7px;background:#fff;padding:12px}.field{display:grid;gap:6px}.field.full{grid-column:1 / -1}.field label{font-size:12px;color:var(--muted);font-weight:600}.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);border-radius:6px;padding:9px 10px;min-height:38px;background:#fff;color:var(--ink)}.field textarea{resize:vertical;min-height:76px}.check-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.check-grid label{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:6px;padding:8px;font-size:13px;background:#fbfcfd}.risk-grid{align-items:start}.risk-card{display:grid;gap:8px;border:1px solid var(--line);border-radius:6px;background:#fbfcfd;padding:10px}.risk-card.active{border-color:var(--brand);background:#f0fdfa}.risk-card .risk-check{border:0;background:transparent;padding:0}.hidden-file{display:none}.photo-grid{display:flex;flex-wrap:wrap;gap:8px}.risk-photo{position:relative;width:86px;height:64px;display:block;overflow:hidden;border:1px solid var(--line);border-radius:6px;background:#fff}.risk-photo img{width:100%;height:100%;display:block;object-fit:cover}.risk-photo .icon-button{position:absolute;top:4px;right:4px;width:24px;height:24px;background:#ffffffeb}.risk-summary-list{display:grid;gap:8px;margin-top:10px}.risk-summary-item{display:grid;gap:7px;border:1px solid var(--line);border-radius:6px;background:#fbfcfd;padding:8px}.photo-grid.compact .risk-photo{width:72px;height:54px}.risk-note-box{display:grid;gap:10px;margin-top:12px}.note-strip{display:grid;gap:4px;border-left:3px solid var(--warn);border-radius:6px;background:#fff7ed;padding:8px 10px;margin-top:10px}.note-strip strong{color:#7c2d12;font-size:12px}.note-strip span{color:#431407;font-size:13px;overflow-wrap:anywhere}.note-strip.danger{border-left-color:var(--danger);background:#fef2f2}.note-strip.danger strong{color:#7f1d1d}.note-strip.danger span{color:#450a0a}.note-strip.reception-note{border-left-color:#f59e0b;background:#fffbeb}.note-strip.reception-note strong{color:#92400e}.note-strip.reception-note span{color:#451a03}.quote-list{display:grid;gap:8px;margin-top:10px}.quote-line{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;border:1px solid var(--line);border-radius:6px;background:#fbfcfd;padding:9px 10px}.quote-line span{color:var(--ink);font-size:13px;overflow-wrap:anywhere}.quote-line strong{font-size:13px;white-space:nowrap}.quote-line.empty-line{border-style:dashed;background:#fff}.inline-list{display:flex;flex-wrap:wrap;gap:7px}.warranty-record-list{display:grid;gap:10px}.warranty-record-card{margin-bottom:0}.warranty-record-card p{margin:6px 0 10px;font-size:13px;overflow-wrap:anywhere}.warranty-record-grid,.warranty-text-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:10px}.warranty-record-grid>div,.warranty-text-grid>div{min-width:0;border:1px solid var(--line);border-radius:7px;background:#fbfcfd;padding:8px}.warranty-record-grid span,.warranty-text-grid span{display:block;color:var(--muted);font-size:12px;margin-bottom:4px}.warranty-record-grid strong{display:block;font-size:13px;overflow-wrap:anywhere}.warranty-record-grid em{display:block;margin-top:4px;color:var(--muted);font-size:12px;font-style:normal;overflow-wrap:anywhere}.warranty-card-actions{margin-top:10px}.pickup-edit-panel{border:1px solid var(--line);border-radius:7px;background:#fbfcfd;margin-top:12px;padding:12px}.pickup-edit-panel .section-header{margin-bottom:10px}.pickup-edit-list{display:grid;gap:8px;margin-top:10px}.pickup-edit-list>strong{font-size:13px}.pickup-edit-row{display:grid;grid-template-columns:minmax(0,1fr) 140px;gap:10px;align-items:center;border:1px solid var(--line);border-radius:7px;background:#fff;padding:9px}.pickup-edit-row span{display:block;margin-top:4px;color:var(--muted);font-size:12px}.invoice-item-card{border:1px solid var(--line);border-radius:7px;background:#fbfcfd;padding:10px;margin-bottom:10px}.invoice-item-card .note-strip{margin-top:10px}.batch-device-list{display:grid;gap:7px;margin-top:10px}.batch-device{display:grid;grid-template-columns:62px 1fr;gap:10px;align-items:center;border:1px solid var(--line);border-radius:6px;background:#fbfcfd;padding:8px 10px}.batch-device strong{font-size:13px}.batch-device span{color:var(--muted);font-size:12px}.log-list{display:grid;gap:8px}.log-item{border:1px solid var(--line);border-radius:7px;background:#fbfcfd;padding:10px}.log-item strong{font-size:13px}.log-item p{margin:6px 0;color:var(--ink);font-size:13px}.log-item span{color:var(--muted);font-size:12px}.query-log-list{margin-top:10px;max-height:280px;overflow:auto}.amount{font-variant-numeric:tabular-nums;white-space:nowrap}.positive{color:var(--ok)}.negative{color:var(--danger)}.muted{color:var(--muted)}.empty{color:var(--muted);border:1px dashed var(--line);border-radius:var(--radius);padding:20px;text-align:center;background:#fbfcfd}.tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.tabs button{border-radius:999px;padding:7px 12px;background:#e8eef3;color:#334155;cursor:pointer}.tabs button.active{background:var(--brand);color:#fff}.bar-list{display:grid;gap:10px}.bar-row{display:grid;grid-template-columns:130px 1fr 90px;align-items:center;gap:10px;font-size:13px}.bar-track{height:12px;background:#e2e8f0;border-radius:999px;overflow:hidden}.bar-fill{height:100%;background:var(--brand-2)}.modal-backdrop{position:fixed;inset:0;background:#0f172a59;display:grid;place-items:center;z-index:20;padding:18px}.modal{width:min(820px,100%);max-height:min(90vh,860px);overflow:auto;background:var(--surface);border-radius:var(--radius);border:1px solid var(--line);box-shadow:0 22px 80px #0f172a47}.modal-head,.modal-foot{padding:16px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:12px}.modal-foot{border-bottom:0;border-top:1px solid var(--line);justify-content:flex-end}.modal-head h2{margin:0;font-size:17px}.modal-head p{margin:4px 0 0;color:var(--muted);font-size:13px}.modal-body{padding:18px}.reject-modal{width:min(520px,100%)}.print-area{background:#fff}@media(max-width:1100px){.app{grid-template-columns:76px minmax(0,1fr)}.brand div:not(.brand-mark),.nav span{display:none}.sidebar{padding:14px 10px}.brand{padding:8px 4px 15px;justify-content:center}.nav button{justify-content:center}.split{grid-template-columns:1fr}.detail{position:static}.grid.four{grid-template-columns:repeat(2,minmax(0,1fr))}.permission-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:760px){.app{display:block}.sidebar{position:static;height:auto}.brand div:not(.brand-mark),.nav span{display:block}.nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.nav button{justify-content:flex-start}.topbar{height:auto;align-items:flex-start;padding:14px;gap:12px;flex-direction:column}.content{padding:14px}.topbar-actions{width:100%;flex-wrap:wrap}.grid.two,.grid.three,.grid.four,.form-grid,.form-grid.three,.permission-grid,.customer-results,.device-summary,.check-grid,.warranty-record-grid,.warranty-text-grid{grid-template-columns:1fr}.section-header,.row-between,.detail-title{align-items:flex-start;flex-direction:column}.bar-row,.pickup-edit-row{grid-template-columns:1fr}table{min-width:720px}.table-scroll{overflow-x:auto}}@media print{body{background:#fff}.sidebar,.topbar,.no-print,.btn,.icon-button{display:none!important}.app,.main{display:block}.content{padding:0}.section{border:0;padding:0}}
