/* Cape Form Builder - Quiz */
.cfb-quiz {
    --cfb-quiz-accent: var(--cfb-accent, #16a34a);
    max-width: 760px;
    margin: 0 auto;
    padding: 8px 16px 32px;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    color: #1f2937;
}

.cfb-quiz-progress-bar {
    height: 4px;
    background: #e5e7eb;
    border-radius: 999px;
    overflow: hidden;
    margin-bottom: 28px;
}
.cfb-quiz-progress-fill {
    height: 100%;
    width: 0;
    background: var(--cfb-quiz-accent);
    border-radius: 999px;
    transition: width .3s ease;
}

.cfb-quiz-question {
    text-align: center;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.35;
    margin: 24px 0 28px;
}
.cfb-quiz-req { color: #dc2626; }

.cfb-quiz-options {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
@media (max-width: 560px) {
    .cfb-quiz-options { grid-template-columns: 1fr; }
}

.cfb-quiz-option {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 18px 20px;
    border: 1.5px solid var(--cfb-quiz-accent);
    border-radius: 12px;
    cursor: pointer;
    transition: background .15s ease, box-shadow .15s ease, transform .05s ease;
    background: #fff;
    font-size: 16px;
}
.cfb-quiz-option:hover { background: #f0fdf4; }
.cfb-quiz-option.selected {
    background: var(--cfb-quiz-accent);
    color: #fff;
    box-shadow: 0 4px 12px rgba(0,0,0,.12);
}
.cfb-quiz-option input { position: absolute; opacity: 0; pointer-events: none; }

.cfb-quiz-radio {
    flex: 0 0 22px;
    width: 22px;
    height: 22px;
    border: 2px solid var(--cfb-quiz-accent);
    border-radius: 50%;
    position: relative;
    background: #fff;
    transition: border-color .15s ease;
}
.cfb-quiz-option.selected .cfb-quiz-radio { border-color: #fff; }
.cfb-quiz-option.selected .cfb-quiz-radio::after {
    content: "";
    position: absolute;
    inset: 4px;
    border-radius: 50%;
    background: #fff;
}
.cfb-quiz-option-label { flex: 1; }

.cfb-quiz-error {
    display: none;
    text-align: center;
    color: #dc2626;
    font-size: 13px;
    margin-top: 14px;
}
.cfb-quiz-has-error .cfb-quiz-error { display: block; }

/* Lead step */
.cfb-quiz-lead-heading { text-align: center; font-size: 24px; font-weight: 800; margin: 8px 0 12px; }
.cfb-quiz-lead-subtext { text-align: center; color: #6b7280; margin: 0 auto 16px; max-width: 520px; }
.cfb-quiz-disclaimer { text-align: center; color: #4b5563; font-size: 14px; font-style: italic; max-width: 560px; margin: 0 auto 24px; line-height: 1.5; }

.cfb-quiz-lead-fields { max-width: 480px; margin: 0 auto; }
.cfb-quiz-lead-field { margin-bottom: 16px; }
.cfb-quiz-lead-label { display: block; font-weight: 600; font-size: 14px; margin-bottom: 6px; }
.cfb-quiz-input {
    width: 100%;
    padding: 14px 16px;
    border: 1.5px solid var(--cfb-quiz-accent);
    border-radius: 10px;
    font-size: 16px;
    box-sizing: border-box;
}
.cfb-quiz-input:focus { outline: none; box-shadow: 0 0 0 3px rgba(22,163,74,.15); }

.cfb-quiz-submit {
    display: block;
    margin: 24px auto 0;
    padding: 14px 32px;
    background: var(--cfb-quiz-accent);
    color: #fff;
    border: none;
    border-radius: 10px;
    font-size: 17px;
    font-weight: 700;
    cursor: pointer;
}
.cfb-quiz-submit:hover { filter: brightness(.95); }
.cfb-quiz-submit:disabled { opacity: .7; cursor: default; }

/* Nav */
.cfb-quiz-nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 36px;
}
.cfb-quiz-prev, .cfb-quiz-next, .cfb-quiz-counter {
    background: var(--cfb-quiz-accent);
    color: #fff;
    border: none;
    border-radius: 999px;
    padding: 10px 24px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
}
.cfb-quiz-counter { cursor: default; }
.cfb-quiz-prev:disabled { opacity: .5; cursor: default; }

.cfb-quiz-messages { margin-top: 16px; text-align: center; }
.cfb-quiz-message-error { color: #dc2626; font-size: 14px; }

.cfb-quiz-done { text-align: center; padding: 48px 16px; }
.cfb-quiz-done-check {
    width: 64px; height: 64px; line-height: 64px;
    margin: 0 auto 16px;
    border-radius: 50%;
    background: var(--cfb-quiz-accent);
    color: #fff;
    font-size: 32px;
}
.cfb-quiz-done p { font-size: 18px; color: #374151; }
