:root{--bg:#f7f7f5;--fg:#1c1c1a;--accent:#2b6cb0;--accent-2:#6b7280;--ok:#15803d;--err:#b91c1c;--panel:#fff;--border:#d8d8d2;--xs:4px;--sm:8px;--md:16px;--lg:24px;--xl:32px;--toolbar-h:40px;--ruler:20px}*{box-sizing:border-box}body{background:var(--bg);height:100vh;color:var(--fg);margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.5;display:flex}.panel{background:var(--panel);border-right:1px solid var(--border);width:280px;height:100vh;padding:var(--lg);gap:var(--lg);flex-direction:column;flex:0 0 280px;display:flex}.app-title{margin:0;font-size:20px;font-weight:600;line-height:1.2}.panel-right{background:var(--panel);border-left:1px solid var(--border);width:280px;height:100vh;padding:var(--lg);gap:var(--lg);border-right:none;flex-direction:column;flex:0 0 280px;display:flex}.gutter-info .info-value{color:var(--fg);font-size:14px;font-weight:400}.gutter-info .control-row{justify-content:space-between;align-items:baseline;gap:var(--sm);flex-direction:row}.gutter-info .info-value.ok{color:var(--ok)}.gutter-info .info-value.warn{color:var(--err)}#layouts-list{gap:var(--sm);flex-direction:column;display:flex}#layouts-list[hidden]{display:none}.layouts-rows{gap:var(--xs);flex-direction:column;display:flex}.layout-row{justify-content:space-between;align-items:baseline;gap:var(--sm);padding:var(--xs) var(--sm);border:1px solid var(--border);cursor:pointer;background:var(--panel);border-radius:4px;display:flex}.layout-row:hover{border-color:var(--accent-2)}.layout-row.is-active{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 8%, var(--panel))}.layout-name{color:var(--fg);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:400;overflow:hidden}.layout-time{color:var(--accent-2);flex:none;font-size:12px}.layout-delete{min-width:24px;min-height:24px;padding:0 var(--xs);color:var(--accent-2);flex:none;font-size:13px}.layout-delete:hover:not(:disabled){color:var(--err)}.layout-name-edit{min-height:24px;padding:0 var(--xs);border:1px solid var(--accent);background:var(--panel);color:var(--fg);border-radius:4px;font-family:inherit;font-size:14px}.prop-header{justify-content:space-between;align-items:center;gap:var(--sm);display:flex}.trash-btn{color:var(--err);border:1px solid var(--border);background:0 0;justify-content:center;align-items:center;display:inline-flex}.trash-btn:hover:not(:disabled){border-color:var(--err)}.trash-icon{width:16px;height:16px}.prop-fields[hidden]{display:none}.top-toolbar{align-items:center;gap:var(--sm);padding:var(--xs) var(--sm);background:var(--panel);border-bottom:1px solid var(--border);z-index:3;display:flex;position:absolute;top:0;left:0;right:0}.toolbar-group{align-items:center;gap:var(--xs);display:flex}.toolbar-divider{background:var(--border);align-self:stretch;width:1px}.top-toolbar .icon-btn svg{width:16px;height:16px;display:block}.ruler{background:var(--bg);border-color:var(--border);pointer-events:none;z-index:2;border-style:solid;border-width:0;position:absolute;overflow:hidden}.ruler-top{top:var(--toolbar-h);left:var(--ruler);height:var(--ruler);border-bottom-width:1px;right:0}.ruler-left{top:calc(var(--toolbar-h) + var(--ruler));width:var(--ruler);border-right-width:1px;bottom:0;left:0}.ruler-corner{top:var(--toolbar-h);width:var(--ruler);height:var(--ruler);background:var(--bg);border-right:1px solid var(--border);border-bottom:1px solid var(--border);pointer-events:none;z-index:2;position:absolute;left:0}.ruler svg{width:100%;height:100%;display:block;overflow:visible}.ruler-tick{stroke:var(--border);stroke-width:1px;fill:none}.ruler-label{fill:var(--accent-2);font-size:10px;font-weight:400}.ruler-indicator{stroke:var(--accent);stroke-width:1px;fill:none}.view-overlay{bottom:var(--md);right:var(--md);align-items:center;gap:var(--sm);background:var(--panel);border:1px solid var(--border);padding:var(--xs);z-index:2;border-radius:6px;display:flex;position:absolute;box-shadow:0 2px 8px #1c1c1a1f}.panel-sections{gap:var(--lg);flex-direction:column;flex:1;min-width:0;min-height:0;display:flex;overflow:hidden auto}.section{gap:var(--md);min-width:0;padding-bottom:var(--lg);border-bottom:1px solid var(--border);flex-direction:column;display:flex}.section:last-child{border-bottom:none;padding-bottom:0}.section-heading{text-transform:uppercase;letter-spacing:.05em;color:var(--fg);margin:0;font-size:12px;font-weight:600;line-height:1.2}summary.section-heading{cursor:pointer;justify-content:space-between;align-items:center;gap:var(--sm);list-style:none;display:flex}summary.section-heading::-webkit-details-marker{display:none}summary.section-heading:after{content:"";border-right:2px solid var(--accent-2);border-bottom:2px solid var(--accent-2);flex:none;width:7px;height:7px;margin-right:2px;transition:transform .15s;display:inline-block;transform:rotate(-45deg)}details[open]>summary.section-heading:after{transform:rotate(45deg)}summary.section-heading:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.control-row{gap:var(--sm);flex-direction:column;min-width:0;display:flex}.label{font-size:14px;font-weight:600;line-height:1.5}.dim-pair{gap:var(--sm);min-width:0;display:flex}.dim{align-items:center;gap:var(--xs);flex:1;font-weight:400;display:flex}.helper{color:var(--accent-2);margin:0;font-size:14px;font-weight:400}.palette-list+.helper{margin-top:var(--sm)}.grid-type{gap:var(--md);flex-wrap:wrap;min-width:0;display:flex}.radio{align-items:center;gap:var(--xs);font-weight:400;display:flex}.segmented{min-width:0;display:flex}.segment{min-width:0;min-height:32px;padding:0 var(--sm);border:1px solid var(--border);background:var(--panel);color:var(--fg);border-right-width:0;border-radius:0;flex:1;font-size:14px;font-weight:400}.segment:first-child{border-top-left-radius:6px;border-bottom-left-radius:6px}.segment:last-child{border-right-width:1px;border-top-right-radius:6px;border-bottom-right-radius:6px}.segment[aria-checked=true]{z-index:1;border-color:var(--accent);background:color-mix(in srgb, var(--accent) 8%, var(--panel));color:var(--accent);border-right-width:1px;font-weight:600;position:relative}.segment:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;z-index:2}.view-controls{align-items:center;gap:var(--sm);display:flex}.zoom-pct{text-align:center;font-variant-numeric:tabular-nums;min-width:48px}input,select{width:100%;min-height:32px;padding:0 var(--sm);border:1px solid var(--border);background:var(--panel);color:var(--fg);border-radius:6px;font-family:inherit;font-size:14px}.dim input{min-width:0}input:focus-visible,select:focus-visible{outline:2px solid var(--accent);outline-offset:0;border-color:var(--accent)}input[type=radio],input[type=checkbox]{accent-color:var(--accent);appearance:auto;background:0 0;border:none;border-radius:0;flex:none;width:16px;min-width:0;height:16px;min-height:0;padding:0}.panel-footer{gap:var(--sm);flex-direction:column;display:flex}button{min-height:32px;padding:0 var(--md);border:1px solid var(--border);cursor:pointer;background:var(--panel);color:var(--fg);border-radius:6px;font-family:inherit;font-size:14px;transition:background .15s,opacity .15s}button:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.icon-btn{width:auto;min-width:32px;padding:0 var(--sm);font-size:16px;line-height:1}.control-head{align-items:center;gap:var(--xs);display:flex}.info-trigger{width:16px;min-width:0;height:16px;min-height:16px;color:var(--accent-2);background:0 0;border:none;padding:0;font-size:16px;line-height:1}.info-trigger:hover:not(:disabled){color:var(--accent)}.tooltip-popover{z-index:3;max-width:280px;padding:var(--sm) var(--md);color:var(--fg);background:var(--panel);border:1px solid var(--border);border-radius:6px;font-size:14px;font-weight:400;line-height:1.5;position:fixed;box-shadow:0 2px 8px #1c1c1a1f}.tooltip-popover[hidden]{display:none}#export-btn{background:var(--accent);color:#fff;border-color:var(--accent);min-height:40px;font-weight:600}button:hover:not(:disabled){opacity:.9}button:disabled{opacity:.5;cursor:not-allowed}.modal-backdrop{z-index:2000;background:#1c1c1a66;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-card{background:var(--panel);border:1px solid var(--border);padding:var(--lg);gap:var(--md);border-radius:6px;flex-direction:column;max-width:360px;display:flex;box-shadow:0 8px 24px #1c1c1a2e}.modal-title{margin:0;font-size:16px;font-weight:600}.modal-body{color:var(--accent-2);margin:0}.modal-actions{justify-content:flex-end;gap:var(--sm);flex-wrap:wrap;display:flex}.modal-actions .modal-default{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}.modal-actions .modal-danger{background:var(--err);color:#fff;border-color:var(--err);font-weight:600}.status{min-height:1.25rem;color:var(--accent);margin:0;font-style:italic}.readout{background:var(--panel);border:1px solid var(--border);padding:var(--md);white-space:pre-wrap;border-radius:6px;margin:0;font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:13px;line-height:1.5}.readout.ok{border-left:4px solid var(--ok)}.readout.err{border-left:4px solid var(--err)}.palette-list{gap:var(--sm);grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.palette-btn{justify-content:center;align-items:center;gap:var(--xs);min-width:0;padding:var(--sm) var(--xs);cursor:grab;touch-action:none;flex-direction:column;display:flex}.palette-btn.grabbing,.palette-btn:active{cursor:grabbing}.palette-icon{fill:none;stroke:currentColor;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;flex:0 0 16px;width:16px;height:16px}.palette-label{max-width:100%;font-size:13px;font-weight:400;line-height:1.2}.canvas{background:var(--bg);user-select:none;flex:1;height:100vh;position:relative;overflow:hidden}.empty-hint{justify-content:center;align-items:center;gap:var(--sm);padding:var(--lg);text-align:center;pointer-events:none;color:var(--accent-2);flex-direction:column;display:flex;position:absolute;inset:0}.empty-hint.hidden{display:none}.empty-hint-title{margin:0;font-size:14px;font-weight:600}.empty-hint-body{max-width:360px;margin:0;font-size:14px;font-weight:400}
