*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f0f;--surface: #1a1a1a;--surface2: #242424;--border: #333;--accent: #d97706;--accent-dim:#92400e;--text: #f5f5f5;--muted: #888;--radius: 8px}body{background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.5;min-height:100vh}header{padding:14px 32px 0}.header-inner{display:flex;align-items:center;gap:8px;height:24px}.header-inner svg{flex-shrink:0}.header-inner h1{font-size:14px;font-weight:800;letter-spacing:.18em;color:var(--accent);line-height:1}main{max-width:1600px;margin:0 auto;padding:8px 24px 64px}.input-section{display:flex;flex-direction:column;align-items:center;gap:12px;max-width:560px;margin:0 auto}.drop-zone{width:100%;border:2px dashed var(--border);border-radius:var(--radius);padding:16px 24px;display:flex;flex-direction:row;align-items:center;gap:14px;color:var(--muted);cursor:pointer;transition:border-color .15s,background .15s}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--accent);background:#d977060d;color:var(--text)}.drop-zone svg{opacity:.5;flex-shrink:0;width:28px;height:28px}.drop-zone p{font-size:14px}.or{font-size:12px;color:var(--muted)}.url-row{display:flex;gap:8px;width:100%}.url-row input{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:10px 14px;font-size:13px;outline:none;transition:border-color .15s}.url-row input:focus{border-color:var(--accent)}.url-row input::placeholder{color:var(--muted)}.btn{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;font-size:13px;padding:10px 18px;transition:background .15s,border-color .15s;white-space:nowrap}.btn:hover{background:#2e2e2e;border-color:#555}.btn-toggle{font-size:12px;padding:6px 14px}.btn-toggle.active,.btn-primary{background:var(--accent);border-color:var(--accent);color:#000;font-weight:600}.btn-primary:hover{background:#b45309;border-color:#b45309}.toast{position:fixed;bottom:24px;right:24px;z-index:2000;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px #00000080;color:var(--muted);font-size:13px;padding:10px 16px;pointer-events:none;opacity:1;transition:opacity .2s}.toast[hidden]{display:none}.toast-error{color:#ef4444;border-color:#ef4444}.results{display:flex;flex-direction:column;gap:40px;padding-top:24px}.results h3{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:16px}.canvas-wrap{max-width:100%}.canvas-container{position:relative;display:block;line-height:0}.label-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.label-overlay .label{position:absolute;transform:translate(-50%,-50%);background:#0009;color:#ffffffe6;font:700 10px system-ui,sans-serif;border-radius:4px;overflow:hidden;transition:background .1s;min-width:36px;border:1px solid #000}.label-overlay .label.hovered{background:#000000e0;color:#fff}.label-swatch{width:100%;height:12px}.label-mixes{display:flex;gap:5px;align-items:center;padding:3px 5px;flex-wrap:wrap}.label-mix-item{display:flex;align-items:center;gap:3px;white-space:nowrap}.label-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;border:1px solid rgba(255,255,255,.25)}#overlayCanvas{position:absolute;top:0;left:0;width:100%!important;height:100%!important;border:none!important;cursor:crosshair}.canvas-wrap-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:16px}.canvas-header-btns{display:flex;gap:8px}.slider-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);white-space:nowrap}.slider-row input[type=number]{width:52px;background:var(--surface);border:1px solid var(--border);border-radius:5px;color:var(--text);font-size:12px;padding:2px 6px;text-align:center;outline:none;-moz-appearance:textfield}.slider-row input[type=number]::-webkit-inner-spin-button,.slider-row input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}.slider-row input[type=number]:focus{border-color:var(--accent)}.slider-row{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--muted)}.slider-row input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:240px;height:4px;background:var(--border);border-radius:2px;outline:none;cursor:pointer}.slider-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;transition:background .15s}.slider-row input[type=range]::-webkit-slider-thumb:hover{background:#b45309}.slider-row input[type=range]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent);border:none;cursor:pointer}.canvas-container canvas{width:100%;height:auto;display:block;border-radius:var(--radius);border:1px solid var(--border)}.results{display:flex;flex-direction:column;gap:24px}.palette-controls{display:flex;align-items:center;gap:12px}.palette-ctrl-label{font-size:12px;color:var(--muted);white-space:nowrap}.palette-expand-btns{display:flex;gap:6px;margin-left:auto}.palette-columns{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px;align-items:start}.palette-col{display:flex;flex-direction:column;gap:4px}.palette-col-header{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding-bottom:8px;border-bottom:1px solid var(--border);margin-bottom:4px;display:flex;align-items:center;justify-content:space-between}.col-expand-btns{display:flex;align-items:center;gap:2px;font-weight:400;letter-spacing:0;text-transform:none}.col-expand-btn{background:none;border:none;color:var(--border);cursor:pointer;font-size:10px;padding:0 2px;transition:color .1s}.col-expand-btn:hover{color:var(--accent)}.col-expand-sep{font-size:10px;color:var(--border)}.paint-group{display:flex;flex-direction:column;gap:3px}.group-header{display:flex;align-items:center;gap:8px;padding:3px 4px;border-radius:5px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .1s}.group-header:hover{background:var(--surface2)}.group-swatch{width:16px;height:16px;border-radius:3px;flex-shrink:0;border:1px solid rgba(255,255,255,.12)}.group-name{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);flex:1}.group-count{font-size:10px;color:var(--border)}.group-arrow{color:var(--muted);flex-shrink:0;transition:transform .15s}.paint-group.collapsed .group-arrow{transform:rotate(-90deg)}.paint-group.collapsed .variant{display:none}.swatch{position:relative;display:flex;gap:10px;align-items:stretch;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:5px 7px;cursor:default;transition:border-color .12s,background .12s}.swatch.highlighted{border-color:var(--accent);background:#d9770614}.swatch.variant{margin-left:26px;padding:4px 6px}.swatch-color{width:28px;flex-shrink:0;border-radius:4px;border:1px solid rgba(255,255,255,.07);min-height:28px}.swatch-recipe{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.mix-line{display:flex;gap:5px;align-items:center;line-height:1.2}.mix-paint-swatch{width:10px;height:10px;border-radius:2px;flex-shrink:0;border:1px solid rgba(255,255,255,.15)}.mix-ratio{font-size:11px;font-weight:700;color:var(--muted);flex-shrink:0;min-width:28px}.mix-name{font-size:11px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shopping-list{display:flex;flex-direction:column;align-items:center}.shopping-list h4{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:10px;font-family:system-ui,sans-serif}.shop-list{list-style:none;display:flex;flex-direction:column;width:400px;background:#222;border-radius:var(--radius);overflow:hidden;font-family:Georgia,Times New Roman,serif}.shop-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-bottom:1px solid var(--border);transition:background .1s}.shop-item:hover{background:#2a2a2a}.shop-item.checked{opacity:.4}.shop-item.checked .shop-name{text-decoration:line-through;color:var(--muted)}.shop-check-wrap{position:relative;flex-shrink:0;cursor:pointer}.shop-check-wrap input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.shop-check-box{display:block;width:16px;height:16px;border:1px solid var(--border);border-radius:3px;background:var(--surface);transition:background .1s,border-color .1s}.shop-check-wrap input:checked~.shop-check-box{background:var(--accent);border-color:var(--accent)}.shop-check-wrap input:checked~.shop-check-box:after{content:"";display:block;width:4px;height:7px;border:2px solid #000;border-top:none;border-left:none;transform:rotate(45deg) translate(3px,1px)}.shop-swatch{width:20px;height:20px;border-radius:3px;flex-shrink:0;border:1px solid rgba(255,255,255,.1)}.shop-name{font-size:15px;color:var(--text);flex:1}.shop-pct{font-size:11px;color:var(--muted)}.canvas-area{flex:1;min-width:0}.attribution{margin-top:6px;font-size:11px;color:var(--muted);text-align:right}.color-tooltip{position:fixed;z-index:1000;pointer-events:none;display:none;flex-direction:column;gap:5px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px #00000080;padding:8px 10px;min-width:140px}.color-tooltip.visible{display:flex}.tooltip-header{display:flex;align-items:center;gap:7px;padding-bottom:6px;border-bottom:1px solid var(--border);margin-bottom:1px}.tooltip-swatch{width:28px;height:28px;border-radius:4px;flex-shrink:0;border:1px solid rgba(255,255,255,.12)}.tooltip-hex{font-size:11px;font-family:monospace;color:var(--muted)}@media (max-width: 700px){.results-layout{flex-direction:column}.swatches{width:100%;flex-direction:row;flex-wrap:wrap}.swatch{width:calc(50% - 3px)}}
