/* color-palette-generator (RT-FUN-091) — tool styles. Card system in share-card.css. */

.cp-tool { display: flex; flex-direction: column; gap: 16px; }
.cp-controls { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.cp-controls select {
    font: inherit; font-weight: 500; padding: 9px 12px; border: 1.5px solid var(--border, #ebebeb);
    border-radius: 8px; background: var(--card-bg, #fff); color: var(--t1, #1a1814);
}
.cp-gen { font: inherit; font-weight: 700; padding: 10px 22px; border: none; border-radius: 999px; background: var(--rt-accent, #e8622a); color: #fff; cursor: pointer; }
.cp-gen:focus-visible { outline: 3px solid #1a1814; outline-offset: 2px; }
.cp-hint { color: var(--t2, #6b6760); font-size: .85rem; }

.cp-row { display: flex; gap: 0; border-radius: 14px; overflow: hidden; min-height: 220px; border: 1px solid var(--border, #ebebeb); }
.cp-swatch { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: space-between; padding: 14px 6px; position: relative; transition: flex .2s ease; }
.cp-swatch:hover { flex: 1.25; }
.cp-lock { background: rgba(0,0,0,.06); border: none; border-radius: 999px; width: 34px; height: 34px; cursor: pointer; font-size: 1rem; line-height: 1; }
.cp-hex { background: none; border: none; cursor: pointer; font: inherit; font-weight: 700; letter-spacing: .5px; color: inherit; padding: 6px 8px; border-radius: 6px; }
.cp-hex:hover { background: rgba(0,0,0,.08); }
.cp-lock:focus-visible, .cp-hex:focus-visible { outline: 2px solid currentColor; outline-offset: 1px; }

@media (prefers-reduced-motion: reduce) { .cp-swatch, .cp-swatch:hover { transition: none; flex: 1; } }
@media (max-width: 520px) { .cp-row { min-height: 160px; } .cp-hex { font-size: .8rem; } }

.cp-stage { background: #0c1827; border-radius: 16px; }

/* Card (1080×1350 coords) */
.cp-card { padding: 0; }
.cp-card .sc-eyebrow { position: absolute; top: 60px; left: 0; right: 0; text-align: center; z-index: 2; color: #fff; text-shadow: 0 1px 6px rgba(0,0,0,.3); }
.cp-card-strip { position: absolute; top: 0; left: 0; right: 0; bottom: 150px; display: flex; flex-direction: column; }
.cp-card-band { flex: 1; display: flex; align-items: center; padding-left: 80px; font-family: var(--sc-font); font-size: 56px; font-weight: 700; letter-spacing: 2px; }
.cp-card .sc-footer { position: absolute; left: 0; right: 0; bottom: 0; height: 150px; z-index: 2; background: #0c1827; padding: 0 80px; margin: 0; }
.cp-card .sc-footer .sc-wordmark, .cp-card .sc-footer .sc-url { color: #fff; }
