.cpal-bc{font-family:var(--font-accent);font-size:.75rem;letter-spacing:.06em;color:var(--muted);margin-bottom:2rem}.cpal-bc a{color:var(--muted);text-decoration:none}.cpal-bc a:hover{color:var(--text)}.cpal-bc span{margin:0 .5rem}.cpal-head{margin-bottom:1.5rem}.cpal-head h1{font-family:var(--font-heading);font-size:1.75rem;font-weight:900;letter-spacing:-.02em;margin-bottom:.4rem}.cpal-head p{font-size:.875rem;color:var(--mid)}.cpal-layout{display:grid;grid-template-columns:292px 1fr;gap:1.25rem;align-items:start;margin-bottom:1.5rem}@media(max-width:780px){.cpal-layout{grid-template-columns:1fr}}.cpal-left{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.25rem;display:flex;flex-direction:column;gap:1rem;position:sticky;top:1rem}.cpal-picker-wrap{border-radius:var(--radius-md);overflow:hidden;border:1.5px solid var(--border);transition:border-color .15s}.cpal-picker-wrap:focus-within{border-color:var(--blue)}#cpalPicker{-webkit-appearance:none;appearance:none;display:block;width:100%;height:80px;border:none;cursor:pointer;padding:0;background:transparent}#cpalPicker::-webkit-color-swatch-wrapper{padding:4px}#cpalPicker::-webkit-color-swatch{border:none;border-radius:6px}#cpalPicker::-moz-color-swatch{border:none}.cpal-fields{display:flex;flex-direction:column;gap:6px}.cpal-field-row{display:flex;align-items:center;gap:8px}.cpal-field-lbl{font-family:var(--font-accent);font-size:.6rem;font-weight:700;letter-spacing:.09em;color:var(--muted);width:26px;flex-shrink:0}.cpal-field{flex:1;height:30px;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:0 8px;font-family:Courier New,monospace;font-size:.8rem;color:var(--text);background:var(--bg);outline:none;transition:border-color .15s}.cpal-field:focus{border-color:var(--blue)}.cpal-multi{display:flex;gap:4px;flex:1}.cpal-num{height:30px;flex:1;min-width:0;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:0 6px;font-family:Courier New,monospace;font-size:.78rem;color:var(--text);background:var(--bg);outline:none;transition:border-color .15s;text-align:center}.cpal-num:focus{border-color:var(--blue)}.cpal-random-btn{border-radius:var(--radius-pill);background:var(--bg);color:var(--mid);border:1.5px solid var(--border);font-family:var(--font-accent);font-size:.68rem;font-weight:700;letter-spacing:.06em;padding:.45rem 1rem;cursor:pointer;transition:all .15s;width:100%}.cpal-random-btn:hover{border-color:var(--blue);color:var(--blue)}.cpal-wcag-title{font-family:var(--font-accent);font-size:.62rem;font-weight:700;letter-spacing:.09em;color:var(--muted);margin-bottom:.4rem}.cpal-wcag-row{display:flex;align-items:center;gap:6px;padding:5px 0;border-bottom:1px solid var(--border)}.cpal-wcag-row:last-child{border-bottom:none}.cpal-wcag-swatch{width:22px;height:22px;border-radius:4px;border:1px solid var(--border);flex-shrink:0}.cpal-wcag-vs{font-family:var(--font-accent);font-size:.6rem;color:var(--muted);flex-shrink:0}.cpal-wcag-ratio{font-family:Courier New,monospace;font-size:.82rem;font-weight:700;color:var(--text);flex:1}.cpal-wcag-badges{display:flex;gap:3px}.cpal-badge{font-family:var(--font-accent);font-size:.55rem;font-weight:700;letter-spacing:.04em;padding:1px 5px;border-radius:var(--radius-pill)}.cpal-badge-pass{background:#a2cc5e33;color:#3a6010;border:1px solid rgba(162,204,94,.4)}.cpal-badge-fail{background:#ec79791f;color:#8a2020;border:1px solid rgba(236,121,121,.3)}.cpal-right{display:flex;flex-direction:column;gap:.875rem}.cpal-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.1rem 1.25rem}.cpal-card-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:.8rem;gap:.5rem}.cpal-card-title{font-family:var(--font-heading);font-size:.9rem;font-weight:900;letter-spacing:-.01em}.cpal-copy-all{font-family:var(--font-accent);font-size:.62rem;font-weight:700;letter-spacing:.05em;padding:.22rem .65rem;border-radius:var(--radius-pill);border:1.5px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;transition:all .15s;white-space:nowrap}.cpal-copy-all:hover{border-color:var(--blue);color:var(--blue)}.cpal-copy-all.cpal-copied{border-color:var(--green);background:var(--green);color:var(--white)}.cpal-swatches{display:flex;flex-wrap:wrap;gap:6px}.cpal-swatch{display:flex;flex-direction:column;align-items:stretch;gap:4px;cursor:pointer;border:1.5px solid transparent;background:transparent;padding:0;border-radius:var(--radius-sm);transition:transform .12s;flex:1;min-width:64px;max-width:160px;overflow:hidden}.cpal-swatch:hover{transform:translateY(-2px);border-color:var(--border)}.cpal-swatch-block{height:64px;border-radius:6px;position:relative;overflow:hidden}.cpal-swatch.cpal-copied .cpal-swatch-block:after{content:"✓";position:absolute;inset:0;background:#00000052;color:#fff;display:grid;place-items:center;font-size:1.2rem;font-weight:900}.cpal-swatch-hex{font-family:Courier New,monospace;font-size:.68rem;color:var(--text);text-align:center;line-height:1.3}.cpal-swatch-sub{font-family:Courier New,monospace;font-size:.6rem;color:var(--muted);text-align:center;line-height:1.3}.cpal-swatches-sm{display:flex;flex-wrap:nowrap;gap:5px;overflow-x:auto;padding-bottom:4px}.cpal-swatches-sm::-webkit-scrollbar{height:4px}.cpal-swatches-sm::-webkit-scrollbar-track{background:var(--bg);border-radius:2px}.cpal-swatches-sm::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.cpal-swatches-sm .cpal-swatch{flex:0 0 62px;min-width:0;max-width:none}.cpal-swatches-sm .cpal-swatch-block{height:46px}.cpal-swatches-sm .cpal-swatch-hex{font-size:.62rem}.cpal-swatches-sm .cpal-swatch-sub{font-size:.57rem}.cpal-ts-wrap{display:flex;flex-direction:column;gap:.5rem}.cpal-ts-row{display:flex;align-items:center;gap:.5rem}.cpal-ts-lbl{font-family:var(--font-accent);font-size:.6rem;font-weight:700;letter-spacing:.08em;color:var(--muted);width:38px;flex-shrink:0}.cpal-tw-code{margin-top:.75rem;background:#1e1e2e;color:#cdd6f4;font-family:Courier New,monospace;font-size:.7rem;line-height:1.65;padding:.875rem 1rem;border-radius:var(--radius-sm);overflow-x:auto;white-space:pre}.cpal-tw-k{color:#89b4fa}.cpal-tw-v{color:#a6e3a1}.cpal-export{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.5rem}.cpal-export-btn{font-family:var(--font-accent);font-size:.68rem;font-weight:700;letter-spacing:.06em;padding:.4rem 1rem;border-radius:var(--radius-pill);border:1.5px solid var(--border);background:var(--white);color:var(--mid);cursor:pointer;transition:all .15s}.cpal-export-btn:hover{border-color:var(--blue);color:var(--blue)}.cpal-export-btn.cpal-copied{border-color:var(--green);background:var(--green);color:var(--white)}
