@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #2a2d35;--surface: #2e3139;--raised: #33363f;--accent: #00e5c0;--accent-dim: #00b89a;--accent-glow: rgba(0, 229, 192, .15);--accent-glow-strong: rgba(0, 229, 192, .3);--text: #c0c4cc;--text-dim: #8a8e96;--text-muted: #5c5f66;--shadow-dark: rgba(0, 0, 0, .45);--shadow-darker: rgba(0, 0, 0, .6);--shadow-light: rgba(255, 255, 255, .05);--shadow-light-strong: rgba(255, 255, 255, .08);--error: #e05555;--success: #55c878;--r: 16px;--r-sm: 10px;--r-xs: 6px;--neu-raised: 6px 6px 14px var(--shadow-dark), -6px -6px 14px var(--shadow-light);--neu-raised-sm: 3px 3px 8px var(--shadow-dark), -3px -3px 8px var(--shadow-light);--neu-pressed: inset 4px 4px 10px var(--shadow-dark), inset -4px -4px 10px var(--shadow-light);--neu-pressed-sm: inset 2px 2px 6px var(--shadow-dark), inset -2px -2px 6px var(--shadow-light);--neu-well: inset 3px 3px 8px var(--shadow-darker), inset -3px -3px 8px var(--shadow-light-strong)}html,body,#root{height:100%;overflow:hidden;font-family:Outfit,sans-serif;background:var(--bg);background-image:var(--tex-surface);color:var(--text);font-size:12px;font-weight:400;user-select:none;-webkit-font-smoothing:antialiased}.app{display:flex;height:100vh;max-height:100vh;overflow:hidden}.sidebar{width:clamp(220px,22vw,290px);max-height:100vh;background:var(--bg);background-image:var(--tex-surface);overflow:hidden;display:flex;flex-direction:column;flex-shrink:0}.sidebar-inner{flex:1;min-height:0;display:flex;flex-direction:column;padding:10px;gap:10px}.sidebar-tabs{display:flex;gap:4px;flex-shrink:0;padding:4px;background:var(--surface);background-image:var(--tex-widget);border-radius:var(--r-sm);box-shadow:var(--neu-pressed-sm)}.sidebar-tab{flex:1;padding:7px 4px;background:transparent;border:none;color:var(--text-dim);font-family:Outfit,sans-serif;font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;cursor:pointer;border-radius:var(--r-xs);transition:color .15s,box-shadow .15s,background .15s}.sidebar-tab:hover{color:var(--text)}.sidebar-tab.active{color:var(--accent);background:var(--bg);background-image:var(--tex-surface);box-shadow:var(--neu-raised-sm)}.sidebar-tab-body{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:10px;padding-right:2px}.sidebar-tab-body::-webkit-scrollbar{width:4px}.sidebar-tab-body::-webkit-scrollbar-track{background:transparent}.sidebar-tab-body::-webkit-scrollbar-thumb{background:var(--raised);border-radius:4px;box-shadow:var(--neu-raised-sm)}.tab-content{display:flex;flex-direction:column;gap:10px}.sidebar-tab-body.has-tabs .tab-content{display:none}.sidebar-tab-body.has-tabs .tab-content.active{display:flex}.sidebar-tab-body.measuring .tab-content{display:flex!important}.sidebar-export{flex-shrink:0}.sidebar-logo{flex-shrink:0;padding:8px 4px 2px}.sidebar-logo img{display:block;width:100%;height:auto;opacity:.95}.sidebar-buttons-row{display:flex;gap:6px;margin-top:10px}.sidebar-buttons-row .btn{flex:1}.export-views{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;margin-bottom:12px}.export-view{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:10px;font-weight:500;letter-spacing:.5px;text-transform:uppercase;color:var(--text-dim);cursor:pointer;padding:4px 2px;border-radius:var(--r-xs);transition:color .15s}.export-view:hover{color:var(--text)}.export-view:has(input:checked){color:var(--accent)}.export-view input[type=checkbox]{appearance:none;width:16px;height:16px;border-radius:4px;background:var(--bg);background-image:var(--tex-surface);box-shadow:var(--neu-well);cursor:pointer;position:relative;margin:0}.export-view input[type=checkbox]:checked{background:var(--accent);box-shadow:var(--neu-raised-sm),0 0 6px var(--accent-glow)}.export-view input[type=checkbox]:checked:after{content:"✓";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#1a1c22;font-size:11px;font-weight:700;line-height:1}.export-controls{display:flex;gap:8px;align-items:stretch}.export-controls .export-format{flex:0 0 auto;padding:8px 24px 8px 10px;background:var(--bg);background-image:var(--tex-surface);border:none;border-radius:var(--r-sm);color:var(--text);font-family:Outfit,sans-serif;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;outline:none;cursor:pointer;box-shadow:var(--neu-well);appearance:none;-webkit-appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--text-dim) 50%),linear-gradient(135deg,var(--text-dim) 50%,transparent 50%),var(--tex-surface);background-position:calc(100% - 12px) calc(50% - 1px),calc(100% - 7px) calc(50% - 1px),0 0;background-size:5px 5px,5px 5px,auto;background-repeat:no-repeat}.export-controls .export-format:focus{box-shadow:var(--neu-well),0 0 0 1px var(--accent-dim),0 0 6px var(--accent-glow)}.export-controls .export-btn{flex:1}.main{flex:1;display:flex;flex-direction:column;min-width:0;max-height:100vh;overflow:hidden;background:var(--bg);background-image:var(--tex-surface);padding:10px;gap:8px}.view-tabs{display:flex;gap:4px;flex-shrink:0;padding:4px;background:var(--surface);background-image:var(--tex-widget);border-radius:var(--r-sm);box-shadow:var(--neu-pressed-sm)}.view-tab{flex:1;padding:8px 4px;background:transparent;border:none;color:var(--text-dim);font-family:Outfit,sans-serif;font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;border-radius:var(--r-xs);transition:color .15s,box-shadow .15s,background .15s}.view-tab:hover{color:var(--text)}.view-tab.active{color:var(--accent);background:var(--bg);background-image:var(--tex-surface);box-shadow:var(--neu-raised-sm)}.view-grid-narrow{grid-template-columns:1fr;grid-template-rows:1fr}.view-grid-cell.narrow-active{grid-column:1 / -1;grid-row:1 / -1}.view-grid-cell.narrow-inactive{position:absolute;left:-10000px;top:0;width:256px;height:256px;pointer-events:none;z-index:-1;visibility:hidden}.view-error{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;gap:6px}.view-error-label{font-size:10px;letter-spacing:2px;color:var(--text-muted)}.view-error-msg{font-size:11px;color:var(--error)}.app-narrow .sidebar{width:clamp(190px,28vw,240px)}.view-grid-wrap{flex:1;position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--neu-pressed);background:var(--bg);background-image:var(--tex-surface)}.view-grid{width:100%;height:100%;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:3px;overflow:hidden;background:#00000040}.view-grid-cell{position:relative;overflow:hidden;background:#1a1c22;padding:20px}.view-grid-cell.hidden{display:none}.view-grid-cell.expanded{grid-column:1 / -1;grid-row:1 / -1}.view-grid-label{position:absolute;top:8px;left:12px;font-size:9px;font-weight:500;letter-spacing:2px;color:var(--text-muted);z-index:1;pointer-events:none;text-transform:uppercase}.view-grid-toggle{position:absolute;top:4px;right:8px;z-index:2;background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:4px 6px;line-height:1;border-radius:var(--r-xs);opacity:0;transition:opacity .2s,color .2s}.view-grid-cell:hover .view-grid-toggle{opacity:1}.view-grid-toggle:hover{color:var(--accent)}.view-grid-cell.expanded .view-grid-toggle{opacity:1}.sidebar-widget{background:var(--surface);background-image:var(--tex-widget);border-radius:var(--r);padding:14px;box-shadow:var(--neu-raised);border:none}.widget-color-picker{padding:16px}.widget-color-picker .color-picker-custom{gap:8px}.widget-color-picker .color-slots{margin-top:12px}input[type=text],input[type=number]{width:100%;padding:10px 12px;background:var(--bg);background-image:var(--tex-surface);border:none;border-radius:var(--r-sm);color:var(--text);font-family:Outfit,sans-serif;font-size:12px;outline:none;box-shadow:var(--neu-well);transition:box-shadow .2s}input[type=text]:focus,input[type=number]:focus{box-shadow:var(--neu-well),0 0 0 1px var(--accent-dim),0 0 6px var(--accent-glow)}input[type=text]::placeholder{color:var(--text-muted)}input.name-conflict{color:var(--error)}input.name-conflict:focus{box-shadow:var(--neu-well),0 0 0 1px var(--error),0 0 6px #e0555533}input[type=range]{-webkit-appearance:none;width:100%;height:8px;background:var(--bg);background-image:var(--tex-surface);border-radius:6px;outline:none;margin:10px 0;box-shadow:var(--neu-well)}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;background-image:var(--tex-knob);background-size:cover;border:none;border-radius:50%;cursor:pointer;box-shadow:3px 3px 8px var(--shadow-dark),-3px -3px 8px var(--shadow-light),0 0 0 1px #00000026;transition:transform .15s,box-shadow .15s}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:3px 3px 8px var(--shadow-dark),-3px -3px 8px var(--shadow-light),0 0 8px var(--accent-glow)}input[type=range]:disabled,input[type=range].range-disabled{background:#2a2c33;background-image:none;cursor:not-allowed;opacity:.55}input[type=range]:disabled::-webkit-slider-thumb,input[type=range].range-disabled::-webkit-slider-thumb{background-image:none;background-color:#3a3d44;cursor:not-allowed;box-shadow:inset 1px 1px 2px #0006,inset -1px -1px 2px #ffffff0a,0 0 0 1px #0000004d}input[type=range]:disabled::-webkit-slider-thumb:hover,input[type=range].range-disabled::-webkit-slider-thumb:hover{transform:none;box-shadow:inset 1px 1px 2px #0006,inset -1px -1px 2px #ffffff0a,0 0 0 1px #0000004d}button.btn{width:100%;padding:10px 12px;background:var(--accent);color:#1a1c22;border:none;border-radius:var(--r-sm);cursor:pointer;font-family:Outfit,sans-serif;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;transition:all .2s;box-shadow:4px 4px 10px var(--shadow-dark),-4px -4px 10px var(--shadow-light),0 0 12px var(--accent-glow)}button.btn:hover{background:#1affd4;box-shadow:4px 4px 10px var(--shadow-dark),-4px -4px 10px var(--shadow-light),0 0 20px var(--accent-glow-strong)}button.btn:active{background:var(--accent-dim);box-shadow:var(--neu-pressed-sm),0 0 8px var(--accent-glow)}button.btn:disabled{background:var(--raised);color:var(--text-muted);cursor:default;box-shadow:var(--neu-raised-sm)}button.btn:disabled:hover{background:var(--raised);box-shadow:var(--neu-raised-sm)}button.btn-secondary{background:var(--surface);background-image:var(--tex-widget);color:var(--text-dim);box-shadow:var(--neu-raised-sm)}button.btn-secondary:hover{color:var(--text);box-shadow:var(--neu-raised-sm),0 0 8px var(--accent-glow)}.sidebar-widget{padding:12px}@media(max-height:720px){.sidebar-widget{padding:10px}.sidebar-inner{gap:8px;padding:8px}.sidebar-tab-body{gap:8px}}@media(max-height:560px){.sidebar-widget{padding:8px}.sidebar-inner{gap:6px;padding:6px}.sidebar-tab-body{gap:6px}.sidebar-logo{padding:4px 2px 0}}.pattern-grid{display:flex;flex-direction:column;gap:6px}.pattern-card{position:relative;border-radius:var(--r-xs);cursor:pointer;transition:box-shadow .15s,border-color .15s;border:1.5px solid transparent;background:var(--surface);overflow:hidden}.pattern-card:hover{border-color:var(--text-muted)}.pattern-card.active{border-color:var(--accent-dim);box-shadow:0 0 8px var(--accent-glow)}.pattern-card-thumb-wrap{width:100%;aspect-ratio:256 / 96;display:flex;align-items:center;justify-content:center;background:var(--bg)}.pattern-card-thumb{display:block;width:100%;height:100%;object-fit:contain}.pattern-card .delete-btn{position:absolute;top:3px;right:3px;opacity:0;background:#0009;border:none;color:var(--text-dim);cursor:pointer;font-size:11px;line-height:1;padding:2px 5px;border-radius:var(--r-xs);transition:opacity .15s,color .15s}.pattern-card .delete-btn:hover{color:var(--error)}.pattern-card:hover .delete-btn{opacity:1}.pattern-card-name{font-size:10px;color:var(--text);padding:5px 8px 6px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-top:1px solid rgba(255,255,255,.05);background:var(--surface)}.pattern-card-thumb-empty{width:100%;height:100%;background:var(--bg)}.save-row{display:flex;gap:6px;align-items:stretch}.save-name{flex:1;min-width:0;background:var(--bg);border:1px solid rgba(255,255,255,.08);color:var(--text);font:inherit;font-size:11px;padding:0 8px;border-radius:var(--r-xs);outline:none}.save-name:focus{border-color:var(--accent-dim)}button.btn.save-btn{width:auto;flex:0 0 auto;font-size:10px;padding:0 14px;letter-spacing:.5px;min-width:64px}.symmetry-label{font-size:9px;letter-spacing:1px;color:var(--text-dim);margin-bottom:8px;text-align:center}.symmetry-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}button.btn.symmetry-btn{font-size:10px;padding:8px 6px;letter-spacing:.5px}button.btn.share-btn{font-size:11px;padding:10px 12px}.toggle-row{display:flex;align-items:center;gap:6px;font-size:10px;color:var(--text-dim);margin-top:8px;cursor:pointer;user-select:none}.toggle-row input{margin:0}.color-actions{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:10px}button.btn.color-action-btn{font-size:10px;padding:8px 6px;letter-spacing:.5px}button.btn.symmetry-btn:disabled,button.btn.color-action-btn:disabled{opacity:.4;cursor:default}.pattern-card.loaded{border-color:var(--accent-dim);box-shadow:0 0 0 1px var(--accent-dim),0 0 10px var(--accent-glow)}.pattern-card-actions{display:flex;gap:2px;position:absolute;top:3px;right:3px;opacity:0;transition:opacity .15s}.pattern-card:hover .pattern-card-actions{opacity:1}.pattern-card-actions button{background:#0009;border:none;color:var(--text-dim);cursor:pointer;font-size:11px;line-height:1;padding:2px 5px;border-radius:var(--r-xs);transition:color .15s}.pattern-card-actions button:hover{color:var(--accent)}.pattern-card-actions button.delete-action:hover{color:var(--error)}.config-row{display:flex;align-items:center;justify-content:space-between;gap:6px}.config-row label{font-size:9px;color:var(--text-dim);white-space:nowrap;letter-spacing:1px;font-weight:500;text-transform:uppercase}.config-row .value{font-weight:700;font-size:13px;min-width:20px;text-align:right;color:var(--accent);font-variant-numeric:tabular-nums}.color-slots{display:flex;gap:8px;margin-top:12px}.color-slot-fill{flex:1;height:32px;border-radius:var(--r-sm);cursor:pointer;border:none;transition:all .2s;box-shadow:var(--neu-raised-sm);display:block}.color-slot-fill:hover{box-shadow:var(--neu-raised-sm),0 0 8px var(--accent-glow)}.color-slot-fill.active{box-shadow:var(--neu-pressed-sm),0 0 0 1.5px var(--accent-dim),0 0 10px var(--accent-glow)}button.color-slot{flex:1;display:flex;flex-direction:column;align-items:stretch;gap:4px;background:transparent;border:none;padding:0;cursor:pointer;touch-action:manipulation}button.color-slot .color-slot-fill{width:100%}button.color-slot.active .color-slot-fill{box-shadow:var(--neu-pressed-sm),0 0 0 1.5px var(--accent-dim),0 0 10px var(--accent-glow)}.color-slot-label{font-size:8px;letter-spacing:1px;text-align:center;color:var(--text-muted)}button.color-slot.active .color-slot-label{color:var(--accent)}.pattern-empty{text-align:center;padding:18px 12px}.pattern-empty-title{font-size:10px;letter-spacing:1px;color:var(--text);margin-bottom:6px}.pattern-empty-hint{font-size:10px;color:var(--text-muted);line-height:1.4}.btn,.sidebar-tab,.view-tab,.palette-swatch,.palette-add-btn,.pattern-card,.color-slot,.export-view,.bezel,.hsl-slider-track{touch-action:manipulation}.color-picker-custom{display:flex;flex-direction:column;gap:8px}.hsl-slider{display:flex;flex-direction:column}.hsl-slider-track{position:relative;height:36px;border-radius:18px;cursor:pointer;border:none;overflow:visible;background:var(--bg);background-image:var(--tex-surface);box-shadow:var(--neu-well)}.hsl-slider-gradient{position:absolute;inset:5px;border-radius:13px;box-shadow:inset 1px 1px 3px #0003}.hsl-slider-noise,.hsl-slider-inset-shadow{display:none}.hsl-slider-thumb{position:absolute;top:50%;width:30px;height:30px;transform:translate(-50%,-50%);pointer-events:none;z-index:2;transition:transform .15s}.mag-color{position:absolute;inset:4px;border-radius:50%;box-shadow:2px 2px 6px var(--shadow-dark),-2px -2px 6px var(--shadow-light),inset 0 0 0 2px #0003}.mag-glass{position:absolute;inset:0;border-radius:50%;background-image:var(--tex-knob);background-size:cover;opacity:0}.mag-bezel{position:absolute;inset:0;border-radius:50%;box-shadow:3px 3px 8px var(--shadow-dark),-3px -3px 8px var(--shadow-light),0 0 0 1px #00000026;background:var(--surface);background-image:var(--tex-widget)}.hsl-slider-thumb .mag-bezel{background:var(--raised);background-image:var(--tex-widget);box-shadow:4px 4px 10px var(--shadow-dark),-4px -4px 10px var(--shadow-light);-webkit-mask:radial-gradient(circle,transparent 38%,black 40%);mask:radial-gradient(circle,transparent 38%,black 40%)}.hsl-slider-thumb .mag-color{inset:22%;box-shadow:inset 2px 2px 4px #00000040,inset -1px -1px 3px #ffffff0f}.hsl-slider-thumb .mag-glass{display:none}.hsl-slider-track:hover .hsl-slider-thumb{transform:translate(-50%,-50%) scale(1.08)}.hsl-slider-track:active .hsl-slider-thumb .mag-bezel{box-shadow:4px 4px 10px var(--shadow-dark),-4px -4px 10px var(--shadow-light),0 0 12px var(--accent-glow)}.palette{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;align-items:center}.palette-swatch{width:100%;aspect-ratio:1;border-radius:var(--r-xs);border:none;cursor:pointer;transition:transform .15s,box-shadow .15s;box-shadow:var(--neu-raised-sm)}.palette-swatch:hover{transform:scale(1.12);box-shadow:var(--neu-raised-sm),0 0 8px var(--accent-glow)}.palette-add-btn{width:100%;aspect-ratio:1;border-radius:var(--r-xs);border:none;background:var(--bg);background-image:var(--tex-surface);color:var(--text-muted);font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .2s;box-shadow:var(--neu-pressed-sm)}.palette-add-btn:hover{color:var(--accent);box-shadow:var(--neu-pressed-sm),0 0 8px var(--accent-glow)}.string-info{font-size:10px;color:var(--text-dim);padding:0 0 8px}.total-strings{font-size:10px;color:var(--text-muted);text-align:center;padding:6px 0 0}.sidebar-reset{flex-shrink:0;padding:10px 14px}.braid-colors-list{display:flex;flex-direction:column;gap:5px;align-items:center}.braid-color-row{display:grid;grid-template-columns:16px 24px 1fr;align-items:center;gap:5px;width:100%}.silk-icon{font-size:11px;flex-shrink:0;text-align:center;line-height:16px;height:16px}.silk-icon.match{color:var(--success)}.silk-icon.no-match{color:var(--error)}.braid-color-swatch{width:24px;height:24px;border-radius:var(--r-xs);border:none;flex-shrink:0;cursor:pointer;transition:transform .12s,box-shadow .12s;box-shadow:var(--neu-raised-sm)}.braid-color-swatch:hover{transform:scale(1.12);box-shadow:var(--neu-raised-sm),0 0 8px var(--accent-glow)}.silk-info{grid-column:3;font-size:10px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.silk-pid{color:var(--text-muted);margin-left:3px}.silk-closest-group{grid-column:3;display:flex;align-items:center;gap:3px;overflow:hidden}.silk-arrow{font-size:11px;color:var(--text-muted);line-height:16px;flex-shrink:0}.silk-closest-swatch{width:22px;height:22px;min-width:22px;border-radius:var(--r-xs);border:none;cursor:pointer;flex-shrink:0;transition:transform .12s,box-shadow .12s;box-shadow:var(--neu-raised-sm)}.silk-closest-swatch:hover{transform:scale(1.12);box-shadow:var(--neu-raised-sm),0 0 8px var(--accent-glow)}.supplies-mismatch{font-size:10px;font-weight:600;color:var(--error);letter-spacing:1px;text-transform:uppercase;padding:4px 0}.supplies-list{display:flex;flex-direction:column;gap:5px}.supplies-row{display:grid;grid-template-columns:24px 24px 1fr auto;align-items:center;gap:4px}.supplies-swatch{width:24px;height:24px;border-radius:var(--r-xs);border:none;box-shadow:var(--neu-raised-sm)}.supplies-count{font-size:10px;font-weight:700;color:var(--accent);font-variant-numeric:tabular-nums}.supplies-name{font-size:10px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.supplies-pid{font-size:9px;color:var(--text-muted);white-space:nowrap}.picker-mode-row{display:flex;justify-content:space-between;align-items:center;gap:8px}.picker-mode-toggle{display:inline-flex;background:var(--bg);background-image:var(--tex-surface);border-radius:var(--r-sm);padding:2px;box-shadow:var(--neu-well)}.picker-mode-toggle button{background:transparent;border:none;color:var(--text-muted);padding:4px 10px;font-size:10px;font-weight:700;letter-spacing:.5px;border-radius:var(--r-xs);cursor:pointer}.picker-mode-toggle button.active{background:var(--raised);color:var(--accent);box-shadow:var(--neu-raised-sm)}.picker-eyedroppers{display:inline-flex;gap:4px}.eyedropper-btn{width:28px;height:28px;border-radius:50%;background:var(--raised);background-image:var(--tex-widget);color:var(--accent);border:none;font-size:14px;cursor:pointer;box-shadow:var(--neu-raised-sm)}.eyedropper-btn:hover{color:var(--accent)}.eyedropper-canvas-host{margin-top:10px;padding:8px;background:var(--bg);background-image:var(--tex-surface);border-radius:var(--r-sm);box-shadow:var(--neu-well)}.eyedropper-canvas-header{display:flex;justify-content:space-between;font-size:10px;color:var(--text-muted);margin-bottom:6px}.eyedropper-canvas-header button{background:transparent;border:none;color:var(--accent);font-size:10px;font-weight:700;cursor:pointer}.color-readouts{display:flex;flex-direction:column;gap:6px;margin-top:4px}.color-name-row{display:flex;align-items:center;gap:8px;padding:4px 6px}.color-name-swatch{width:18px;height:18px;border-radius:var(--r-xs);box-shadow:inset 0 0 0 1px #00000040}.color-name-label{font-size:11px;letter-spacing:.5px;font-weight:700;color:var(--text)}.color-readout-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px}.readout-chip{display:flex;flex-direction:column;gap:2px;background:var(--bg);background-image:var(--tex-surface);border-radius:var(--r-xs);border:none;padding:4px 8px;cursor:copy;text-align:left;box-shadow:var(--neu-well);color:var(--text)}.readout-chip:hover{box-shadow:var(--neu-raised-sm)}.readout-label{font-size:8px;letter-spacing:1px;color:var(--text-muted)}.readout-value{font-size:10px;font-family:monospace;color:var(--text)}.color-subtabs{display:grid;grid-template-columns:repeat(5,1fr);gap:2px;background:var(--bg);background-image:var(--tex-surface);border-radius:var(--r-sm);padding:3px;box-shadow:var(--neu-well);margin-bottom:8px}.color-subtab{background:transparent;border:none;font-size:9px;font-weight:700;letter-spacing:.6px;color:var(--text-muted);padding:6px 4px;cursor:pointer;border-radius:var(--r-xs)}.color-subtab.active{background:var(--raised);color:var(--accent);box-shadow:var(--neu-raised-sm)}.sub-header{font-size:10px;font-weight:700;letter-spacing:.5px;color:var(--text-muted);margin-bottom:6px}.harmonies-panel{display:flex;flex-direction:column;gap:6px}.harmonies-label{font-size:10px;font-weight:700;letter-spacing:.5px;color:var(--text-muted)}.harmonies-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.harmony-card{background:var(--bg);background-image:var(--tex-surface);border-radius:var(--r-sm);border:none;padding:6px 4px;cursor:pointer;display:flex;flex-direction:column;gap:4px;align-items:center;box-shadow:var(--neu-well);color:var(--text)}.harmony-card.active,.harmony-card:hover{box-shadow:var(--neu-raised-sm);color:var(--accent)}.harmony-card-strip{display:flex;width:100%;height:22px;border-radius:var(--r-xs);overflow:hidden;box-shadow:inset 0 0 0 1px #0003}.harmony-card-swatch{flex:1}.harmony-card-name{font-size:9px;font-weight:700;letter-spacing:.3px;text-align:center}.variations-panel{display:flex;flex-direction:column;gap:6px}.variations-header{font-size:10px;font-weight:700;letter-spacing:.5px;color:var(--text-muted)}.variations-rotate{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.variations-generate-btn{width:100%}.variations-results{display:flex;flex-direction:column;gap:4px}.variation-row{display:flex;background:var(--bg);background-image:var(--tex-surface);border-radius:var(--r-xs);border:none;padding:4px;cursor:pointer;gap:1px;box-shadow:var(--neu-well)}.variation-row:hover{box-shadow:var(--neu-raised-sm)}.variation-swatch{flex:1;height:14px;border-radius:2px}.contrast-checker{display:flex;flex-direction:column;gap:6px}.contrast-checker-header{display:flex;justify-content:space-between}.checker-title{font-size:10px;font-weight:700;letter-spacing:.5px;color:var(--text-muted)}.checker-count{font-size:10px;color:var(--text-muted)}.checker-pass{font-size:11px;color:var(--accent);padding:6px;text-align:center;background:var(--bg);border-radius:var(--r-xs)}.checker-list{display:flex;flex-direction:column;gap:3px}.checker-row{display:grid;grid-template-columns:14px 14px 50px 1fr auto;align-items:center;gap:6px;background:var(--bg);background-image:var(--tex-surface);border:none;padding:4px 6px;border-radius:var(--r-xs);text-align:left;font-size:10px;cursor:pointer;box-shadow:var(--neu-well);color:var(--text)}.checker-row.band-fail{box-shadow:var(--neu-well),inset 0 0 0 1px #c4445a}.checker-row.band-low{box-shadow:var(--neu-well),inset 0 0 0 1px #c4a445}.checker-swatch{width:14px;height:14px;border-radius:3px}.checker-pair-label{font-family:monospace;font-size:10px;color:var(--text-muted)}.checker-delta{font-family:monospace;font-size:10px}.checker-contrast{font-family:monospace;font-size:9px;color:var(--text-muted)}.palette-analytics{display:flex;flex-direction:column;gap:6px}.analytics-header{font-size:10px;font-weight:700;letter-spacing:.5px;color:var(--text-muted)}.analytics-row{display:flex;justify-content:space-between;font-size:10px}.analytics-label{color:var(--text-muted)}.analytics-value{color:var(--text);font-family:monospace}.analytics-value.warning-low,.analytics-value.warning-flat{color:#c4a445}.analytics-value.warning-extreme{color:#c4445a}.warmcool-meter{display:flex;flex-direction:column;gap:3px}.warmcool-track{position:relative;height:14px;border-radius:7px;background:linear-gradient(to right,#3aa8df,#cdc8be,#df7a3a);box-shadow:var(--neu-well)}.warmcool-marker{position:absolute;top:-2px;width:6px;height:18px;background:var(--text);border-radius:2px;transform:translate(-50%);box-shadow:0 0 4px #0006}.warmcool-labels{display:flex;justify-content:space-between;font-size:8px;color:var(--text-muted)}.hue-histogram{display:flex;align-items:flex-end;gap:2px;height:48px;background:var(--bg);background-image:var(--tex-surface);border-radius:var(--r-xs);padding:3px;box-shadow:var(--neu-well)}.hue-histogram-bar{flex:1;min-height:2px;border-radius:2px}.hue-histogram-bar.neutral{background:var(--text-muted)}.render-prefs{display:flex;flex-direction:column;gap:10px}.render-prefs-section{display:flex;flex-direction:column;gap:4px}.render-prefs-label{font-size:10px;font-weight:700;letter-spacing:.5px;color:var(--text-muted)}.chirality-toggle,.cvd-buttons,.lighting-buttons,.material-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:4px}.cvd-buttons,.lighting-buttons{grid-template-columns:repeat(3,1fr)}.chirality-toggle button,.cvd-buttons button,.lighting-buttons button,.material-buttons button{background:var(--bg);background-image:var(--tex-surface);border:none;font-size:9px;font-weight:700;letter-spacing:.4px;color:var(--text-muted);padding:6px 4px;border-radius:var(--r-xs);cursor:pointer;box-shadow:var(--neu-well)}.chirality-toggle button.active,.cvd-buttons button.active,.lighting-buttons button.active,.material-buttons button.active{color:var(--accent);box-shadow:var(--neu-raised-sm)}.library-browser{display:flex;flex-direction:column;gap:6px}.library-browser-header{display:flex;justify-content:space-between;align-items:center}.library-browser-title{font-size:10px;font-weight:700;letter-spacing:.5px;color:var(--text-muted)}.stash-only-toggle{display:inline-flex;gap:4px;font-size:10px;color:var(--text-muted);cursor:pointer;align-items:center}.library-tabs{display:flex;flex-direction:column;gap:4px}.library-tab-group-label{font-size:8px;letter-spacing:1px;color:var(--text-muted);margin-bottom:2px}.library-tab-row{display:flex;flex-wrap:wrap;gap:3px}.library-tab{background:var(--bg);background-image:var(--tex-surface);border:none;font-size:9px;font-weight:700;letter-spacing:.3px;color:var(--text-muted);padding:4px 8px;border-radius:var(--r-xs);cursor:pointer;box-shadow:var(--neu-well)}.library-tab.active{color:var(--accent);box-shadow:var(--neu-raised-sm)}.library-controls{display:flex}.library-search{flex:1;background:var(--bg);background-image:var(--tex-surface);border:none;color:var(--text);padding:6px 10px;font-size:11px;border-radius:var(--r-xs);box-shadow:var(--neu-well)}.library-meta{display:flex;justify-content:space-between;font-size:9px;color:var(--text-muted)}.library-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:3px;max-height:320px;overflow-y:auto}.library-swatch{aspect-ratio:1;border:none;border-radius:4px;cursor:pointer;position:relative;box-shadow:inset 0 0 0 1px #0003;overflow:hidden}.library-swatch:hover,.library-swatch.owned{box-shadow:inset 0 0 0 2px var(--accent)}.library-swatch-label{position:absolute;bottom:0;left:0;right:0;font-size:7px;background:#0009;color:#fff;text-align:center;padding:1px 0;font-family:monospace}.library-settings{font-size:10px}.library-settings-list{display:flex;flex-direction:column;gap:2px;padding:4px}.library-settings-row{display:flex;align-items:center;gap:6px;cursor:pointer}.library-settings-kind{margin-left:auto;font-size:9px;color:var(--text-muted)}.substitution-panel{display:flex;flex-direction:column;gap:4px}.substitution-header{font-size:10px;font-weight:700;letter-spacing:.5px;color:var(--text-muted)}.substitution-list{display:flex;flex-direction:column;gap:2px}.substitution-row{display:grid;grid-template-columns:16px auto 1fr auto;align-items:center;gap:6px;background:var(--bg);background-image:var(--tex-surface);border:none;padding:4px 6px;border-radius:var(--r-xs);cursor:pointer;text-align:left;font-size:10px;box-shadow:var(--neu-well);color:var(--text)}.substitution-row:hover{box-shadow:var(--neu-raised-sm)}.substitution-row.exact{box-shadow:var(--neu-well),inset 0 0 0 1px var(--accent)}.substitution-swatch{width:16px;height:16px;border-radius:3px;box-shadow:inset 0 0 0 1px #00000040}.substitution-brand{font-size:9px;color:var(--text-muted);font-weight:700}.substitution-id{font-family:monospace;font-size:9px}.substitution-delta{font-family:monospace;font-size:9px;color:var(--text-muted)}.theme-palettes{display:flex;flex-direction:column;gap:6px}.theme-palettes-header{font-size:10px;font-weight:700;letter-spacing:.5px;color:var(--text-muted)}.theme-palettes-list{display:flex;flex-direction:column;gap:4px}.theme-card{position:relative;background:var(--bg);background-image:var(--tex-surface);border-radius:var(--r-sm);padding:6px;box-shadow:var(--neu-well)}.theme-card-main{display:flex;flex-direction:column;gap:4px;background:transparent;border:none;width:100%;cursor:pointer;text-align:left;color:var(--text)}.theme-card-strip{display:flex;height:18px;border-radius:var(--r-xs);overflow:hidden;box-shadow:inset 0 0 0 1px #0003}.theme-card-swatch{flex:1}.theme-card-name{font-size:10px;font-weight:700;color:var(--text)}.theme-card-info{position:absolute;top:4px;right:4px;width:18px;height:18px;border-radius:50%;background:var(--raised);border:none;color:var(--accent);font-size:10px;font-weight:700;cursor:pointer;box-shadow:var(--neu-raised-sm)}.theme-card-detail{margin-top:6px;font-size:10px;color:var(--text-muted)}.theme-card-description{margin-bottom:4px}.theme-card-colors{display:flex;flex-direction:column;gap:2px}.theme-card-color-row{display:grid;grid-template-columns:16px 1fr auto;gap:6px;align-items:center}.theme-card-color-chip{width:16px;height:16px;border-radius:3px;box-shadow:inset 0 0 0 1px #00000040}.theme-card-color-hex{font-family:monospace;font-size:9px;color:var(--text-muted)}.stash-panel{display:flex;flex-direction:column;gap:6px}.stash-panel-header{display:flex;justify-content:space-between;align-items:center}.stash-title{font-size:10px;font-weight:700;letter-spacing:.5px;color:var(--text-muted)}.stash-empty{padding:10px;font-size:11px;color:var(--text-muted);text-align:center;background:var(--bg);border-radius:var(--r-sm)}.stash-list{display:flex;flex-direction:column;gap:3px}.stash-entry{position:relative;display:grid;grid-template-columns:1fr 22px 22px;gap:3px}.stash-entry-main{display:grid;grid-template-columns:18px 1fr auto auto;align-items:center;gap:6px;background:var(--bg);background-image:var(--tex-surface);border:none;padding:4px 6px;border-radius:var(--r-xs);cursor:pointer;text-align:left;box-shadow:var(--neu-well);color:var(--text)}.stash-swatch{width:18px;height:18px;border-radius:4px;box-shadow:inset 0 0 0 1px #00000040}.stash-label{display:flex;flex-direction:column;gap:1px;min-width:0}.stash-name{font-size:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stash-id{font-size:8px;color:var(--text-muted);font-family:monospace}.stash-dyelot,.stash-qty{font-size:9px;font-family:monospace;color:var(--text-muted);background:#0003;border-radius:3px;padding:1px 4px}.stash-entry-edit,.stash-entry-delete{background:var(--bg);background-image:var(--tex-surface);border:none;border-radius:var(--r-xs);color:var(--accent);cursor:pointer;font-size:11px;box-shadow:var(--neu-well)}.stash-entry-delete{color:#c4445a}.stash-editor{grid-column:1 / -1;display:flex;flex-direction:column;gap:4px;padding:6px;background:var(--bg);border-radius:var(--r-sm);box-shadow:var(--neu-well);margin-top:4px}.stash-editor-row{display:grid;grid-template-columns:60px 1fr;gap:6px;align-items:center;font-size:10px}.stash-editor-row label{color:var(--text-muted)}.stash-editor-row input,.stash-editor-row select{background:var(--raised);background-image:var(--tex-surface);border:none;color:var(--text);padding:4px 6px;border-radius:var(--r-xs);font-size:10px;box-shadow:var(--neu-well)}.stash-editor-qty{display:flex;gap:4px}.stash-editor-qty input{flex:1}.stash-editor-close{align-self:flex-end;font-size:10px;padding:4px 10px}.palette-io-panel{display:flex;flex-direction:column;gap:6px}.palette-io-header{font-size:10px;font-weight:700;letter-spacing:.5px;color:var(--text-muted)}.palette-io-row{display:flex;gap:4px}.palette-io-row input,.palette-io-row select{flex:1;background:var(--bg);background-image:var(--tex-surface);border:none;color:var(--text);padding:6px 8px;border-radius:var(--r-xs);font-size:10px;box-shadow:var(--neu-well)}.palette-io-error{font-size:10px;color:#c4445a;padding:4px 6px}.sheen-panel{font-size:10px}.sheen-panel summary{color:var(--text-muted);font-size:10px;cursor:pointer;padding:4px 0}.sheen-list{display:flex;flex-direction:column;gap:3px}.sheen-row{display:grid;grid-template-columns:18px 1fr 90px auto auto;align-items:center;gap:6px;font-size:10px}.sheen-swatch{width:18px;height:18px;border-radius:4px;box-shadow:inset 0 0 0 1px #00000040}.sheen-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.sheen-row input[type=range]{width:100%}.sheen-value{font-family:monospace;color:var(--text-muted)}.sheen-clear{width:18px;height:18px;border:none;border-radius:50%;background:var(--raised);color:#c4445a;cursor:pointer;font-size:10px}
