:root {

    --cmp-current: #2563eb;

    --cmp-answered: #16a34a;

    --cmp-not-answered: #dc2626;

    --cmp-review: #aa5ff0;

    --cmp-answered-review: #deeb35;

    --cmp-not-visited: #d1d5db;

}


.cmp-question-card {

    margin-bottom: 30px;

    padding: 15px;

    border: 1px solid #ddd;

    border-radius: 8px;

    background: #fff;

}


.cmp-clear-response {

    background: #fff;

    border: 1px solid #d1d5db;

    padding: 10px 20px;

    border-radius: 6px;

    cursor: pointer;

}

.cmp-submit-btn {

    background: #2563eb;

    color: #fff;

    border: none;

    padding: 12px 24px;

    border-radius: 6px;

    cursor: pointer;

}

.cmp-result-card {

    background: #fff;

    border-radius: 12px;

    padding: 24px;

    box-shadow:
        0 2px 8px
        rgba(0,0,0,.08);

}

.cmp-palette {

    display: flex;

    flex-wrap: wrap;

    gap: 10px;

    margin-bottom: 20px;

    max-width: 300px;

}


.cmp-palette-item {

    width: 50px;

    height: 50px;

    display: flex;

    align-items: center;

    justify-content: center;

    background: var(--cmp-not-visited);

    border-radius: 8px;

    font-weight: 600;

    cursor: pointer;

    text-decoration: none;

    color: #111827;

}

.cmp-question {

    display: none;

}

.cmp-question.active {

    display: block;

}

.cmp-navigation {

    display: flex;

    gap: 10px;

    margin-top: 20px;

    flex-wrap: wrap;

}



.cmp-prev-btn,
.cmp-next-btn {

    background: #2a3c4c;

    color: #fff;

    border: none;

    padding: 10px 20px;

    border-radius: 6px;

    cursor: pointer;

}

.cmp-review-btn {

    background: var(--cmp-review);

    color: #fff;

    border: none;

    padding: 10px 20px;

    border-radius: 6px;

    cursor: pointer;

}

.cmp-review-btn:hover {

    opacity: .9;

}

.cmp-palette-item.current {

    background: var(--cmp-current);

    color: white;

}


.cmp-quiz-layout {

    display: grid;

    grid-template-columns:
        4fr 1.4fr;

    gap: 24px;

    align-items: start;

}

.cmp-main-content {

    min-width: 0;

}

.cmp-sidebar {

    position: sticky;

    top: 80px;

    background: #fff;

    padding: 16px;

    border: 1px solid #ddd;

    border-radius: 10px;

}

.cmp-palette {

    display: grid;

    grid-template-columns:
        repeat(5, 1fr);

    gap: 8px;

}

.cmp-legend {

    margin-top: 20px;

    font-size: 14px;

}

@media (max-width: 768px) {

    .cmp-quiz-layout {

        grid-template-columns:
            1fr;

        }

}

.cmp-legend {

    display: grid;

    grid-template-columns:
        1fr 1fr;

    gap: 8px;

    margin-top: 15px;

    font-size: 13px;

}

.cmp-legend p {

    margin: 0;

}

.cmp-legend-box {

    display:inline-block;

    width:12px;

    height:12px;

    margin-right:6px;

}

.cmp-current-box {

    background:var(--cmp-current);

}

.cmp-answered-box {

    background:var(--cmp-answered);

}

.cmp-not-answered-box {

    background:var(--cmp-not-answered);

}

.cmp-review-box {

    background:var(--cmp-review);

}

.cmp-answered-review-box {

    background:var(--cmp-answered-review);

}

.cmp-not-visited-box {

    background:var(--cmp-not-visited);

}