*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,sans-serif;background:#f5f5f5;display:flex;height:100vh;overflow:hidden}.sidebar{width:280px;background:#fff;border-right:1px solid #e0e0e0;padding:12px;overflow-y:auto;height:100vh;display:flex;flex-direction:column}.logo{font-size:18px;font-weight:600;color:#1976d2;margin-bottom:12px}.version-tag{display:inline-block;font-size:11px;color:#1976d2;background-color:#e3f2fd;padding:4px 6px;border-radius:4px;margin-left:8px;vertical-align:middle;font-weight:500;line-height:1.2}.section{flex-shrink:0;display:flex;flex-direction:column}.section:last-child{flex-grow:1;flex-shrink:1;min-height:0}.section-title{font-size:13px;font-weight:600;color:#666;text-transform:uppercase;margin-bottom:6px}.btn-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.btn{padding:6px;background:#fff;border:1px solid #e0e0e0;border-radius:4px;cursor:pointer;text-align:center;font-size:14px;transition:all .2s}.btn:hover{border-color:#1976d2;background:#e3f2fd;color:#1976d2}.main{flex:1;display:flex;background:radial-gradient(circle,#e0e0e0 1px,transparent 1px);background-size:20px 20px;position:relative;margin-bottom:48px;overflow:auto;min-width:0}.main::-webkit-scrollbar{width:12px;height:12px}.main::-webkit-scrollbar-track{background:#0000000d}.main::-webkit-scrollbar-thumb{background:silver;border-radius:6px;border:2px solid transparent;background-clip:padding-box}.main::-webkit-scrollbar-thumb:hover{background:#1976d2;border:2px solid transparent;background-clip:padding-box}.canvas-wrapper{background:#fff;box-shadow:0 4px 20px #0000001a;border-radius:8px;overflow:hidden;flex-shrink:0;margin:auto}.zoom-bar{position:fixed;bottom:0;left:280px;right:350px;background:#fff;border-top:2px solid #1976d2;padding:8px 16px;display:flex;align-items:center;justify-content:center;gap:12px;box-shadow:0 -2px 10px #0000001a;z-index:1000}.zoom-bar label{font-size:14px;color:#666;font-weight:500;white-space:nowrap}.zoom-bar input[type=range]{flex:1;max-width:300px}.zoom-bar #zoomInfo{min-width:50px;text-align:center;font-size:14px;color:#1976d2;font-weight:600}.zoom-bar .zoom-controls{display:flex;gap:4px}.zoom-btn{width:28px;height:28px;font-size:16px;cursor:pointer;border:1px solid #e0e0e0;background:#fff;border-radius:4px}.zoom-btn-text{padding:0 10px;height:28px;font-size:13px;cursor:pointer;border:1px solid #e0e0e0;background:#fff;border-radius:4px}.zoom-btn-text.active{background:#1976d2;color:#fff;border-color:#1976d2}.properties{width:350px;background:#fff;border-left:1px solid #e0e0e0;padding:12px;overflow-y:auto;height:100vh}.properties::-webkit-scrollbar,.sidebar::-webkit-scrollbar,.template-list::-webkit-scrollbar,.component-list::-webkit-scrollbar{width:8px}.properties::-webkit-scrollbar-track,.sidebar::-webkit-scrollbar-track,.template-list::-webkit-scrollbar-track,.component-list::-webkit-scrollbar-track{background:#f5f5f5;border-radius:4px}.properties::-webkit-scrollbar-thumb,.sidebar::-webkit-scrollbar-thumb,.template-list::-webkit-scrollbar-thumb,.component-list::-webkit-scrollbar-thumb{background:silver;border-radius:4px;transition:background .2s}.properties::-webkit-scrollbar-thumb:hover,.sidebar::-webkit-scrollbar-thumb:hover,.template-list::-webkit-scrollbar-thumb:hover,.component-list::-webkit-scrollbar-thumb:hover{background:#1976d2}.prop-group{margin-bottom:10px}.prop-label{font-size:14px;font-weight:500;color:#044281;margin-bottom:4px;display:block}input,select{width:100%;padding:6px;border:1px solid #e0e0e0;border-radius:4px;font-size:14px;font-family:inherit}input:focus,select:focus{outline:none;border-color:#1976d2}input[type=color]{height:32px;padding:3px}.btn-row{display:flex;gap:4px;margin:5px 0}.btn-prop{flex:1;padding:6px;background:#fff;border:1px solid #e0e0e0;border-radius:4px;cursor:pointer;font-size:14px}.btn-prop:hover{background:#f5f5f5}.btn-prop.active{background:#1976d2;color:#fff;border-color:#1976d2}.btn-primary{padding:6px;background:#1976d2;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;margin:4px 0}.btn-primary:hover{background:#1565c0}.btn-row .btn-primary{margin:0;flex:1}.btn-danger{background:#d32f2f;margin-bottom:5px;width:100%}.btn-danger:hover{background:#b71c1c}.btn-row .btn-danger{margin:0;flex:1;width:auto}.hidden{display:none!important}small{font-size:13px;color:#999}.dpi-hint{display:block;margin-top:3px}.welcome-text{color:#999;font-size:14px;line-height:1.5}.welcome-title{color:#333;display:block;margin-bottom:6px}#canvasInfo{margin-top:8px;font-size:13px;color:#999;line-height:1.4;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-evenly}.prop-row{display:flex;gap:6px;margin-bottom:10px}.prop-group-inline{flex:1;display:flex;flex-direction:column}.prop-group-inline label{font-size:13px;font-weight:500;color:#666;margin-bottom:3px;display:block}.prop-group-inline input,.prop-group-inline select{width:100%;padding:7px;border:1px solid #e0e0e0;border-radius:4px;font-size:14px}.toggle{position:relative;display:inline-block;width:40px;height:20px}.toggle input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;border-radius:20px;transition:.3s}.slider:before{position:absolute;content:"";height:14px;width:14px;left:3px;bottom:3px;background-color:#fff;border-radius:50%;transition:.3s}input:checked+.slider{background-color:#1976d2}input:checked+.slider:before{transform:translate(20px)}.radio-group{display:flex;flex-direction:column;gap:6px}.radio-group label{font-size:14px;display:flex;align-items:center;gap:6px;cursor:pointer}.template-list{max-height:300px;overflow-y:auto}.component-list-container{flex-grow:1;min-height:100px;display:flex;flex-direction:column}.component-list{flex-grow:1;overflow-y:auto;min-height:0}.component-section-title,.template-section-title{font-size:13px;font-weight:600;color:#666;text-transform:uppercase;padding:15px 0 5px;margin-top:8px;letter-spacing:.5px}.component-section-title:first-child,.template-section-title:first-child{margin-top:0}.component-item{padding:3px 8px;border-bottom:1px solid #f5f5f5;transition:all .2s;cursor:move}.component-item:hover{background:#f5f5f5}.component-item:last-child{border-bottom:none}.component-item.dragging{opacity:.4;background:#e3f2fd;cursor:move}.component-item.drag-over{border-top:2px solid #1976d2;background:#e3f2fd}.component-main{display:flex;justify-content:space-between;align-items:center;cursor:pointer}.component-name{font-size:14px;flex:1}.component-actions{display:flex;gap:4px;align-items:center}.component-toggle,.component-delete{background:none;border:none;cursor:pointer;font-size:14px;padding:2px 4px;border-radius:3px;transition:all .2s;display:flex;align-items:center;justify-content:center}.component-toggle:hover{background:#e3f2fd}.component-delete:hover{background:#ffebee}.component-hidden{opacity:.5}.component-hidden .component-name{text-decoration:line-through}.component-selected{background:#e3f2fd;border-left:3px solid #1976d2}.prop-check-row{flex:1;display:flex;align-items:center;min-height:30px}.prop-check-row label{font-size:13px;font-weight:500;color:#666;margin-right:8px;margin-bottom:0;cursor:pointer}.prop-check-row input{width:auto;margin:0}.alignment-toolbar{position:fixed;right:360px;top:45%;transform:translateY(-50%);background:#fff;padding:8px;border-radius:8px;box-shadow:0 2px 10px #0000001a;display:flex;flex-direction:column;gap:8px;z-index:2000}.btn-align{width:32px;height:32px;border:1px solid #e0e0e0;background:#fff;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#666;transition:all .2s}.btn-align:hover{background:#e3f2fd;color:#1976d2;border-color:#1976d2}.align-divider{height:1px;background:#e0e0e0;margin:4px 0}.variable-list{max-height:200px;overflow-y:auto;margin-bottom:10px}.variable-list::-webkit-scrollbar{width:8px}.variable-list::-webkit-scrollbar-track{background:#f5f5f5;border-radius:4px}.variable-list::-webkit-scrollbar-thumb{background:silver;border-radius:4px;transition:background .2s}.variable-list::-webkit-scrollbar-thumb:hover{background:#1976d2}.variable-item{display:flex;justify-content:space-between;align-items:center;padding:6px 8px;border-bottom:1px solid #f5f5f5;transition:all .2s}.variable-item:hover{background:#f5f5f5}.variable-item:last-child{border-bottom:none}.variable-item span{font-size:12px;color:#333}.btn-small{padding:2px 8px;font-size:11px;background:#f44336;color:#fff;border:none;border-radius:3px;cursor:pointer;transition:all .2s}.btn-small:hover{background:#d32f2f}.template-item{display:flex;justify-content:space-between;align-items:center;padding:6px 8px;border-bottom:1px solid #f5f5f5;transition:all .2s;cursor:pointer}.template-item:hover{background:#f5f5f5}.template-item:last-child{border-bottom:none}.template-item-delete{color:#f44336;font-size:18px;font-weight:700;cursor:pointer;padding:0 4px}.template-item-delete:hover{color:#d32f2f}.mode-options,.color-mode-options{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.mode-options label,.color-mode-options label{display:flex!important;align-items:center;gap:6px;padding:8px 12px;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:13px;font-weight:500;color:#666;min-width:70px;justify-content:center;position:relative}.mode-options label:hover,.color-mode-options label:hover{background:#e3f2fd;border-color:#1976d2;color:#1976d2;transform:translateY(-1px);box-shadow:0 2px 4px #1976d21a}.mode-options input[type=radio],.color-mode-options input[type=radio]{width:auto!important;margin:0;accent-color:#1976d2}.mode-options label.selected,.color-mode-options label.selected{background:#e3f2fd;border-color:#1976d2;color:#1976d2;font-weight:600;box-shadow:0 2px 6px #1976d233}.shortcut-notification{position:fixed;top:20px;left:50%;transform:translate(-50%);background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;padding:16px 20px;display:flex;align-items:center;gap:12px;z-index:10000;border:1px solid #e0e0e0;min-width:200px;max-width:300px;animation:slideDown .3s ease-out}.notification-content{display:flex;align-items:center;gap:12px;width:100%}.notification-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.notification-icon svg{width:100%;height:100%}.notification-success svg{color:#4caf50}.notification-toggle svg{color:#757575}.notification-info svg{color:#2196f3}.notification-text{font-size:14px;font-weight:500;color:#333;flex:1;text-align:center}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(max-width:768px){.shortcut-notification{min-width:180px;max-width:280px;padding:12px 16px}.notification-text{font-size:13px}}textarea{width:100%;padding:6px;border:1px solid #e0e0e0;border-radius:4px;font-size:14px;transition:border-color .2s;resize:vertical;min-height:60px;font-family:inherit}textarea:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 2px #1976d21a}.component-toolbar{position:fixed;top:20px;left:300px;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;z-index:1000;transition:all .3s ease}.toolbar-header{display:flex;justify-content:space-between;align-items:center;padding:5px 15px;border-bottom:1px solid #e0e0e0;background:#f8f9fa;border-radius:8px 8px 0 0}.toolbar-title{font-size:14px;font-weight:600;color:#1976d2}.toolbar-toggle{background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.toolbar-toggle:hover{background:#e3f2fd}.toolbar-content{padding:10px;transition:all .3s ease}.toolbar-buttons{display:flex;gap:8px;flex-wrap:wrap}.toolbar-btn{width:35px;height:35px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .2s}.toolbar-btn:hover{background:#e3f2fd;border-color:#1976d2;color:#1976d2}.component-toolbar.collapsed{border-radius:8px}.component-toolbar.collapsed .toolbar-header{border-bottom:none;border-radius:8px}.component-toolbar.collapsed .toolbar-content{display:none}textarea[data-fabric=textarea]{position:fixed!important;opacity:0}#textInput{max-height:200px}.radial-menu{position:fixed;width:200px;height:200px;left:-9999px;top:-9999px;transform:translate(-50%,-50%) scale(.94);opacity:0;pointer-events:none;transition:opacity .12s ease,transform .12s ease;z-index:3000;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:6px;padding:10px;box-sizing:border-box}.radial-menu.open{opacity:1;transform:translate(-50%,-50%) scale(1);pointer-events:auto}.radial-ring{position:absolute;inset:0;border-radius:12px;background:#eeeeeee5;box-shadow:0 8px 18px #0000001f,0 0 0 1px #1976d20d}.radial-item{position:relative;width:100%;height:100%;border:none;background:#ffffffb3;color:#66717c;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:12px;box-shadow:0 8px 16px #0000001a;z-index:1;transition:transform .12s ease,box-shadow .12s ease,background .12s ease;font-size:13px;text-align:center;line-height:1.25;padding:6px}.radial-item span{display:block;white-space:normal;word-break:break-word}.radial-item:hover{background:#1976d21f;box-shadow:0 10px 20px #1976d229;transform:translateY(-1px)}.slot-top{grid-column:2;grid-row:1}.slot-right{grid-column:3;grid-row:2}.slot-bottom{grid-column:2;grid-row:3}.slot-left{grid-column:1;grid-row:2}.minimap-container{position:fixed;right:360px;bottom:60px;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;z-index:2000;overflow:hidden;min-width:120px}.minimap-header{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:#f8f9fa;border-bottom:1px solid #e0e0e0;cursor:move;-webkit-user-select:none;user-select:none}.minimap-title{font-size:12px;font-weight:600;color:#1976d2}.minimap-toggle{background:none;border:none;cursor:pointer;font-size:14px;font-weight:700;color:#666;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.minimap-toggle:hover{background:#e3f2fd;color:#1976d2}.minimap-content{position:relative;padding:8px;background:#fafafa}.minimap-content canvas{display:block;border:1px solid #e0e0e0;border-radius:4px}.minimap-viewport{position:absolute;border:2px solid #1976d2;background:#1976d21a;cursor:move;border-radius:2px;pointer-events:auto}.minimap-viewport:hover{background:#1976d233}.context-menu{position:fixed;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026,0 0 0 1px #0000000d;z-index:10000;min-width:180px;padding:6px 0;display:none;animation:contextMenuFadeIn .15s ease-out}.context-menu-visible{display:block}@keyframes contextMenuFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu-item{display:flex;align-items:center;padding:8px 12px;cursor:pointer;transition:all .15s ease;gap:10px}.context-menu-item:hover{background:#f5f7fa}.context-menu-item-disabled{opacity:.4;pointer-events:none}.context-menu-item-danger:hover{background:#fff5f5}.context-menu-item-danger:hover .context-menu-icon,.context-menu-item-danger:hover .context-menu-text{color:#d32f2f}.context-menu-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:#666;flex-shrink:0}.context-menu-icon svg{width:16px;height:16px}.context-menu-text{flex:1;font-size:13px;color:#333;font-weight:500}.context-menu-shortcut{font-size:11px;color:#999;margin-left:auto;padding-left:16px}.context-menu-divider{height:1px;background:#e8e8e8;margin:6px 0}
