:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f6f7f9;color:#17202a;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{height:100vh;margin:0;min-width:320px;overflow:hidden}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed}.button:disabled,.snap-button:disabled,.segmented button:disabled{opacity:.48}#app{display:flex;flex-direction:column;height:100vh;min-height:0}.app-header{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:18px 24px;border-bottom:1px solid #d9dee7;background:#fff}.app-header h1,.app-header p,.palette-heading h2,.selected-panel h2,.selected-panel h3{margin:0}.app-header h1{font-size:24px;line-height:1.2;letter-spacing:0}.app-header p{margin-top:4px;color:#5d6878;font-size:14px}.header-actions,.palette-heading,.preview-toolbar,.preview-tools,.preview-top-controls,.tool-actions,.canvas-row,.selected-title{display:flex;align-items:center;gap:12px}.header-actions{flex-wrap:wrap;justify-content:flex-end}.button{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 13px;border:1px solid #b8c1cc;border-radius:6px;background:#fff;color:#17202a;font-weight:650;text-decoration:none;white-space:nowrap}.icon-button{gap:8px}.button-icon{width:16px;height:16px;flex:0 0 auto;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.button:hover:not(:disabled){border-color:#748196;background:#f2f5f8}.button.primary{border-color:#176b87;background:#176b87;color:#fff}.button.compact{min-height:34px;padding:0 10px;font-size:13px}.button.full-width{width:100%}.button input{display:none}.workspace{flex:1 1 auto;display:grid;grid-template-columns:minmax(0,1fr) 410px;gap:22px;min-height:0;overflow:hidden;padding:22px 24px 28px}.preview-section,.palette-section{min-width:0}.preview-section{min-height:0;overflow:auto;scrollbar-gutter:stable}.drop-zone{display:flex;align-items:center;justify-content:center;gap:8px;min-height:68px;border:2px dashed #aeb7c4;border-radius:8px;background:#fff;color:#334155}.drop-zone span{color:#667085}.drop-zone.dragging{border-color:#176b87;background:#eaf6f7}.warning-list{display:grid;gap:8px;margin-top:14px}.warning,.notice{border-radius:6px;padding:10px 12px;font-size:14px}.warning{border:1px solid #e1a2a2;background:#fff1f0;color:#8d2626}.notice{border:1px solid #97c4a7;background:#eef9f1;color:#285a38}.status-panel{display:grid;grid-template-columns:repeat(5,minmax(120px,1fr));gap:1px;margin-top:14px;overflow:hidden;border:1px solid #d9dee7;border-radius:8px;background:#d9dee7}.status-panel div{min-width:0;padding:11px 12px;background:#fff}.status-panel span{display:block;color:#667085;font-size:12px;font-weight:700;text-transform:uppercase}.status-panel strong{display:block;margin-top:3px;overflow-wrap:anywhere;font-size:15px}.ok{color:#116149}.warn{color:#9a5b00}.bad{color:#b42318}.preview-toolbar{justify-content:space-between;margin-top:18px;color:#5d6878;font-size:14px}.preview-tools,.preview-top-controls{flex-wrap:wrap}.tool-actions{flex-wrap:wrap;gap:8px}.history-scope .scope-button{min-width:66px;min-height:32px;border:0;border-right:1px solid #d9dee7;background:#fff;color:#334155;font-weight:700}.history-scope .scope-button:last-child{border-right:0}.history-scope .scope-button.active{background:#263442;color:#fff}.preview-mode .view-button{min-width:74px;min-height:32px;border:0;border-right:1px solid #d9dee7;background:#fff;color:#334155;font-weight:700}.preview-mode .view-button:last-child{border-right:0}.preview-mode .view-button.active{background:#263442;color:#fff}.tool-status{margin-top:10px;color:#667085;font-size:13px;font-weight:700}.segmented{display:inline-flex;overflow:hidden;border:1px solid #b8c1cc;border-radius:6px;background:#fff}.segmented button{min-width:46px;min-height:32px;border:0;border-right:1px solid #d9dee7;background:#fff;color:#334155;font-weight:700}.segmented button:last-child{border-right:0}.segmented button.active{background:#263442;color:#fff}.button.active{border-color:#176b87;background:#e8f5f7;color:#176b87}.canvas-row{align-items:flex-start;margin-top:12px}.canvas-row figure{flex:1 1 0;width:100%;min-width:0;margin:0}.canvas-row[data-mode=original] figure,.canvas-row[data-mode=updated] figure{flex-basis:100%}.canvas-row figcaption{margin-bottom:7px;color:#334155;font-size:13px;font-weight:800;text-transform:uppercase}.canvas-wrap{width:100%;min-height:248px;overflow:auto;border:1px solid #c7d0dd;border-radius:8px;background-color:#fff}.checkerboard{background-image:linear-gradient(45deg,#d4dbe5 25%,transparent 25%),linear-gradient(-45deg,#d4dbe5 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#d4dbe5 75%),linear-gradient(-45deg,transparent 75%,#d4dbe5 75%);background-position:0 0,0 8px,8px -8px,-8px 0;background-size:16px 16px}canvas{display:block;image-rendering:pixelated;image-rendering:crisp-edges}canvas.eyedropper-active{cursor:crosshair}canvas.pen-active{cursor:cell}.palette-section{display:flex;flex-direction:column;gap:12px;min-height:0;overflow-y:auto;padding-right:4px;scrollbar-gutter:stable}.palette-heading{justify-content:space-between}.palette-heading h2{font-size:18px;letter-spacing:0}.palette-heading span{display:block;margin-top:2px;color:#667085;font-size:13px}.palette-grid{display:grid;gap:8px}.slot-card{display:grid;grid-template-columns:48px minmax(0,1fr) 58px;align-items:center;gap:9px;padding:8px;border:1px solid #d8dee8;border-radius:8px;background:#fff}.slot-card.selected{border-color:#176b87;box-shadow:0 0 0 2px #b9e4ec}.slot-card.unsafe{border-color:#e1a2a2}.slot-card.unused{opacity:.74}.slot-swatch{width:48px;height:48px;border:1px solid rgb(0 0 0 / .18);border-radius:6px;font-size:18px;font-weight:900;line-height:1}.slot-meta{display:grid;min-width:0;gap:2px}.slot-meta strong,.slot-meta code,.slot-meta span,.slot-meta small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.slot-meta strong{font-size:13px}.slot-meta code{color:#334155;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:12px}.slot-meta span,.slot-meta small{font-size:12px}.slot-ok{color:#116149;font-weight:800}.slot-bad{color:#b42318;font-weight:800}.snap-button{min-height:30px;border:1px solid #c2cad7;border-radius:6px;background:#fff;color:#263442;font-size:12px;font-weight:800}.snap-button:hover:not(:disabled){background:#f1f5f9}.selected-panel{display:grid;gap:12px;padding:14px;border:1px solid #d8dee8;border-radius:8px;background:#fff}.selected-panel h2{font-size:18px;letter-spacing:0}.selected-panel h3{margin-top:2px;font-size:14px;letter-spacing:0}.selected-panel p{margin:0;color:#667085}.selected-title{justify-content:space-between}.selected-sample{width:40px;height:40px;flex:0 0 auto;border:1px solid rgb(0 0 0 / .18);border-radius:6px}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 12px;margin:0}.detail-grid dt{color:#667085;font-size:12px;font-weight:800;text-transform:uppercase}.detail-grid dd{margin:0;font-size:13px;font-weight:750}.blue-row{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:5px}.blue-button{min-width:0;min-height:30px;border:1px solid rgb(0 0 0 / .18);border-radius:5px;font-size:11px;font-weight:800}.blue-button.active{outline:2px solid #17202a;outline-offset:1px}.safe-colour-grid{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:5px}.safe-colour-grid button{aspect-ratio:1;min-width:0;border:1px solid rgb(0 0 0 / .16);border-radius:4px}.safe-colour-grid button.active{outline:3px solid #17202a;outline-offset:1px}@media(max-width:1180px){.workspace{grid-template-columns:1fr;grid-template-rows:minmax(300px,48%) minmax(0,1fr)}.palette-section{display:grid;grid-template-columns:minmax(0,1fr) 360px;align-items:start}.palette-heading{grid-column:1 / -1}}@media(max-width:760px){.app-header{align-items:flex-start;flex-direction:column}.header-actions{justify-content:flex-start}.workspace{grid-template-rows:minmax(260px,48%) minmax(0,1fr);padding:16px}.preview-toolbar{align-items:flex-start;flex-direction:column}.preview-top-controls,.tool-actions{width:100%}.status-panel{grid-template-columns:1fr 1fr}.canvas-row{flex-direction:column}.canvas-row figure:nth-child(2){order:-1}.palette-section{display:flex}.slot-card{grid-template-columns:44px minmax(0,1fr)}.snap-button{grid-column:1 / -1}}
