body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;-webkit-user-select:none;user-select:none}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.print-page{box-shadow:0 2px 8px #00000026;margin:0 auto 20px}.markdown-body table{border-collapse:collapse;margin:16px 0;width:100%}.markdown-body td,.markdown-body th{border:1px solid #d0d7de;padding:8px 12px;text-align:left}.markdown-body th{font-weight:600}.markdown-body th,.markdown-body tr:nth-child(2n){background:#f6f8fa}.markdown-body code{background:#f6f8fa;border-radius:4px;font-size:13px;padding:2px 6px}.markdown-body pre{background:#f6f8fa;border:1px solid #e1e4e8;border-radius:6px;color:#24292e;overflow-x:auto;padding:16px}.markdown-body pre code{background:#0000;padding:0}.markdown-body h1,.markdown-body h2,.markdown-body h3{border-bottom:1px solid #e1e4e8;margin-top:24px;padding-bottom:8px}.react-band-designer{background:#f5f5f5;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;height:100vh}.toolbar{align-items:center;background:#fff;border-bottom:1px solid #ddd;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;padding:10px 20px}.toolbar-left,.toolbar-right{align-items:center;display:flex;gap:10px}.btn{border:1px solid #ddd;padding:6px 12px}.btn:hover{background:#f0f0f0}.btn-primary{background:#4d90fe;border-color:#357ae8}.btn-primary:hover{background:#357ae8}.btn-danger{background:#ff6b6b;border-color:#ff5252}.btn-danger:hover{background:#ff5252}.btn-small{font-size:12px;padding:3px 8px}.checkbox{align-items:center;cursor:pointer;display:flex;font-size:14px;gap:5px}.workspace{display:flex;flex:1 1;overflow:hidden}.control-panel{background:#fafafa;border-right:1px solid #ddd;overflow-y:auto;padding:15px;width:155px}.control-panel h3{color:#333;font-size:16px;margin:0 0 15px}.control-group{margin-bottom:20px}.control-group h4{color:#666;font-size:14px;font-weight:500;margin:0 0 10px}.control-list{display:flex;flex-direction:row;flex-wrap:wrap;gap:8px}.control-item{align-items:center;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;display:flex;flex-direction:column;font-size:12px;justify-content:center;padding:8px;transition:all .2s;width:48px}.control-item:hover{background:#f0f7ff;border-color:#4d90fe}.control-icon{align-items:center;background:#4d90fe;border-radius:3px;color:#fff;display:flex;font-size:12px;height:24px;justify-content:center;width:24px}.data-fields-panel{border-top:1px solid #eee;margin-top:20px;padding-top:20px}.panel-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.panel-header h4{color:#333;font-size:14px;margin:0}.field-list{flex-direction:column;gap:6px}.field-item{background:#fff;border:1px solid #ddd;font-size:13px;margin-bottom:6px;padding:6px 10px;transition:all .2s}.field-item:last-child{margin-bottom:0}.field-item:hover{background:#f0f7ff;border-color:#4d90fe}.field-group{margin-bottom:12px}.field-group-title{border-bottom:1px solid #eee;color:#666;font-size:12px;font-weight:500;margin-bottom:6px;padding:4px 0}.field-item.detail-field{background:#fff8e6;border-color:#ffd666}.field-item.detail-field:hover{background:#fff2cc;border-color:#faad14}.design-area{background:#f9f9f9;display:flex;flex:1 1;flex-direction:column}.canvas-nav{background:#fff;color:#666;font-size:14px;padding:10px 20px}.position-info,.selected-info{align-items:center;display:flex;gap:5px}.canvas-wrapper{flex:1 1;overflow:auto;position:relative}.canvas-container{background:#fff;box-shadow:0 2px 10px #0000001a;height:100%;margin:0 auto;position:relative;width:100%}.grid-layer{background-image:linear-gradient(90deg,#0000001a 1px,#0000 0),linear-gradient(180deg,#0000001a 1px,#0000 0);opacity:.3;pointer-events:none}.boundary-layer,.grid-layer{bottom:0;left:0;position:absolute;right:0;top:0}.boundary-layer{pointer-events:auto}.boundary-line{height:4px;z-index:100}.boundary-line.dragging,.boundary-line:hover{background-color:#666!important}.boundary-label{background:inherit;border-radius:3px;color:#fff;left:10px;pointer-events:none;top:-20px}.band-layer{bottom:0;pointer-events:none;top:0}.band-layer,.band-placeholder{left:0;position:absolute;right:0}.band-placeholder{background:repeating-linear-gradient(90deg,#999,#999 5px,#0000 0,#0000 10px);cursor:pointer;height:2px}.band-placeholder:hover{background:#ff6b6b!important}.band-area{box-sizing:border-box;cursor:pointer;left:0;opacity:.85;overflow:hidden;position:absolute;right:0;transition:all .3s}.band-area.selected,.band-area:hover{opacity:.95}.band-area.selected{border-color:#ff6b6b!important}.band-label{background:#ffffffe6;border-radius:3px;color:#333;font-size:12px;left:5px;padding:2px 6px;pointer-events:none;position:absolute;top:5px}.object-layer{bottom:0;left:0;position:absolute;right:0;top:0}.design-object{cursor:move;position:absolute;-webkit-user-select:none;user-select:none}.band-controls{background:#fff;border-top:1px solid #ddd;display:flex;flex-wrap:wrap;gap:20px;padding:10px 20px}.band-control{align-items:center;background:#f8f9fa;border-radius:4px;display:flex;font-size:14px;gap:10px;padding:8px 12px}.band-name{font-weight:500;min-width:60px}.band-height{color:#666;min-width:50px;text-align:right}.property-panel{background:#fafafa;border-left:1px solid #ddd;overflow-y:auto}.property-panel h3{color:#333;font-size:16px;margin:0 0 15px}.property-editor{gap:20px}.property-group{border:1px solid #eee}.property-group h4{color:#333;font-size:14px;font-weight:500;margin:0 0 10px}.property-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.property-row:last-child{margin-bottom:0}.property-row label{color:#666;font-size:14px;min-width:80px}.property-row input[type=number],.property-row input[type=text]{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:4px 8px;width:150px}.property-row input[type=color]{border:1px solid #ddd;border-radius:4px;cursor:pointer;height:30px;width:50px}.color-input-wrapper{align-items:center;display:flex;gap:4px}.btn-clear-color{align-items:center;background:#fff;border:1px solid #ddd;border-radius:4px;color:#999;cursor:pointer;display:flex;font-size:16px;height:24px;justify-content:center;line-height:1;padding:0;transition:all .15s ease;width:24px}.btn-clear-color:hover{background:#fff1f0;border-color:#ff4d4f;color:#ff4d4f}.property-row input[type=checkbox]{cursor:pointer;height:16px;width:16px}.property-value{color:#333;font-size:14px;font-weight:500}.property-actions{border-top:1px solid #eee;margin-top:20px;padding-top:20px;text-align:center}.empty-state{color:#999}.empty-state p{margin:10px 0 0}.status-bar{background:#fff;border-top:1px solid #ddd;color:#666;display:flex;font-size:13px;gap:30px;padding:8px 20px}.status-item{align-items:center;display:flex;gap:5px}.status-item span:first-child{color:#333;font-weight:500}@media (max-width:1200px){.canvas-container{height:900px;width:600px}}@media (max-width:900px){.workspace{flex-direction:column}.control-panel{border-bottom:1px solid #ddd;border-right:none;height:200px;width:100%}.property-panel{border-left:none;border-top:1px solid #ddd;height:300px;width:100%}.canvas-container{height:600px;width:100%}}.band-area.dragging{transition:all .1s ease}.band-object-count{background:#0000001a;border-radius:3px;bottom:5px;color:#666;font-size:10px;padding:2px 6px;position:absolute;right:5px}.boundary-line{background-color:#f3f3f3;border-bottom:1px solid #aeadad;border-top:1px solid #aeadad;cursor:ns-resize;height:20px;left:0;position:absolute;right:0;transition:background-color .2s ease;z-index:1000}.boundary-label{background:#0000;border-radius:4px;color:#c3c3c3;font-size:12px;left:0;padding:2px 8px;position:absolute;top:50%;transform:translateY(-50%);white-space:nowrap}.text-content-wrapper{box-sizing:border-box;display:flex;flex-direction:column;height:100%;margin:0;padding:0;width:100%}.text-content{box-sizing:border-box;overflow:hidden;white-space:pre-wrap;width:100%;word-break:break-word}.multi-selection-info{background:#f5f5f5;border-left:3px solid #4d90fe;border-radius:4px;margin-top:15px;padding:10px}.multi-selection-info p{color:#666;font-size:12px;margin:5px 0}.multi-selection-info .btn-small{font-size:12px;margin-top:8px;padding:4px 12px}.status-bar .status-item:last-child{color:#4d90fe;font-weight:700}.toolbar .selected-count{background:#4d90fe;border-radius:10px;color:#fff;font-size:12px;margin-left:5px;padding:2px 8px}.band-controls{max-height:200px;overflow-y:auto}@keyframes object-focus-blink{0%,to{box-shadow:0 0 8px #4d90fe99;outline:2px solid #4d90fe;outline-offset:2px}50%{box-shadow:0 0 12px #ff9800cc;outline:2px solid #ff9800;outline-offset:2px}}.object-focus-blink{animation:object-focus-blink .5s ease-in-out 3;z-index:9999!important}.context-menu{background:#fff;border:1px solid #d9d9d9;border-radius:6px;box-shadow:0 6px 16px #0000001f;font-size:13px;min-width:180px;padding:4px 0;-webkit-user-select:none;user-select:none}.context-menu-item{align-items:center;cursor:pointer;display:flex;padding:6px 12px;position:relative;transition:background-color .15s}.context-menu-item:hover{background-color:#f5f5f5}.context-menu-item[data-disabled=true]{cursor:not-allowed;opacity:.4;pointer-events:none}.context-menu-item.delete:hover{background-color:#fff1f0;color:#ff4d4f}.menu-icon{font-size:12px;margin-right:8px;text-align:center;width:20px}.menu-label{flex:1 1}.menu-shortcut{color:#999;font-size:11px;margin-left:16px}.menu-arrow{color:#999;font-size:10px;margin-left:8px}.context-menu-divider{background-color:#e8e8e8;height:1px;margin:4px 0}.context-menu-submenu{position:relative}.context-submenu{background:#fff;border:1px solid #d9d9d9;border-radius:6px;box-shadow:0 6px 16px #0000001f;display:none;left:100%;min-width:150px;padding:4px 0;position:absolute;top:-4px;z-index:1}.context-menu-submenu:hover>.context-submenu{display:block}.context-submenu .context-menu-item{padding:6px 16px}.context-submenu .context-menu-item:hover{background-color:#f5f5f5}@keyframes contextMenuFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu{animation:contextMenuFadeIn .1s ease-out}.selection-rect{box-sizing:border-box}.selected-object-border{animation:pulse-border 2s infinite;box-sizing:border-box}@keyframes pulse-border{0%{border-color:#4d90fe}50%{border-color:#4d90fe80}to{border-color:#4d90fe}}.canvas-nav{align-items:center;background:#f5f5f5;border-bottom:1px solid #ddd;display:flex;justify-content:space-between;padding:8px 16px}.keyboard-hint{background:#fff;border:1px solid #ddd;border-radius:4px;color:#666;font-size:12px;padding:4px 8px}.canvas-container.selecting{cursor:crosshair!important}.canvas-container.moving{cursor:move!important}.shortcut-hint{background:#000c;border-radius:6px;bottom:20px;color:#fff;font-size:12px;padding:10px 15px;position:fixed;right:20px;z-index:3000}.shortcut-hint kbd{background:#333;border-radius:3px;font-family:monospace;margin:0 2px;padding:2px 6px}.rich-text-content{height:100%;overflow:hidden;width:100%}.rich-text-content p{margin:0 0 .3em}.rich-text-content p:last-child{margin-bottom:0}.rich-text-content ol,.rich-text-content ul{margin:.3em 0;padding-left:1.2em}.rich-text-content li{margin:.1em 0}.rich-text-content b,.rich-text-content strong{font-weight:700}.rich-text-content em,.rich-text-content i{font-style:italic}.rich-text-content u{text-decoration:underline}.rich-text-content s,.rich-text-content strike{text-decoration:line-through}.color-picker{display:inline-flex;position:relative}.color-picker.disabled{cursor:not-allowed;opacity:.6}.color-preview-btn{align-items:center;background:#fff;border:1px solid #d9d9d9;border-radius:4px;cursor:pointer;display:flex;gap:4px;padding:2px;transition:border-color .2s}.color-preview-btn:hover{border-color:#1890ff}.color-picker.disabled .color-preview-btn{background:#f5f5f5;cursor:not-allowed}.color-swatch{align-items:center;border:1px solid #e8e8e8;border-radius:2px;display:flex;height:20px;justify-content:center;width:24px}.no-color-icon{color:#999;font-size:18px}.dropdown-arrow{align-items:center;display:flex}.color-panel{background:#fff;border:1px solid #e8e8e8;border-radius:6px;box-shadow:0 4px 12px #00000026;left:0;margin-top:4px;padding:8px;position:absolute;top:100%;width:190px;z-index:10000}.preset-colors{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(6,1fr);margin-bottom:8px}.color-item{border:2px solid #0000;border-radius:4px;cursor:pointer;height:24px;transition:all .15s;width:24px}.color-item:hover{border-color:#1890ff;transform:scale(1.1)}.color-item.active{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff4d}.color-item.clear-color{align-items:center;background:#fff!important;border:1px solid #d9d9d9!important;display:flex;justify-content:center;overflow:hidden;position:relative}.color-item.clear-color:after{background:#ff4d4f;content:"";height:2px;left:50%;margin-left:-15px;margin-top:-1px;position:absolute;top:50%;transform:rotate(-45deg);width:30px}.color-item.clear-color:hover{border-color:#ff4d4f!important}.clear-icon{display:none}.custom-color-row{border-top:1px solid #f0f0f0;padding-top:8px}.btn-custom-color{background:#fafafa;border:1px solid #d9d9d9;border-radius:4px;color:#666;cursor:pointer;font-size:12px;padding:6px 12px;transition:all .15s;width:100%}.btn-custom-color:hover{background:#e6f7ff;border-color:#1890ff;color:#1890ff}.band-property-panel{background:#fafafa;border-left:1px solid #e8e8e8;display:flex;flex-direction:column;height:100%;overflow:hidden;width:300px}.band-property-panel h3{background:#fff;border-bottom:1px solid #e8e8e8;color:#333;flex-shrink:0;font-size:14px;font-weight:600;margin:0;padding:12px 16px}.band-property-editor{display:flex;flex:1 1;flex-direction:column;gap:12px;overflow-y:auto;padding:12px}.band-property-editor::-webkit-scrollbar{width:6px}.band-property-editor::-webkit-scrollbar-track{background:#0000}.band-property-editor::-webkit-scrollbar-thumb{background:#d9d9d9;border-radius:3px}.band-property-editor::-webkit-scrollbar-thumb:hover{background:#bfbfbf}.band-property-group{background:#fff;border:1px solid #e8e8e8;border-radius:6px;flex-shrink:0}.band-property-group.control-list-group{display:flex;flex:1 1;flex-direction:column;flex-shrink:1;min-height:0;overflow:hidden}.band-property-group.control-list-group .object-list{background-color:#fafafa;border-top:1px solid #e8e8e8;flex:1 1;min-height:0;overflow-y:auto}.band-property-group.control-list-group .object-list::-webkit-scrollbar{width:6px}.band-property-group.control-list-group .object-list::-webkit-scrollbar-track{background:#0000}.band-property-group.control-list-group .object-list::-webkit-scrollbar-thumb{background:#d9d9d9;border-radius:3px}.band-property-group.control-list-group .object-list::-webkit-scrollbar-thumb:hover{background:#bfbfbf}.band-property-group h4{background:#fafafa;border-bottom:1px solid #e8e8e8;color:#333;font-size:13px;font-weight:600;margin:0;padding:10px 12px}.band-property-row{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;gap:8px;padding:10px 12px}.band-property-row:last-child{border-bottom:none}.band-property-row label{color:#666;flex-shrink:0;font-size:13px;width:80px}.band-property-row>div{flex:1 1;min-width:0}.band-property-value{background:#f5f5f5;border-radius:4px;color:#333;font-size:13px;padding:4px 8px}.band-property-row input[type=number],.band-property-row input[type=text]{background:#fff;border:1px solid #d9d9d9;border-radius:4px;color:#333;font-size:13px;min-width:0;outline:none;padding:6px 10px;transition:border-color .2s}.band-property-row input[type=number]{width:80px}.band-property-row input[type=text]{flex:1 1}.band-property-row input[type=number]:hover,.band-property-row input[type=text]:hover{border-color:#40a9ff}.band-property-row input[type=number]:focus,.band-property-row input[type=text]:focus{border-color:#40a9ff;box-shadow:0 0 0 2px #1890ff1a}.band-property-row select{background:#fff;border:1px solid #d9d9d9;border-radius:4px;color:#333;cursor:pointer;flex:1 1;font-size:13px;outline:none;padding:6px 10px}.band-property-row select:hover{border-color:#40a9ff}.band-property-row select:focus{border-color:#40a9ff;box-shadow:0 0 0 2px #1890ff1a}.band-property-row input[type=color]{border:1px solid #d9d9d9;border-radius:4px;cursor:pointer;height:24px;padding:0;width:32px}@media (max-width:1200px){.band-property-panel{width:280px}}.rich-text-editor{background:#fff;border:1px solid #d9d9d9;border-radius:4px}.rte-toolbar{background:#fafafa;border-bottom:1px solid #e8e8e8;flex-wrap:wrap;gap:2px;padding:4px 6px}.rte-btn,.rte-toolbar{align-items:center;display:flex}.rte-btn{background:#0000;border:1px solid #0000;border-radius:4px;color:#333;cursor:pointer;font-size:13px;height:26px;justify-content:center;padding:0;transition:all .15s;width:26px}.rte-btn:hover{background:#e6f7ff;border-color:#91d5ff}.rte-btn:active{background:#bae7ff}.rte-select{background:#fff;border:1px solid #d9d9d9;border-radius:4px;cursor:pointer;font-size:12px;height:26px;min-width:80px!important;padding:0 6px!important}.rte-select:focus{border-color:#1890ff;outline:none}.rte-color{background:#fff;border:1px solid #d9d9d9;border-radius:4px;cursor:pointer;height:26px;padding:2px;width:26px}.rte-color::-webkit-color-swatch-wrapper{padding:2px}.rte-color::-webkit-color-swatch{border:none;border-radius:2px}.rte-separator{background:#e8e8e8;height:20px;margin:0 4px;width:1px}.rte-content{font-size:14px;line-height:1.6;max-height:300px;min-height:120px;outline:none;overflow-y:auto;padding:8px 10px}.rte-content:empty:before{color:#bfbfbf;content:attr(data-placeholder);pointer-events:none}.rte-content:focus{background:#fafafa}.rte-content p{margin:0 0 .5em}.rte-content ol,.rte-content ul{margin:.5em 0;padding-left:1.5em}.rte-content li{margin:.25em 0}.property-panel{background:linear-gradient(180deg,#fafbfc,#f6f8fa);border-left:1px solid #e1e4e8;display:flex;flex-direction:column;height:100%;overflow:hidden;width:300px}.property-panel-header{align-items:center;display:flex;flex-shrink:0;gap:10px;padding:8px}.property-panel-header .type-icon{align-items:center;background:#4d90fe;border-radius:8px;color:#fff;display:flex;font-size:16px;font-weight:600;height:36px;justify-content:center;width:36px}.property-panel-header .type-info{flex:1 1}.property-panel-header .type-name{color:#24292e;font-size:15px;font-weight:600;margin:0 0 2px}.property-panel-header .type-id{color:#6a737d;font-family:SFMono-Regular,Consolas,monospace;font-size:11px}.property-editor{display:flex;flex:1 1;flex-direction:column;gap:12px;overflow-y:auto}.property-editor::-webkit-scrollbar{width:6px}.property-editor::-webkit-scrollbar-track{background:#0000}.property-editor::-webkit-scrollbar-thumb{background:#d1d5da;border-radius:3px}.property-editor::-webkit-scrollbar-thumb:hover{background:#959da5}.property-group{background:#fff;border:1px solid #e1e4e8;box-shadow:0 1px 3px #0000000a}.property-group-header{align-items:center;background:linear-gradient(180deg,#fafbfc,#f6f8fa);border-bottom:1px solid #e1e4e8;cursor:pointer;display:flex;justify-content:space-between;padding:10px 12px;transition:background .15s ease;-webkit-user-select:none;user-select:none}.property-group-header:hover{background:linear-gradient(180deg,#f3f4f6,#ebedf0)}.property-group-header h4{align-items:center;color:#24292e;display:flex;font-size:12px;font-weight:600;gap:6px;letter-spacing:.5px;margin:0;text-transform:uppercase}.property-group-header h4:before{background:linear-gradient(180deg,#667eea,#764ba2);border-radius:2px;content:"";height:12px;width:3px}.property-group-header .collapse-icon{color:#6a737d;font-size:10px;transition:transform .2s ease}.property-group-header .collapse-icon.collapsed{transform:rotate(-90deg)}.property-group-content{padding:12px}.property-group-content.collapsed{display:none}.property-panel .property-row{align-items:center;display:flex;margin-bottom:12px}.property-panel .property-row:last-child{margin-bottom:0}.property-panel .property-row label{color:#586069;flex-shrink:0;font-size:13px;width:72px}.property-panel .property-row .property-value{background:#f6f8fa;border-radius:4px;color:#24292e;flex:1 1;font-size:13px;font-weight:500;padding:6px 10px}.property-panel .property-row input[type=text],.property-panel .property-row textarea{background:#fff;border:1px solid #d1d5da;border-radius:4px;color:#24292e;flex:1 1;font-size:13px;min-width:0;outline:none;padding:6px 10px}.property-panel .property-row input[type=number]{background:#fff;border:1px solid #d1d5da;border-radius:4px;color:#24292e;flex:1 1;flex-shrink:0;font-size:13px;outline:none;padding:6px 10px}.property-panel .property-row input:hover,.property-panel .property-row select:hover,.property-panel .property-row textarea:hover{border-color:#0366d6}.property-panel .property-row input:focus,.property-panel .property-row select:focus,.property-panel .property-row textarea:focus{border-color:#0366d6;box-shadow:0 0 0 2px #0366d61a}.property-panel .property-row input:disabled{background:#f6f8fa;color:#6a737d;cursor:not-allowed}.property-panel .property-row select{background:#fff;border:1px solid #d1d5da;border-radius:4px;color:#24292e;cursor:pointer;flex:1 1;font-size:13px;min-width:0;outline:none;padding:6px 10px}.property-panel .property-row input[type=checkbox]{accent-color:#0366d6;cursor:pointer;flex-shrink:0;height:16px;width:16px}.property-panel .checkbox-wrapper{align-items:center;display:flex;gap:8px}.property-panel .checkbox-wrapper .checkbox-label{color:#586069;font-size:12px}.property-panel .color-input-wrapper{align-items:center;display:flex;flex:1 1;gap:6px}.property-panel .property-row input[type=color]{background:#fff;border:1px solid #d1d5da;border-radius:6px;cursor:pointer;flex-shrink:0;height:32px;padding:2px;width:36px}.property-panel .property-row input[type=color]:hover{border-color:#0366d6}.property-panel .color-value{background:#f6f8fa;border-radius:4px;color:#6a737d;flex:1 1;font-family:SFMono-Regular,Consolas,monospace;font-size:11px;min-width:0;overflow:hidden;padding:4px 8px;text-overflow:ellipsis}.property-panel .btn-clear-color{align-items:center;background:#fff;border:1px solid #d1d5da;border-radius:6px;color:#6a737d;cursor:pointer;display:flex;flex-shrink:0;font-size:14px;height:28px;justify-content:center;line-height:1;padding:0;transition:all .15s ease;width:28px}.property-panel .btn-clear-color:hover{background:#ffeef0;border-color:#d73a49;color:#d73a49}.btn-sm{border:1px solid #0000;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;padding:5px 12px;transition:all .15s ease}.btn-primary{background:linear-gradient(180deg,#0366d6,#0256b9);border-color:#0256b9}.btn-primary:hover{background:linear-gradient(180deg,#0256b9,#044289)}.btn-secondary{background:#f6f8fa;border-color:#d1d5da;color:#24292e}.btn-secondary:hover{background:#e1e4e8}.alignment-buttons{display:flex;flex:1 1;gap:4px}.alignment-btn{align-items:center;background:#fff;border:1px solid #d1d5da;border-radius:6px;color:#6a737d;cursor:pointer;display:flex;flex:1 1;height:32px;justify-content:center;transition:all .15s ease}.alignment-btn:hover{border-color:#0366d6;color:#0366d6}.alignment-btn.active{background:linear-gradient(180deg,#0366d6,#0256b9);border-color:#0256b9;color:#fff}.padding-inputs{grid-gap:8px;display:grid;flex:1 1;gap:8px;grid-template-columns:1fr 1fr}.padding-input-item{align-items:center;display:flex;gap:4px}.padding-input-item .padding-label{color:#6a737d;font-size:11px;min-width:16px}.padding-inputs input{font-size:12px;padding:4px 6px!important;text-align:center;width:50px!important}.padding-hint{display:none}.zindex-controls{align-items:center;display:flex;flex:1 1;gap:6px}.zindex-controls input{width:60px!important}.zindex-btn{align-items:center;background:#f6f8fa;border:1px solid #d1d5da;border-radius:4px;color:#586069;cursor:pointer;display:flex;font-size:11px;gap:3px;padding:4px 8px;transition:all .15s ease}.zindex-btn:hover{background:#e1e4e8;border-color:#959da5}.image-preview-container{align-items:center;background:#f6f8fa;border:1px solid #e1e4e8;border-radius:6px;display:flex;height:80px;justify-content:center;margin-top:8px;overflow:hidden;width:100%}.image-preview-container img{max-height:100%;max-width:100%;object-fit:contain}.file-upload-btn{align-items:center;background:linear-gradient(180deg,#0366d6,#0256b9);border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:12px;font-weight:500;gap:6px;padding:6px 12px;transition:all .15s ease}.file-upload-btn:hover{background:linear-gradient(180deg,#0256b9,#044289)}.file-clear-btn{background:#fff;border:1px solid #d73a49;border-radius:6px;color:#d73a49;cursor:pointer;font-size:12px;padding:6px 10px;transition:all .15s ease}.file-clear-btn:hover{background:#ffeef0}.formula-input-wrapper{display:flex;flex:1 1;gap:6px;min-width:0}.formula-input-wrapper input{flex:1 1;min-width:0}.btn-edit-formula{background:linear-gradient(180deg,#28a745,#22863a);border:none;border-radius:6px;color:#fff;cursor:pointer;flex-shrink:0;font-size:12px;font-weight:500;padding:6px 12px;transition:all .15s ease;white-space:nowrap}.btn-edit-formula:hover{background:linear-gradient(180deg,#22863a,#176f2c)}.property-actions{background:#fff;border-top:1px solid #e1e4e8;flex-shrink:0;padding:12px}.btn-danger{align-items:center;background:linear-gradient(180deg,#d73a49,#cb2431);border-radius:6px;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;justify-content:center;padding:10px;transition:all .15s ease;width:100%}.btn-danger:hover{background:linear-gradient(180deg,#cb2431,#9e1c23)}.btn-danger:before{content:"🗑";font-size:14px}.empty-state{color:#6a737d;padding:40px 20px;text-align:center}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state-text{font-size:14px;line-height:1.5}@media (max-width:1200px){.property-panel{width:280px}}@media (max-width:900px){.property-panel{border-left:none;border-top:1px solid #e1e4e8;height:300px;width:100%}}.multi-select-toolbar{align-items:center;background:#fff;border-bottom:1px solid #e8e8e8;box-sizing:border-box;display:flex;flex-wrap:wrap;gap:4px;padding:8px 12px;width:100%}.toolbar-section{align-items:center;display:flex;gap:8px}.toolbar-section:last-child{border-right:none}.section-label{color:#1890ff;font-size:12px;font-weight:600;margin-right:4px;white-space:nowrap}.type-hint{color:#999;font-size:11px;margin-left:4px}.section-title{color:#666;font-size:12px;font-weight:500}.toolbar-buttons{gap:2px}.toolbar-btn,.toolbar-buttons{align-items:center;display:flex}.toolbar-btn{background:#fff;border:1px solid #d9d9d9;border-radius:4px;color:#333;cursor:pointer;font-size:12px;height:28px;justify-content:center;min-width:28px;transition:all .15s ease}.toolbar-btn:hover{background:#e6f7ff;border-color:#1890ff;color:#1890ff}.toolbar-btn:active{background:#bae7ff}.toolbar-btn:disabled{cursor:not-allowed;opacity:.6}.toolbar-btn:disabled,.toolbar-btn:disabled:hover{background:#f5f5f5;border-color:#d9d9d9;color:#bfbfbf}.toolbar-btn.active{background:#1890ff;border-color:#1890ff;color:#fff}.toolbar-btn svg{flex-shrink:0}.toolbar-btn.btn-clear{background:#fff;border-color:#ff7875;color:#ff4d4f}.toolbar-btn.btn-clear:hover{background:#fff1f0;border-color:#ff4d4f}.toolbar-btn.btn-delete{align-items:center;background:#fff;border-color:#d9d9d9;color:#333;display:flex;gap:4px}.toolbar-btn.btn-delete:hover:not(:disabled){background:#fff1f0;border-color:#ff4d4f;color:#ff4d4f}.toolbar-btn.btn-delete:disabled{background:#f5f5f5;border-color:#d9d9d9;color:#bfbfbf}.separator{background:#e8e8e8;height:20px;margin:0 4px;width:1px}.toolbar-controls{align-items:center;display:flex;gap:6px}.toolbar-control-item{align-items:center;display:flex;gap:4px}.toolbar-control-item,.toolbar-control-item span{color:#666;font-size:12px}.toolbar-control-item input[type=number]{border:1px solid #d9d9d9;border-radius:4px;font-size:12px;height:26px;margin:0;padding:0;text-align:center;width:56px}.toolbar-control-item input[type=number]:focus{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff1a;outline:none}.toolbar-control-item input[type=color]{border:1px solid #d9d9d9;border-radius:4px;cursor:pointer;height:26px;overflow:hidden;padding:2px;width:28px}.toolbar-control-item input[type=color]::-webkit-color-swatch-wrapper{padding:2px}.toolbar-control-item input[type=color]::-webkit-color-swatch{border:none;border-radius:2px}.toolbar-control-item input:disabled,.toolbar-control-item select:disabled{background:#f5f5f5;border-color:#d9d9d9;color:#bfbfbf;cursor:not-allowed;opacity:.6}.toolbar-control-item select{background:#fff;border:1px solid #d9d9d9;border-radius:4px;cursor:pointer;font-size:12px;height:26px;padding:2px 8px}.toolbar-control-item select:focus{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff1a;outline:none}.color-input-group,.toolbar-actions{align-items:center;display:flex}.color-input-group{gap:2px}.btn-clear-sm{align-items:center;background:#fff;border:1px solid #d9d9d9;border-radius:4px;color:#999;cursor:pointer;display:flex;font-size:12px;height:20px;justify-content:center;line-height:1;padding:0;transition:all .15s ease;width:20px}.btn-clear-sm:hover:not(:disabled){background:#fff1f0;border-color:#ff4d4f;color:#ff4d4f}.btn-clear-sm:disabled{background:#f5f5f5;border-color:#d9d9d9;color:#d9d9d9;cursor:not-allowed}@media (max-width:1400px){.multi-select-toolbar{gap:4px;padding:8px 12px}.toolbar-section{padding:4px 8px}}@media (max-width:1200px){.section-title{display:none}}.toolbar-dropdown-btn{gap:4px;padding:0 8px}.dropdown-arrow{color:#999;font-size:8px;margin-left:2px}.toolbar-dropdown-menu{background:#fff;border:1px solid #e8e8e8;border-radius:6px;box-shadow:0 6px 16px #0000001f;margin-top:4px;min-width:160px;padding:4px 0;position:fixed;z-index:10000}.control-dropdown{min-width:180px}.dropdown-category{padding:4px 0}.category-title{color:#999;font-size:11px;font-weight:500;letter-spacing:.5px;padding:6px 12px 4px;text-transform:uppercase}.dropdown-item{align-items:center;cursor:pointer;display:flex;padding:8px 12px;transition:background .15s}.dropdown-item:hover{background:#e6f7ff}.item-icon{font-size:14px;margin-right:8px;text-align:center;width:24px}.item-name{color:#333;font-size:13px}.dropdown-divider{background:#e8e8e8;height:1px;margin:4px 0}.toolbar-section{position:relative}.field-modal-overlay{align-items:center;background:#00000073;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.field-modal{animation:modalFadeIn .2s ease-out;background:#fff;border-radius:8px;box-shadow:0 8px 24px #0003;display:flex;flex-direction:column;max-height:80vh;width:520px}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.field-modal-header{align-items:center;border-bottom:1px solid #e8e8e8;display:flex;justify-content:space-between;padding:16px 20px}.field-modal-header h3{color:#333;font-size:16px;font-weight:600;margin:0}.modal-close-btn{align-items:center;background:#0000;border:none;border-radius:4px;color:#999;cursor:pointer;display:flex;font-size:20px;height:28px;justify-content:center;transition:all .15s;width:28px}.modal-close-btn:hover{background:#f5f5f5;color:#333}.field-modal-body{max-height:400px;overflow-y:auto;padding:16px 20px}.field-group{margin-bottom:16px}.field-group:last-child{margin-bottom:0}.field-group-title{background:#f5f5f5;border-radius:4px;color:#333;font-size:13px;font-weight:600;margin-bottom:8px;padding:4px 8px}.field-list{display:flex;flex-wrap:wrap;gap:8px}.field-item{align-items:center;border:1px solid #d9d9d9;border-radius:4px;box-sizing:border-box;cursor:pointer;display:flex;flex-basis:calc(50% - 4px);flex-grow:0;flex-shrink:0;gap:8px;padding:8px 12px;transition:all .15s}.field-item.selected,.field-item:hover{background:#e6f7ff;border-color:#1890ff}.field-item input[type=checkbox]{cursor:pointer;height:16px;width:16px}.field-label{color:#333;font-size:13px;font-weight:500}.field-name{color:#999;font-size:11px;margin-left:auto}.field-modal-footer{align-items:center;background:#fafafa;border-radius:0 0 8px 8px;border-top:1px solid #e8e8e8;display:flex;justify-content:space-between;padding:16px 20px}.arrangement-options{align-items:center;color:#666;display:flex;font-size:13px;gap:12px}.arrangement-options label{align-items:center;cursor:pointer;display:flex;gap:4px}.arrangement-options input[type=radio]{cursor:pointer;height:14px;width:14px}.modal-buttons{display:flex;gap:8px}.modal-buttons .btn{border-radius:4px;cursor:pointer;font-size:13px;padding:6px 16px;transition:all .15s}.modal-buttons .btn-cancel{background:#fff;border:1px solid #d9d9d9;color:#666}.modal-buttons .btn-cancel:hover{border-color:#40a9ff;color:#40a9ff}.modal-buttons .btn-confirm{background:#1890ff;border:1px solid #1890ff;color:#fff}.modal-buttons .btn-confirm:hover{background:#40a9ff;border-color:#40a9ff}.modal-buttons .btn-confirm:disabled{background:#f5f5f5;border-color:#d9d9d9;color:#bfbfbf;cursor:not-allowed}.toolbar-btn.btn-primary{background:#1890ff;border-color:#1890ff;color:#fff}.toolbar-btn.btn-primary:hover{background:#40a9ff;border-color:#40a9ff}.print-preview-modal{align-items:center;bottom:0;display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.preview-overlay{animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:#0009;bottom:0;left:0;position:absolute;right:0;top:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.preview-container{animation:slideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003,0 0 0 1px #ffffff1a;display:flex;flex-direction:column;height:95vh;max-width:95%;position:relative;width:900px}@keyframes slideIn{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.preview-toolbar{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:1px solid #dee2e6;box-shadow:0 2px 8px #0000000d;display:flex;flex-shrink:0;justify-content:space-between;min-height:60px;padding:12px 20px}.toolbar-center,.toolbar-left,.toolbar-right{align-items:center;display:flex;gap:12px}.btn{align-items:center;background:#fff;border:1px solid #d9d9d9;border-radius:6px;color:#333;display:inline-flex;font-weight:500;gap:6px;justify-content:center;overflow:hidden;padding:8px 16px;position:relative;transition:all .2s cubic-bezier(.645,.045,.355,1)}.btn:before{background:#0000001a;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .4s,height .4s;width:0}.btn:hover:before{height:200px;width:200px}.btn:hover{border-color:#40a9ff;box-shadow:0 4px 12px #1890ff33;color:#40a9ff;transform:translateY(-1px)}.btn:active{box-shadow:0 2px 6px #1890ff33;transform:translateY(0)}.btn-primary{background:linear-gradient(135deg,#1890ff,#096dd9);border:none;box-shadow:0 2px 8px #1890ff4d;color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#40a9ff,#1890ff);border:none;box-shadow:0 4px 12px #1890ff66;color:#fff}.btn-danger{background:#ff4d4f;border:none;color:#fff}.btn-danger:hover{background:#ff7875;border:none;color:#fff}.btn-small{font-size:13px;min-height:28px;padding:4px 12px}.btn:disabled{cursor:not-allowed;opacity:.5}.btn:disabled,.btn:disabled:hover{box-shadow:none;transform:none}.btn-primary:disabled{background:#91caff}.zoom-select{background:#fff;border:1px solid #d9d9d9;border-radius:6px;color:#333;cursor:pointer;font-size:14px;min-width:90px;padding:6px 10px;transition:all .2s}.zoom-select:hover{border-color:#40a9ff}.zoom-select:focus{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff33;outline:none}.page-controls{background:#fffc;border:1px solid #e8e8e8;border-radius:8px;margin-left:20px;padding:6px 12px}.page-controls,.page-info{align-items:center;display:flex;gap:8px}.page-info{color:#595959;font-size:14px;font-weight:500}.page-input{border:1px solid #d9d9d9;border-radius:4px;color:#333;font-size:14px;padding:4px 8px;text-align:center;transition:all .2s;width:60px}.page-input:focus{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff33;outline:none}.data-info{align-items:center;background:#fff;border:1px solid #e8e8e8;border-radius:6px;color:#595959;display:flex;font-size:14px;gap:8px;padding:6px 12px}.data-info:before{content:"📊";font-size:16px}.preview-content{background:linear-gradient(135deg,#f5f5f5,#f0f0f0);flex:1 1;overflow-y:scroll;padding:20px;position:relative}.preview-page{background-color:#fff;border:1px solid #e0e0e0;border-radius:2px;box-shadow:0 8px 32px #00000026;height:1123px;margin:0 auto;overflow:hidden;position:relative;transform-origin:top center;width:794px}.page-margins{bottom:0;pointer-events:none}.margin-top,.page-margins{left:0;position:absolute;right:0;top:0}.margin-top{border-bottom:2px dashed #40a9ff4d;height:40px}.margin-bottom{border-top:2px dashed #40a9ff4d;height:40px;right:0}.margin-bottom,.margin-left{bottom:0;left:0;position:absolute}.margin-left{border-right:2px dashed #40a9ff4d;top:0;width:30px}.margin-right{border-left:2px dashed #40a9ff4d;bottom:0;position:absolute;right:0;top:0;width:30px}.preview-band{overflow:visible;position:absolute}.detail-row{left:0;position:absolute;width:100%}.page-number{background:#ffffffe6;border:1px solid #f0f0f0;border-radius:12px;bottom:15px;color:#8c8c8c;font-family:Arial,sans-serif;font-size:12px;padding:4px 12px;position:absolute;right:35px}.preview-stats{background:linear-gradient(135deg,#fafafa,#f5f5f5);border-top:1px solid #f0f0f0;flex-shrink:0;gap:32px;justify-content:center;padding:16px 20px}.preview-stats,.stat-item{align-items:center;display:flex}.stat-item{background:#fff;border:1px solid #e8e8e8;border-radius:8px;box-shadow:0 2px 4px #00000005;color:#666;font-size:13px;gap:8px;padding:8px 16px;transition:all .2s}.stat-item:hover{border-color:#d9d9d9;box-shadow:0 4px 8px #0000000d;transform:translateY(-1px)}.stat-item span:first-child{color:#8c8c8c;font-weight:500}.stat-item span:last-child{color:#1890ff;font-weight:600}.preview-content::-webkit-scrollbar{height:8px;width:8px}.preview-content::-webkit-scrollbar-track{background:#0000000d;border-radius:4px}.preview-content::-webkit-scrollbar-thumb{background:#0003;border-radius:4px}.preview-content::-webkit-scrollbar-thumb:hover{background:#0000004d}@media (max-width:1400px){.preview-container{width:98%}.preview-page{transform:scale(.9)}}@media (max-width:1200px){.preview-page{transform:scale(.8)}.preview-toolbar{flex-wrap:wrap;gap:10px}.toolbar-center{justify-content:center;margin-top:10px;order:3;width:100%}}@media (max-width:768px){.preview-container{border-radius:0;height:95vh;width:100%}.preview-page{transform:scale(.7)}.preview-stats{flex-wrap:wrap;gap:12px;justify-content:flex-start;overflow-x:auto}.stat-item{flex-shrink:0}}@media print{.print-preview-modal{background:#fff;position:static}.data-info,.margin-bottom,.margin-left,.margin-right,.margin-top,.multi-select-toolbar,.page-controls,.page-margins,.preview-overlay,.preview-stats,.preview-toolbar,.status-bar{display:none!important}.preview-container{border:none;border-radius:0;box-shadow:none;height:auto;width:100%}.preview-content{background:#fff;padding:0}.preview-page{border:none;box-shadow:none!important;margin:0!important;page-break-after:always;transform:none!important}.preview-page:last-child{page-break-after:auto}.page-margins{display:none!important}}@page{margin:0}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.loading{animation:pulse 1.5s ease-in-out infinite}.empty-state{align-items:center;color:#bfbfbf;display:flex;flex-direction:column;gap:16px;height:200px;justify-content:center}.empty-state svg{height:64px;opacity:.3;width:64px}.empty-state p{font-size:16px;font-weight:500}.tooltip{display:inline-block;position:relative}.tooltip .tooltip-text{background-color:#333;border-radius:6px;bottom:125%;color:#fff;font-size:12px;left:50%;line-height:1.4;margin-left:-100px;opacity:0;padding:8px;position:absolute;text-align:center;transition:opacity .3s;visibility:hidden;width:200px;z-index:1}.tooltip:hover .tooltip-text{opacity:.9;visibility:visible}.custom-scrollbar{scrollbar-color:#0003 #0000;scrollbar-width:thin}.page-settings-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.page-settings-panel{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;display:flex;flex-direction:column;max-height:90vh;width:400px}.page-settings-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:16px 20px}.page-settings-header h3{color:#333;font-size:16px;font-weight:600;margin:0}.page-settings-header .close-btn{background:none;border:none;color:#999;cursor:pointer;font-size:20px;line-height:1;padding:0}.page-settings-header .close-btn:hover{color:#333}.page-settings-content{flex:1 1;overflow-y:auto;padding:20px}.settings-section{margin-bottom:20px}.settings-section:last-child{margin-bottom:0}.section-label{color:#333;display:block;font-size:13px;font-weight:500;margin-bottom:8px}.settings-select{background:#fff;border:1px solid #ddd;border-radius:4px;color:#333;cursor:pointer;font-size:14px;padding:8px 12px;width:100%}.settings-select:focus{border-color:#4a90d9;outline:none}.dimensions-section .dimension-row{align-items:center;display:flex;gap:10px;margin-bottom:10px}.dimensions-section .dimension-row:last-child{margin-bottom:0}.dimensions-section .dimension-row label{color:#666;font-size:13px;width:40px}.dimensions-section .dimension-row input{border:1px solid #ddd;border-radius:4px;flex:1 1;font-size:14px;padding:6px 10px}.dimensions-section .dimension-row input:disabled{background:#f5f5f5;color:#999}.dimensions-section .dimension-row .unit{color:#999;font-size:12px;width:30px}.orientation-options{display:flex;gap:20px}.orientation-option{align-items:center;cursor:pointer;display:flex;gap:8px}.orientation-option input{margin:0}.orientation-icon{align-items:center;color:#666;display:flex;justify-content:center}.orientation-option input:checked+.orientation-icon{color:#4a90d9}.orientation-icon.landscape svg{transform:rotate(90deg)}.margins-section .margins-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.margin-input{align-items:center;display:flex;gap:4px}.margin-input label{color:#666;flex-shrink:0;font-size:13px;width:16px}.margin-input input{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;flex:1 1;font-size:13px;min-width:0;padding:6px 8px;width:50px}.margin-input input:focus{border-color:#4a90d9;outline:none}.margin-input .unit{color:#999;flex-shrink:0;font-size:12px;width:24px}.preview-section{border-top:1px solid #eee;margin-top:20px;padding-top:20px}.page-preview-container{align-items:center;display:flex;flex-direction:column;gap:10px}.page-preview{background:#fff;border:1px solid #ccc;box-shadow:0 2px 8px #0000001a;max-height:150px;position:relative;width:100px}.page-preview-content{background:#f0f7ff;border:1px dashed #4a90d9;position:absolute}.page-preview-info{color:#666;font-size:12px}.page-settings-footer{border-top:1px solid #eee;display:flex;gap:10px;justify-content:flex-end;padding:16px 20px}.btn{border-radius:4px;cursor:pointer;font-size:14px;padding:8px 20px;transition:all .2s}.btn-cancel{background:#fff;border:1px solid #ddd;color:#666}.btn-cancel:hover{background:#f5f5f5;border-color:#ccc}.btn-apply{background:#4a90d9;border:1px solid #4a90d9;color:#fff}.btn-apply:hover{background:#3a7bc8;border-color:#3a7bc8}
/*# sourceMappingURL=main.328bd7fd.css.map*/