.editor-body{overflow:hidden}.editor-root{display:grid;width:100vw;height:100vh;grid-template-areas:"toolbar toolbar toolbar" "left    canvas  right" "status  status  status";grid-template-rows:var(--toolbar-h) 1fr var(--statusbar-h);grid-template-columns:var(--panel-left-w) 1fr var(--panel-right-w)}.toolbar{grid-area:toolbar;display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-2);background:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:var(--z-panel)}.toolbar-left{display:flex;align-items:center;gap:0;flex-shrink:0}.toolbar-logo{display:flex;align-items:center;justify-content:center;padding:0 var(--space-3);height:var(--toolbar-h);color:var(--color-green);font-family:var(--font-mono);font-size:var(--font-size-md);font-weight:700;letter-spacing:.05em;border-right:1px solid var(--color-border);text-decoration:none;transition:color var(--transition-fast)}.toolbar-logo:hover{color:var(--color-text)}.toolbar-menus{display:flex;align-items:center}.toolbar-center{flex:1;display:flex;align-items:center;justify-content:center}.toolbar-docname{color:var(--color-text-muted);font-size:var(--font-size-sm);letter-spacing:.03em}.toolbar-right{display:flex;align-items:center;gap:var(--space-1);flex-shrink:0}.toolbar-btn{display:inline-flex;align-items:center;justify-content:center;padding:4px var(--space-2);min-width:28px;height:26px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--color-text-muted);font-family:var(--font-mono);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast)}.toolbar-btn:hover:not(:disabled){background:var(--color-surface-2);border-color:var(--color-border);color:var(--color-text)}.toolbar-btn:disabled{opacity:.3;cursor:default}.toolbar-btn--primary{background:var(--color-green-dim);border-color:var(--color-green);color:var(--color-text);font-weight:600;padding:4px var(--space-3)}.toolbar-btn--primary:hover{background:var(--color-green);color:#000}.toolbar-sep{width:1px;height:20px;background:var(--color-border);margin:0 var(--space-1)}.panel-left{grid-area:left;display:flex;flex-direction:column;align-items:center;padding:var(--space-2) 0;gap:var(--space-1);background:var(--color-surface);border-right:1px solid var(--color-border);overflow-y:auto;overflow-x:hidden;z-index:var(--z-panel)}.tool-group{display:flex;flex-direction:column;align-items:center;gap:2px;width:100%;padding:0 var(--space-1)}.tool-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.tool-btn svg{width:16px;height:16px}.tool-btn:hover{background:var(--color-surface-2);border-color:var(--color-border);color:var(--color-text)}.tool-btn.active{background:var(--color-green-glow);border-color:var(--color-green-dim);color:var(--color-green)}.tool-btn--action:hover{border-color:var(--color-blue-dim);color:var(--color-blue);background:#58a6ff1a}.tool-divider{width:28px;height:1px;background:var(--color-border-subtle);margin:var(--space-1) 0}.workspace{grid-area:canvas;position:relative;overflow:hidden;background:var(--color-bg)}.panel-right{grid-area:right;display:flex;flex-direction:column;background:var(--color-surface);border-left:1px solid var(--color-border);overflow:hidden;z-index:var(--z-panel)}.panel-tabs{display:flex;border-bottom:1px solid var(--color-border);flex-shrink:0}.panel-tab{flex:1;padding:var(--space-2) 0;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--color-text-muted);font-family:var(--font-mono);font-size:var(--font-size-xs);letter-spacing:.08em;cursor:pointer;transition:all var(--transition-fast)}.panel-tab:hover{color:var(--color-text);background:var(--color-surface-2)}.panel-tab.active{color:var(--color-green);border-bottom-color:var(--color-green)}.panel-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--space-3)}.statusbar{grid-area:status;display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-3);background:var(--color-surface);border-top:1px solid var(--color-border);font-size:var(--font-size-xs);color:var(--color-text-muted)}.statusbar-left,.statusbar-right{display:flex;align-items:center;gap:var(--space-2)}.status-item{display:flex;align-items:center;gap:var(--space-1)}.status-label{color:var(--color-text-dim)}.status-val{color:var(--color-text-muted);font-size:var(--font-size-xs)}.status-sep{color:var(--color-border-strong);margin:0 2px}.status-hint{color:var(--color-text-dim);font-size:var(--font-size-xs)}.props-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-6) var(--space-3);color:var(--color-text-dim);text-align:center}.props-empty-icon{font-size:24px;color:var(--color-border-strong)}.props-empty p{font-size:var(--font-size-sm);line-height:1.8;color:var(--color-text-muted)}.prop-section{margin-bottom:var(--space-4)}.prop-section-title{font-size:var(--font-size-xs);color:var(--color-text-dim);letter-spacing:.08em;text-transform:uppercase;padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border-subtle);margin-bottom:var(--space-2)}.prop-section-title:before{content:"// ";color:var(--color-green-dim)}.prop-row{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.prop-label{flex-shrink:0;width:52px;font-size:var(--font-size-xs);color:var(--color-text-muted)}.prop-label:before{content:"> ";color:var(--color-green-dim)}.prop-value{flex:1}.prop-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2);margin-bottom:var(--space-2)}.prop-grid-2 .prop-row{margin-bottom:0}.prop-toggle-row{display:flex;gap:var(--space-1);flex-wrap:wrap}.prop-toggle-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:24px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);font-family:var(--font-mono);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast)}.prop-toggle-btn:hover{border-color:var(--color-border-strong);color:var(--color-text)}.prop-toggle-btn.active{background:var(--color-green-glow);border-color:var(--color-green-dim);color:var(--color-green)}.prop-align-row{display:flex;gap:var(--space-1)}.prop-align-btn{display:inline-flex;align-items:center;justify-content:center;flex:1;height:24px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-fast)}.prop-align-btn:hover{border-color:var(--color-border-strong);color:var(--color-text)}.prop-align-btn.active{background:var(--color-green-glow);border-color:var(--color-green-dim);color:var(--color-green)}.prop-slider-row{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-2)}.prop-slider-header{display:flex;justify-content:space-between;align-items:center}.prop-slider-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.prop-slider-label:before{content:"> ";color:var(--color-green-dim)}.prop-slider-val{font-size:var(--font-size-xs);color:var(--color-text-dim)}.layers-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border-subtle)}.layers-title{font-size:var(--font-size-xs);color:var(--color-green-dim);letter-spacing:.05em}.layers-empty{color:var(--color-text-muted);font-size:var(--font-size-sm);padding:var(--space-4) 0;text-align:center}.layers-list{display:flex;flex-direction:column;gap:2px}.layer-item{display:flex;align-items:center;gap:var(--space-1);padding:4px var(--space-1);border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.layer-item:hover{background:var(--color-surface-2);border-color:var(--color-border-subtle)}.layer-item.selected{background:var(--color-green-glow);border-color:var(--color-green-dim)}.layer-item.drag-over{border-color:var(--color-blue);background:#58a6ff0d}.layer-item.locked{opacity:.5}.layer-item.hidden{opacity:.3}.layer-drag-handle{color:var(--color-text-dim);font-size:10px;cursor:grab;padding:0 2px}.layer-drag-handle:active{cursor:grabbing}.layer-icon{width:14px;height:14px;display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--color-text-dim);flex-shrink:0}.layer-name{flex:1;font-size:var(--font-size-xs);color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.layer-name[contenteditable=true]{outline:1px solid var(--color-blue);border-radius:2px;padding:0 2px;color:var(--color-text)}.layer-actions{display:flex;gap:2px;flex-shrink:0;opacity:0;transition:opacity var(--transition-fast)}.layer-item:hover .layer-actions{opacity:1}.layer-action-btn{display:flex;align-items:center;justify-content:center;width:18px;height:18px;background:transparent;border:none;border-radius:2px;color:var(--color-text-dim);font-size:10px;cursor:pointer;transition:all var(--transition-fast)}.layer-action-btn:hover{background:var(--color-surface-3);color:var(--color-text)}.layer-action-btn.active{color:var(--color-green)}.layer-action-btn--delete:hover{color:var(--color-red)}.preset-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2);margin-bottom:var(--space-4)}.preset-btn{display:flex;flex-direction:column;align-items:flex-start;padding:var(--space-2) var(--space-3);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);text-align:left}.preset-btn:hover{border-color:var(--color-green-dim);background:var(--color-green-glow)}.preset-btn-name{font-size:var(--font-size-sm);color:var(--color-text);margin-bottom:2px}.preset-btn-dim{font-size:var(--font-size-xs);color:var(--color-text-dim)}.custom-size{padding-top:var(--space-3);border-top:1px solid var(--color-border-subtle)}.custom-size .form-row{margin-bottom:var(--space-2)}.custom-size .btn-primary{margin-top:var(--space-2);width:100%;justify-content:center}.pdf-confirm-msg{font-family:var(--font-mono);font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.8;padding:var(--space-3) var(--space-4);background:var(--color-bg);border:1px solid var(--color-border);border-left:3px solid var(--color-amber);border-radius:var(--radius-sm)}.pdf-confirm-msg strong{color:var(--color-amber)}.pdf-confirm-file{margin-top:var(--space-3);font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--color-text-dim)}.pdf-pages-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:var(--space-2);max-height:320px;overflow-y:auto}.pdf-page-thumb{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-2);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.pdf-page-thumb:hover{border-color:var(--color-green-dim);background:var(--color-green-glow)}.pdf-page-thumb canvas{border:1px solid var(--color-border-subtle)}.pdf-page-num{font-size:var(--font-size-xs);color:var(--color-text-dim)}.readonly-banner{position:fixed;top:var(--toolbar-h);left:0;right:0;z-index:var(--z-panel);display:flex;align-items:center;justify-content:center;gap:var(--space-4);padding:6px var(--space-4);background:color-mix(in srgb,var(--color-amber) 15%,var(--color-surface));border-bottom:1px solid var(--color-amber);font-size:var(--font-size-sm)}.readonly-banner-text{color:var(--color-amber)}.readonly-banner-btn{padding:3px 12px;background:transparent;border:1px solid var(--color-amber);border-radius:var(--radius-sm);color:var(--color-amber);font-family:var(--font-mono);font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-fast)}.readonly-banner-btn:hover{background:color-mix(in srgb,var(--color-amber) 20%,transparent)}.modal-desc{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.7}.modal-body--scroll{max-height:70vh;overflow-y:auto}.share-url-row{display:flex;gap:var(--space-2);margin-top:var(--space-3)}.share-url-input{flex:1;font-family:var(--font-mono);font-size:var(--font-size-xs);background:var(--color-bg);color:var(--color-text-dim)}.share-expires-note{margin-top:var(--space-2);font-size:var(--font-size-xs);color:var(--color-text-dim)}.projects-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.projects-slot-info{font-size:var(--font-size-xs);color:var(--color-text-muted)}.projects-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--space-3)}.project-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:border-color var(--transition-fast)}.project-card:hover{border-color:var(--color-green-dim)}.project-thumb{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;background:var(--color-bg)}.project-thumb--empty{display:flex;align-items:center;justify-content:center;color:var(--color-text-dim);font-size:20px}.project-info{padding:var(--space-2) var(--space-2) 0;display:flex;flex-direction:column;gap:2px}.project-name{font-size:var(--font-size-sm);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-size{font-size:var(--font-size-xs);color:var(--color-text-muted)}.project-actions{display:flex;gap:var(--space-1);padding:var(--space-2)}.project-btn{flex:1;padding:4px 0;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-dim);font-family:var(--font-mono);font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-fast)}.project-btn:hover{border-color:var(--color-green-dim);color:var(--color-text)}.project-btn--danger:hover{border-color:var(--color-red);color:var(--color-red)}.tmpl-tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.tmpl-tag-label{display:flex;align-items:center;gap:6px;font-size:var(--font-size-xs);color:var(--color-text-muted);cursor:pointer}.tmpl-tag-label:hover{color:var(--color-text)}.workspace{position:relative;overflow:hidden;background-color:var(--color-bg);background-image:linear-gradient(var(--color-border-subtle) 1px,transparent 1px),linear-gradient(90deg,var(--color-border-subtle) 1px,transparent 1px);background-size:20px 20px;background-position:center center;cursor:default}.workspace.panning{cursor:grabbing}.workspace.grid-off{background-image:none}.workspace.tool-text{cursor:text}.workspace.tool-crosshair{cursor:crosshair}#design-frame{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 1px var(--color-border),0 8px 32px #00000080,0 0 80px #0000004d;line-height:0}#design-frame .canvas-container{position:relative!important;top:auto!important;left:auto!important;transform:none!important}#design-frame .lower-canvas,#design-frame .upper-canvas{position:absolute!important;top:0!important;left:0!important}.zoom-controls{position:absolute;bottom:var(--space-3);right:var(--space-3);display:flex;align-items:center;gap:var(--space-1);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-base);padding:var(--space-1);z-index:var(--z-panel);box-shadow:0 2px 8px #0000004d}.zoom-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--color-text-muted);font-family:var(--font-mono);font-size:var(--font-size-md);cursor:pointer;transition:all var(--transition-fast);line-height:1}.zoom-btn:hover{background:var(--color-surface-2);border-color:var(--color-border);color:var(--color-text)}.zoom-btn--reset{font-size:var(--font-size-sm)}.zoom-level{min-width:40px;text-align:center;font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--color-text-muted);padding:0 var(--space-1)}
