body{background:#f0f2f5;margin:0;padding-bottom:100px;font-family:Microsoft YaHei,PingFang SC,Helvetica Neue,Arial,sans-serif}body,html{overflow-x:hidden}[v-cloak]{display:none}.modal-mask{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:2000}.modal-box{width:90%;max-width:500px;background:#fff;padding:20px;border-radius:10px;box-shadow:0 4px 15px rgba(0,0,0,.2)}.modal-box textarea{width:100%;height:120px;padding:10px;box-sizing:border-box;border:1px solid #ccc;border-radius:0;font-size:14px;resize:none}.modal-suggest-list{margin-top:8px;border:1px solid #ddd;background:#fff;max-height:140px;overflow-y:auto}.modal-suggest-item{padding:6px 8px;font-size:13px;color:#333;cursor:pointer}.modal-suggest-item:hover{background:#f5f7fa}.sheet-mask{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.45);z-index:2100;display:flex;align-items:flex-end;justify-content:center}.sheet-mask.option-picker-mask{z-index:2600}.sheet-panel{width:100%;max-width:640px;background:#fff;border-radius:12px 12px 0 0;padding:12px 16px 10px;max-height:70vh;display:flex;flex-direction:column;gap:10px}.sheet-handle{width:40px;height:4px;background:#e0e0e0;border-radius:2px;margin:0 auto}.sheet-header .form-input{height:36px}.sheet-list{overflow-y:auto;flex:1;border-top:1px solid #f0f0f0}.sheet-item{padding:10px 2px;border-bottom:1px solid #f2f2f2;font-size:14px;color:#333}.sheet-item.option-item{display:flex;align-items:center;gap:8px}.sheet-item-text{flex:1;min-width:0;word-break:break-all}.sheet-item-delete{border:none;background:transparent;color:#999;font-size:16px;line-height:1;padding:2px 6px}.sheet-item:active{background:#f5f7fa}.sheet-empty{padding:16px 0;text-align:center;color:#999;font-size:13px}.sheet-actions{display:flex;gap:10px}.sheet-btn{flex:1;height:36px;border:1px solid #ddd;background:#fff;border-radius:0;font-size:14px}.sheet-btn.primary{background:#007aff;color:#fff;border-color:#007aff}.export-mask{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.45);justify-content:center;z-index:3000}.export-box,.export-mask{display:flex;align-items:center}.export-box{flex-direction:column;gap:12px;color:#fff;font-size:14px}.export-preview-mask{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.88);display:flex;align-items:center;justify-content:center;z-index:3000;padding:0;box-sizing:border-box}.export-preview-box{width:100%;max-width:none;height:100%;background:#111;border-radius:0;overflow:hidden;color:#fff;display:flex;flex-direction:column}.export-preview-body{padding:8px;background:#000;display:flex;align-items:center;justify-content:center;min-height:240px;flex:1;overflow:auto;-webkit-overflow-scrolling:touch;touch-action:pan-x pan-y pinch-zoom}.export-preview-body img{max-width:100%;max-height:70vh;width:auto;height:auto;min-width:100px;min-height:100px;background:#fff;-o-object-fit:contain;object-fit:contain;flex-shrink:0;transition:transform .1s ease-out;transform-origin:center center;margin:auto}.export-preview-pdf{display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:12px;color:#fff;text-align:center;font-size:13px;line-height:1.5;width:100%;height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch;touch-action:pan-y}.export-preview-pdf-frame{width:100%;height:calc(100vh - 80px);border:none;border-radius:6px;background:#fff}.pdf-image-list{width:100%;flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;touch-action:pan-y;will-change:transform;padding-bottom:20px}.pdf-image-page{width:auto;max-width:100%;max-height:70vh;height:auto;min-width:100px;background:#fff;border-radius:4px;flex-shrink:0}.export-close-float{position:fixed;top:20px;right:20px;width:44px;height:44px;border-radius:50%;background:#fff;border:1px solid #000;color:#000;font-size:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:3010;transition:transform .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0}.export-close-float:active,.export-close-float:hover{transform:scale(1.1)}.export-close-icon{display:block;width:20px;height:20px;line-height:20px;font-size:24px;font-weight:600;text-align:center;color:#000}.pdf-page-tip{font-size:12px;color:#cfcfcf;padding:4px 0 10px}.export-preview-actions{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);z-index:3010}.export-action-btn{padding:12px 24px;background:hsla(0,0%,100%,.95);border:1px solid #000;border-radius:8px;color:#000;font-size:14px;font-weight:500;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.15);transition:all .2s}.export-action-btn:active{transform:scale(.95);background:hsla(0,0%,94%,.95)}.export-spinner{width:42px;height:42px;border:3px solid hsla(0,0%,100%,.4);border-top-color:#fff;border-radius:50%;animation:export-spin .9s linear infinite}@keyframes export-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.mobile-view{width:95%;margin:15px auto;background:#fff;padding:20px;box-sizing:border-box;box-shadow:0 4px 12px rgba(0,0,0,.08);border-radius:12px}.mobile-header{position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.mobile-title{font-weight:600;text-align:center}.back-btn,.mobile-title{font-size:20px;color:#333}.back-btn{position:absolute;left:0;width:34px;height:34px;border-radius:50%;border:1px solid #e5e7eb;background:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.readonly-mode .add-btn,.readonly-mode .checkbox-group,.readonly-mode .edit-btn,.readonly-mode .item-list button,.readonly-mode input,.readonly-mode select,.readonly-mode textarea{pointer-events:none}.readonly-mode .form-section{opacity:.8}.edit-btn{color:#007aff;cursor:pointer;padding:2px 6px;display:inline-block;min-width:30px;border-radius:4px;transition:all .2s}.edit-btn:hover{background-color:rgba(0,122,255,.1)}.edit-btn:empty:before{content:"点击填写";color:#999;font-size:12px}.clause-edit:hover{background:#f0f8ff;cursor:pointer;border-radius:4px}.form-section{margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid #f0f0f0}.form-section:last-child{border-bottom:none}.form-title{font-size:16px;font-weight:700;color:#333;margin-bottom:12px;display:flex;align-items:center}.form-title:before{content:"";display:inline-block;width:4px;height:16px;background:#007aff;margin-right:8px;border-radius:2px}.form-row{display:flex;margin-bottom:10px;align-items:center}.query-panel{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;background:#f9fafc;border:1px solid #edf0f5;border-radius:10px;padding:12px;margin-bottom:12px}.query-field{display:flex;flex-direction:column;gap:6px}.query-label{font-size:12px;color:#666}.query-actions{display:flex;align-items:flex-end}.query-actions .primary{height:36px;padding:0 18px;border-radius:6px}.status-flow-tips{margin-top:8px;font-size:12px;color:#8c8c8c}.status-flow-list{margin-top:8px;max-height:120px;overflow:auto;border:1px solid #f0f0f0;border-radius:6px;background:#fafafa;padding:4px 8px}.status-flow-item{display:flex;justify-content:space-between;align-items:center;gap:8px;min-height:24px;font-size:12px;color:#595959;border-bottom:1px dashed #eee}.status-flow-item:last-child{border-bottom:none}.approval-chain{margin-top:10px;border:1px solid #f0f0f0;border-radius:6px;background:#fafafa;padding:8px}.approval-chain-title{font-size:11px;color:#666;margin-bottom:6px}.approval-chain-item{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:28px;border-bottom:1px dashed #eee}.approval-chain-item:last-child{border-bottom:none}.approval-chain-left{display:flex;align-items:center;gap:6px;min-width:0;white-space:nowrap}.approval-chain-node{font-size:11px;color:#999;white-space:nowrap}.approval-chain-node.passed{color:#52c41a}.approval-chain-time{font-size:11px;color:#8c8c8c;white-space:nowrap}.approval-chain-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.approval-chain-btn{border:1px solid #d9d9d9;border-radius:4px;background:#fff;color:#666;font-size:11px;height:24px;padding:0 8px;white-space:nowrap}.approval-chain-btn.passed{border-color:#52c41a;color:#52c41a}.form-label{width:80px;flex-shrink:0;color:#666;font-size:14px;text-align:right;padding-right:8px;box-sizing:border-box}.required-mark{color:#ff4d4f;margin-left:4px;font-weight:600}.tip-toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(0,0,0,.78);color:#fff;padding:10px 16px;border-radius:6px;font-size:14px;z-index:10000;max-width:80%;text-align:center;line-height:1.4}.form-content{flex:1;min-width:0;font-size:14px;color:#333}.checkbox-group{display:flex;gap:15px;flex-wrap:wrap}.checkbox-label{display:flex;align-items:center;gap:4px;cursor:pointer;font-size:14px}input[type=checkbox],input[type=radio]{width:16px;height:16px;accent-color:#007aff}.flex-row{display:flex;justify-content:space-between;font-size:14px;margin-bottom:10px}.table{width:100%;border-collapse:collapse;border:1.5px solid #000;margin:10px 0}.table tr{page-break-inside:avoid;-moz-column-break-inside:avoid;break-inside:avoid}.table td{border:1px solid #000;padding:8px;font-size:14px}.table .label{font-weight:700;width:90px;text-align:center}.a4-print-area{position:absolute;top:-10000px;left:-10000px;width:210mm;min-height:297mm;padding:0;background:#fff;color:#000;box-sizing:border-box}.a4-print-area,.a4-print-area *{box-shadow:none!important;text-shadow:none!important}.a4-page{width:794px;height:1123px;padding:22px;background:#fff;font-family:SimSun,STSong,serif}.a4-frame,.a4-page{position:relative;box-sizing:border-box}.a4-frame{width:100%;height:100%;padding:12px}.crop{position:absolute;width:26px;height:26px;pointer-events:none}.crop:after,.crop:before{content:"";position:absolute;background:#000}.crop.tl{top:6px;left:6px}.crop.tl:before{top:0;left:0;width:22px;height:1px}.crop.tl:after{top:0;left:0;width:1px;height:22px}.crop.tr{top:6px;right:6px}.crop.tr:before{top:0;right:0;width:22px;height:1px}.crop.tr:after{top:0;right:0;width:1px;height:22px}.crop.bl{bottom:6px;left:6px}.crop.bl:before{bottom:0;left:0;width:22px;height:1px}.crop.bl:after{bottom:0;left:0;width:1px;height:22px}.crop.br{bottom:6px;right:6px}.crop.br:before{bottom:0;right:0;width:22px;height:1px}.crop.br:after{bottom:0;right:0;width:1px;height:22px}.punch-dot{position:absolute;left:10px;width:4px;height:4px;border-radius:50%;background:#000;opacity:.75}.punch-dot.d1{top:520px}.punch-dot.d2{top:540px}.punch-dot.d3{top:560px}.a4-header{justify-content:space-between;margin-bottom:2px;gap:10px}.a4-header,.a4-logo{display:flex;align-items:center}.a4-logo{width:120px}.a4-title{text-align:center;font-size:26px;font-weight:500;margin:0;flex:1;font-family:Microsoft YaHei,sans-serif;line-height:1.1}.a4-contract-no{min-width:170px;text-align:right;justify-content:flex-end;gap:6px;white-space:nowrap}.a4-contract-no,.a4-line-row{font-size:14px;display:flex;align-items:baseline}.a4-line-row{gap:14px;margin:5px 0;line-height:1.3;page-break-inside:avoid;-moz-column-break-inside:avoid;break-inside:avoid}.a4-line-row .group{display:flex;align-items:baseline;gap:6px;flex:1;min-width:0}.field-line{display:inline-block;border-bottom:1px solid #000;min-height:18px;line-height:18px;padding:0 4px;box-sizing:border-box;white-space:normal;word-wrap:break-word;vertical-align:bottom}.field-inline{white-space:nowrap;width:auto;min-width:40px}.field-line.w-xl{width:300px}.field-line.w-lg{width:240px}.field-line.w-md{width:160px}.field-line.w-sm{width:100px}.field-line.w-xs{width:70px}.contract-table{width:100%;border-collapse:collapse;border:.5px solid #000;margin-top:12px}.contract-table tr{page-break-inside:avoid;-moz-column-break-inside:avoid;break-inside:avoid}.contract-table .field-line{border-bottom:none}.contract-table td{border:.5px solid #000;font-size:13px;padding:3px;vertical-align:middle;box-sizing:border-box;line-height:1.2}.contract-table td.label{width:90px;text-align:center;font-weight:500;letter-spacing:3px}.contract-table td.content{width:auto}.contract-table td.empty-center{text-align:center!important}.contract-table .row-flex{display:flex;align-items:baseline;justify-content:space-between;gap:10px}.contract-table .row-flex .left{flex:1;min-width:0}.contract-table .row-flex .right{display:flex;align-items:baseline;gap:6px;white-space:nowrap}.contract-table .note{font-size:13px;text-align:center;letter-spacing:.2px}.contract-table .other{height:48px;vertical-align:top;padding-top:6px}.amount-row{font-size:14px;padding:0 10px}.amount-dx{display:inline-block;margin:0 10px;letter-spacing:2px;white-space:nowrap}.clauses{margin-top:6px;font-size:13px;line-height:1.6;text-align:justify;page-break-inside:avoid;-moz-column-break-inside:avoid;break-inside:avoid}.clauses ol{margin:0;padding-left:20px}.clauses li{margin:5px 0;padding:0;line-height:1.6;page-break-inside:avoid;-moz-column-break-inside:avoid;break-inside:avoid}.remind{margin-top:10px;padding-top:8px;border-top:1px solid #000;font-size:13px;line-height:1.5}.sign-row{display:flex;justify-content:space-between;gap:40px;margin-top:16px;font-size:14px;page-break-inside:avoid;-moz-column-break-inside:avoid;break-inside:avoid}.sign-col{flex:1}.sign-col .line{display:inline-block;width:220px;height:18px;vertical-align:baseline}.sign-col .block{margin-top:6px}.bottom-bar{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:95%;max-width:640px;background:#fff;padding:12px;text-align:center;border-top:1px solid #ddd;z-index:1000;box-sizing:border-box;border-radius:12px 12px 0 0;box-shadow:0 -4px 12px rgba(0,0,0,.08)}.bottom-actions{display:flex;gap:8px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.action-btn{flex:1;min-width:80px;height:38px;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;padding:0 8px;line-height:1.1}.bottom-actions.purchase-actions .action-btn{font-size:11px;min-width:70px}.action-btn.primary{background:#007aff;color:#fff}.action-btn.secondary{background:#fff;color:#007aff;border:1px solid #007aff}.item-list{display:flex;flex-direction:column;gap:6px}.item-head,.item-row{display:flex;gap:10px;align-items:flex-start}.item-row{align-items:stretch}.item-row.purchase-status-pending{border-left:3px solid #faad14;padding-left:6px}.item-row.purchase-status-done{border-left:3px solid #52c41a;padding-left:6px}.item-name{width:120rpx;width:64px;flex:0 0 120rpx;flex:0 0 64px;color:#333;font-size:14px;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:6px;flex-wrap:nowrap;padding-top:0}.item-name-title{width:100%;min-height:34px;display:flex;align-items:center;text-align:left}.item-name-custom{align-items:flex-start;gap:6px;padding-top:0}.item-purchase-status-wrap{margin-top:0}.item-profit-line{min-height:24px;display:flex;align-items:center;font-size:12px;color:#666}.item-profit-line.pending{color:#faad14}.item-detail{flex:1.2;min-width:0;display:flex;flex-direction:column;gap:6px}.item-meta{display:grid;grid-template-columns:56px minmax(0,1.1fr) minmax(0,1.1fr) minmax(0,1.4fr);gap:4px;align-items:center;flex:1;min-width:0}.item-meta input{width:100%}.item-meta>*{min-width:0}.item-meta .item-input-price,.item-meta .item-input-qty,.item-meta .item-input-subtotal,.item-meta .item-input-unit{max-width:none;width:100%}.item-meta.h{grid-template-columns:56px minmax(0,1.1fr) minmax(0,1.1fr) minmax(0,1.4fr)}.item-meta.h>div{width:auto!important;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.purchase-inline-meta{border:1px dashed #d9d9d9;border-radius:4px;padding:4px;display:flex;flex-direction:column;gap:4px}.purchase-inline-row{display:flex;gap:4px;align-items:center;min-width:0}.purchase-inline-label{color:#666;font-size:12px;white-space:nowrap}.purchase-inline-input,.purchase-inline-input-flex{height:28px;padding:0 6px;min-width:0;flex:1}.purchase-inline-date{width:100%}.item-list .h{font-weight:600;color:#666;font-size:12px}.item-list input{height:32px;box-sizing:border-box;border:1px solid #ddd;border-radius:0;padding:0 8px;font-size:14px;background:#fff;transition:border-color .15s ease,box-shadow .15s ease}.item-list input:focus{border-color:#007aff;box-shadow:0 0 0 2px rgba(0,122,255,.15);outline:none}.contract-list .item-name{width:120px;flex:0 0 120px}.contract-list .item-meta,.contract-list .item-meta.h{grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr) minmax(0,1fr) minmax(0,1fr) 90px 140px}.contract-list .item-meta .call-btn,.contract-list .item-meta button.primary{display:inline-flex;align-items:center;justify-content:center;height:28px;padding:0 10px;border-radius:6px;border:1px solid #007aff;background:#fff;color:#007aff;font-size:12px;cursor:pointer;text-decoration:none;margin-right:6px}.contract-list .item-meta button.primary{background:#007aff;color:#fff;border:none}.order-list{display:flex;flex-direction:column;gap:12px;padding:4px 0}.order-empty{text-align:center;color:#999;font-size:14px;padding:16px 0}.order-card{background:#fff;border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,.06);padding:12px;display:flex;flex-direction:column;gap:8px}.order-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.order-title{font-size:15px;font-weight:600;color:#222;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.order-amount{font-size:18px;font-weight:700;color:#ff5722}.order-sub{align-items:center;justify-content:space-between;font-size:12px;color:#666}.order-actions,.order-sub{display:flex;gap:8px}.order-btn{flex:1;height:34px;border-radius:8px;border:1px solid #e5e7eb;background:#f8fafc;color:#111;font-size:13px;cursor:pointer;text-align:center;display:inline-flex;align-items:center;justify-content:center;text-decoration:none}.order-btn.primary{background:#007aff;color:#fff;border:none}.status-badge{display:inline-flex;align-items:center;justify-content:center;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:500;background:#eef5ff;color:#1a73e8}.status-badge.status-0{background:#fff3d6;color:#f59e0b}.status-badge.status-1{background:#e8f7ff;color:#0284c7}.status-badge.status-2{background:#eef2ff;color:#4f46e5}.status-badge.status-3{background:#f3e8ff;color:#7c3aed}.status-badge.status-4,.status-badge.status-5{background:#e8f7ee;color:#16a34a}.status-badge.status-6{background:#dcfce7;color:#15803d}.status-badge.status-7{background:#ffedd5;color:#ea580c}.status-badge.status-cancel,.status-badge.status-invalid{background:#fee2e2;color:#dc2626}.status-badge.status-unknown{background:#f2f2f2;color:#999}.floating-add{position:fixed;right:18px;bottom:110px;width:52px;height:52px;border-radius:50%;border:none;background:#007aff;color:#fff;font-size:28px;line-height:52px;text-align:center;box-shadow:0 10px 20px rgba(0,122,255,.35);cursor:pointer;z-index:1200}.detail-line{display:grid;align-items:center;gap:6px;width:100%}.detail-label{color:#666;font-size:12px;white-space:nowrap}.detail-line.model-line{grid-template-columns:28px 1fr}.detail-line.color-line{grid-template-columns:40px 32px 1fr 32px 1fr}.detail-line.open-line,.detail-line.sash-detail-line{grid-template-columns:60px 1fr}.detail-line.sash-detail-line{margin-top:4px}.detail-line input{width:100%}.sash-detail-trigger{height:28px;padding:0 10px;border:1px solid #007aff;border-radius:4px;background:#fff;color:#007aff;font-size:12px;cursor:pointer;text-align:left}.sash-detail-trigger.status-pending{border-color:#faad14;background:#fff7e6;color:#d48806}.sash-detail-trigger.status-done{border-color:#52c41a;background:#f6ffed;color:#389e0d}.purchase-item-trigger{display:inline-flex;align-items:center;justify-content:center;height:24px;padding:0 6px;border:1px solid #0aa06e;border-radius:4px;background:#fff;color:#0aa06e;font-size:11px;cursor:pointer;text-align:center;box-sizing:border-box}.purchase-item-trigger.status-pending{border-color:#faad14;background:#fff7e6;color:#d48806}.purchase-item-trigger.status-done{border-color:#52c41a;background:#f6ffed;color:#389e0d}.purchase-item-status-readonly{cursor:default;pointer-events:none}.sash-detail-card{border:1px solid #e5e7eb;border-radius:6px;padding:10px;margin-bottom:10px;background:#fff}.sash-detail-position-card{border-color:#91caff;background:#f8fbff}.sash-detail-inner-card{border-color:#d9d9d9;background:#fff;display:flex;flex-wrap:wrap;gap:8px 10px}.sash-detail-inner-card>.form-row{width:100%;margin-bottom:0}.sash-detail-inner-card>.form-row.sash-compact-row{width:calc(50% - 5px)}.sash-inline-split{display:flex;gap:8px;align-items:center;width:100%}.sash-inline-split .form-input{flex:1;min-width:0}.sash-inline-mini-label{color:#666;font-size:13px;flex:0 0 auto}.sash-detail-summary{margin:6px 2px 10px;font-size:12px;color:#1f2937;line-height:1.6}.sash-setting-tags{display:flex;gap:8px;flex-wrap:wrap;width:100%}.sash-setting-tag{height:30px;padding:0 10px;border-radius:16px;border:1px solid #b7d7ff;background:#eef6ff;color:#1d4f91;font-size:12px;cursor:pointer}.sash-setting-tag.value{border-color:#d9d9d9;background:#fafafa;color:#555}.suggest-wrap{position:relative;display:inline-flex;align-items:center}.suggest-wrap.full{display:flex;flex:1;width:100%}.suggest-wrap.full input{flex:1;width:100%}.suggest-list{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 6px 16px rgba(0,0,0,.12);max-height:160px;overflow-y:auto;z-index:10;margin-top:4px}.suggest-item{padding:6px 8px;font-size:12px;color:#333;cursor:pointer;white-space:nowrap}.suggest-item:hover{background:#f0f8ff}.item-input-xs{width:70px}.item-input-sm{width:94px}.item-input-md{width:128px}.item-input-flex{width:100%;max-width:100%}.item-input-unit{max-width:58px;min-width:58px;width:58px}.item-input-price,.item-input-qty{max-width:64px}.item-input-subtotal{max-width:120px}.item-divider{height:1px;background:#eee;margin:4px 0 2px}.add-btn{margin-top:10px;height:32px;padding:0 12px;border:1px dashed #007aff;color:#007aff;border-radius:6px;font-size:13px}.add-btn,.remove-btn{background:#fff;cursor:pointer}.remove-btn{height:28px;padding:0 8px;border:1px solid #ff4d4f;color:#ff4d4f;border-radius:6px;font-size:12px;flex:0 0 auto}.item-attachments{display:flex;flex-wrap:wrap;gap:6px 8px;margin-top:4px;align-items:center}.item-purchase-panel{margin-top:4px;display:flex;flex-direction:column;align-items:flex-start;gap:4px}.item-purchase-row{display:flex;align-items:center;min-height:24px}.item-purchase-panel .attachment-upload-btn,.item-purchase-panel .purchase-item-trigger{width:64px;height:24px;justify-content:center;text-align:center;padding:0 2px;box-sizing:border-box}.item-purchase-profit{font-size:11px;color:#666}.item-purchase-profit.pending{color:#faad14}.item-name .attachment-upload-btn,.item-name .purchase-item-trigger,.item-name .sash-detail-trigger{width:64px;height:24px;justify-content:center;text-align:center;padding:0 2px;box-sizing:border-box}.attachment-upload-btn{position:relative;display:inline-flex;align-items:center;height:24px;padding:0 6px;border:1px solid #007aff;border-radius:4px;color:#007aff;background:#fff;font-size:11px;cursor:pointer;white-space:nowrap}.attachment-upload-btn input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.attachment-file-tag{display:inline-flex;align-items:center;max-width:320px;border-radius:4px;background:#f0f8ff;color:#1f4f8f;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attachment-file-tag,.attachment-remove-btn{height:26px;padding:0 8px;font-size:12px;cursor:pointer}.attachment-remove-btn{border:1px solid #ff4d4f;border-radius:4px;background:#fff;color:#ff4d4f}.attachment-file-group{display:inline-flex;align-items:center;gap:4px;max-width:100%}.attachment-count-btn{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border-radius:11px;background:#f0f8ff;color:#007aff;font-size:12px;cursor:pointer;white-space:nowrap}.attachment-sheet-toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:10px}.material-quote-form{border:1px solid #eef3fb;background:#f9fbff;border-radius:8px;padding:10px;margin-bottom:10px}.material-quote-form .form-row:last-child{margin-bottom:0}.material-quote-form .form-label{width:96px}.attachment-sheet-body{flex:1;min-height:0;overflow-y:auto;padding-bottom:4px}.attachment-sheet-panel .sheet-actions{position:sticky;bottom:0;background:#fff;padding-top:6px;border-top:1px solid #f0f0f0}.purchase-item-confirm-panel .form-row{display:flex;align-items:center;padding:2px 10px;margin-bottom:4px;border-bottom:none}.purchase-item-confirm-panel .form-label{width:86px;font-size:13px;color:#333;flex-shrink:0;text-align:right;padding-right:6px;box-sizing:border-box}.purchase-item-confirm-panel .form-label .required{color:#ff4d4f;margin-left:2px}.purchase-item-confirm-panel .form-content{flex:1;min-width:0}.purchase-item-confirm-panel .form-input{width:100%;height:34px;padding:0 8px;border:1px solid #d9d9d9;border-radius:4px;font-size:13px;box-sizing:border-box;min-width:0}.purchase-item-confirm-panel .form-input:focus{border-color:#007aff;outline:none}.purchase-item-confirm-panel .attachment-buttons{display:flex;gap:10px;flex-wrap:wrap}.purchase-item-confirm-panel .attachment-buttons .attachment-upload-btn{flex:1 1 96px;min-width:96px;justify-content:center;padding:0 6px}.attachment-sheet-type-list{margin-bottom:10px;border:1px solid #eef1f5;border-radius:8px;overflow:hidden;background:#fff}.attachment-sheet-type-item{padding:10px 12px;border-bottom:1px solid #eef1f5;cursor:pointer}.attachment-sheet-type-item:last-child{border-bottom:none}.attachment-sheet-type-main{font-size:14px;color:#333}.attachment-sheet-type-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.attachment-sheet-type-toggle{font-size:12px;color:#888}.attachment-sheet-type-content{margin-top:8px;padding-top:8px;border-top:1px dashed #eef1f5}.attachment-sheet-type-extra{margin-top:4px;font-size:12px;color:#888;line-height:1.5}.attachment-sheet-preview{margin-bottom:10px}.attachment-sheet-preview-actions{margin-top:8px;display:flex;justify-content:flex-end}.attachment-sheet-preview-image{width:100%;max-height:34vh;-o-object-fit:contain;object-fit:contain;border:1px solid #eee;border-radius:6px;background:#fafafa;cursor:zoom-in}.attachment-sheet-preview-pdf{width:100%;height:34vh;border:1px solid #eee;border-radius:6px;background:#fff}.attachment-sheet-preview-pdf-list{width:100%;max-height:34vh;overflow:auto;border:1px solid #eee;border-radius:6px;background:#fafafa;padding:4px;box-sizing:border-box;display:flex;flex-direction:column;gap:6px;-webkit-overflow-scrolling:touch}.attachment-sheet-preview-pdf-page{width:100%;background:#fff;border-radius:4px}.attachment-sheet-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;max-height:32vh;overflow:auto}.attachment-sheet-item{position:relative;border:1px solid #e5e5e5;border-radius:6px;padding:4px;background:#fff;cursor:pointer}.attachment-sheet-item.active{border-color:#007aff;box-shadow:0 0 0 1px rgba(0,122,255,.2)}.attachment-sheet-item-image{width:100%;aspect-ratio:1/1;-o-object-fit:cover;object-fit:cover;border-radius:4px;display:block;background:#f5f5f5}.attachment-file-square{width:100%;aspect-ratio:1/1;border-radius:4px;background:#f7f7f7;border:1px dashed #ccc;display:flex;align-items:center;justify-content:center;text-align:center;padding:8px;font-size:12px;color:#333;word-break:break-all;box-sizing:border-box}.attachment-sheet-item-actions{position:absolute;right:6px;bottom:6px}.attachment-mini-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;height:24px;padding:0 8px;border-radius:4px;background:rgba(0,0,0,.58);color:#fff;font-size:12px;cursor:pointer;overflow:hidden;white-space:nowrap}.attachment-mini-btn input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.purchase-drawing-frame{display:flex;flex-direction:column;gap:12px;padding-top:18px}.purchase-drawing-title{font-size:22px;font-weight:700;line-height:1.4;word-break:break-all}.purchase-drawing-image-wrap{flex:1;min-height:0;border:1px solid #000;display:flex;align-items:center;justify-content:center;padding:8px;box-sizing:border-box}.purchase-drawing-image{max-width:100%;max-height:100%;-o-object-fit:contain;object-fit:contain}.purchase-drawing-file-tip{border:1px dashed #666;padding:12px;font-size:18px;line-height:1.6;word-break:break-all}.install-sheet-title{text-align:center;font-size:52px;font-weight:700;letter-spacing:2px;margin-top:42px}.install-sheet-date{margin-top:44px;display:flex;justify-content:flex-end;font-size:36px}.install-sheet-table{margin-top:18px;font-size:34px}.form-input{width:100%;height:34px;box-sizing:border-box;border:1px solid #ddd;border-radius:0;padding:0 8px;font-size:14px}.form-actions{display:flex;gap:8px}.form-actions button{height:34px;padding:0 10px;border-radius:6px;border:1px solid #007aff;background:#fff;color:#007aff;font-size:13px;cursor:pointer}.form-actions button.primary{background:#007aff;color:#fff;border:none}.tpl-doors .a4-header{border-bottom:1px solid #000}.tpl-sunroom .a4-header{border-bottom:4px solid #000}.tpl-sunroom .a4-title{color:#000}.tpl-maintenance .a4-header{border-bottom:2px dashed #666}.tpl-maintenance .a4-title{color:#666}.form-input.sm{width:110px}.form-input.xs{width:80px}.mobile-view input[type=number]:disabled,.mobile-view input[type=text]:disabled{background:#f5f5f5;color:#999}.list-pagination{margin-top:15px;padding:15px 0;text-align:center;border-top:1px solid #f0f0f0}.pagination-info{font-size:13px;color:#666;margin-bottom:10px}.load-more-btn{width:100%;height:40px;border:1px solid #007aff;border-radius:6px;background:#fff;color:#007aff;font-size:14px;cursor:pointer;transition:all .3s}.load-more-btn:hover:not(:disabled){background:#007aff;color:#fff}.load-more-btn:disabled{border-color:#ccc;color:#999;cursor:not-allowed}.no-more-tip{font-size:13px;color:#999}.permission-denied{padding:60px 20px;text-align:center}.permission-icon{font-size:48px;margin-bottom:15px}.permission-text{font-size:18px;font-weight:600;color:#333;margin-bottom:8px}.permission-desc{font-size:14px;color:#999}.login-wrap{position:relative;min-height:100%;display:flex;align-items:center;justify-content:center;padding:20px;background:#f5f7fa;overflow:hidden}.login-bg{display:none}.login-card{position:relative;z-index:1;width:min(92vw,440px);max-width:420px;padding:24px 20px 22px;border-radius:16px;background:#fff;box-shadow:0 2px 12px rgba(0,0,0,.08)}.login-input{width:100%;display:block;box-sizing:border-box;-webkit-appearance:none;height:44px;border:1px solid #d8dfef;border-radius:10px;padding:0 12px;margin-bottom:12px;font-size:16px;outline:none;transition:border-color .2s,box-shadow .2s}@supports (padding:env(safe-area-inset-left)){.login-wrap{padding-left:calc(20px + env(safe-area-inset-left));padding-right:calc(20px + env(safe-area-inset-right))}}.login-input:focus{border-color:#3a67ff;box-shadow:0 0 0 3px rgba(58,103,255,.12)}.login-error{color:#ff4d4f;font-size:12px;margin-bottom:10px}.login-btn{width:100%;height:44px;border:none;border-radius:10px;color:#fff;background:linear-gradient(90deg,#2d5cff,#4a8dff);font-size:15px;font-weight:600}.login-btn:disabled{opacity:.75}.password-wrap{position:relative;min-height:100%;display:flex;align-items:center;justify-content:center;padding:20px;background:#f5f7fa;overflow:hidden}.password-bg{display:none}.password-card{position:relative;z-index:1;width:min(92vw,440px);max-width:420px;padding:24px 20px 22px;border-radius:16px;background:#fff;box-shadow:0 2px 12px rgba(0,0,0,.08)}.back-icon-btn{position:absolute;top:16px;left:16px;width:36px;height:36px;border:none;border-radius:50%;background:#f5f7fa;color:#333;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.back-icon-btn:hover{background:#e8ecf0}.brand{font-size:24px;line-height:1.2;color:#111a36;font-weight:700;letter-spacing:1px}.brand,.subtitle{text-align:center}.subtitle{margin:8px 0 18px;color:#63708d;font-size:13px}.pwd-input{width:100%;display:block;box-sizing:border-box;-webkit-appearance:none;height:44px;border:1px solid #d8dfef;border-radius:10px;padding:0 12px;margin-bottom:12px;font-size:16px;outline:none;transition:border-color .2s,box-shadow .2s}@supports (padding:env(safe-area-inset-left)){.password-wrap{padding-left:calc(20px + env(safe-area-inset-left));padding-right:calc(20px + env(safe-area-inset-right))}}.pwd-input:focus{border-color:#3a67ff;box-shadow:0 0 0 3px rgba(58,103,255,.12)}.error-text{color:#ff4d4f;font-size:12px;margin-bottom:10px}.success-text{color:#52c41a;font-size:14px;margin-bottom:14px;text-align:center}.pwd-btn{width:100%;height:44px;border:none;border-radius:10px;color:#fff;background:linear-gradient(90deg,#2d5cff,#4a8dff);font-size:15px;font-weight:600;cursor:pointer}.pwd-btn:disabled{opacity:.75}#app,body,html{margin:0;width:100%;height:100%}.auth-bar{height:44px;padding:0 12px;display:flex;align-items:center;justify-content:space-between;background:#fff;border-bottom:1px solid #edf0f5;box-sizing:content-box;padding-top:env(safe-area-inset-top,0)}.auth-user{font-size:13px;color:#333;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.action-link{padding:0 8px;background:#e8f0fe;color:#2d5cff}.action-link,.logout-btn{height:28px;border:none;border-radius:4px;font-size:12px;cursor:pointer}.logout-btn{padding:0 10px;background:#ff4d4f;color:#fff}