.toolbar{height:44px;padding:0 var(--space-sm);background:var(--bg-secondary);border-bottom:1px solid var(--border);align-items:center;gap:var(--space-sm);display:flex}.toolbar-left{align-items:center;gap:var(--space-xs);display:flex}.toolbar-center{flex:1;justify-content:center;min-width:0;display:flex}.toolbar-right{align-items:center;gap:var(--space-sm);display:flex}.toolbar-sep{background:var(--border);width:1px;height:20px;margin:0 var(--space-xs);flex-shrink:0}.toolbar-hint{color:var(--text-muted);font-size:12px}.btn{justify-content:center;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast);white-space:nowrap;font-size:12px;line-height:1.5;display:inline-flex}.btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--text-muted)}.btn:active:not(:disabled){background:var(--bg-active)}.btn:disabled{opacity:.4;cursor:default}.btn svg{flex-shrink:0}.btn-icon{padding:var(--space-xs) 6px}.btn-with-icon{padding:var(--space-xs) 10px}.segmented-control{border:1px solid var(--border);border-radius:var(--radius-sm);display:inline-flex;overflow:hidden}.segmented-control.disabled{opacity:.4;pointer-events:none}.segmented-btn{background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);border:none;padding:3px 12px;font-size:11px;line-height:1.5}.segmented-btn:not(:last-child){border-right:1px solid var(--border)}.segmented-btn:hover:not(:disabled):not(.active){background:var(--bg-hover);color:var(--text-primary)}.segmented-btn.active{background:var(--accent);color:#fff}.segmented-btn:disabled{cursor:default}.btn-back-overview{border:1px solid var(--accent);border-radius:var(--radius-sm);background:var(--accent-dim);color:#fff;cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast);align-items:center;gap:5px;padding:6px 18px 6px 12px;font-size:13px;font-weight:600;display:inline-flex}.btn-back-overview:hover{background:var(--accent)}.editor-mode-toggle .segmented-btn{padding:4px 16px;font-size:12px;font-weight:600}.editor-mode-toggle .segmented-btn.active[data-value=edit]{background:var(--accent);color:#fff;box-shadow:0 0 0 1px var(--accent)}.breadcrumb-nav{align-items:center;gap:2px;min-width:0;display:flex}.breadcrumb-segment{position:relative}.breadcrumb-btn{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);white-space:nowrap;background:0 0;border:none;align-items:center;gap:2px;padding:2px 8px;font-size:12px;line-height:1.5;display:inline-flex}.breadcrumb-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.breadcrumb-text{text-overflow:ellipsis;max-width:120px;overflow:hidden}.breadcrumb-sep{color:var(--text-muted);-webkit-user-select:none;user-select:none;font-size:12px}.breadcrumb-leaf{color:var(--accent);white-space:nowrap;padding:2px 8px;font-size:12px}.breadcrumb-dropdown{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);min-width:140px;max-height:240px;box-shadow:var(--shadow-md);z-index:100;padding:var(--space-xs) 0;margin-top:4px;position:absolute;top:100%;left:0;overflow-y:auto}.breadcrumb-dropdown-item{width:100%;color:var(--text-secondary);cursor:pointer;text-align:left;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;padding:4px 12px;font-size:12px;display:block}.breadcrumb-dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary)}.breadcrumb-dropdown-item.active{color:var(--accent)}.beta-badge{color:#fef3c7;letter-spacing:.06em;-webkit-user-select:none;user-select:none;background:#b45309;border-radius:3px;flex-shrink:0;align-items:center;padding:2px 7px;font-size:10px;font-weight:700;line-height:1.4;display:inline-flex}.drop-zone-overlay{z-index:9999;pointer-events:none;background:#1e1e2ed9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.drop-zone-box{align-items:center;gap:var(--space-md);padding:var(--space-xl) 64px;border:2px dashed var(--accent);border-radius:var(--radius-lg);color:var(--text-primary);flex-direction:column;display:flex}.drop-zone-icon svg{opacity:.7}.drop-zone-text{font-size:16px;font-weight:500}.drop-zone-hint{color:var(--text-muted);font-size:12px}.info-btn{border:1px solid var(--border);background:var(--bg-tertiary);width:22px;height:22px;color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-family:Georgia,Times New Roman,serif;font-size:12px;font-style:italic;font-weight:700;line-height:1;display:inline-flex}.info-btn:hover{background:var(--bg-hover);border-color:var(--text-muted);color:var(--text-primary)}.info-modal-backdrop{z-index:10000;background:#0009;justify-content:center;align-items:center;animation:.15s info-fade-in;display:flex;position:fixed;inset:0}@keyframes info-fade-in{0%{opacity:0}to{opacity:1}}.info-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:560px;max-width:calc(100vw - 48px);max-height:calc(100vh - 96px);padding:var(--space-lg) var(--space-xl);animation:.2s info-slide-in;overflow-y:auto}@keyframes info-slide-in{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.info-modal-title{color:var(--text-primary);margin:0 0 var(--space-lg) 0;font-size:18px;font-weight:700}.info-section{margin-bottom:var(--space-lg)}.info-section:last-of-type{margin-bottom:var(--space-md)}.info-section-heading{color:var(--accent);margin:0 0 var(--space-sm) 0;text-transform:uppercase;letter-spacing:.04em;font-size:13px;font-weight:700}.info-section-heading--caution{color:#e0a040}.info-section-heading--safe{color:var(--success)}.info-section ul{padding:0 0 0 var(--space-md);margin:0;list-style:none}.info-section li{color:var(--text-secondary);padding:3px 0;font-size:13px;line-height:1.5;position:relative}.info-section li:before{content:"•";color:var(--text-muted);position:absolute;left:-14px}.info-modal-close{width:100%;margin-top:var(--space-md);border:1px solid var(--accent);border-radius:var(--radius-sm);background:var(--accent-dim);color:#fff;cursor:pointer;transition:background var(--transition-fast);padding:10px;font-size:13px;font-weight:600;display:block}.info-modal-close:hover{background:var(--accent)}.npd-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.npd-dialog{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md,8px);flex-direction:column;width:520px;max-height:80vh;display:flex;box-shadow:0 8px 32px #0000004d}.npd-header{justify-content:space-between;align-items:center;padding:16px 20px 8px;display:flex}.npd-title{color:var(--text-primary);margin:0;font-size:16px;font-weight:600}.npd-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:20px;line-height:1}.npd-close:hover{color:var(--text-primary)}.npd-desc{color:var(--text-secondary);margin:0;padding:0 20px 12px;font-size:12px}.npd-devices{flex:1;padding:0 20px;overflow-y:auto}.npd-group{margin-bottom:12px}.npd-group-name{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:11px;font-weight:600}.npd-group-options{flex-wrap:wrap;gap:8px;display:flex}.npd-device{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);cursor:pointer;align-items:center;gap:10px;min-width:140px;padding:8px 12px;transition:border-color .15s,background .15s;display:flex}.npd-device:hover{background:var(--bg-hover);border-color:var(--text-muted)}.npd-device.selected{border-color:var(--accent);background:var(--accent-dim,#3b82f61a)}.npd-device-screen{border:1px solid var(--text-muted);background:var(--bg-tertiary);border-radius:2px;flex-shrink:0}.npd-device-info{flex-direction:column;gap:2px;display:flex}.npd-device-name{color:var(--text-primary);font-size:12px;font-weight:500}.npd-device-res{color:var(--text-muted);font-family:SF Mono,Menlo,monospace;font-size:10px}.npd-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:12px 20px 16px;display:flex}.npd-btn{border-radius:var(--radius-sm);cursor:pointer;border:1px solid var(--border);padding:6px 16px;font-size:12px;font-weight:500}.npd-btn-cancel{background:var(--bg-secondary);color:var(--text-secondary)}.npd-btn-cancel:hover{background:var(--bg-hover)}.npd-btn-create{background:var(--accent);border-color:var(--accent);color:#fff}.npd-btn-create:hover{opacity:.9}.symbol-palette-inline{padding:var(--space-xs) 0}.palette-category{padding:var(--space-sm) var(--space-sm)}.palette-category+.palette-category{border-top:1px solid var(--border)}.palette-grid{grid-template-columns:repeat(auto-fill,minmax(56px,1fr));gap:4px;display:grid}.palette-btn{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;text-align:center;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);white-space:nowrap;text-overflow:ellipsis;padding:4px 2px;font-size:10px;overflow:hidden}.palette-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent-dim)}.palette-btn:active{background:var(--bg-active)}.palette-tooltip{z-index:99999;background:var(--bg-primary,#1e1e2e);color:var(--text-primary,#cdd6f4);white-space:normal;border:1px solid var(--border,#45475a);pointer-events:none;border-radius:4px;max-width:240px;padding:6px 10px;font-size:11px;line-height:1.4;position:fixed;box-shadow:0 2px 12px #0006}.palette-tooltip strong{color:var(--accent,#89b4fa)}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.sidebar-empty{color:var(--text-muted);text-align:center;padding:20px 12px;font-size:12px}.sidebar-tabs{border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0;display:flex}.sidebar-tab{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast), border-color var(--transition-fast);text-align:center;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:8px 4px;font-size:11px;font-weight:600}.sidebar-tab:hover{color:var(--text-secondary)}.sidebar-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.sidebar-content{flex:1;overflow:hidden auto}.sidebar-tab-panel{animation:sidebar-fade-in var(--transition-fast)}@keyframes sidebar-fade-in{0%{opacity:0}to{opacity:1}}.sidebar-filter{padding:var(--space-sm);border-bottom:1px solid var(--border)}.sidebar-filter-input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);width:100%;color:var(--text-primary);box-sizing:border-box;transition:border-color var(--transition-fast);outline:none;padding:5px 8px;font-size:12px}.sidebar-filter-input::placeholder{color:var(--text-muted)}.sidebar-filter-input:focus{border-color:var(--accent)}.sidebar-section{border-bottom:1px solid var(--border)}.sidebar-heading{padding:var(--space-sm) var(--space-sm) var(--space-xs);text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:10px;font-weight:600}.sidebar-mode-header{padding:5px var(--space-sm);cursor:pointer;color:var(--text-secondary);-webkit-user-select:none;user-select:none;transition:background var(--transition-fast);align-items:center;gap:4px;font-size:12px;display:flex}.sidebar-mode-header:hover{background:var(--bg-hover)}.sidebar-mode-header.active{background:var(--bg-active);color:var(--text-primary)}.mode-chevron{width:14px;height:14px;color:var(--text-muted);transition:transform var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;font-size:8px;display:inline-flex}.mode-chevron.expanded{transform:rotate(90deg)}.mode-badge{background:var(--bg-tertiary);letter-spacing:.5px;text-align:center;border-radius:3px;flex-shrink:0;min-width:28px;padding:1px 4px;font-size:9px;font-weight:700;display:inline-block}.mode-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.page-count-badge{background:var(--bg-tertiary);color:var(--text-muted);border-radius:8px;flex-shrink:0;margin-left:auto;padding:0 5px;font-size:10px;font-weight:600;line-height:16px}.sidebar-pages{padding-left:26px}.sidebar-page{padding:4px var(--space-sm);cursor:pointer;color:var(--text-secondary);-webkit-user-select:none;user-select:none;transition:background var(--transition-fast), color var(--transition-fast);border-left:2px solid #0000;font-size:12px}.sidebar-page:hover{background:var(--bg-hover)}.sidebar-page{justify-content:space-between;align-items:center;display:flex}.sidebar-page.active{color:var(--accent);background:var(--bg-tertiary);border-left-color:var(--accent)}.thermal-badge{color:#fff;letter-spacing:.5px;vertical-align:middle;background:#c44;border-radius:3px;margin-left:5px;padding:0 4px;font-size:9px;font-weight:700;line-height:14px;display:inline-block}.page-remove-btn{color:var(--text-muted);cursor:pointer;opacity:.5;transition:opacity var(--transition-fast), color var(--transition-fast);background:0 0;border:none;padding:0 2px;font-size:14px;line-height:1}.page-remove-btn:hover{opacity:1;color:var(--error,#e55)}.page-add-btn{width:100%;padding:4px var(--space-sm);color:var(--text-muted);cursor:pointer;text-align:left;transition:color var(--transition-fast), background var(--transition-fast);background:0 0;border:none;font-size:11px;display:block}.page-add-btn:hover{color:var(--accent);background:var(--bg-hover)}.sidebar-settings-item{padding:6px var(--space-sm);cursor:pointer;color:var(--text-secondary);-webkit-user-select:none;user-select:none;transition:background var(--transition-fast), color var(--transition-fast);font-size:12px}.sidebar-settings-item:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-settings-item.active{color:var(--accent);background:var(--bg-tertiary)}.sidebar-settings-item{justify-content:space-between;align-items:center;display:flex}.sidebar-settings-item.absent{opacity:.5}.sidebar-settings-item.absent:hover{opacity:1}.sidebar-settings-add{color:var(--accent);font-size:14px;font-weight:600;line-height:1}.canvas-container{background:#141420;flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.canvas-wrapper{flex-direction:column;justify-content:center;align-items:center;transition:transform 60ms ease-out;display:flex;position:relative}.device-frame{background:linear-gradient(145deg,#3a3a3e 0%,#2a2a2e 40%,#1e1e22 100%);border:1px solid #444;border-radius:24px;align-items:stretch;padding:12px 6px;display:flex;position:relative;box-shadow:0 8px 32px #0009,inset 0 1px #ffffff14,inset 0 -1px #0000004d}.device-frame.portrait{flex-direction:row}.device-frame.landscape{border-radius:20px;flex-direction:row;padding:6px 12px}.device-buttons{flex-direction:column;flex-shrink:0;justify-content:space-between;align-items:center;width:18px;padding:18px 3px;display:flex}.device-btn{background:linear-gradient(#555 0%,#3a3a3a 50%,#2a2a2a 100%);border:1px solid #222;border-radius:3px;width:10px;height:22px;box-shadow:inset 0 1px #ffffff1a}.device-knob{background:radial-gradient(circle at 40% 35%,#666,#333);border:1px solid #222;border-radius:50%;width:14px;height:14px;box-shadow:0 1px 2px #00000080}.device-label{transform-origin:100%;letter-spacing:2px;color:#555;white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none;font-size:11px;font-weight:700;position:absolute;top:50%;left:-2px;transform:translate(-100%)rotate(-90deg)translateY(-50%)}.device-screen{background:#000;border-radius:6px;flex-direction:column;display:flex;overflow:hidden;box-shadow:inset 0 0 8px #000c}.thermal-indicator{color:#fff;text-align:center;letter-spacing:.3px;z-index:1;background:#c33;border-radius:4px 4px 0 0;align-self:center;margin-bottom:-2px;padding:3px 16px;font-size:11px;font-style:italic;font-weight:700}.canvas-inner{position:relative}.canvas-wrapper canvas{display:block}.canvas-empty{color:var(--text-muted);text-align:center;font-size:14px}.symbol-hover-overlay{border:1px solid #4285f466;border-radius:1px}.symbol-selection-overlay{border:1px dashed var(--accent);border-radius:1px}.sym-resize-handle{background:var(--accent);z-index:10;pointer-events:auto;box-sizing:border-box;border:1px solid #fff;width:8px;height:8px;position:absolute}.snap-guide{pointer-events:none;z-index:6;position:absolute}.snap-guide-x{background:#ff3264b3;width:1px;top:0}.snap-guide-y{background:#ff3264b3;height:1px;left:0}.zoom-controls{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);z-index:20;-webkit-user-select:none;user-select:none;align-items:center;gap:2px;padding:2px;display:flex;position:absolute;bottom:12px;right:12px}.zoom-btn{width:24px;height:24px;color:var(--text-primary);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;font-size:14px;font-weight:600;line-height:1;display:flex}.zoom-btn:hover{background:var(--bg-hover)}.zoom-badge{color:var(--text-secondary);text-align:center;min-width:36px;padding:0 2px;font-size:11px}.context-overlay{z-index:99;position:fixed;inset:0}.context-menu{z-index:100;background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;min-width:140px;padding:4px 0;position:fixed;box-shadow:0 4px 12px #0006}.context-item{cursor:pointer;color:var(--text-primary);padding:6px 14px;font-size:12px}.context-item:hover{background:var(--accent);color:#fff}.context-sep{background:var(--border);height:1px;margin:4px 0}.grid-view{padding:var(--space-lg);scroll-behavior:smooth;background:#141420;flex:1;position:relative;overflow:auto}.grid-size-control{z-index:10;margin-bottom:var(--space-sm);justify-content:flex-end;display:flex;position:sticky;top:0;right:0}.grid-size-control .size-buttons{background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border);gap:2px;padding:2px;display:flex}.grid-size-control button{color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:3px;padding:3px 10px;font-size:11px;font-weight:600;line-height:1}.grid-size-control button:hover{color:var(--text-secondary);background:var(--bg-hover)}.grid-size-control button.active{background:var(--bg-active);color:var(--text-primary)}.grid-table{gap:var(--space-sm);flex-direction:column;min-width:100%;display:inline-flex}.grid-table:focus{outline:none}.grid-header-row{align-items:center;gap:var(--space-sm);z-index:5;padding-bottom:var(--space-xs);background:#141420;display:flex;position:sticky;top:0}.grid-header-row .grid-mode-label{flex-shrink:0}.grid-col-header{text-align:center;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);background:var(--bg-secondary);border-radius:var(--radius-sm);flex-shrink:0;padding:6px 0;font-size:10px;font-weight:700}.grid-row{align-items:center;gap:var(--space-sm);display:flex}.grid-mode-label{z-index:3;background:#141420;flex-shrink:0;justify-content:center;align-items:center;width:60px;display:flex;position:sticky;left:0}.mode-badge{color:var(--text-secondary);background:var(--bg-secondary);white-space:nowrap;border-radius:10px;padding:3px 8px;font-size:10px;font-weight:600}.grid-empty-row{align-items:center;padding:12px 16px;display:flex}.grid-no-pages{color:var(--text-muted);font-size:11px;font-style:italic}.grid-cell{cursor:pointer;border-radius:var(--radius-md);transition:border-color var(--transition-normal), transform var(--transition-normal), box-shadow var(--transition-normal);border:2px solid #0000;flex-direction:column;flex-shrink:0;align-items:center;padding:3px;display:flex}.grid-cell:hover{border-color:var(--bg-active);box-shadow:var(--shadow-md);transform:scale(1.03)}.grid-cell-focused{border-color:var(--accent-dim);box-shadow:0 0 0 1px var(--accent-dim)}.grid-cell-selected{border-color:var(--accent);box-shadow:0 0 8px #4285f459}.grid-thermal-banner{color:#fff;text-align:center;border-radius:var(--radius-sm) var(--radius-sm) 0 0;background:#e00;padding:2px 0;font-size:11px;font-style:italic;font-weight:700;line-height:1.2}.grid-cell canvas{border-radius:var(--radius-sm);display:block}.grid-cell-label{color:var(--text-muted);text-align:center;text-overflow:ellipsis;white-space:nowrap;margin-top:3px;font-size:10px;overflow:hidden}.grid-cell-empty{border:2px dashed var(--border);border-radius:var(--radius-md);cursor:default;background-image:repeating-linear-gradient(45deg,#0000,#0000 8px,#ffffff04 8px 16px)}.grid-cell-empty:hover{box-shadow:none;border-color:var(--border);transform:none}.grid-cell-add{justify-content:center;align-items:center;padding:4px;display:flex}.grid-add-page-btn{border:1px dashed var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;background:0 0;width:100%;padding:6px 16px;font-size:11px;transition:color .15s,border-color .15s,background .15s}.grid-add-page-btn:hover{color:var(--accent);border-color:var(--accent);background:#3b82f60d}.grid-cell{position:relative}.grid-cell-remove{width:20px;height:20px;color:var(--text-muted);cursor:pointer;opacity:0;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:14px;line-height:1;transition:opacity .15s,background .15s,color .15s;display:flex;position:absolute;top:6px;right:6px}.grid-cell:hover .grid-cell-remove{opacity:1}.grid-cell-remove:hover{color:#fff;background:#dc3232cc}.property-panel{background:var(--bg-secondary);border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.panel-empty{color:var(--text-muted);text-align:center;padding:20px 12px;font-size:12px}.panel-header{align-items:center;gap:var(--space-sm);border-bottom:1px solid var(--border);flex-shrink:0;padding:10px 12px;display:flex}.panel-type{border-radius:var(--radius-sm);background:var(--accent-dim);color:#fff;text-transform:uppercase;padding:2px 6px;font-size:10px;font-weight:600}.panel-label{color:var(--text-primary);font-size:13px;font-weight:500}.pp-scroll{flex:1;overflow-y:auto}.pp-section{border-bottom:1px solid var(--border)}.pp-section-header{cursor:pointer;-webkit-user-select:none;user-select:none;background:0 0;border:none;align-items:center;gap:6px;width:100%;padding:8px 12px;display:flex}.pp-section-header:hover{background:var(--bg-hover)}.pp-section-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:10px;font-weight:600}.pp-chevron{color:var(--text-muted);transition:transform var(--transition-fast);font-size:8px;display:inline-block}.pp-chevron--open{transform:rotate(90deg)}.pp-chevron--small{font-size:7px}.pp-section-body{max-height:0;transition:max-height var(--transition-normal);overflow:hidden}.pp-section-body--open{max-height:600px}.pp-section-inner{padding:0 12px 8px}.prop-grid{gap:var(--space-xs);grid-template-columns:1fr 1fr;display:grid}.pp-num-field{align-items:center;gap:var(--space-xs);display:flex}.pp-num-label{color:var(--text-muted);flex-shrink:0;min-width:24px;font-size:11px}.pp-num-wrap{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);flex:1;align-items:stretch;min-width:0;display:flex;overflow:hidden}.pp-num-wrap:focus-within{border-color:var(--accent)}.pp-num-input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;min-width:0;padding:3px 6px;font-family:SF Mono,Menlo,monospace;font-size:12px}.pp-text-input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);flex:1}.pp-text-input:focus{border-color:var(--accent);outline:none}.pp-num-steppers{border-left:1px solid var(--border);flex-direction:column;display:flex}.pp-num-step{background:var(--bg-tertiary);width:16px;color:var(--text-muted);cursor:pointer;border:none;flex:1;justify-content:center;align-items:center;padding:0;font-size:6px;line-height:1;display:flex}.pp-num-step:hover{background:var(--bg-hover);color:var(--text-primary)}.pp-color-field{align-items:center;gap:var(--space-xs);margin-bottom:var(--space-xs);display:flex}.pp-color-wrap{align-items:center;gap:var(--space-xs);flex:1;min-width:0;display:flex}.pp-color-swatch{border-radius:var(--radius-sm);border:1px solid var(--border);cursor:pointer;flex-shrink:0;width:22px;height:22px;padding:0}.pp-color-swatch:hover{border-color:var(--text-muted)}.pp-color-native{opacity:0;pointer-events:none;width:0;height:0;position:absolute}.pp-color-field .pp-num-input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary)}.pp-color-field .pp-num-input:focus{border-color:var(--accent)}.pp-datasym-picker{align-items:center;gap:var(--space-xs);margin-bottom:var(--space-xs);display:flex;position:relative}.pp-datasym-btn{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);cursor:pointer;text-align:left;flex:1;justify-content:space-between;align-items:center;min-width:0;padding:4px 6px;font-size:11px;display:flex}.pp-datasym-btn:hover{border-color:var(--text-muted)}.pp-datasym-val{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.pp-datasym-dropdown{z-index:1000;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md)}.pp-datasym-search{border:none;border-bottom:1px solid var(--border);width:100%;color:var(--text-primary);box-sizing:border-box;background:0 0;outline:none;padding:6px 8px;font-size:11px}.pp-datasym-list{max-height:200px;overflow-y:auto}.pp-datasym-item{width:100%;color:var(--text-secondary);cursor:pointer;text-align:left;white-space:nowrap;text-overflow:ellipsis;background:0 0;border:none;padding:4px 8px;font-size:11px;display:block;overflow:hidden}.pp-datasym-item:hover{background:var(--bg-hover);color:var(--text-primary)}.pp-datasym-item--active{background:var(--accent-dim);color:#fff}.pp-datasym-id{font-family:SF Mono,Menlo,monospace}.pp-datasym-lbl{color:var(--text-muted)}.pp-datasym-item--active .pp-datasym-lbl{color:#ffffffb3}.pp-datasym-empty{color:var(--text-muted);text-align:center;padding:8px;font-size:11px}.pp-field-row{align-items:center;gap:var(--space-xs);display:flex}.attr-list{max-height:300px;overflow-y:auto}.attr-row{align-items:center;gap:6px;padding:2px 0;display:flex}.attr-key{color:var(--text-muted);min-width:60px;font-family:SF Mono,Menlo,monospace;font-size:11px}.attr-val{border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);border-radius:2px;flex:1;min-width:0;padding:2px 4px;font-family:SF Mono,Menlo,monospace;font-size:11px}.attr-val:focus{border-color:var(--accent);outline:none}.symbol-palette{background:var(--bg-secondary);border-left:1px solid var(--border);width:260px;min-width:260px;overflow-y:auto}.palette-category{border-bottom:1px solid var(--border);padding:8px 12px}.palette-cat-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:6px;font-size:10px;font-weight:600}.palette-items{flex-wrap:wrap;gap:4px;display:flex}.palette-item{border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;border-radius:3px;padding:3px 6px;font-size:10px}.palette-item:hover{background:var(--bg-hover);color:var(--text-primary)}.settings-panel{background:var(--bg-primary);flex-direction:column;flex:1;display:flex;overflow:hidden}.sp-scroll{flex:1;padding-bottom:20px;overflow-y:auto}.sp-section{border-bottom:1px solid var(--border)}.sp-section-header{background:var(--bg-secondary);width:100%;color:var(--text-primary);cursor:pointer;text-align:left;border:none;align-items:center;gap:6px;padding:8px 12px;font-size:12px;font-weight:600;display:flex}.sp-section-header:hover{background:var(--bg-hover)}.sp-chevron{color:var(--text-muted);font-size:8px;transition:transform .15s}.sp-chevron--open{transform:rotate(90deg)}.sp-section-title{flex:1}.sp-section-body{padding:6px 12px 10px}.sp-field{align-items:center;gap:8px;min-height:28px;padding:3px 0;display:flex}.sp-label{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;flex:0 0 140px;font-size:11px;overflow:hidden}.sp-input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-tertiary);min-width:0;color:var(--text-primary);flex:1;padding:3px 6px;font-family:SF Mono,Menlo,monospace;font-size:11px}.sp-input:focus{border-color:var(--accent);outline:none}.sp-input--num{max-width:100px}.sp-input--color{flex:1}.sp-toggle{cursor:pointer;width:32px;height:18px;display:inline-block;position:relative}.sp-toggle input{opacity:0;width:0;height:0}.sp-toggle-slider{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:9px;transition:background .2s;position:absolute;inset:0}.sp-toggle-slider:before{content:"";background:var(--text-muted);border-radius:50%;width:12px;height:12px;transition:transform .2s,background .2s;position:absolute;bottom:2px;left:2px}.sp-toggle input:checked+.sp-toggle-slider{background:var(--accent-dim);border-color:var(--accent)}.sp-toggle input:checked+.sp-toggle-slider:before{background:var(--accent);transform:translate(14px)}.sp-color-wrap{flex:1;align-items:center;gap:6px;min-width:0;display:flex}.sp-color-picker{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:0 0;flex-shrink:0;width:24px;height:24px;padding:0}.sp-color-picker::-webkit-color-swatch-wrapper{padding:1px}.sp-color-picker::-webkit-color-swatch{border:none;border-radius:2px}.sp-fill-group{padding:4px 0}.sp-fill-label{color:var(--text-primary);margin-bottom:2px;font-size:11px;font-weight:600}.sp-fill-fields{padding-left:8px}.sp-subtree{padding-left:0}.sp-subtree-item{padding:4px 0}.sp-select{appearance:auto;cursor:pointer;max-width:140px}.sp-add-section{flex-direction:column;gap:10px;padding:20px 16px;display:flex}.sp-add-desc{color:var(--text-secondary);margin:0;font-size:12px}.sp-add-btn{border:1px solid var(--accent);border-radius:var(--radius-sm);background:var(--accent-dim);color:var(--accent);cursor:pointer;align-self:flex-start;padding:6px 12px;font-size:12px}.sp-add-btn:hover{background:var(--accent);color:#fff}.sp-page-picker{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;max-width:160px;margin-left:auto;padding:2px 6px;font-size:11px}.panel-readonly-badge{color:var(--text-muted);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);margin-left:auto;padding:1px 6px;font-size:10px;font-weight:500}.sp-toggle--readonly{opacity:.6;cursor:default}.sp-palette{flex-wrap:wrap;gap:2px;margin-top:2px;display:flex}.sp-palette-swatch{border:1px solid var(--border);cursor:pointer;border-radius:2px;width:12px;height:12px}.sp-palette-swatch:hover{border-color:var(--accent);transform:scale(1.3)}.welcome{background:var(--bg-primary);flex:1;justify-content:center;align-items:center;padding:40px 20px;display:flex;overflow-y:auto}.welcome-card{text-align:center;flex-direction:column;align-items:center;max-width:480px;display:flex}.welcome-icon{color:var(--accent);opacity:.7;margin-bottom:16px}.welcome-title{color:var(--text-primary);letter-spacing:-.5px;margin:0 0 6px;font-size:28px;font-weight:700}.welcome-subtitle{color:var(--text-muted);margin:0 0 32px;font-size:14px}.welcome-upload-btn{border-radius:var(--radius-md,8px);background:var(--accent);color:#fff;cursor:pointer;border:none;align-items:center;gap:10px;padding:14px 36px;font-size:16px;font-weight:600;transition:background .15s,transform .1s;display:inline-flex}.welcome-upload-btn:hover{filter:brightness(1.15);transform:translateY(-1px)}.welcome-upload-btn:active{transform:translateY(0)}.welcome-buttons{align-items:center;gap:12px;display:flex}.welcome-new-btn{border:1px solid var(--accent);border-radius:var(--radius-md,8px);color:var(--accent);cursor:pointer;background:0 0;align-items:center;gap:10px;padding:14px 36px;font-size:16px;font-weight:600;transition:background .15s,transform .1s;display:inline-flex}.welcome-new-btn:hover{background:var(--accent-dim,#3b82f61a);transform:translateY(-1px)}.welcome-new-btn:active{transform:translateY(0)}.welcome-drop-hint{color:var(--text-muted);margin:10px 0 0;font-size:12px}.welcome-features{text-align:left;grid-template-columns:1fr 1fr;gap:16px;width:100%;margin-top:40px;display:grid}.welcome-feature{align-items:flex-start;gap:10px;display:flex}.welcome-feature-icon{color:var(--accent);opacity:.8;flex-shrink:0;margin-top:1px}.welcome-feature-title{color:var(--text-primary);margin-bottom:2px;font-size:12px;font-weight:600}.welcome-feature-desc{color:var(--text-muted);font-size:11px;line-height:1.4}.welcome-compat{color:var(--text-muted);opacity:.6;margin-top:36px;font-size:11px}.disclaimer-banner{justify-content:space-between;align-items:center;gap:var(--space-sm);padding:6px var(--space-md);color:#d4a648;background:#292317;border-bottom:1px solid #5a3e10;flex-shrink:0;font-size:12px;line-height:1.5;display:flex}.disclaimer-banner-content{align-items:center;gap:var(--space-xs);min-width:0;display:flex}.disclaimer-icon{opacity:.8;flex-shrink:0}.disclaimer-dismiss{color:#a07830;cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;padding:3px;display:inline-flex}.disclaimer-dismiss:hover{color:#d4a648;background:#ffffff12}.checklist-editor{background:var(--bg-primary);flex-direction:column;flex:1;display:flex;overflow:hidden}.cl-preview-wrap{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border);background:#000;flex-shrink:0;justify-content:center;display:flex;overflow:hidden}.cl-preview-canvas{border:1px solid var(--border);border-radius:var(--radius-sm)}.cl-toolbar{align-items:center;gap:var(--space-sm);padding:6px var(--space-md);border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0;display:flex}.cl-toolbar-title{color:var(--text-primary);font-size:13px;font-weight:600}.cl-toolbar-count{color:var(--text-muted);margin-left:auto;font-size:11px}.cl-toolbar-btn{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);padding:4px 10px;font-size:11px}.cl-toolbar-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.cl-list{flex:1;overflow:hidden auto}.cl-item{align-items:center;gap:var(--space-xs);padding:3px var(--space-sm);border-bottom:1px solid var(--border);background:var(--bg-primary);transition:background var(--transition-fast);min-height:32px;display:flex}.cl-item:hover{background:var(--bg-hover)}.cl-item--header{background:var(--bg-tertiary)}.cl-item--header:hover{background:var(--bg-active)}.cl-item--other{opacity:.6}.cl-type-toggle{border-radius:var(--radius-sm);cursor:pointer;border:1px solid var(--border);background:var(--bg-tertiary);width:24px;height:24px;color:var(--text-muted);transition:background var(--transition-fast), color var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:11px;font-weight:700;display:flex}.cl-type-toggle:hover{border-color:var(--text-muted)}.cl-item--header .cl-type-toggle{color:#000;background:#b89800;border-color:#d4b000}.cl-item--header .cl-type-toggle:hover{background:#d4b000}.cl-item-text{border-radius:var(--radius-sm);color:var(--text-primary);min-width:0;transition:background var(--transition-fast), border-color var(--transition-fast);background:0 0;border:1px solid #0000;outline:none;flex:1;padding:4px 8px;font-size:13px}.cl-item-text:focus{background:var(--bg-primary);border-color:var(--accent)}.cl-item--header .cl-item-text{color:#e0c000;font-weight:600}.cl-item-actions{opacity:0;transition:opacity var(--transition-fast);flex-shrink:0;gap:2px;display:flex}.cl-item:hover .cl-item-actions{opacity:1}.cl-item-btn{border-radius:var(--radius-sm);background:var(--bg-tertiary);width:22px;height:22px;color:var(--text-muted);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);border:none;justify-content:center;align-items:center;padding:0;font-size:10px;display:flex}.cl-item-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.cl-item-btn:disabled{opacity:.3;cursor:default}.cl-item-btn--delete:hover:not(:disabled){background:var(--danger);color:#fff}.cl-empty{padding:var(--space-xl) var(--space-md);text-align:center;color:var(--text-muted);font-size:12px}.cl-add-bar{gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border-top:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0;display:flex}.cl-add-input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);box-sizing:border-box;min-width:0;transition:border-color var(--transition-fast);outline:none;flex:1;padding:6px 10px;font-size:12px}.cl-add-input:focus{border-color:var(--accent)}.cl-add-input::placeholder{color:var(--text-muted)}.cl-add-btn{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);padding:6px 12px;font-size:11px;font-weight:600}.cl-add-btn:hover{background:var(--accent-dim);color:#fff;border-color:var(--accent)}.cl-add-btn--header:hover{color:#000;background:#b89800;border-color:#d4b000}:root{--bg-primary:#1e1e2e;--bg-secondary:#2a2a3c;--bg-tertiary:#353548;--bg-hover:#3a3a50;--bg-active:#4a4a65;--text-primary:#e0e0e0;--text-secondary:#a0a0b0;--text-muted:#707080;--border:#3a3a4a;--accent:#4285f4;--accent-dim:#3060b0;--danger:#e04040;--success:#40c040;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080;--transition-fast:.15s ease;--transition-normal:.25s ease}@font-face{font-family:LX;src:url(/assets/lxfont.ttf)format("truetype");font-weight:400;font-style:normal;font-display:swap}*{box-sizing:border-box;margin:0;padding:0}html,body,#app{width:100%;height:100%;color:var(--text-primary);background:var(--bg-primary);font-family:system-ui,-apple-system,Segoe UI,sans-serif;font-size:13px;overflow:hidden}.app{flex-direction:column;height:100%;display:flex}.app-body,.app-main{flex:1;display:flex;overflow:hidden}.resize-handle{cursor:col-resize;z-index:10;flex-shrink:0;width:4px;position:relative}.resize-handle:after{content:"";background:var(--border);opacity:0;width:2px;height:32px;transition:opacity var(--transition-fast);border-radius:1px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.resize-handle:hover:after,.resize-handle.active:after{opacity:1;background:var(--accent)}body.resizing,body.resizing *{cursor:col-resize!important;-webkit-user-select:none!important;user-select:none!important}::-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)}.status-bar{background:var(--bg-secondary);border-top:1px solid var(--border);height:28px;color:var(--text-muted);flex-shrink:0;align-items:center;padding:0 12px;font-size:11px;display:flex}.status-bar-left{flex:1;align-items:center;gap:16px;min-width:0;display:flex}.status-bar-right{color:var(--text-muted);flex-shrink:0;align-items:center;gap:12px;display:flex}
