UNPKG

@mindfiredigital/page-builder

Version:
1 lines 29 kB
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap");body,html{background-color:#f8fafc;color:#334155;display:flex;flex-direction:column;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0;overflow:hidden;padding:0}#preview-navbar{align-items:center;background-color:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a;display:flex;justify-content:space-between;padding:0 12px}.preview-btn{background-color:#fff;border:1px solid #fff;color:#64748b;cursor:pointer;padding:6px 8px;transition:all .2s ease}.preview-btn:hover{background-color:#f1f5f9;border-color:#cbd5e1;color:#475569}.preview-btn:active{background-color:#e2e8f0}#app{background-color:#f8fafc;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;overflow:hidden}#sidebar{background-color:#fff;border-right:1px solid #e2e8f0;flex-shrink:0;overflow-y:auto;padding:16px 12px;width:180px}#sidebar h3{color:#1e293b;font-size:16px;font-weight:600;margin-bottom:20px;text-align:center}#canvas{background-color:#fff;background-image:linear-gradient(90deg,#f1f5f9 1px,#0000 0);box-sizing:border-box;flex-grow:1;height:calc(100vh - 40px);min-width:0;overflow:auto;width:100%}#canvas.grid-layout-active{display:block;height:calc(100vh - 40px)}#canvas.preview-printable{background-color:#fff;border-radius:4px;box-shadow:0 4px 12px #00000026;margin-left:auto;margin-right:auto;max-height:1123px;max-width:869px;overflow:auto;padding-left:75px;padding-right:75px;padding-top:75px;position:relative}#canvas.preview-printable:before{border-left:1.5px solid #94a3b8;left:75px}#canvas.preview-printable:after,#canvas.preview-printable:before{border-top:1.5px solid #94a3b8;content:"";height:20px;pointer-events:none;position:absolute;top:75px;width:20px;z-index:1}#canvas.preview-printable:after{border-right:1.5px solid #94a3b8;right:75px}#canvas.preview-printable{background-image:linear-gradient(90deg,#94a3b8 1.5px,#0000 0),linear-gradient(180deg,#94a3b8 1.5px,#0000 0),linear-gradient(270deg,#94a3b8 1.5px,#0000 0),linear-gradient(180deg,#94a3b8 1.5px,#0000 0);background-position:75px calc(100% - 75px),75px calc(100% - 75px),calc(100% - 75px) calc(100% - 75px),calc(100% - 75px) calc(100% - 75px);background-repeat:no-repeat;background-size:20px 1.5px,1.5px 20px,20px 1.5px,1.5px 20px}#canvas.preview-printable.grid-layout-active{border-radius:0;box-shadow:none;margin:0;max-width:100%;padding:0}#customization{background-color:#fff;border-left:1px solid #e2e8f0;box-shadow:-1px 0 3px #0000001a;color:#334155;display:none;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:13px;line-height:1.5;overflow:auto;padding:0;position:relative;right:0;width:300px}.draggable{align-items:center;background-color:#f8fafc;border:1px solid #f1f5f9;border-radius:6px;box-sizing:border-box;color:#64748b;cursor:grab;display:inline-block;display:inline-flex;flex-direction:column;font-size:11px;gap:6px;justify-content:center;margin-bottom:12px;margin-right:8px;min-height:70px;padding:12px 8px;text-align:center;transition:all .2s ease;vertical-align:top;width:calc(50% - 6px)}.draggable:nth-child(2n){margin-right:4px}.category{display:block;margin-bottom:20px;width:100%}.draggable:hover{background-color:#f1f5f9;border-color:#e2e8f0;box-shadow:0 2px 4px #0000000d;transform:translateY(-1px)}.draggable:active{cursor:grabbing}.component{background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 1px 3px #0000001a;cursor:pointer;padding:16px;position:relative;transition:all .2s ease}.component:hover{border-color:#94a3b8;box-shadow:0 2px 8px #0000001a}.text-component{color:#334155;font-size:16px;line-height:1.5}.button-component{background-color:#3b82f6;border:none;color:#000;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.button-component:hover{transform:translateY(-1px)}.header-component{color:#1e293b;font-size:24px;font-weight:700;margin:0}.image-component{background-color:#f8fafc;border:2px dashed #cbd5e1;border-radius:6px;display:flex;justify-content:center;max-width:100%;overflow:hidden;position:relative}.preview-desktop,.preview-tablet{max-width:100%;transition:all .5s ease}.preview-tablet{border-radius:8px;box-shadow:0 4px 12px #0000001a;margin-left:auto;margin-right:auto;max-width:768px;overflow-x:hidden}@media (max-width:768px){.preview-tablet{width:100%}}.canvas{overflow-x:hidden}.preview-mobile{border-radius:12px;box-shadow:0 4px 12px #00000026;margin-left:auto;margin-right:auto;max-width:375px;transition:all .5s ease}.table-cell-content{box-sizing:border-box;height:100%;padding:8px 12px;width:100%}.hidden{display:none}.editable-component{background-color:#fff;border:1px dashed #cbd5e1;cursor:text;pointer-events:auto;position:relative;transition:all .2s ease}.component-text-content{box-sizing:border-box;display:block;height:100%;width:100%}.component-resizer{overflow:hidden!important;resize:both!important}.container-component{border:1px dashed #cbd5e1;border-radius:4px;box-sizing:border-box;min-height:100px;min-width:100px;pointer-events:auto;position:relative}.container-component:hover{border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f666}.container-component.container-grid-active{display:block}.container-highlight{border-color:#3b82f6!important;box-shadow:0 0 0 2px #3b82f61a!important}.component-icon{height:28px;object-fit:contain;opacity:.7;transition:opacity .2s ease;width:28px}.draggable:hover .component-icon{opacity:1}.custom-component-letter{align-items:center;background-color:#3b82f6;border-radius:4px;color:#fff;display:flex;font-size:14px;font-weight:600;height:28px;justify-content:center;width:28px}.drag-text{color:#6b7280;font-size:10px;font-weight:500;line-height:1.2;margin-top:4px;text-align:center}.nav-icon{height:25px;object-fit:contain;width:25px}.left-buttons,.right-buttons{display:flex;gap:8px}.center-text{align-items:center;color:#1e293b;display:flex;flex-grow:1;font-size:18px;font-weight:600;justify-content:center;text-align:center}.column-label,.component-label{background-color:#1e293b;border-radius:4px;color:#fff;display:none;font-size:10px;font-weight:500;left:6px;padding:2px 6px;pointer-events:none;position:absolute;top:-2px;z-index:9000}.column:hover .column-label{display:block}.upload-btn{background-color:#ffffffe6;border:1px solid #e2e8f0;border-radius:4px;color:#64748b;cursor:pointer;display:none;font-size:14px;left:8px;padding:6px;position:absolute;top:8px;transition:all .2s ease;z-index:10}.image-component:hover .upload-btn{display:block}.upload-btn:hover{background-color:#f1f5f9;color:#475569}.notification{background-color:#10b981;border-radius:6px;bottom:20px;box-shadow:0 4px 12px #10b9814d;color:#fff;font-size:14px;font-weight:500;opacity:0;padding:12px 20px;position:fixed;right:20px}.notification.visible{opacity:1}.notification.hidden{opacity:0}.dialog{align-items:center;background:#00000080;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.dialog.hidden{display:none}.dialog-content{background:#fff;border-radius:8px;box-shadow:0 10px 25px #0003;padding:24px;text-align:center;width:350px}.dialog-btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;margin:8px 6px;padding:10px 20px}#dialog-yes{background-color:#ef4444;color:#fff}#dialog-yes:hover{background-color:#dc2626}#dialog-no{background-color:#f1f5f9;border:1px solid #e2e8f0;color:#64748b}#dialog-no:hover{background-color:#e2e8f0}.component-controls{align-items:center;background-color:#fffffff2;border-radius:4px;box-shadow:0 1px 3px #0000001a;cursor:pointer;display:none;padding:2px;position:absolute;right:4px;top:4px;z-index:9000}.component-controls img{pointer-events:auto}.delete-icon{cursor:pointer;height:14px;opacity:.7;transition:all .2s ease;width:14px}.delete-icon:hover{opacity:1;transform:scale(1.1)}.layers-mode-toggle{background-color:#f8fafc;border-bottom:1px solid #e2e8f0;margin:0;padding:0}.layers-mode-toggle button{background-color:initial;border:none;border-right:1px solid #e2e8f0;color:#64748b;font-size:12px;padding:10px 12px}.layers-mode-toggle button:last-child{border-right:none}.layers-mode-toggle button:hover{background-color:#f1f5f9;color:#334155}#component-name{background-color:#f8fafc;border-bottom:1px solid #e2e8f0;border-radius:0;color:#334155;font-size:13px;font-weight:600;margin:0;padding:12px 14px}#component-name span{color:#64748b;font-size:11px;font-weight:400}#controls{background-color:#fff;gap:0;height:calc(100vh - 139px);overflow:auto;padding:0}.control-wrapper{background-color:initial;border:none;border-bottom:1px solid #e2e8f0;border-radius:0;display:flex;flex-direction:column;gap:6px;margin:0;padding:10px 14px}.control-wrapper:last-child{border-bottom:none}.control-wrapper label{color:#64748b;display:block;font-size:12px;font-weight:500;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.control-wrapper input[type=number],.control-wrapper input[type=text]{background-color:#fff;border:1px solid #cbd5e1;border-radius:3px;color:#334155;font-size:13px;padding:8px 10px;transition:all .2s ease}.control-wrapper input[type=number]:focus,.control-wrapper input[type=text]:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633;outline:none}.control-wrapper select{background-color:#fff;border:1px solid #cbd5e1;border-radius:3px;color:#334155;font-size:13px;padding:8px 10px;transition:all .2s ease}.control-wrapper select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633;outline:none}.input-wrapper{align-items:center;display:flex;gap:8px}.input-wrapper input[type=number]{font-size:12px;padding:6px 8px;width:60px}.input-wrapper select{font-size:12px;min-width:50px;padding:6px 8px}.control-wrapper input[type=color]{background-color:initial;border:1px solid #fff;border-radius:4px;cursor:pointer;height:32px;margin:0;padding:0;width:32px}.control-wrapper input[type=color]:hover{border-color:#94a3b8}#color-value{background-color:#f8fafc;border:1px solid #cbd5e1;border-radius:3px;color:#334155;font-family:Courier New,monospace;font-size:12px;padding:4px 6px;width:70px}.close-button{align-items:center;background-color:red;border:1px solid #000;border-radius:3px;color:#000;cursor:pointer;display:flex;font-size:15px;height:26px;justify-content:center;position:fixed;right:18.3rem;top:3.5rem;transition:all .2s ease;width:26px}.close-button:hover{background-color:#ef4444;border-color:#ef4444;color:#fff}#functions-panel{color:#334155;padding:0}#functions-panel .control-wrapper{background-color:initial;border-bottom:1px solid #e2e8f0}#functions-panel .control-wrapper:last-child{border-bottom:none}#layers-view{background-color:#fff;color:#334155;font-size:13px;padding:14px}.control-wrapper.compact{gap:6px;padding:8px 14px}.control-wrapper.compact label{font-size:11px;min-width:60px}.control-wrapper.vertical{align-items:flex-start;flex-direction:column}.control-wrapper:hover{background-color:#3b82f60d}#customization::-webkit-scrollbar{width:4px}#customization::-webkit-scrollbar-track{background:#f8fafc}#customization::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:2px}#customization::-webkit-scrollbar-thumb:hover{background:#94a3b8}#customization *{font-size:inherit;line-height:inherit}.control-wrapper input,.control-wrapper select{box-sizing:border-box;width:100%}.input-wrapper input,.input-wrapper select{flex:1;width:auto}.control-wrapper label{opacity:.9}.control-wrapper input:focus+label,.control-wrapper select:focus+label{color:#3b82f6}.control-wrapper input[type=checkbox]{accent-color:#3b82f6;height:18px;margin:0;width:18px}#functions-panel button{background-color:#3b82f6;border:none;border-radius:3px;color:#fff;cursor:pointer;font-size:12px;padding:8px 14px;transition:all .2s ease}#functions-panel button:hover{background-color:#2563eb}.set-attribute-button{background-color:#3b82f6;border:none;border-radius:3px;color:#fff;cursor:pointer;display:block;font-size:12px;margin-bottom:6px;padding:8px 14px;transition:all .2s ease;width:100%}.set-attribute-button:hover{background-color:#2563eb}.delete-attribute-button{background-color:#fff1f2!important;border:1px solid #fecaca!important;border-radius:3px;color:#dc2626!important;cursor:pointer;display:block;font-size:12px;margin-bottom:6px;padding:8px 14px;transition:all .2s ease;width:100%}.delete-attribute-button:hover{background-color:#fee2e2!important;border-color:#f87171!important;color:#b91c1c!important}.input-wrapper{flex-wrap:wrap}.input-wrapper input[type=text]{flex:none;font-family:Courier New,monospace;font-size:11px;width:70px}#preview-modal{background-color:#fff;height:100%;left:0;overflow:auto;position:fixed;top:0;width:100%;z-index:9999}#close-modal-btn{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:4px;color:#64748b;cursor:pointer;font-size:18px;height:36px;left:16px;position:absolute;top:16px;transition:all .2s ease;width:36px;z-index:10000}#close-modal-btn:hover{background-color:#f1f5f9;color:#475569}.modal{align-items:center;background:#00000080;display:none;height:100%;justify-content:center;left:0;position:fixed;top:0;transition:all .3s ease;width:100%;z-index:9000}.modal.show{display:flex;opacity:1}.modal.hide{opacity:0}.export-modal-content{background:#fff;border-radius:8px;box-shadow:0 10px 25px #0003;display:flex;height:70%;max-height:600px;max-width:1000px;padding:20px;position:relative;width:90%}.close-btn{position:absolute;right:2px}.modal-section{width:50%}.modal-section h2{color:#1e293b;font-size:18px;font-weight:600;margin-bottom:12px}.code-block{background-color:#1e293b;border:1px solid #e2e8f0;border-radius:6px;color:#e2e8f0;font-family:JetBrains Mono,Fira Code,Courier New,monospace;font-size:12px;height:80%;line-height:1.5;overflow-y:auto;padding:16px;white-space:pre-wrap;width:95%}.tag{color:#7dd3fc}.attribute{color:#fbbf24}.string{color:#34d399}.property{color:#a78bfa}.value{color:#fbbf24}.bracket{color:#f97316}.button-wrapper{display:flex;flex-direction:column;gap:8px;padding:20px}.export-btn{background-color:#3b82f6;border:none;border-radius:6px;bottom:20px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;position:absolute;right:20px;transition:all .2s ease}.export-btn:hover{background-color:#2563eb;transform:translateY(-1px)}.modal-search-container{align-items:center;display:flex;position:relative}.search-icon{color:#999;height:18px;position:absolute;right:20px;width:18px}.modal-search-input{border-radius:5px;outline:none;padding:5px;width:100%}.table-component{background-color:#fff;border-radius:6px;border-radius:4px;box-shadow:0 1px 3px #0000001a;overflow:auto;padding:12px}.table-cell{box-sizing:border-box}.table-row{border-inline:1px solid #2f3132;padding:0 .7px}.link-component{align-items:center;background-color:#fff;border:none;border-radius:4px;display:flex;gap:8px;padding:8px}.link-component-label{color:#3b82f6;cursor:pointer;font-size:14px;font-weight:500;margin:0;text-decoration:none;transition:all .2s ease}.link-component-label:hover{color:#2563eb;text-decoration:underline}.edit-link{background-color:#f8fafc!important;border:1px solid #e2e8f0;border-radius:3px;bottom:2px;color:#64748b;cursor:pointer;display:none;font-size:10px;font-weight:500;left:4px;padding:2px 6px;position:absolute;transition:all .2s ease}.link-component:hover .edit-link{display:block}.edit-link:hover{background-color:#f1f5f9!important}.edit-link-form{background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 2px 8px #0000001a;display:none;flex-direction:column;gap:8px;padding:12px}.edit-link-form button,.edit-link-form input{border:1px solid #d1d5db;border-radius:4px;font-size:13px;padding:6px 10px;transition:all .2}.edit-link-form button{background-color:#3b82f6;border:none;color:#fff;cursor:pointer;font-weight:500}.edit-link-form button:hover{background-color:#2563eb}.categoryHeading{color:#9ca3af;font-size:11px;font-weight:600;letter-spacing:.5px;margin:0 0 16px;padding-left:4px;text-align:left;text-transform:uppercase}.video-component{align-items:center;background-color:#f8fafc;border:2px dashed #cbd5e1;border-radius:6px;display:flex;height:300px;justify-content:center;position:relative;width:300px}.video-component .upload-text{color:#64748b;font-weight:500;text-align:center}.export-dropdown{background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 4px 12px #0000001a;display:none;margin-top:4px;overflow:hidden;position:absolute;right:20px;z-index:1000}.export-dropdown.visible{display:block}.export-option{background:#0000;border:none;color:#374151;cursor:pointer;font-size:13px;font-weight:500;padding:10px 16px;text-align:left;transition:all .2s ease;width:100%}.export-option:hover{background-color:#f8fafc;color:#1e293b}.expand-config{display:flex;flex-direction:column;gap:8px;padding:12px 0}.dropdown-btn{background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#374151;cursor:pointer;font-size:14px;font-weight:600;padding:12px 16px;text-align:left;transition:all .2s ease;width:100%}.dropdown-btn.active{background-color:#f8fafc;border-color:#3b82f6;color:#3b82f6}.dropdown-btn:hover{background-color:#f8fafc;border-color:#cbd5e1}#functions-panel,.dropdown-panel{background-color:#fff;border-left:3px solid #3b82f6;border-radius:4px;box-shadow:0 1px 3px #0000000d;margin-top:6px;padding:12px}#functions-panel{display:flex;flex-direction:column}.layers-mode-toggle{border:1px solid #e2e8f0;border-radius:6px;display:flex;margin-bottom:12px;overflow:hidden}.layers-mode-toggle button{background-color:#f8fafc;border:1px solid #e2e8f0;color:#374151;cursor:pointer;flex:1;font-size:13px;font-weight:500;padding:4px;transition:all .2s ease}.layers-mode-toggle button.active{background-color:#3b82f6;border-color:#3b82f6;color:#fff}.layers-mode-toggle button:hover:not(.active){background-color:#f1f5f9;color:#1e293b}.layer-item{align-items:center;background-color:#fff;border:1px solid #f1f5f9;border-radius:6px;color:#374151;display:flex;font-size:13px;justify-content:space-between;list-style:none;margin-bottom:2px;min-height:36px;padding:10px 2px;transition:all .2s ease}.layer-item:hover{background-color:#f8fafc;border-color:#e2e8f0;transform:translateX(2px)}.layer-children{border-left:2px solid #f1f5f9;list-style:none;margin:4px 0;max-height:0;overflow:hidden;padding:0 0 0 16px;transition:all .3s ease}.layer-children.expanded{max-height:400px;opacity:1}.layer-expand-toggle{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:4px;color:#64748b;cursor:pointer;font-size:14px;margin-right:10px;min-width:24px;padding:4px 6px;text-align:center;transition:all .2s ease}.layer-expand-toggle:hover{background-color:#f1f5f9;color:#374151}.drop-preview{background-color:#3b82f60d;border:2px dashed #3b82f6;border-radius:4px;display:none;pointer-events:none;position:absolute}.drop-preview.visible{display:block}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media (max-width:1200px){#sidebar{width:90px}.draggable{width:100%}.draggable,.draggable:nth-child(2n){margin-right:0}#customization{width:320px}}@media (max-width:1400px){#customization{width:300px}}@media (max-width:550px){.nav-icon{height:20px;width:20px}.preview-btn{padding:4px 6px}.center-text{font-size:17px}}.modal-overlay{align-items:center;backdrop-filter:blur(2px);background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}.modal-content{animation:fadeInScale .2s ease-out;background-color:#fff;border:1px solid #0000000d;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;max-width:500px;overflow:hidden;position:relative;width:100%;z-index:10001}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95) translate3d(0,-10px,0)}to{opacity:1;transform:scale(1) translateZ(0)}}.modal-header{background-color:#fafafa;border-bottom:1px solid #e5e5e5;padding:20px 24px}.modal-header-content{align-items:center;display:flex;justify-content:space-between}.modal-title{color:#111827;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:18px;font-weight:600;margin:0}.modal-close-button{align-items:center;background:none;border:none;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all .2s ease}.modal-close-button:hover{background-color:#f3f4f6;color:#374151}.modal-close-button svg{height:20px;width:20px}.modal-body{max-height:60vh;overflow-y:auto;padding:24px}.modal-form{gap:16px}.form-field,.modal-form{display:flex;flex-direction:column}.form-field{background-color:#fefefe;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.form-field-header{align-items:center;background-color:#f8fafc;border-bottom:1px solid #e5e7eb;cursor:pointer;display:flex;padding:12px 16px;transition:background-color .2s ease}.form-field-header:hover{background-color:#f1f5f9}.expand-button{align-items:center;background:none;border:none;color:#6b7280;cursor:pointer;display:flex;justify-content:center;margin-right:12px;padding:0}.expand-icon{height:16px;transition:transform .2s ease;width:16px}.title-key-container{display:flex;flex:1;flex-direction:column;gap:2px}.form-title{color:#374151;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;font-weight:600}.form-key{color:#6b7280;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:12px;font-weight:500}.form-value-container{background-color:#fff;overflow:hidden;padding:16px;transition:all .3s ease}.form-value-collapsed{max-height:0;opacity:0;padding-bottom:0;padding-top:0}.form-label{color:#374151;font-size:13px;font-weight:600;letter-spacing:.025em;margin-bottom:8px;margin-right:6px;text-transform:uppercase}.form-input,.form-label{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.form-input{background-color:#fff;border:1px solid #d1d5db;border-radius:8px;font-size:14px;padding:12px 14px;transition:all .2s ease}.form-input:focus{background-color:#fefefe;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.form-input:disabled{background-color:#f9fafb;color:#6b7280;cursor:not-allowed}.form-display-value{word-wrap:break-word;border-radius:8px;color:#374151;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;user-select:text;white-space:pre-wrap}.image-wrapper{align-items:center;display:flex;flex-direction:column;gap:12px}.image-preview{border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a;max-height:160px;max-width:240px;object-fit:contain;width:100%}.image-input{width:100%}.error-text{color:#dc2626;font-size:13px;font-weight:500}.modal-footer{background-color:#fafafa;border-top:1px solid #e5e5e5;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.save-button{background-color:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;font-weight:600;min-width:80px;padding:10px 20px;transition:all .2s ease}.save-button:hover{background-color:#1d4ed8;box-shadow:0 4px 8px #2563eb4d;transform:translateY(-1px)}.save-button:active{transform:translateY(0)}.save-button:focus{box-shadow:0 0 0 3px #2563eb4d;outline:none}.modal-hidden{display:none!important}.form-field.selected{border:2px solid #2563eb;box-shadow:0 0 0 2px #2563eb4d;transform:translateY(-2px);transition:all .2s ease-in-out}.attribute-input-container{background:#fff;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-wrap:wrap;margin-bottom:20px;padding:6px;position:relative;transition:all .2s ease}.attribute-input-container:hover{border-color:#cbd5e1;box-shadow:0 2px 4px #0000000d}.attribute-input-container.input-focused{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.attribute-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:5px}.attribute-label{color:#374151;font-size:14px;font-weight:600;margin:0}.readonly-badge{background:#fef3c7;border-radius:12px;color:#92400e;font-size:11px;font-weight:500;letter-spacing:.5px;padding:2px 8px;text-transform:uppercase}.attribute-input-wrapper{align-items:center;display:flex;position:relative}.attribute-input{background:#fff;border:2px solid #e5e7eb;border-radius:6px;font-family:inherit;font-size:14px;outline:none;padding:10px 12px;transition:all .2s ease;width:100%}.attribute-input:focus{background:#fefefe;border-color:#3b82f6}.attribute-input:disabled{background:#f9fafb;border-color:#d1d5db;color:#6b7280;cursor:not-allowed}.attribute-input::placeholder{color:#9ca3af;font-style:italic}.input-status-indicator{border-radius:50%;height:8px;position:absolute;right:8px;transition:all .2s ease;width:8px}.input-status-indicator.editable{background:#10b981;box-shadow:0 0 4px #10b9814d}.input-status-indicator.readonly{background:#f59e0b;box-shadow:0 0 4px #f59e0b4d}.event-configurator{border-top:1px solid #f3f4f6;margin-top:10px;padding-top:10px;width:100%}.event-trigger-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:1px;padding:8px}.trigger-header{align-items:center;display:flex;gap:6px;margin-bottom:8px}.trigger-icon{color:#f59e0b;font-size:14px}.trigger-label{color:#4b5563;font-size:12px!important;font-weight:600;letter-spacing:.5px;margin:0;text-transform:uppercase}.trigger-select-wrapper{display:inline-block;position:relative;width:100%}.event-selector{appearance:none;background:#fff;border:1px solid #d1d5db;border-radius:4px;color:#374151;cursor:pointer;font-size:12px!important;padding:6px 30px 6px 10px;transition:all .2s ease;width:100%}.event-selector:hover{border-color:#9ca3af}.event-selector:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;outline:none}.select-arrow{color:#6b7280;font-size:10px;pointer-events:none;position:absolute;right:10px;top:50%;transform:translateY(-50%);transition:transform .2s ease}.trigger-select-wrapper:hover .select-arrow{color:#374151}.trigger-select-wrapper.trigger-changed{animation:pulse-border .3s ease}.trigger-select-wrapper.trigger-changed .select-arrow{transform:translateY(-50%) rotate(180deg)}@keyframes pulse-border{0%{border-color:#d1d5db}50%{border-color:#10b981}to{border-color:#d1d5db}}@media (prefers-color-scheme:dark){.attribute-input-container{background:#1f2937;border-color:#374151}.attribute-label{color:#f9fafb}.attribute-input{background:#111827;border-color:#4b5563;color:#f9fafb}.attribute-input:focus{background:#1f2937}.event-trigger-section{background:#111827;border-color:#374151}.trigger-label{color:#d1d5db}.event-selector{background:#1f2937;border-color:#4b5563;color:#f9fafb}}.rules-panel{display:flex;flex-direction:column;gap:1rem;padding:1rem}.panel-title{color:#1a202c;font-size:1.25rem;font-weight:700;margin:0}.rules-list{display:flex;flex-direction:column;gap:.75rem}.rule-item{align-items:center;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 1px 2px 0 #0000000d;display:flex;justify-content:space-between;padding:.75rem}.rule-item-text{color:#4a5568;font-size:.875rem}.rule-item-text strong{color:#2b6cb0}.rule-item-text strong:nth-child(2){color:#38a169}.rule-item-text strong:nth-child(3){color:#805ad5}.delete-rule-btn{background:none;border:none;border-radius:.25rem;color:#a0aec0;cursor:pointer;padding:.25rem;transition:color .2s ease-in-out}.delete-rule-btn:hover{color:#e53e3e}.rule-builder-form{border-top:1px solid #e2e8f0}.rule-builder-form-title{color:#2d3748;font-size:1.125rem;font-weight:600;margin-bottom:1rem}.form-row{display:flex;gap:.5rem;margin-bottom:1rem}.form-row input,.form-row select{border:1px solid #e2e8f0;border-radius:.375rem;box-shadow:0 1px 2px 0 #0000000d;flex:1;outline:none;padding:.5rem .1rem}.form-row input:focus,.form-row select:focus{border-color:#4299e1;box-shadow:0 0 0 2px #4299e133}.add-rule-btn{align-items:center;background-color:#3182ce;border:none;border-radius:.375rem;box-shadow:0 1px 2px 0 #0000000d;color:#fff;cursor:pointer;display:flex;flex:1;gap:.5rem;justify-content:center;padding:.5rem;transition:background-color .2s ease-in-out}.add-rule-btn:hover{background-color:#2b6cb0}.icon{height:1rem;width:1rem}.editable-component.selected,.table-cell-content.selected,.table-row.selected{border:2px solid #3b82f6!important;box-shadow:0 0 0 3px #3b82f633;outline:none;position:relative}.editable-component.selected>.component-controls:first-of-type{display:flex!important}.editable-component.selected>.component-label:first-of-type,.editable-component:hover>.component-label:first-of-type{display:block!important}.editable-component:hover>.component-controls:first-of-type{display:flex;gap:2px}.editable-component:hover{border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f666}