:root{--bg-primary:#1e1e2e;--bg-secondary:#2a2a3e;--bg-tertiary:#353550;--bg-canvas:#3a3a50;--bg-hover:#40405a;--bg-active:#4a4a65;--text-primary:#e0e0e8;--text-secondary:#a0a0b8;--text-muted:#707088;--border-color:#404058;--accent:#6c63ff;--accent-hover:#7b73ff;--accent-light:#6c63ff26;--danger:#ff4757;--danger-hover:#ff6b7a;--success:#2ed573;--warning:#ffa502;--info:#1e90ff;--panel-width:260px;--toolbar-height:48px;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080;--transition:.15s ease}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:13px;line-height:1.5}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--bg-active)}.app-layout{flex-direction:column;width:100vw;height:100vh;display:flex}.app-body{flex:1;display:flex;overflow:hidden}.toolbar{height:var(--toolbar-height);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);z-index:100;flex-shrink:0;align-items:center;gap:4px;padding:0 12px;display:flex}.toolbar-group{border-right:1px solid var(--border-color);align-items:center;gap:2px;padding:0 8px;display:flex}.toolbar-group:last-child{border-right:none}.toolbar-spacer{flex:1}.toolbar-btn{width:32px;height:32px;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.toolbar-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.toolbar-btn.active{background:var(--accent-light);color:var(--accent)}.toolbar-btn:disabled{opacity:.3;cursor:not-allowed}.toolbar-btn-text{align-items:center;gap:5px;width:auto;padding:0 10px;font-size:12px;display:flex}.toolbar-select{background:var(--bg-tertiary);border:1px solid var(--border-color);height:30px;color:var(--text-primary);border-radius:var(--radius-sm);cursor:pointer;outline:none;padding:0 8px;font-size:12px}.toolbar-select:focus{border-color:var(--accent)}.toolbar-label{color:var(--text-muted);white-space:nowrap;margin-right:4px;font-size:11px}.left-panel{width:var(--panel-width);background:var(--bg-secondary);border-right:1px solid var(--border-color);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.right-panel{width:var(--panel-width);background:var(--bg-secondary);border-left:1px solid var(--border-color);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.panel-tabs{border-bottom:1px solid var(--border-color);flex-shrink:0;display:flex}.panel-tab{text-align:center;color:var(--text-muted);cursor:pointer;transition:all var(--transition);text-transform:uppercase;letter-spacing:.5px;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:8px 4px;font-size:11px;font-weight:500}.panel-tab:hover{color:var(--text-secondary);background:var(--bg-hover)}.panel-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.panel-content{flex:1;padding:8px;overflow-y:auto}.panel-header{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color);flex-shrink:0;padding:10px 12px;font-size:11px;font-weight:600}.element-grid{grid-template-columns:1fr 1fr;gap:6px;padding:4px 0;display:grid}.element-tool{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:grab;transition:all var(--transition);flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:12px 8px;display:flex}.element-tool:hover{background:var(--bg-hover);border-color:var(--accent);transform:translateY(-1px)}.element-tool:active{cursor:grabbing;transform:translateY(0)}.element-tool-icon{color:var(--accent);font-size:20px}.element-tool-label{color:var(--text-secondary);text-align:center;font-size:10px;font-weight:500}.canvas-area{background:var(--bg-canvas);flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.canvas-container{position:relative}.property-group{margin-bottom:12px}.property-group-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color);margin-bottom:8px;padding:8px 0 6px;font-size:11px;font-weight:600}.property-row{align-items:center;gap:8px;margin-bottom:6px;display:flex}.property-label{color:var(--text-secondary);flex-shrink:0;width:70px;font-size:11px}.property-input{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);height:28px;color:var(--text-primary);transition:border-color var(--transition);outline:none;flex:1;padding:0 8px;font-size:12px}.property-input:focus{border-color:var(--accent)}.property-input-sm{flex:none;width:60px}.property-textarea{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);min-height:60px;color:var(--text-primary);resize:vertical;transition:border-color var(--transition);outline:none;flex:1;padding:6px 8px;font-family:inherit;font-size:12px}.property-textarea:focus{border-color:var(--accent)}.property-select{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);height:28px;color:var(--text-primary);cursor:pointer;outline:none;flex:1;padding:0 6px;font-size:12px}.property-select:focus{border-color:var(--accent)}.property-color{border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;background:var(--bg-tertiary);width:28px;height:28px;padding:2px}.property-color::-webkit-color-swatch-wrapper{padding:0}.property-color::-webkit-color-swatch{border:none;border-radius:2px}.property-checkbox{cursor:pointer;align-items:center;gap:6px;display:flex}.property-checkbox input{accent-color:var(--accent)}.layer-item{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);border:1px solid #0000;align-items:center;gap:6px;padding:6px 8px;font-size:12px;display:flex}.layer-item:hover{background:var(--bg-hover)}.layer-item.selected{background:var(--accent-light);border-color:var(--accent)}.layer-item.layer-item-active-container{background:#8b5cf611;border-color:#8b5cf644}.layer-item-icon{color:var(--text-muted);flex-shrink:0}.layer-item-name{text-overflow:ellipsis;white-space:nowrap;cursor:default;flex:1;overflow:hidden}.layer-name-input{background:var(--bg-primary);border:1px solid var(--accent);min-width:0;color:var(--text-primary);border-radius:3px;outline:none;flex:1;height:18px;padding:0 4px;font-size:12px}.layer-group{margin-bottom:2px}.layer-group-header{background:var(--bg-tertiary);border-radius:var(--radius-sm)}.layer-item-actions{opacity:0;transition:opacity var(--transition);gap:2px;display:flex}.layer-item:hover .layer-item-actions{opacity:1}.layer-action-btn{width:22px;height:22px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:3px;justify-content:center;align-items:center;display:flex}.layer-action-btn:hover{background:var(--bg-active);color:var(--text-primary)}.page-item{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);border:1px solid #0000;align-items:center;gap:8px;margin-bottom:4px;padding:8px 10px;font-size:12px;display:flex}.page-item:hover{background:var(--bg-hover)}.page-item.active{background:var(--accent-light);border-color:var(--accent)}.page-item-number{background:var(--bg-tertiary);border-radius:var(--radius-sm);width:24px;height:24px;color:var(--text-secondary);justify-content:center;align-items:center;font-size:11px;font-weight:600;display:flex}.page-item.active .page-item-number{background:var(--accent);color:#fff}.page-item-name{flex:1}.page-item-delete{opacity:0;transition:opacity var(--transition)}.page-item:hover .page-item-delete{opacity:1}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);border:none;justify-content:center;align-items:center;gap:6px;padding:6px 14px;font-size:12px;font-weight:500;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:var(--danger-hover)}.btn-sm{padding:4px 10px;font-size:11px}.btn-block{width:100%}.modal-overlay{z-index:1000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);flex-direction:column;width:90%;max-width:600px;max-height:80vh;display:flex}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-title{font-size:16px;font-weight:600}.modal-close{width:28px;height:28px;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-body{flex:1;padding:20px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:8px;padding:16px 20px;display:flex}.file-menu-btn{border-radius:var(--radius-sm);align-items:center;gap:2px;height:28px;padding:0 10px;font-size:12px;font-weight:500;display:flex}.file-menu-dropdown{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);min-width:170px;box-shadow:var(--shadow-lg);z-index:500;padding:4px;position:absolute;top:calc(100% + 4px);left:0}.file-menu-item{width:100%;color:var(--text-primary);border-radius:var(--radius-sm);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:7px 10px;font-size:12px;display:flex}.file-menu-item:hover{background:var(--bg-hover)}.file-menu-divider{background:var(--border-color);height:1px;margin:4px 0}.templates-dialog{width:90vw;max-width:860px;max-height:85vh}.templates-dialog-body{padding:20px 24px}.templates-dialog-section-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:12px;font-size:10px;font-weight:700}.templates-dialog-hint{color:var(--text-muted);margin-bottom:12px;font-size:12px}.templates-dialog-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;display:grid}.templates-dialog-card-wrapper{position:relative}.templates-dialog-card-wrapper:hover .templates-dialog-delete{opacity:1}.templates-dialog-delete{z-index:10;opacity:0;border-radius:var(--radius-sm);color:#fff;cursor:pointer;background:#000000a6;border:none;justify-content:center;align-items:center;padding:4px 5px;transition:opacity .15s;display:flex;position:absolute;top:6px;right:6px}.templates-dialog-delete:hover{background:var(--danger)}.templates-dialog-card{border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);text-align:left;background:0 0;padding:0;position:relative;overflow:hidden}.templates-dialog-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.templates-dialog-preview{background:var(--bg-secondary);width:100%;line-height:0;overflow:hidden}.templates-dialog-preview img{width:100%;height:auto;display:block}.templates-dialog-overlay{color:#fff;background:linear-gradient(#0000,#000000e0);padding:28px 10px 10px;position:absolute;bottom:0;left:0;right:0}.templates-dialog-name{text-shadow:0 1px 3px #0009;font-size:12px;font-weight:700;line-height:1.3}.templates-dialog-desc{color:#fffc;text-shadow:0 1px 2px #00000080;margin-top:3px;font-size:10px;line-height:1.4;display:none}.templates-dialog-card:hover .templates-dialog-desc{display:block}.template-section-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:20px 0 8px;font-size:10px;font-weight:700}.template-section-label:first-child{padding-top:6px}.template-grid{flex-direction:column;gap:14px;display:flex}.template-card{border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);position:relative;overflow:hidden}.template-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}.template-card-preview{background:var(--bg-secondary);width:100%;line-height:0;overflow:hidden}.template-card-preview img{width:100%;height:auto;display:block}.template-card-overlay{color:#fff;background:linear-gradient(#0000,#000000e0);padding:32px 14px 14px;position:absolute;bottom:0;left:0;right:0}.template-card-name{text-shadow:0 1px 3px #0009;font-size:13px;font-weight:700;line-height:1.3}.template-card-desc{color:#ffffffd9;text-shadow:0 1px 2px #00000080;margin-top:4px;font-size:11px;line-height:1.4;display:none}.template-card:hover .template-card-desc{display:block}.validation-list{flex-direction:column;gap:6px;display:flex}.validation-item{border-radius:var(--radius-sm);align-items:flex-start;gap:8px;padding:8px 10px;font-size:12px;display:flex}.validation-item.error{color:var(--danger);background:#ff47571a}.validation-item.warning{color:var(--warning);background:#ffa5021a}.zoom-controls{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:10;align-items:center;gap:4px;padding:4px;display:flex;position:absolute;bottom:16px;right:16px}.zoom-label{color:var(--text-secondary);text-align:center;min-width:45px;padding:0 8px;font-size:11px}.page-nav{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:10;align-items:center;gap:8px;padding:4px 12px;display:flex;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.page-nav-label{color:var(--text-secondary);font-size:12px}.color-picker-popover{z-index:200;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:12px;position:absolute}.color-picker-popover .react-colorful{width:180px!important;height:150px!important}.data-preview-editor{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:100%;min-height:200px;color:var(--text-primary);resize:vertical;outline:none;padding:10px;font-family:Courier New,monospace;font-size:12px}.data-preview-editor:focus{border-color:var(--accent)}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;padding:40px 20px;display:flex}.empty-state-icon{opacity:.5;margin-bottom:12px;font-size:36px}.empty-state-text{font-size:12px}.tooltip{position:relative}.tooltip:after{content:attr(data-tooltip);background:var(--bg-primary);color:var(--text-primary);border-radius:var(--radius-sm);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity var(--transition);margin-bottom:4px;padding:4px 8px;font-size:11px;position:absolute;bottom:-100%;left:50%;transform:translate(-50%)}.tooltip:hover:after{opacity:1}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.2s fadeIn}.slide-up{animation:.2s slideUp}
/*$vite$:1*/