:root{--accent-50: #f4f8ff;--accent-100: #e8f0fe;--accent-400: #5c8dff;--accent: #2b6bf5;--accent-hover: #1f57d6;--accent-soft: var(--accent-100);--accent-soft-border: #c7d3f0;--ink: #1a1f2b;--ink-700: #3a4254;--text-secondary: #6b7385;--text-faint: #9aa1b1;--text-fainter: #c0c5d0;--surface-panel: #ffffff;--surface-app: #f6f7f9;--surface-canvas: #f6f7f9;--surface-input: #ffffff;--surface-fill: #f0f2f5;--surface-fill-2: #fbfbfc;--border-hairline: #eff1f5;--border-control: #e5e8ef;--border-card: #e5e8ef;--border-divider: #eff1f5;--success: #1f8a5b;--danger: #d64545;--danger-soft-border: #ecc9c5;--critic-text: #9a7400;--critic-accent: #c79a3a;--critic-bg: #fbf1d6;--ruler-tick: #c0c5d0;--grid-line: rgba(43, 107, 245, .08);--glass: rgba(255, 255, 255, .85);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 10px;--shadow-sm: 0 1px 2px rgba(16, 24, 40, .06);--shadow-md: 0 4px 14px rgba(16, 24, 40, .1);--shadow-lg: 0 6px 18px rgba(16, 24, 40, .12);--shadow-floating: var(--shadow-lg);--shadow-artboard: 0 0 0 1px #e9ebf0, 0 1px 3px rgba(16, 24, 40, .05);--ring-selection: 0 0 0 3px rgba(43, 107, 245, .15);--font-body: "IBM Plex Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-display: "IBM Plex Sans", system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, "Cascadia Code", Consolas, monospace;--bg: var(--surface-app);--panel: var(--surface-panel);--panel-2: var(--surface-input);--border: var(--border-control);--text: var(--ink);--text-dim: var(--ink-700);--artboard-bg: var(--surface-canvas);color-scheme:light;font-family:var(--font-body);font-size:13px;color:var(--text)}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{background:var(--bg)}.loading{display:grid;place-items:center;height:100%;color:var(--text-dim)}.panel-title,.subsection-title,.lib-rail-title,.group-label,.ge-head,.ge-label,.preview-title,.assistant-round-head{font-family:var(--font-display)}.zoom-label,.preview-size-label,.ge-scale-val,.node-badge,.ge-num,input[type=number]{font-family:var(--font-mono)}.app{display:flex;flex-direction:column;height:100%}.toolbar{display:flex;flex-direction:column;background:var(--panel);border-bottom:1px solid var(--border);flex:0 0 auto}.toolbar-tier{display:flex;align-items:center;gap:14px;height:52px;padding:0 14px;min-width:0}.toolbar-tier-2{height:46px;gap:12px;background:var(--surface-fill-2);border-top:1px solid var(--border-hairline)}.toolbar-group{display:flex;align-items:center;gap:8px;min-width:0}.toolbar-tier .tool,.toolbar-tier .btn-outline,.toolbar-tier .btn-accent{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 15px;font-family:var(--font-display);font-weight:600}.snap-controls{display:inline-flex;align-items:center;gap:10px;min-width:0}.brand{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:700;letter-spacing:.5px;white-space:nowrap;color:var(--text)}.project-name{color:var(--text-dim)}.zoom-label{min-width:40px;text-align:center;color:var(--text-dim);font-variant-numeric:tabular-nums}.toggle{display:flex;align-items:center;gap:6px;color:var(--text-dim);cursor:pointer;user-select:none}.workspace{display:flex;flex:1 1 auto;min-height:0}.sidebar{flex:0 0 240px;background:var(--panel);overflow-y:auto}.sidebar-left{border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.sidebar-left>.panel{flex:1 1 auto;overflow-y:auto;border-bottom:none}.sidebar-right{border-left:1px solid var(--border)}.canvas-area{flex:1 1 auto;min-width:0;display:flex;flex-direction:column}button{font:inherit;color:var(--text);background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius-md);padding:4px 10px;cursor:pointer}button:hover:not(:disabled){border-color:var(--accent)}button:focus-visible,select:focus-visible,[role=button]:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--accent);outline-offset:1px}button:disabled{opacity:.4;cursor:default}button.tool.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}input[type=range]{width:100%;accent-color:var(--accent)}input[type=color]{width:100%;height:28px;padding:0;background:transparent;border:1px solid var(--border);border-radius:6px;cursor:pointer}input[type=color]::-webkit-color-swatch-wrapper{padding:0}input[type=color]::-webkit-color-swatch{border:none;border-radius:inherit}input[type=color]::-moz-color-swatch{border:none;border-radius:inherit}.panel{padding:14px;border-bottom:1px solid var(--border)}.panel-title{margin:0 0 6px;font-size:13px;font-weight:600}.panel-hint{margin:0 0 12px;font-size:11.5px;line-height:1.5;color:var(--text-dim)}.field{display:block;margin-bottom:14px}.field-label{display:block;margin-bottom:6px;color:var(--text-dim)}.subsection{margin-top:14px}.subsection-title{margin:0 0 8px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim)}.subsection-title.spaced{margin-top:14px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:6px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px}.list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.list-item{display:flex;align-items:center;gap:8px;width:100%;text-align:left;padding:6px 8px;border-radius:6px;background:var(--panel-2);border:1px solid transparent}button.list-item{cursor:pointer}.list-item.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.list-item.static{cursor:default}.node-badge{font-size:10px;text-transform:uppercase;letter-spacing:.04em;padding:1px 6px;border-radius:4px;background:var(--accent-soft);color:var(--accent-hover)}.node-name{color:var(--text)}.artboard{position:absolute;inset:0;background:var(--artboard-bg);overflow:hidden;user-select:none;touch-action:none}.artboard-svg{display:block}.icon-bg{fill:var(--surface, #ffffff)}.icon-frame{fill:none;stroke:var(--accent);opacity:.5;stroke-width:1;vector-effect:non-scaling-stroke}.pixel-grid line{stroke:var(--grid-line);stroke-width:1;vector-effect:non-scaling-stroke}.selection-overlay rect{fill:none;stroke:var(--accent);stroke-width:1;vector-effect:non-scaling-stroke}.pen-preview .pen-rubber{stroke:var(--accent);stroke-width:1;stroke-dasharray:4 3;vector-effect:non-scaling-stroke}.pen-preview circle{fill:#fff;stroke:var(--accent);stroke-width:1;vector-effect:non-scaling-stroke}.pen-preview .pen-endpoint{fill:var(--accent);stroke:#fff;stroke-width:1.5;vector-effect:non-scaling-stroke}.prop-title{display:flex;align-items:center;gap:8px;margin-bottom:16px}.prop-name{flex:1 1 auto;min-width:0;margin:-3px -6px;padding:3px 6px;background:transparent;border:1px solid transparent;border-radius:6px;font-family:var(--font-display);font-size:14px;font-weight:600;color:var(--ink)}.prop-name:hover{border-color:var(--border-control)}.prop-name:focus{outline:none;background:var(--surface-input);border-color:var(--accent)}.prop-row{display:flex;gap:7px;margin-bottom:8px}.prop-field{flex:1 1 0;min-width:0;display:flex;flex-direction:column;gap:4px}.prop-field-label{font-family:var(--font-mono);font-size:10px;color:var(--text-faint)}.prop-field input,.prop-field select{width:100%;min-width:0;background:var(--surface-input);color:var(--text);border:1px solid var(--border-control);border-radius:6px;padding:7px 9px;font-size:12px}.prop-field input{font-family:var(--font-mono)}.prop-field select{font-family:inherit}.prop-field input:focus,.prop-field select:focus,.field-row input:focus,.field-controls input:focus,.field-controls select:focus{outline:none;border-color:var(--accent);background:var(--accent-50);box-shadow:var(--ring-selection)}.field-row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.field-row .field-label{margin:0;flex:0 0 auto}.field-controls{display:flex;align-items:center;gap:6px;flex:1 1 auto;min-width:0}.gradient-editor{display:flex;flex-direction:column;gap:8px;margin-top:4px;padding:8px;background:var(--panel-2);border:1px solid var(--border);border-radius:6px}.grad-preview{position:relative;height:22px;border-radius:var(--radius-sm);border:1px solid var(--border-control);cursor:copy}.grad-marker{position:absolute;top:50%;width:12px;height:12px;padding:0;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px var(--text-faint);transform:translate(-50%,-50%);cursor:pointer}.grad-marker.active{box-shadow:0 0 0 2px var(--accent)}.grad-stops-head{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-dim)}.grad-stops{display:flex;flex-direction:column;gap:4px}.grad-stop{display:grid;grid-template-columns:22px minmax(0,1fr) auto;align-items:center;gap:6px;padding:2px;border-radius:var(--radius-sm);cursor:pointer}.grad-stop.selected{background:var(--accent-soft)}.grad-selstop{display:grid;grid-template-columns:22px minmax(0,1fr) auto;align-items:center;gap:6px;padding:6px;background:var(--surface-fill-2);border:1px solid var(--border);border-radius:6px}.grad-hex{width:100%;min-width:0;font-family:var(--font-mono);font-size:11px;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:4px 6px}.grad-sw{position:relative;width:22px;height:22px;border-radius:4px;border:1px solid var(--border-control);overflow:hidden;cursor:pointer}.grad-sw input[type=color]{position:absolute;inset:-4px;width:calc(100% + 8px);height:calc(100% + 8px);border:none;padding:0;opacity:0;cursor:pointer}.grad-color-sel{min-width:0;width:100%;font-size:11px}.grad-pos{display:flex;align-items:center;gap:2px}.grad-pos input{width:40px;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:4px;font:inherit;font-size:11px}.grad-unit{color:var(--text-dim);font-size:11px;flex:0 0 auto}.grad-add{align-self:flex-start;font-size:12px;padding:3px 8px}.field-row input[type=text],.field-row input[type=number],.field-controls input[type=number],.field-controls select{flex:1 1 auto;min-width:0;width:100%;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:4px 8px;font:inherit}.field-controls input[type=color]{flex:0 0 32px;width:32px;height:26px}.swatch-select{position:relative;flex:1 1 auto;min-width:0}.swatch-select-trigger{display:flex;align-items:center;gap:7px;width:100%;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:4px 8px}.swatch-select.open .swatch-select-trigger,.swatch-select-trigger:hover{border-color:var(--accent)}.swatch-select-value{flex:1 1 auto;min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.swatch-select-caret{flex:0 0 auto;color:var(--text-dim);font-size:10px}.swatch-chip{flex:0 0 auto;width:13px;height:13px;border-radius:3px;border:1px solid var(--border-control);box-shadow:inset 0 0 0 1px #ffffff80}.swatch-chip-none{background:repeating-linear-gradient(-45deg,#fff,#fff 2px,#e0e0da 2px 4px);box-shadow:none}.swatch-select-list{position:absolute;top:calc(100% + 3px);right:0;left:auto;width:max-content;min-width:100%;max-width:min(15rem,80vw);z-index:50;margin:0;padding:4px;list-style:none;background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);max-height:240px;overflow-y:auto}.swatch-select-header{padding:5px 6px 2px;font-family:var(--font-display);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim)}.swatch-select-option{display:flex;align-items:center;gap:7px;padding:5px 6px;border-radius:var(--radius-sm);cursor:pointer}.swatch-select-option:hover{background:var(--surface-fill)}.swatch-select-option.active{background:var(--accent-soft);color:var(--accent)}.context-menu{position:fixed;z-index:1000;min-width:184px;padding:4px;background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);font-size:12px;user-select:none}.context-menu-item{display:flex;align-items:center;justify-content:space-between;gap:18px;width:100%;padding:5px 8px;border:none;background:none;color:var(--text);border-radius:var(--radius-sm);cursor:pointer;text-align:left}.context-menu-item:hover:not(:disabled){background:var(--accent-soft);color:var(--accent)}.context-menu-item:disabled{color:var(--text-faint);cursor:default}.context-menu-item.danger:hover:not(:disabled){background:var(--danger-soft-border);color:var(--danger)}.context-menu-shortcut{font-family:var(--font-mono);font-size:10px;color:var(--text-faint)}.context-menu-item:hover:not(:disabled) .context-menu-shortcut{color:inherit}.context-menu-sep{height:1px;margin:4px 6px;background:var(--border)}button.danger{margin-top:12px;width:100%;border-color:var(--danger-soft-border);color:var(--danger)}button.danger:hover:not(:disabled){border-color:var(--danger)}.button-row{display:flex;gap:8px;margin-bottom:10px}.button-row button{flex:1 1 auto}.button-row.guide-add{flex-wrap:wrap;gap:6px}.button-row.guide-reset{margin-top:8px}.button-row.guide-add button{flex:1 1 40%;font-size:11px;padding:4px 6px}.export-code{width:100%;height:140px;resize:vertical;background:var(--surface-fill-2);color:var(--ink);border:1px solid var(--border);border-radius:6px;padding:8px;font-family:var(--font-mono);font-size:11px;line-height:1.5;white-space:pre}.assistant-content{padding:14px}.assistant-input{width:100%;min-height:64px;resize:vertical;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:8px;font:inherit;margin-bottom:10px}.assistant-input:focus{outline:none;border-color:var(--accent)}.assistant-spec{min-height:110px}.assistant-error{margin:8px 0 0;font-size:11.5px;line-height:1.5;color:var(--danger);word-break:break-word}.assistant-log{margin-top:12px;display:flex;flex-direction:column;gap:4px}.assistant-call{font-family:var(--font-mono);font-size:11px;line-height:1.5;color:var(--text-dim);word-break:break-word}.assistant-call.ok code{color:var(--accent-hover)}.assistant-call.err{color:var(--danger)}.assistant-final{margin:10px 0 0;font-size:12px;line-height:1.5;color:var(--text)}.assistant-status{margin:8px 0 0;font-size:11.5px;color:var(--text-dim)}.assistant-round+.assistant-round{margin-top:8px;padding-top:8px;border-top:1px dashed var(--border)}.assistant-round-head{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);margin-bottom:4px}.assistant-critique{margin:8px 0 0;font-size:11.5px;line-height:1.5;color:var(--critic-text)}.assistant-critique.ok{color:var(--accent-hover)}.layer-item{display:flex;flex-direction:column;gap:4px}.layer-row{display:flex;align-items:center;gap:4px;border-radius:6px;border:1px solid transparent;background:var(--panel-2)}.layer-item.active>.layer-row{border-color:var(--accent);background:var(--accent-soft)}.layer-item.editing>.layer-row{border-color:var(--accent);border-style:dashed}.layer-item.readonly>.layer-row{opacity:.6}.layer-children{margin:0}.layer-caret{flex:0 0 auto;width:16px;background:transparent;border:none;padding:0;color:var(--text-dim);cursor:pointer;font-size:10px;line-height:1}.layer-caret-spacer{flex:0 0 auto;width:16px}.layer-count{font-family:var(--font-mono);font-size:10px;color:var(--text-dim);margin-left:2px}.layer-select{display:flex;align-items:center;gap:8px;flex:1 1 auto;min-width:0;text-align:left;background:transparent;border:none;padding:6px 8px}.layer-select:hover{border:none}.icon-btn{flex:0 0 auto;background:transparent;border:none;padding:4px 8px;color:var(--text-dim)}.icon-btn:hover{border:none;color:var(--text)}.icon-btn.on{color:var(--accent)}.layer-item.dragging{opacity:.5}.layer-rename{flex:1 1 auto;min-width:0;margin:2px 4px;background:var(--panel-2);color:var(--text);border:1px solid var(--accent);border-radius:4px;padding:4px 8px;font:inherit}.group-label{color:var(--text-dim);font-size:11px}.token-group-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.token-group-head .subsection-title{margin:0}.section-toggle{display:flex;align-items:center;gap:4px;flex:1 1 auto;min-width:0;background:none;border:none;padding:0;cursor:pointer;text-align:left}.section-toggle .subsection-title{margin:0}.token-empty{margin:4px 0 0;color:var(--text-dim);font-size:11.5px}.hex-input{font-family:var(--font-mono);font-size:11px;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:4px 8px;min-width:0}.field-controls .hex-input{flex:0 0 76px;width:76px}.mode-switch{display:flex;flex-direction:column;gap:8px;margin-top:4px}.mode-chips{display:flex;flex-wrap:wrap;gap:6px}.mode-chip{display:inline-flex;align-items:center;background:var(--panel-2);color:var(--text-dim);border:1px solid var(--border);border-radius:999px;font:inherit;font-size:12px;overflow:hidden}button.mode-chip{padding:3px 12px;cursor:pointer}.mode-chip.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.mode-chip-label{background:none;border:none;color:inherit;cursor:pointer;padding:3px 6px 3px 12px;font:inherit}.mode-chip-x{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:3px 8px 3px 2px;font-size:10px}.mode-chip-x:hover{color:var(--danger)}.mode-add{display:flex;gap:6px}.mode-add input{flex:1 1 auto;min-width:0;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:4px 8px;font:inherit}.mode-banner{margin:8px 0 0;padding:6px 8px;border-radius:6px;font-size:12px;color:var(--text);background:var(--accent-soft);border:1px solid var(--accent-soft-border)}.export-opts{display:flex;gap:18px}.swatches{display:flex;flex-wrap:wrap;gap:4px;margin:2px 0 4px;padding-left:2px}.swatch{width:18px;height:18px;border-radius:4px;border:1px solid var(--border);cursor:pointer;padding:0}.swatch.role{border-radius:9px}.swatch:hover{border-color:var(--accent)}.swatch.active{box-shadow:0 0 0 2px var(--accent);border-color:var(--accent)}.swatch.literal{border-style:dashed}.swatches-literal{margin-top:0}.swatch-add{display:inline-flex;align-items:center;justify-content:center;font-size:13px;line-height:1;color:var(--text-dim);background:var(--panel);border-style:dashed}.palette-list{display:flex;flex-direction:column;gap:4px}.palette-row{display:flex;align-items:center;gap:8px}.palette-row .swatch{cursor:default}.palette-hex{flex:1;font-family:var(--font-mono);font-size:12px;color:var(--text-dim)}.palette-promote{font-size:11px;padding:2px 6px;border:1px solid var(--border);border-radius:4px;background:var(--panel);color:var(--text-dim);cursor:pointer}.palette-promote:hover{border-color:var(--accent);color:var(--accent)}.snap-indicator line,.snap-indicator circle{fill:none;stroke:var(--critic-accent);stroke-width:1.5;vector-effect:non-scaling-stroke}.align-guides line{stroke:var(--danger);stroke-width:1;vector-effect:non-scaling-stroke;pointer-events:none}.anchor-overlay .anchor-dot{fill:#fff;stroke:var(--accent);stroke-width:1;vector-effect:non-scaling-stroke;pointer-events:all;cursor:pointer}.anchor-overlay .anchor-dot.selected{fill:var(--accent)}.anchor-overlay .handle-line{stroke:var(--accent);stroke-width:1;vector-effect:non-scaling-stroke;opacity:.6;pointer-events:none}.anchor-overlay .handle-dot{fill:var(--accent);stroke:#fff;stroke-width:1;vector-effect:non-scaling-stroke;pointer-events:all;cursor:pointer}.segment-overlay{pointer-events:none}.segment-overlay .segment-selected{fill:none;stroke:var(--accent);stroke-width:3;stroke-linecap:round;vector-effect:non-scaling-stroke}.segment-overlay .segment-hover{fill:none;stroke:var(--accent);stroke-width:2;stroke-linecap:round;opacity:.45;vector-effect:non-scaling-stroke}.segment-overlay .segment-add-marker{fill:#fff;stroke:var(--accent);stroke-width:1.5;vector-effect:non-scaling-stroke}.freehand-preview{fill:none;stroke:var(--accent);stroke-width:1.5;vector-effect:non-scaling-stroke}.marquee{fill:#2a4be01a;stroke:var(--accent);stroke-width:1;stroke-dasharray:3 2;vector-effect:non-scaling-stroke;pointer-events:none}.transform-overlay .resize-handle{fill:#fff;stroke:var(--accent);stroke-width:1;vector-effect:non-scaling-stroke;pointer-events:all}.transform-overlay .resize-handle[data-transform-handle=nw],.transform-overlay .resize-handle[data-transform-handle=se]{cursor:nwse-resize}.transform-overlay .resize-handle[data-transform-handle=ne],.transform-overlay .resize-handle[data-transform-handle=sw]{cursor:nesw-resize}.transform-overlay .rotate-stem{stroke:var(--accent);stroke-width:1;vector-effect:non-scaling-stroke;pointer-events:none}.transform-overlay .rotate-handle{fill:#fff;stroke:var(--accent);stroke-width:1;vector-effect:non-scaling-stroke;pointer-events:all;cursor:grab}.library{flex:1 1 auto;min-height:0;display:grid;grid-template-columns:184px minmax(0,1fr) 236px;overflow:hidden}.lib-rail{border-right:1px solid var(--border);padding:18px 12px;overflow-y:auto}.lib-rail-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);padding:0 8px 8px}.lib-cats{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.lib-cat{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:6px 8px;background:transparent;border:none;border-radius:6px;color:var(--text-dim);text-align:left;text-transform:capitalize;cursor:pointer}.lib-cat:hover{background:var(--panel-2);color:var(--text)}.lib-cat.on{background:var(--accent-soft);color:var(--accent)}.lib-cat-count{font-size:11px;color:var(--text-dim)}.lib-cat.on .lib-cat-count{color:var(--accent)}.lib-clear{margin-top:12px;width:100%;font-size:11px;color:var(--text-dim);background:transparent;border:1px dashed var(--border);border-radius:6px;padding:5px 8px;cursor:pointer}.lib-main{min-width:0;overflow-y:auto;padding:18px 20px 48px}.lib-toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:16px}.lib-view{display:flex;flex:0 0 auto;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.lib-view button{border:none;border-radius:0;background:var(--panel-2);color:var(--text-dim);padding:6px 11px;font-size:14px;line-height:1}.lib-view button.on{background:var(--accent);color:#fff}.lib-sort{flex:0 0 auto;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-md);padding:6px 8px;font:inherit}.lib-panel{border-left:1px solid var(--border);overflow-y:auto}.lib-inspector{border-top:1px solid var(--border);padding:14px 14px 16px}.lib-inspector-head{font-size:12px;color:var(--text-secondary);margin-bottom:9px}.lib-inspector-head b{color:var(--ink);font-weight:600}.lib-inspector-chips{display:flex;flex-wrap:wrap;gap:6px}.lib-token-chip{padding:3px 9px;border-radius:999px;border:1px solid var(--accent-soft-border);background:var(--accent-soft);color:var(--accent);font-family:var(--font-mono);font-size:11px;cursor:pointer}.lib-token-chip:hover{border-color:var(--accent)}.lib-search{flex:1 1 200px;min-width:160px;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-md);padding:7px 12px;font:inherit}.lib-search:focus{outline:none;border-color:var(--accent);background:var(--accent-50);box-shadow:var(--ring-selection)}.tag-chip{background:var(--panel-2);color:var(--text-dim);border:1px solid var(--border);border-radius:999px;padding:2px 10px;font-size:11px;cursor:pointer}.tag-chip:hover{color:var(--text);border-color:var(--accent)}.tag-chip.on{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.tile-tags{display:flex;align-items:center;gap:4px;flex-wrap:wrap;padding:0}.tag-chip.removable{padding:1px 6px;font-size:10px}.tag-add{flex:1 1 40px;min-width:40px;background:transparent;color:var(--text);border:none;border-bottom:1px dashed var(--border);padding:1px 2px;font:inherit;font-size:11px}.tag-add:focus{outline:none;border-bottom-color:var(--accent)}.global-edits{display:flex;flex-direction:column;gap:16px;padding:16px 14px}.ge-head{font-weight:600;color:var(--text-dim);text-transform:uppercase;font-size:11px;letter-spacing:.06em}.ge-group{display:flex;flex-direction:column;gap:6px}.ge-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim)}.ge-row{display:flex;align-items:center;gap:8px}.ge-row input[type=range]{flex:1 1 auto;min-width:0}.ge-swatch{width:30px;height:28px;flex:0 0 auto;padding:0;border:1px solid var(--border);border-radius:6px;background:none}.ge-text,.ge-num{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-md);padding:5px 8px;font:inherit}.ge-text:focus,.ge-num:focus{outline:none;border-color:var(--accent);background:var(--accent-50);box-shadow:var(--ring-selection)}.ge-text{flex:1 1 auto;min-width:0}.ge-num{width:58px;flex:0 0 auto}.ge-scale{justify-content:space-between}.ge-scale button{width:38px}.ge-scale-val{color:var(--text);font-size:12px}.ge-caption{font-size:11px;color:var(--text-dim)}.ge-apply{margin-top:4px;background:var(--accent);color:#fff;border:none;border-radius:6px;padding:8px;font-weight:600;cursor:pointer}.ge-apply:hover{background:var(--accent-hover)}.icon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}.icon-tile{position:relative;display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--border);border-radius:10px;overflow:hidden;padding:0}.icon-tile.active{border-color:var(--accent)}.icon-tile.selected{border-color:var(--accent);box-shadow:var(--ring-selection)}.icon-tile.dragging{opacity:.5}.tile-select{position:absolute;top:6px;right:6px;z-index:2;background:#ffffffc7;border:none;border-radius:var(--radius-sm);padding:0 4px;font-size:13px;line-height:1.4;color:var(--text);opacity:0}.icon-tile:hover .tile-select,.tile-select.on{opacity:1}.tile-select.on{color:var(--accent-hover)}.bulk-bar{display:flex;align-items:center;gap:12px;padding:10px 14px;margin-bottom:16px;background:var(--accent-soft);border:1px solid var(--accent);border-radius:8px}.bulk-bar span{color:var(--ink);font-weight:600}.bulk-bar .bulk-del:hover:not(:disabled){border-color:var(--danger);color:var(--danger)}.tile-canvas{background:transparent;border:none;border-radius:0;padding:14px;cursor:pointer}.tile-canvas:hover{border:none;background:var(--panel-2)}.tile-svg{display:block;width:100%;aspect-ratio:1 / 1}.tile-bg{fill:var(--tok-color-surface, #fff)}.tile-body{display:flex;flex-direction:column;gap:6px;padding:8px;border-top:1px solid var(--border)}.tile-name{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text);cursor:default}.tile-rename{flex:1 1 auto;min-width:0;background:var(--panel-2);color:var(--text);border:1px solid var(--accent);border-radius:4px;padding:2px 6px;font:inherit}.tile-action-row{display:flex;gap:5px;opacity:0}.icon-tile:hover .tile-action-row,.icon-tile.active .tile-action-row{opacity:1}.tile-action-row button{flex:1 1 0;min-width:0;padding:3px 4px;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tile-action-row .tile-del:hover:not(:disabled){border-color:var(--danger);color:var(--danger)}.tile-del:hover:not(:disabled){color:var(--danger)}.new-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:160px;color:var(--text-dim);border-style:dashed;cursor:pointer}.new-tile:hover{border-color:var(--accent);color:var(--text)}.new-plus{font-size:28px;line-height:1}.new-tile .tile-name{flex:0 0 auto;text-align:center}.icon-grid.list{grid-template-columns:1fr;gap:8px}.icon-grid.list .icon-tile{flex-direction:row;align-items:stretch}.icon-grid.list .tile-canvas{flex:0 0 auto;width:64px;padding:8px}.icon-grid.list .tile-body{flex:1 1 auto;flex-direction:row;align-items:center;gap:12px;border-top:none;border-left:1px solid var(--border);min-width:0}.icon-grid.list .tile-name{flex:0 0 132px}.icon-grid.list .tile-tags{flex:1 1 auto}.icon-grid.list .tile-action-row,.icon-grid.list .tile-action-row button{flex:0 0 auto}.icon-grid.list .new-tile{flex-direction:row;align-items:center;justify-content:flex-start;gap:12px;min-height:0;padding:14px}.chip-x{margin-left:4px;opacity:0}.tag-chip.removable:hover .chip-x{opacity:.8}.tile-tags .tag-add{opacity:0}.icon-tile:hover .tile-tags .tag-add,.tile-tags .tag-add:focus{opacity:1}.boolean-ghost{opacity:.28}.group-breadcrumb{position:absolute;top:12px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;padding:6px 8px 6px 14px;background:var(--panel);border:1px solid var(--accent);border-radius:var(--radius-lg);box-shadow:var(--shadow-floating);z-index:5}.group-breadcrumb span{color:var(--text);font-size:12px}.canvas-mode-menu{position:absolute;top:30px;left:50%;transform:translate(-50%);z-index:6}.canvas-mode-trigger{display:flex;align-items:center;gap:8px;padding:5px 9px 5px 7px;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-floating);color:var(--text);font-family:var(--font-display);font-size:12px;cursor:pointer}.canvas-mode-trigger:hover{border-color:var(--accent-soft-border)}.canvas-mode-trigger.open{border-color:var(--accent)}.canvas-mode-swatch{width:14px;height:14px;border-radius:4px;border:1px solid var(--border-hairline);flex-shrink:0}.canvas-mode-name{font-weight:600}.canvas-mode-caret{margin-left:2px;color:var(--text-dim);font-size:10px}.canvas-mode-list{position:absolute;top:calc(100% + 4px);left:0;min-width:100%;margin:0;padding:4px;list-style:none;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-floating)}.canvas-mode-option{display:flex;align-items:center;gap:8px;width:100%;padding:5px 8px;background:none;border:none;border-radius:6px;color:var(--text);font-family:var(--font-display);font-size:12px;text-align:left;white-space:nowrap;cursor:pointer}.canvas-mode-option:hover{background:var(--surface-fill)}.canvas-mode-option.active{color:var(--accent)}@keyframes anim-spin{to{transform:rotate(360deg)}}@keyframes anim-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.18)}}@keyframes anim-fade{0%,to{opacity:1}50%{opacity:.15}}@keyframes anim-draw{0%{stroke-dashoffset:1}to{stroke-dashoffset:0}}.state-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.chip{background:var(--panel-2);color:var(--text-dim);border:1px solid var(--border);border-radius:6px;padding:4px 10px;cursor:pointer}.chip:hover{color:var(--text);border-color:var(--accent)}.chip.on{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.toolbar-spacer{flex:1 1 auto}.seg{display:inline-flex;gap:2px;padding:3px;background:var(--surface-fill);border-radius:var(--radius-md)}.seg-btn{border:none;background:transparent;color:var(--text-secondary);border-radius:var(--radius-sm);padding:6px 14px;font-family:var(--font-display);font-size:13px;font-weight:600;line-height:1}.seg-btn:hover:not(:disabled){border:none;background:transparent;color:var(--ink)}.seg-btn.active{background:var(--surface-input);color:var(--accent);box-shadow:var(--shadow-sm)}.seg-btn:disabled{opacity:.45;cursor:default}.header-size{display:flex;align-items:center;gap:6px}.size-stroke-scale{font-family:var(--font-mono);font-size:11px;color:var(--accent);background:var(--accent-soft);border:1px solid var(--accent-soft-border);border-radius:6px;padding:2px 6px;cursor:pointer}.size-stroke-scale:hover{background:var(--accent-soft-border)}.field-scale{font-family:var(--font-mono);font-size:10px;font-weight:600;color:var(--accent);margin-left:6px}.header-size select{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:4px 6px;font:inherit;font-family:var(--font-mono);font-size:12px}.tb-div{flex:0 0 auto;width:1px;height:20px;background:var(--border)}.zoom-pill{display:flex;align-items:center;gap:4px;padding:3px 5px;background:var(--surface-fill);border:1px solid var(--border-control);border-radius:var(--radius-md)}.zoom-pill .zoom-label{min-width:46px}.zoom-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-dim);font-size:15px;line-height:1}.zoom-btn:hover:not(:disabled){border:none;background:var(--surface-fill-2);color:var(--text)}.btn-square{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;background:transparent;border:1px solid transparent;border-radius:var(--radius-md);color:var(--text-secondary);font-size:15px;line-height:1}.btn-square:hover:not(:disabled){background:var(--surface-fill);border-color:transparent;color:var(--text)}.toggle-row{cursor:pointer}.toggle-row input[type=checkbox]{margin-left:auto}.right-rail{position:relative;flex:0 0 auto;display:flex;overflow:hidden}.rail-resize{position:absolute;left:0;top:0;bottom:0;width:8px;cursor:col-resize;z-index:5;background:transparent}.rail-resize:hover{background:var(--accent-soft)}.rail-body{flex:0 0 268px;overflow-y:auto}.rail-body>.panel{padding:16px}.rail-nav{flex:0 0 46px;display:flex;flex-direction:column;gap:2px;padding:8px 6px;border-left:1px solid var(--border);background:var(--panel-2)}.rail-expanded .rail-nav{flex-basis:132px}.rail-nav-toggle{align-self:flex-end;background:transparent;border:none;color:var(--text-dim);cursor:pointer;padding:2px 6px;margin-bottom:4px}.rail-nav-toggle:hover{color:var(--text)}.rail-nav-item{display:flex;align-items:center;justify-content:center;gap:10px;background:transparent;border:1px solid transparent;border-radius:6px;padding:7px;color:var(--text-dim);cursor:pointer}.rail-expanded .rail-nav-item{justify-content:flex-start}.rail-nav-item:hover{background:var(--surface-fill);color:var(--text)}.rail-nav-item.active{background:var(--accent-soft);border-color:var(--accent-soft-border);color:var(--accent)}.rail-nav-icon{width:18px;font-size:16px;line-height:1;text-align:center}.rail-nav-label{font-size:13px}.preview-strip{flex-shrink:0;display:flex;flex-direction:column;gap:12px;padding:13px 14px;border-top:1px solid var(--border-divider);background:var(--panel)}.preview-row{display:flex;align-items:flex-end;gap:11px}.preview-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--text-faint)}.preview-cell{display:flex;flex-direction:column;align-items:center;gap:4px}.preview-svg{display:block;background:#fff;border-radius:4px;border:1px solid var(--border)}.preview-size-label{font-size:10px;color:var(--text-dim);font-variant-numeric:tabular-nums}.canvas-viewport{position:relative;flex:1 1 auto;min-height:0;overflow:hidden}.snap-master{display:inline-flex;align-items:center;gap:7px;padding:4px 10px;border-radius:6px;background:transparent;border:1px solid transparent;color:var(--text-secondary);font-family:var(--font-display);font-size:11px;font-weight:600}.snap-master .snap-dot{width:7px;height:7px;border-radius:50%;background:var(--text-fainter)}.snap-master.on{background:var(--accent-soft);border-color:var(--accent-soft-border);color:var(--accent)}.snap-master.on .snap-dot{background:var(--accent)}.snap-modes{display:inline-flex;gap:2px;padding:2px;background:var(--surface-fill);border-radius:var(--radius-md)}.snap-mode{padding:3px 10px;border:1px solid transparent;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-family:var(--font-display);font-size:11px;font-weight:600;letter-spacing:.2px}.snap-mode:hover:not(:disabled){color:var(--ink);border-color:transparent}.snap-mode.on{background:var(--surface-input);color:var(--accent);box-shadow:var(--shadow-sm)}.snap-mode:disabled{opacity:.45}.status-bar{flex:0 0 auto;display:flex;align-items:center;gap:14px;height:28px;padding:0 12px;background:var(--surface-panel);border-top:1px solid var(--border-hairline);font-family:var(--font-mono);font-size:10.5px;color:var(--text-secondary);font-variant-numeric:tabular-nums}.sb-field{display:inline-flex;align-items:baseline;gap:5px}.sb-label{color:var(--text-faint)}.sb-val{color:var(--ink)}.sb-spacer{flex:1 1 auto}.sb-snap,.sb-readout{color:var(--text-faint);letter-spacing:.3px}.sb-snap.on{color:var(--accent)}.guide-layer{position:absolute;inset:0;z-index:3;pointer-events:none}.guide-layer text{font-family:var(--font-mono)}.ruler{position:absolute;background:var(--surface-panel);pointer-events:none;z-index:4}.ruler-top{top:0;left:0;border-bottom:1px solid var(--border-hairline)}.ruler-left{top:0;left:0;border-right:1px solid var(--border-hairline)}.ruler-corner{top:0;left:0;width:22px;height:22px;border-right:1px solid var(--border-hairline);border-bottom:1px solid var(--border-hairline);z-index:5}.ruler line{stroke:var(--ruler-tick);stroke-width:1}.ruler text{fill:var(--text-faint);font-family:var(--font-mono);font-size:8px}.tool-rail{flex:0 0 56px;display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 0;background:var(--surface-panel);border-right:1px solid var(--border-hairline)}.tool-rail-btn{width:38px;height:38px;display:grid;place-items:center;padding:0;border:1px solid transparent;border-radius:8px;background:transparent;color:var(--text-secondary)}.tool-rail-btn:hover:not(:disabled){background:var(--surface-fill);border-color:transparent;color:var(--ink)}.tool-rail-btn.active{background:var(--accent-soft);border-color:var(--accent-soft-border);color:var(--accent)}.tool-rail-divider{width:24px;height:1px;margin:4px 0;background:var(--border-hairline)}.rail-nav-spacer{flex:1 1 auto}.rail-nav-divider{width:22px;height:1px;margin:6px auto;background:var(--border-hairline)}.assist-bar{position:absolute;left:50%;bottom:18px;transform:translate(-50%);z-index:8;width:min(540px,72%);display:flex;flex-direction:column;gap:8px;padding:10px 12px;background:var(--surface-panel);border:1px solid var(--border-hairline);border-radius:var(--radius-lg);box-shadow:var(--shadow-floating)}.assist-bar-main{display:flex;align-items:center;gap:8px}.assist-spark{color:var(--accent);font-size:14px}.assist-bar-input{flex:1 1 auto;min-width:0;border:none;background:transparent;color:var(--ink);font:inherit;font-size:13px;padding:4px 2px}.assist-bar-input:focus{outline:none}.assist-bar-input::placeholder{color:var(--text-faint)}.assist-bar-send{flex:0 0 auto;width:30px;height:30px;display:grid;place-items:center;padding:0;border:none;border-radius:8px;background:var(--accent);color:#fff;font-size:15px}.assist-bar-send:hover:not(:disabled){background:var(--accent-hover);border:none}.assist-bar-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.assist-chips{display:flex;flex-wrap:wrap;gap:6px;min-width:0}.assist-chip{padding:3px 9px;border:1px solid var(--border-control);border-radius:20px;background:var(--surface-fill);color:var(--text-secondary);font-size:11px}.assist-chip:hover{border-color:var(--accent-soft-border);background:var(--accent-soft);color:var(--accent)}.assist-open-link{flex:0 0 auto;border:none;background:transparent;color:var(--accent);font-size:11px;padding:2px 4px;white-space:nowrap}.assist-open-link:hover{border:none;color:var(--accent-hover)}.rail-mode-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px 0}.rail-mode-header .panel-title{margin:0}.brand-mark{display:block}.breadcrumb{display:inline-flex;align-items:center;gap:7px;min-width:0;font-size:12px;white-space:nowrap}.crumb-dim{color:var(--text-faint)}.crumb-sep{color:var(--text-fainter)}.crumb{min-width:0;overflow:hidden;text-overflow:ellipsis;color:var(--ink);font-weight:600;cursor:text}.crumb-edit{font:inherit;color:var(--ink);background:var(--panel-2);border:1px solid var(--accent);border-radius:var(--radius-sm);padding:1px 5px;min-width:0;outline:none}.draft-tag{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.04em;padding:1px 6px;border-radius:4px;background:var(--critic-bg);color:var(--critic-text)}.btn-outline{font-family:var(--font-display);font-weight:600}.btn-accent{background:var(--accent);border-color:var(--accent);color:#fff;font-family:var(--font-display);font-weight:600}.btn-accent:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.assistant-stop{flex:1 1 auto;background:var(--danger);border-color:var(--danger);color:#fff;font-weight:600}.assistant-stop:hover:not(:disabled){border-color:var(--danger);filter:brightness(.93)}.tokens-view{flex:1 1 auto;min-height:0;overflow-y:auto;padding:22px 26px 56px}.tokens-head{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:22px}.tokens-title{font-family:var(--font-display);font-size:20px;font-weight:600;margin:0;color:var(--ink)}.tokens-sub{margin:4px 0 0;max-width:520px;font-size:13px;line-height:1.55;color:var(--text-secondary)}.tokens-modes{display:flex;align-items:center;flex-wrap:wrap;gap:6px}.tokens-modes-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;color:var(--text-faint);margin-right:2px}.mode-pill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;background:var(--surface-fill);border:1px solid var(--border-control);font-size:12px;color:var(--text-secondary)}.mode-pill.base{background:var(--accent-soft);border-color:var(--accent-soft-border);color:var(--accent)}.mode-pill-x{border:none;background:none;padding:0 0 0 2px;font-size:10px;color:var(--text-faint);cursor:pointer}.mode-pill-x:hover{color:var(--danger)}.tokens-mode-add{width:116px;height:28px;background:var(--panel-2);border:1px dashed var(--border-control);border-radius:var(--radius-md);padding:0 10px;font:inherit;font-size:12px;color:var(--text)}.token-preview-pick{background:var(--panel-2);color:var(--text);border:1px solid var(--border-control);border-radius:var(--radius-sm);padding:3px 8px;font:inherit;font-size:12px}.tt-name{flex:1 1 auto;min-width:0;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);padding:5px 7px;font-family:var(--font-mono);font-size:12.5px;color:var(--ink)}.preview-pill{flex:none;display:inline-flex;align-items:center;gap:8px;height:32px;padding:0 10px;border-radius:8px;background:var(--accent-soft);border:1px solid var(--accent-soft-border);cursor:pointer}.preview-pill-icon{display:flex;align-items:center;justify-content:center;width:18px;height:18px}.preview-pill-label{font-size:12px;color:var(--text-secondary, var(--text-dim))}.preview-pill-select{border:none;background:transparent;color:var(--accent);font-family:var(--font-mono);font-size:12px;font-weight:600;cursor:pointer;padding:0}.preview-pill-select:focus{outline:none}.ledger-section{max-width:1180px;margin-bottom:22px}.ledger-section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.ledger-section-head-text{display:flex;align-items:baseline;gap:9px;min-width:0}.ledger-section-title{font-family:var(--font-display);font-size:14px;font-weight:600;margin:0;color:var(--ink)}.ledger-unit{font-family:var(--font-mono);font-size:11px;color:var(--text-faint)}.ledger-hint{font-size:12px;color:var(--text-faint)}.ledger-add{flex:none;display:inline-flex;align-items:center;gap:5px;height:26px;padding:0 10px;border:1px solid var(--border-control);border-radius:8px;background:var(--surface, #fff);color:var(--text-dim);font-family:var(--font-display);font-size:11px;font-weight:500}.ledger-add:hover{background:var(--surface-fill);color:var(--accent);border-color:var(--accent-soft-border)}.ledger-scroll{overflow-x:auto;background:var(--surface-panel);border:1px solid var(--border-control);border-radius:var(--radius-lg);padding:6px}.ledger-row{display:flex;align-items:stretch;min-width:max-content;gap:0}.ledger-head-row{border-bottom:1px solid var(--border-hairline);margin-bottom:4px}.ledger-token-cell{flex:0 0 268px;min-width:0;display:flex;align-items:center;gap:9px;padding:8px 12px}.ledger-col-head,.ledger-mode-head{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-faint)}.ledger-col-head{align-self:center}.ledger-token-swatch{flex:0 0 auto;width:22px;height:22px;border-radius:var(--radius-sm);box-shadow:inset 0 0 0 1px #0000001a}.ledger-token-meta{flex:1 1 auto;min-width:0;display:flex;flex-direction:column}.ledger-token-name{padding:2px 4px}.ledger-token-desc{font-size:11px;color:var(--text-faint);padding:0 4px}.ledger-desc-input{width:100%;border:1px solid transparent;background:transparent;border-radius:var(--radius-sm);padding:1px 4px;font-size:11px;color:var(--text-dim)}.ledger-desc-input::placeholder{color:var(--text-faint);font-style:italic}.ledger-desc-input:hover{border-color:var(--border-hairline)}.ledger-desc-input:focus{outline:none;border-color:var(--accent);color:var(--text)}.ledger-pinned-row{background:var(--surface-sunken, rgba(0, 0, 0, .025));border-radius:var(--radius-md);margin-bottom:6px}.ledger-pinned-swatch{box-shadow:inset 0 0 0 1px var(--border-control)}.ledger-pinned-name{font-size:13px;font-weight:600;color:var(--text);padding:2px 4px}.ledger-mode-cell{flex:0 0 200px;display:flex;align-items:center;gap:6px}.ledger-mode-head{flex:0 0 192px;margin:4px;padding:6px 8px;gap:9px;background:var(--surface-fill);border:1px solid var(--border-hairline);border-radius:11px;text-transform:none;letter-spacing:0}.ledger-color-cell{flex:0 0 192px;min-width:0;margin:4px;padding:7px 10px;gap:9px;background:var(--surface, #fff);border:1px solid var(--border-hairline);border-radius:9px}.ledger-color-cell.inherited{border-style:dashed}.ledger-color-cell.dark{border-color:#0003}.ledger-color-cell.dark .tt-hex{color:#eef2f8;background:#0006;border-radius:5px;padding:2px 6px}.ledger-color-cell.dark .tt-hex:hover,.ledger-color-cell.dark .tt-hex:focus{border-color:#ffffff80}.ledger-color-cell.dark .tt-reset,.ledger-color-cell.dark .tt-inherit{color:#eef2f8a6}.ledger-color-cell.dark input[type=color].tt-swatch{border-color:#ffffff59}.tt-inherit{flex:0 0 auto;margin-left:auto;font-size:13px;color:var(--text-faint);line-height:1}.mode-chip-preview{flex:0 0 auto;display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--radius-sm);border:1px solid var(--border-hairline)}.mode-chip-name{flex:1 1 auto;font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--ink);text-transform:none;letter-spacing:0}.mode-chip-rename{flex:1 1 auto;min-width:0;border:1px solid var(--accent);border-radius:var(--radius-sm);background:var(--accent-50);padding:3px 6px;font:inherit;font-size:13px}.mode-chip-base{flex:0 0 auto;font-family:var(--font-mono);font-size:9px;letter-spacing:.08em;color:var(--accent);background:var(--accent-soft);border-radius:999px;padding:2px 7px}.mode-chip-kebab,.token-kebab{flex:0 0 auto;color:var(--text-faint);font-size:15px;line-height:1}.token-kebab:hover{color:var(--text)}.ledger-addmode{flex:0 0 150px;border:1px dashed var(--accent-soft-border);border-radius:var(--radius-md);background:transparent;color:var(--accent);font-family:var(--font-display);font-size:12px;font-weight:600;margin:4px}.ledger-addmode:hover{background:var(--accent-50);border-color:var(--accent)}.ledger-addmode-spacer{flex:0 0 150px;border-left:1px dashed var(--border-hairline);margin:4px}.scalar-cards{display:flex;flex-wrap:wrap;gap:10px}.scalar-card{flex:1 1 232px;min-width:218px;max-width:320px;display:flex;align-items:center;gap:13px;padding:11px 14px;background:var(--surface-fill);border:1px solid var(--border-hairline);border-radius:12px}.scalar-chip{flex:0 0 auto;display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--surface, #fff);border:1px solid var(--border-hairline);border-radius:var(--radius-md)}.scalar-card-meta{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:4px}.scalar-card-row{display:flex;align-items:center;gap:8px}.scalar-num{width:64px}.usage-pill{display:inline-flex;align-items:center;gap:5px;height:24px;padding:0 9px;border:1px solid var(--accent-soft-border);background:var(--accent-soft);color:var(--accent);border-radius:999px;font-family:var(--font-mono);font-size:11px}.usage-pill:hover{border-color:var(--accent);background:var(--accent-soft)}.panel-link{border:none;background:none;padding:0;color:var(--accent);font:inherit;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.panel-link:hover{color:var(--accent-strong, var(--accent))}.cref-list{display:flex;flex-direction:column;gap:1px;margin-top:4px}.cref-row{display:flex;align-items:center;gap:9px;padding:5px 4px}.cref-swatch{flex:0 0 auto;width:24px;height:24px;border-radius:var(--radius-sm);box-shadow:inset 0 0 0 1px #0000001f}.cref-row .scalar-chip{width:30px;height:30px;border:1px solid var(--border-hairline)}.cref-name{flex:1 1 auto;min-width:0;font-size:12.5px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cref-value{flex:0 0 auto;font-family:var(--font-mono);font-size:11px;color:var(--text-dim)}.usage-scrim{position:absolute;inset:0;z-index:60;background:#0e132073;display:flex;align-items:center;justify-content:center}.usage-modal{width:min(560px,92%);max-height:80%;overflow-y:auto;background:var(--surface-input);border-radius:var(--radius-lg);box-shadow:0 30px 70px #10182859;padding:18px 20px 20px}.usage-modal-head{display:flex;align-items:center;gap:12px}.usage-modal-swatch{flex:0 0 auto;width:40px;height:40px;border-radius:var(--radius-md);box-shadow:inset 0 0 0 1px #0000001a}.usage-modal-title{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--ink)}.usage-modal-sub{font-family:var(--font-mono);font-size:12px;color:var(--text-faint)}.usage-modal-x{margin-left:auto}.usage-modal-count{font-size:13px;color:var(--text-secondary);margin:16px 0 10px}.usage-modal-count b{color:var(--accent)}.usage-modal-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}.usage-icon-tile{display:flex;flex-direction:column;align-items:center;gap:5px;padding:10px 4px 7px;background:var(--surface-fill-2);border:1px solid var(--border-hairline);border-radius:var(--radius-md)}.usage-icon-tile:hover{border-color:var(--accent)}.usage-icon-name{font-size:10px;color:var(--text-faint);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tt-name:hover{border-color:var(--border-hairline)}.tt-name:focus{outline:none;border-color:var(--accent);background:var(--accent-50)}.tt-color{display:flex;align-items:center;gap:6px}.tt-color.inherited{opacity:.45}input[type=color].tt-swatch{flex:0 0 22px;width:22px;height:22px;padding:0;border:1px solid var(--border-control);border-radius:var(--radius-sm);background:none;cursor:pointer}.tt-hex{flex:0 0 auto;width:68px;background:transparent;color:var(--text);border:1px solid transparent;border-radius:var(--radius-sm);padding:3px 4px;font-family:var(--font-mono);font-size:12px}.tt-hex:hover{border-color:var(--border-hairline)}.tt-hex:focus{outline:none;border-color:var(--accent)}.tt-reset{flex:0 0 auto;margin-left:auto;border:none;background:none;padding:2px;font-size:13px;line-height:1;color:var(--text-faint);cursor:pointer}.tt-reset:hover{color:var(--accent)}.tt-num{width:100%;background:var(--panel-2);color:var(--text);border:1px solid var(--border-control);border-radius:var(--radius-sm);padding:5px 8px;font-family:var(--font-mono);font-size:12px}.auth-screen{display:grid;place-items:center;height:100%;background:var(--bg);padding:24px}.auth-card{display:flex;flex-direction:column;gap:12px;width:100%;max-width:360px;background:var(--surface-panel);border:1px solid var(--border-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:28px}.auth-brand{font-size:16px;margin-bottom:4px}.auth-title{font-family:var(--font-display);font-size:18px;font-weight:700;margin:0;color:var(--text)}.auth-hint{margin:0;color:var(--text-secondary);font-size:13px;line-height:1.4}.auth-form{display:flex;flex-direction:column;gap:10px;margin-top:4px}.auth-input{width:100%;background:var(--surface-input);color:var(--text);border:1px solid var(--border-control);border-radius:var(--radius-md);padding:9px 11px;font-family:var(--font-body);font-size:14px}.auth-submit{width:100%;padding:9px 11px}.auth-secondary{align-self:flex-start;margin-top:4px}.auth-error{margin:0;color:var(--danger);font-size:12px}.account{display:inline-flex;align-items:center}.account-trigger{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.context-menu-header{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:4px 8px 6px;color:var(--text-secondary);font-size:11px}.modal-overlay{position:fixed;inset:0;z-index:1000;display:grid;place-items:center;background:#10182866;padding:24px}.modal{width:100%;max-width:560px;max-height:80vh;overflow:auto;background:var(--surface-panel);border:1px solid var(--border-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:20px}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.modal-close{border:none;background:none;font-size:20px;line-height:1;color:var(--text-secondary);cursor:pointer;padding:2px 6px}.modal-close:hover{color:var(--text)}.admin-table{width:100%;border-collapse:collapse;margin-top:8px;font-size:13px}.admin-table th,.admin-table td{text-align:left;padding:7px 8px;border-bottom:1px solid var(--border-divider)}.admin-table th{color:var(--text-secondary);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em}.admin-email{font-family:var(--font-mono);font-size:12px;word-break:break-all}
