*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Arial,Helvetica Neue,sans-serif;font-size:14px;background:#f1f5f9;color:#1e293b;min-height:100vh}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:52px;background:#1e40af;color:#fff;flex-shrink:0;box-shadow:0 2px 6px #00000040}.header-brand{display:flex;align-items:center;gap:10px}.header-logo{font-size:22px}.header-title{font-size:18px;font-weight:700;letter-spacing:-.3px}.header-subtitle{font-size:12px;opacity:.75;margin-left:4px}.header-meta{font-size:12px;opacity:.8}.block-count{background:#fff3;padding:2px 10px;border-radius:999px}.undo-redo{display:flex;gap:4px;margin-right:8px}.undo-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:5px;width:28px;height:28px;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s;padding:0}.undo-btn:hover:not(:disabled){background:#ffffff4d}.undo-btn:disabled{opacity:.35;cursor:not-allowed}.workspace{display:flex;flex:1;overflow:hidden;min-height:0}.panel-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#64748b;margin-bottom:12px}.palette{width:200px;flex-shrink:0;background:#fff;border-right:1px solid #e2e8f0;padding:16px 12px;overflow-y:auto}.palette-hint{font-size:11px;color:#94a3b8;margin-bottom:12px}.palette-item{display:flex;align-items:center;gap:10px;padding:10px;margin-bottom:8px;border:1px solid #e2e8f0;border-radius:8px;cursor:grab;-webkit-user-select:none;user-select:none;background:#f8fafc;transition:background .15s,box-shadow .15s}.palette-item:hover{background:#eff6ff;border-color:#93c5fd;box-shadow:0 2px 6px #6395ff26}.palette-item.dragging{opacity:.4}.palette-icon{font-size:20px;flex-shrink:0;width:28px;text-align:center}.palette-label{font-size:13px;font-weight:600;color:#1e293b}.palette-desc{font-size:11px;color:#94a3b8;margin-top:1px;line-height:1.3}.palette-section{margin-top:16px;border-top:1px solid #e2e8f0;padding-top:12px}.palette-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#94a3b8;margin-bottom:4px}.table-presets-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;margin-top:6px}.table-preset-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 4px;border:1px solid #e2e8f0;border-radius:6px;background:#f8fafc;cursor:pointer;transition:background .1s,border-color .1s}.table-preset-btn:hover{background:#eff6ff;border-color:#93c5fd}.table-preset-label{font-size:9px;color:#64748b;font-weight:600;white-space:nowrap}.table-preset-mini{display:flex;flex-direction:column;gap:2px;width:36px}.table-preset-mini-row{display:flex;gap:2px;height:8px}.table-preset-mini-cell{flex:1;background:#cbd5e1;border-radius:1px}.glyphs-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:4px;margin-top:6px}.glyph-btn{display:flex;align-items:center;justify-content:center;padding:5px;border:1px solid #e2e8f0;border-radius:6px;background:#f8fafc;cursor:pointer;transition:background .1s,border-color .1s}.glyph-btn:hover{background:#eff6ff;border-color:#93c5fd}.text-editor-wrap{position:relative}.field-suggest{position:absolute;left:0;right:0;background:#fff;border:1px solid #93c5fd;border-radius:6px;box-shadow:0 4px 14px #0000001f;z-index:200;max-height:180px;overflow-y:auto}.field-suggest-item{display:block;width:100%;text-align:left;padding:6px 10px;border:none;background:none;font-size:12px;font-family:Courier New,monospace;cursor:pointer;color:#1e40af}.field-suggest-item:hover{background:#eff6ff}.canvas{flex:1;padding:16px 20px;overflow-y:auto;background:#f8fafc;border-right:1px solid #e2e8f0;min-height:0;transition:background .15s}.canvas.drop-over{background:#eff6ff}.canvas-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:60px 20px;border:2px dashed #cbd5e1;border-radius:12px;color:#94a3b8;text-align:center;margin-top:12px}.canvas-empty-icon{font-size:28px}.canvas-block{display:flex;align-items:flex-start;gap:6px;margin-bottom:8px;padding:10px;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;cursor:pointer;box-shadow:0 1px 3px #0000000a;transition:border-color .15s,box-shadow .15s;position:relative}.canvas-block:hover{border-color:#a5b4fc}.canvas-block.selected{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f}.block-handle{cursor:grab;padding:2px 4px;color:#cbd5e1;font-size:16px;flex-shrink:0;border-radius:4px;transition:color .15s;touch-action:none}.block-handle:hover{color:#94a3b8}.block-content{flex:1;min-width:0;overflow:hidden}.block-remove{flex-shrink:0;background:none;border:none;cursor:pointer;color:#cbd5e1;font-size:14px;padding:2px 5px;border-radius:4px;line-height:1;transition:color .15s,background .15s}.block-remove:hover{color:#ef4444;background:#fef2f2}.image-placeholder{border:1px dashed #cbd5e1;border-radius:6px;padding:12px;color:#94a3b8;font-size:12px;text-align:center}.img-mode-toggle{display:flex;gap:0;border:1.5px solid #e2e8f0;border-radius:6px;overflow:hidden;margin-bottom:10px}.img-mode-btn{flex:1;padding:5px 0;font-size:12px;font-weight:500;background:transparent;border:none;cursor:pointer;color:#64748b;transition:background .12s,color .12s}.img-mode-btn.active{background:#6366f1;color:#fff}.image-drop-zone{border:1.5px dashed #c7d2fe;border-radius:8px;padding:20px 12px;text-align:center;cursor:pointer;background:#fafafa;transition:border-color .15s,background .15s;margin-bottom:6px;display:flex;align-items:center;justify-content:center;min-height:72px}.image-drop-zone:hover,.image-drop-zone.dragging{border-color:#6366f1;background:#eef2ff}.image-drop-zone.has-image{padding:8px;border-style:solid;border-color:#e2e8f0}.image-drop-zone.has-image:hover{border-color:#6366f1}.drop-zone-icon{font-size:22px;margin-bottom:4px;color:#a5b4fc}.drop-zone-hint{color:#94a3b8;font-size:12px;line-height:1.5}.drop-zone-sub{font-size:10px;color:#cbd5e1;margin-top:2px}.image-clear-btn{display:block;width:100%;margin-bottom:10px;padding:4px 0;font-size:12px;color:#ef4444;background:transparent;border:1px solid #fecaca;border-radius:4px;cursor:pointer;transition:background .12s}.image-clear-btn:hover{background:#fef2f2}.img-size-row{display:flex;align-items:flex-end;gap:4px}.img-lock-btn{margin-bottom:4px}.lock-icon{font-size:14px;color:#cbd5e1;transition:color .12s}.lock-icon.locked{color:#6366f1}.social-icon-list{display:flex;flex-direction:column;gap:10px;margin-bottom:10px}.social-icon-row{display:flex;gap:8px;align-items:flex-start}.social-icon-thumb{display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.social-icon-actions{display:flex;flex-direction:column;gap:2px;flex-shrink:0}.icon-order-btn{width:22px;height:22px;padding:0;font-size:12px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:4px;cursor:pointer;color:#64748b;line-height:1}.icon-order-btn:disabled{opacity:.35;cursor:default}.icon-order-btn:not(:disabled):hover{background:#e2e8f0}.icon-remove-btn{width:22px;height:22px;padding:0;font-size:11px;background:transparent;border:1px solid #fecaca;border-radius:4px;cursor:pointer;color:#ef4444;margin-top:2px;line-height:1}.icon-remove-btn:hover{background:#fef2f2}.social-add-btn{width:100%;padding:6px 0;font-size:12px;font-weight:500;color:#6366f1;background:#eef2ff;border:1.5px dashed #a5b4fc;border-radius:6px;cursor:pointer;transition:background .12s}.social-add-btn:hover{background:#e0e7ff}.properties{width:260px;flex-shrink:0;background:#fff;padding:16px 14px;overflow-y:auto}.props-empty{color:#94a3b8;font-size:13px;line-height:1.5;margin-top:4px}.prop-type-badge{display:inline-block;background:#dbeafe;color:#1d4ed8;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 8px;border-radius:999px;margin-bottom:14px}.prop-label{display:flex;flex-direction:column;gap:4px;margin-bottom:12px;font-size:12px;font-weight:600;color:#475569}.prop-input,.prop-select,.prop-textarea{width:100%;padding:6px 8px;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;color:#1e293b;background:#f8fafc;font-family:inherit;transition:border-color .15s}.prop-input:focus,.prop-select:focus,.prop-textarea:focus{outline:none;border-color:#3b82f6;background:#fff}.prop-textarea{resize:vertical;min-height:80px}.prop-color{width:40px;height:32px;padding:2px;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;background:#f8fafc}.prop-file{font-size:12px;padding:4px 0}.prop-fieldset{border:1px solid #e2e8f0;border-radius:8px;padding:10px 12px 4px;margin-top:12px}.prop-fieldset legend{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#94a3b8;padding:0 4px}.prop-sub-legend{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#94a3b8;margin:8px 0 4px}.prop-label-row{flex-direction:row;align-items:center;gap:8px}.prop-hint{font-size:12px;color:#94a3b8;margin-top:4px}.preview{background:#fff;border-top:1px solid #e2e8f0;flex-shrink:0;max-height:340px;display:flex;flex-direction:column}.preview-header{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid #e2e8f0;background:#f8fafc;flex-wrap:wrap}.preview-tabs-nav{display:flex;gap:4px}.tab-btn{padding:4px 14px;border-radius:6px;border:1px solid #e2e8f0;background:transparent;font-size:12px;font-weight:600;color:#64748b;cursor:pointer;transition:background .15s,color .15s}.tab-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.tab-btn:not(.active):hover{background:#f1f5f9}.preview-actions{display:flex;gap:8px;margin-left:auto}.preview-body{flex:1;overflow:auto}.preview-frame{padding:16px 20px;min-height:80px}.preview-source{padding:14px 16px;font-family:Courier New,monospace;font-size:12px;color:#334155;background:#f8fafc;white-space:pre-wrap;word-break:break-all;overflow-y:auto;min-height:80px}.test-data-panel{border-top:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0;background:#f8fafc;padding:12px 16px}.test-data-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px}.test-data-field{display:flex;flex-direction:column;gap:3px}.test-data-key{font-size:10px;font-family:Courier New,monospace;color:#1e40af;font-weight:600}.btn-primary{padding:6px 16px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{padding:6px 16px;background:#f1f5f9;color:#334155;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.btn-secondary:hover:not(:disabled){background:#e2e8f0}.btn-secondary.active{background:#dbeafe;border-color:#93c5fd;color:#1e40af}.btn-danger{width:100%;padding:8px;background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.btn-danger:hover{background:#fee2e2}.drag-overlay{padding:8px 18px;background:#1e40af;color:#fff;border-radius:8px;font-size:13px;font-weight:700;box-shadow:0 8px 24px #00000040;pointer-events:none}.table-block{border-collapse:collapse;width:100%;table-layout:fixed}.table-block-nested{font-size:12px}.table-cell{border:1px solid #e2e8f0;padding:6px;min-width:60px;min-height:36px;vertical-align:top;cursor:pointer;transition:outline .1s;outline:2px solid transparent;outline-offset:-1px}.table-cell:hover{outline-color:#6366f147}.table-cell-selected{outline:2.5px solid #6366f1!important;outline-offset:-1px!important;cursor:default}.table-block-nested .table-cell{min-width:40px;min-height:24px;padding:4px}.cell-empty-hint{font-size:11px;color:#94a3b8;pointer-events:none;-webkit-user-select:none;user-select:none}.cell-el-item{margin-bottom:5px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:4px 6px}.cell-el-row{display:flex;align-items:center;justify-content:space-between;gap:4px}.cell-el-preview{flex:1;min-width:0;overflow:hidden}.cell-el-remove{flex-shrink:0;background:none;border:none;cursor:pointer;color:#94a3b8;font-size:12px;padding:2px 4px;border-radius:4px;line-height:1;transition:color .12s,background .12s}.cell-el-remove:hover{color:#ef4444;background:#fef2f2}.cell-el-editor{margin-top:6px;padding-top:6px;border-top:1px solid #e2e8f0}.cell-el-textarea,.cell-el-input,.cell-el-select{width:100%;padding:4px 6px;border:1px solid #e2e8f0;border-radius:5px;font-size:12px;font-family:inherit;background:#f8fafc;color:#1e293b}.cell-el-textarea:focus,.cell-el-input:focus,.cell-el-select:focus{outline:none;border-color:#3b82f6;background:#fff}.cell-el-textarea{min-height:50px;resize:vertical}.cell-style-row{display:flex;align-items:center;gap:4px;margin-top:4px;flex-wrap:wrap}.cell-style-row input[type=color]{width:28px;height:24px;padding:1px;border:1px solid #e2e8f0;border-radius:4px;cursor:pointer}.cell-style-row select{font-size:11px;padding:2px 4px;border:1px solid #e2e8f0;border-radius:4px;background:#f8fafc;cursor:pointer}.cell-size-input{width:52px;padding:2px 4px;border:1px solid #e2e8f0;border-radius:4px;font-size:11px;background:#f8fafc}.cell-add-bar{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px;padding-top:6px;border-top:1px dashed #bfdbfe}.cell-add-btn{padding:3px 8px;font-size:11px;font-weight:600;background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe;border-radius:5px;cursor:pointer;transition:background .12s}.cell-add-btn:hover{background:#dbeafe}.cell-nested-table-wrap{margin:4px 0}.cell-nested-table-header{display:flex;align-items:center;justify-content:space-between;padding:2px 6px;background:#f0fdf4;border:1px solid #bbf7d0;border-bottom:none;border-radius:4px 4px 0 0}.cell-nested-table-label{font-size:11px;color:#16a34a;font-weight:600}.prop-divider{height:1px;background:#e2e8f0;margin:14px 0}.cell-edit-status{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:10px 12px}.cell-edit-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#3b82f6;margin-bottom:4px}.cell-edit-path{font-size:12px;color:#1e40af;font-family:Courier New,monospace;margin-bottom:8px;line-height:1.5}.cell-deselect-btn{font-size:11px;padding:3px 10px;background:#dbeafe;color:#1d4ed8;border:1px solid #bfdbfe;border-radius:5px;cursor:pointer;font-weight:600;transition:background .12s}.cell-deselect-btn:hover{background:#bfdbfe}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}
