/* ===============================
   CARE QUIZ UI STYLES
   =============================== */

/* Base font & colors */
.care-quiz,
.care-quiz * {
    font-family: "Poppins", sans-serif;
    color: #292a61;
    font-weight:600;
    box-sizing: border-box;
}

/* Buttons */
.care-quiz-navigation button {
    background: #f0117a;
    color: #ffffff;
    border: none;
    padding: 12px 22px;
    font-family: "Poppins", sans-serif;
    font-weight: 600;
    font-size: 15px;
    border-radius: 40px;
    cursor: pointer;
    margin-right: 8px;
    transition: 0.2s ease-in-out;

}

.care-quiz-navigation{
        display:flex;
    justify-content:center;
    align-items:center;
    flex-direction:row;
}

.care-quiz-navigation button:hover {
    opacity: 0.85;
}

/* Error state for unanswered question */
.care-quiz-question-error {
    border-left: 3px solid #f0117a;
    padding-left: 8px;
}

/* Progress text */
.care-quiz-step-indicator {
    font-size: 14px;
    display: block;
    opacity: 0.8;
}

.care-quiz-results{
    /*padding-top:100px;*/
    /*padding-bottom:100px;*/
}

.care-quiz-intro{
    font-weight:400;
    text-align:center;
}

/* ===============================
   Accordion Styles (Final Version)
   =============================== */

.care-quiz-accordion {
    width: 100%;
    margin-top: 25px;
    border: 1px solid #d5d8dc;
    border-radius: 0px;
    overflow: hidden;
}

/* Remove all gaps between items */
.care-quiz-accordion-item {
    width: 100%;
    border-bottom: 1px solid #d5d8dc;
}

.care-quiz-accordion-item:last-child {
    border-bottom: none;
}

/* Accordion Header */
.care-quiz-accordion-header {
    width: 100%;
    display: block;
    padding: 14px 18px;
    background: #ffffff;
    cursor: pointer;
    border: none !important;
    outline: none !important;
    text-align: left;
    font-family: "Poppins", sans-serif !important;
    font-weight: 600 !important;
    font-size: 16px;
    color: #292a61 !important;
    line-height: 1.3em;
    transition: color 0.2s ease-in-out, background 0.2s ease-in-out;
}

/* Active Header (open accordion) */
.care-quiz-accordion-item.active .care-quiz-accordion-header {
    color: #f0117a !important;
}

.care-quiz-accordion-header button:hover, .care-quiz-accordion-header button:hover{
    background-color:white;
    color:#f0117a;
}


/* Accordion Content */
.care-quiz-accordion-panel {
    display: none;
    background: #ffffff;
    padding: 18px;
    border-top: 1px solid #d5d8dc;
    animation: fadeIn 0.25s ease;

}

.care-quiz-accordion-panel p{
        font-weight:400 !important;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

/**/

/* Question wrapper as a single card */
.care-quiz-question {
    margin: 20px auto;
    border: 1px solid #d5d8dc;
    border-radius: 16px;
    padding: 24px 24px 18px;
    max-width: 700px;
    background: #ffffff;
}

/* Big centered question text */
.care-quiz-question legend {
    text-align: center;
    font-size: 24px;
    font-weight: 600;
    margin-bottom: 18px;
    font-family: "Poppins", sans-serif;
    color: #292a61;
    line-height: 1.2em;
}

/* Answer wrapper as row inside the card */
.care-quiz-answer {
    display: block;
    margin-bottom: 6px;
}

/* Hide the radio itself, but keep functional */
.care-quiz-answer input[type="radio"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

/* The visible row */
.care-quiz-answer span {
    display: block;
    padding: 20px 20px;
    border-radius: 10px;
    border: 1px solid transparent;
    background: transparent;
    font-size: 16px;
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
    text-align:center;
}

/* Hover row highlight */
.care-quiz-answer span:hover {
    background: #fdf3f9;
    border-color: #f0117a33;
}

/* Selected answer row (JS adds .care-quiz-answer-selected) */
.care-quiz-answer.care-quiz-answer-selected span {
    background: #fdf3f9;
    border-color: #f0117a;
    color: #f0117a;
}

/* Ensure the quiz question area becomes a positioned container */
.care-quiz-questions {
    position: relative;
    padding-bottom: 40px; /* prevent overlap with step indicator */
}

/* Position step indicator absolutely at the bottom center */
.care-quiz-progress {
    position: absolute;
    bottom: 40px;
    left: 50%;
    transform: translateX(-50%);
    text-align: center;
    width: 100%;
    pointer-events: none;
    background-color:white;
    width:fit-content;
    padding:10px 20px;
    border-radius:100px;
    border: solid 1px #d5d8dc;
}

.care-quiz-step-indicator {
    display: inline-block;
    font-family: "Poppins", sans-serif;
    font-weight: 600;
    font-size: 14px;
    color: #292a61;
}

.care-quiz-error-message {
    background: #ffe9ef;
    color: #d8184f;
    border: 1px solid #f4b5c5;
    padding: 10px 15px;
    margin: 10px 0 20px;
    border-radius: 8px;
    font-family: "Public Sans", sans-serif;
    font-size: 14px;
    text-align:center;
}

.care-quiz-navigation .care-quiz-restart {
    display: none; /* JS will show it after finishing */
}

