.crc-comp { max-width: 820px; margin: 0 auto; }
.crc-head { text-align: center; margin-bottom: 18px; }
.crc-progress { height: 8px; background: #eee; border-radius: 999px; overflow: hidden; margin-bottom: 16px; }
.crc-progress-bar { height: 8px; background: #000; width: 0%; transition: width .25s; }
.crc-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 10px; }
.crc-grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 12px; }
.crc-pill { padding: 12px 14px; border: 1px solid #ddd; border-radius: 16px; text-align:left; background:#fff; }
.crc-pill.active, .crc-pill:hover { border-color: #000; box-shadow: 0 0 0 2px #000 inset; }
.crc-range { margin-top: 16px; }
.crc-nav { display:flex; justify-content: space-between; gap: 12px; margin-top: 14px; }
.crc-prev, .crc-next, .crc-submit { padding: 10px 14px; border-radius: 10px; border: 1px solid #ddd; background:#fff; }
.crc-next, .crc-submit { background:#000; color:#fff; border-color:#000; }
.crc-consent { display:flex; align-items: flex-start; gap: 8px; margin-top: 10px; }
.crc-note { font-size: 12px; color:#666; margin-top: 8px; }
@media (max-width: 640px){ .crc-grid, .crc-grid-2 { grid-template-columns: 1fr; } }
