/* CSS cho Khảo sát SME Health Check - Layout tùy chỉnh v2.1.4 - Fix Result Text Color */

/* --- Biến màu --- */
:root {
    --sme-brand-orange: #F58220; /* <<< THAY MÃ MÀU CAM CỦA BẠN VÀO ĐÂY */
    --sme-brand-white: #ffffff;
    --sme-brand-dark-grey: #6c757d;
    --sme-brand-light-grey: #a0a5aa;
    --sme-brand-dark-blue: #2c3e50;
    --sme-brand-footer-bg: #34495e;
    --sme-brand-footer-text: #bdc3c7;
    --sme-border-color: #eee;
    --sme-text-color: #333; /* Màu chữ mặc định tối */
    --sme-heading-color: #2c3e50; /* Màu tiêu đề */
    --sme-link-color: #0073aa;
    --sme-link-hover-color: #005177;
    --sme-error-color: #dc3232;
    --sme-error-bg: #ffeeee;
    --sme-error-border: #fecaca;
    --sme-level-red-bg: #dc3232;
    --sme-level-orange-bg: #ffb900;
    --sme-level-yellow-bg: #f0e000;
    --sme-level-green-bg: #46b450;
}

/* --- Thiết lập cơ bản --- */
body.sme-quiz-layout-active { background-color: #f0f2f5; margin: 0; padding: 0; font-family: sans-serif; display: flex; flex-direction: column; min-height: 100vh; color: var(--sme-text-color); /* Đặt màu chữ mặc định */}
#sme-quiz-page-wrapper { width: 100%; flex-grow: 1; display: flex; flex-direction: column; }
.sme-quiz-container { max-width: 1100px; margin: 0 auto; padding: 0 15px; width: 100%; box-sizing: border-box; }
.sme-quiz-section { padding: 0; }

/* --- Header --- */
#sme-quiz-header { background-color: var(--sme-brand-dark-blue); padding: 0; line-height: 0; font-size: 0; }
.sme-quiz-banner-image { display: block; width: 100%; max-width: 100%; height: auto; margin: 0; padding: 0; vertical-align: bottom; font-size: 1rem; line-height: normal; }
.fallback-title { color: var(--sme-brand-white); padding: 20px 0; margin: 0; text-align: center; font-size: 1.5em; background-color: var(--sme-brand-dark-blue); line-height: normal; }

/* --- Main Content Area --- */
#sme-quiz-content { flex-grow: 1; padding: 40px 0; }

/* --- Box Nội dung Khảo sát --- */
#sme-quiz-container-v2 { max-width: 800px; margin: 0 auto; background-color: var(--sme-brand-white); border-radius: 8px; box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1); padding: 30px 40px; overflow: hidden; }

/* --- Các style còn lại cho các bước, form, câu hỏi, nút, kết quả --- */
.sme-quiz-page { display: none; animation: smeFadeIn 0.5s ease-in-out; }
.sme-quiz-page.active { display: block; }
@keyframes smeFadeIn { from { opacity: 0; } to { opacity: 1; } }
.sme-page-content { padding: 0; margin-bottom: 25px; }
.sme-page-title { text-align: center; color: var(--sme-heading-color); margin-bottom: 20px; font-size: 1.5em; border-bottom: 1px solid var(--sme-border-color); padding-bottom: 15px; }
.sme-page-subtitle { text-align: center; color: #555; font-size: 1.05em; margin-bottom: 25px; }
.sme-divider { border: 0; height: 1px; background-color: var(--sme-link-color); margin: 25px 0; }
.sme-divider-light { border: 0; height: 1px; background-color: #e0e0e0; margin: 25px 0; }
.sme-page-content h3 { color: var(--sme-link-color); margin-top: 20px; margin-bottom: 10px; font-size: 1.2em; }
.sme-page-content ul, .sme-page-content ol { margin-left: 20px; line-height: 1.7; } /* Màu kế thừa từ body */
.sme-page-content ul ul { margin-top: 5px; margin-bottom: 5px; }
.sme-form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 15px 25px; margin-top: 20px; }
.sme-form-group { margin-bottom: 0; }
.sme-form-group.sme-full-width { grid-column: 1 / -1; }
.sme-form-group label { display: block; margin-bottom: 5px; font-weight: bold; color: #444; font-size: 0.95em; }
.sme-form-group input[type="text"], .sme-form-group input[type="email"], .sme-form-group input[type="tel"], .sme-form-group select { width: 100%; padding: 8px 10px; border: 1px solid #ccc; border-radius: 4px; box-sizing: border-box; }
.sme-form-group input.sme-input-error { border-color: var(--sme-error-color); }
.sme-radio-group label { display: block; margin-bottom: 5px; font-weight: normal; cursor: pointer; }
.sme-radio-group label input[type="radio"] { margin-right: 8px; }
.sme-radio-group.sme-input-error { border: 1px solid var(--sme-error-color); padding: 5px; border-radius: 4px; }
.sme-required { color: var(--sme-error-color); margin-left: 2px; }
.sme-privacy-note { margin-top: 20px; font-size: 0.9em; color: #666; font-style: italic; text-align: center; grid-column: 1 / -1; }
.sme-error-message { color: var(--sme-error-color); font-size: 0.9em; margin-top: 3px; margin-bottom: 8px; }
.sme-question-block { margin-bottom: 20px; padding-bottom: 15px; border-bottom: 1px dashed var(--sme-border-color); }
.sme-question-block:last-child { border-bottom: none; margin-bottom: 0; }
.sme-question { font-weight: 600; margin-bottom: 15px; color: var(--sme-heading-color); font-size: 1.05em; line-height: 1.5; }
.sme-question.sme-input-error { color: var(--sme-error-color); }
.sme-options label { display: block; margin-bottom: 5px; cursor: pointer; padding: 8px 12px; border: 1px solid var(--sme-border-color); border-radius: 5px; transition: background-color 0.2s ease, border-color 0.2s ease; font-weight: normal; }
.sme-options label:hover { background-color: #f5f5f5; border-color: #ccc; }
.sme-options label input[type="radio"] { margin-right: 10px; vertical-align: middle; }

/* --- Navigation & Button Styling --- */
.sme-navigation { margin-top: 25px; padding-top: 20px; border-top: 1px solid var(--sme-border-color); display: flex; justify-content: space-between; align-items: center; }
.sme-quiz-page[data-step="1"] .sme-navigation, .sme-quiz-page[data-step="8"] .sme-navigation { justify-content: center; }
.sme-quiz-page[data-step="7"] .sme-navigation { justify-content: space-between; }
#sme-quiz-container-v2 .sme-button { appearance: none; -webkit-appearance: none; display: inline-block; padding: 10px 25px; min-width: 150px; text-align: center; background-color: var(--sme-brand-white) !important; border: 2px solid var(--sme-brand-orange) !important; border-radius: 5px; color: var(--sme-brand-orange) !important; font-size: 1em; font-weight: 600; text-decoration: none; line-height: 1.4; cursor: pointer; transition: background-color 0.25s ease-in-out, color 0.25s ease-in-out, border-color 0.25s ease-in-out; }
#sme-quiz-container-v2 .sme-button:hover, #sme-quiz-container-v2 .sme-button:focus { background-color: var(--sme-brand-orange) !important; color: var(--sme-brand-white) !important; border-color: var(--sme-brand-orange) !important; outline: none; }
/* Style nút Quay lại nếu cần */
#sme-quiz-container-v2 .sme-button:disabled { background-color: var(--sme-brand-light-grey) !important; border-color: var(--sme-brand-light-grey) !important; color: var(--sme-brand-white) !important; cursor: not-allowed; opacity: 0.7; }

/* --- Results Page --- */
#sme-section-results .sme-result-section { margin-bottom: 15px; padding: 15px; background-color: #f8f9fa; border-left: 5px solid var(--sme-link-color); border-radius: 0 4px 4px 0; }
#sme-section-results .sme-result-section h4 { margin-top: 0; margin-bottom: 8px; color: var(--sme-link-hover-color); font-size: 1.1em;}
#sme-section-results .sme-result-section p { margin-bottom: 0; font-size: 0.95em; } /* Màu kế thừa từ body */
#sme-overall-results { margin-top: 20px; padding: 15px; border: 1px solid #ccc; border-radius: 5px; background-color: var(--sme-brand-white); }
#sme-overall-results p { margin-bottom: 8px; font-size: 1.05em; }
#sme-overall-results span { font-weight: bold; } /* Màu kế thừa từ p */

/* --- ĐIỀU CHỈNH MÀU CHỮ PHÂN LOẠI TẠI ĐÂY --- */
#sme-overall-results #sme-overall-level {
    display: inline-block;
    padding: 3px 8px;
    border-radius: 4px;
    color: var(--sme-text-color); /* <-- Đặt màu chữ mặc định là màu tối */
    /* Bỏ màu nền chung ở đây, sẽ đặt theo từng data-level-class */
    /* background-color: transparent; */
    margin-left: 5px; /* Thêm khoảng cách nhỏ sau chữ "Phân loại:" */
}
/* Đặt màu nền VÀ màu chữ cho từng loại */
#sme-overall-results span[data-level-class="level-red"] {
    background-color: var(--sme-level-red-bg);
    color: var(--sme-brand-white); /* Chữ trắng trên nền đỏ */
}
#sme-overall-results span[data-level-class="level-orange"] {
    background-color: var(--sme-level-orange-bg);
    color: var(--sme-text-color); /* Chữ tối trên nền cam */
}
#sme-overall-results span[data-level-class="level-yellow"] {
    background-color: var(--sme-level-yellow-bg);
    color: var(--sme-text-color); /* Chữ tối trên nền vàng */
}
#sme-overall-results span[data-level-class="level-green"] {
    background-color: var(--sme-level-green-bg);
    color: var(--sme-brand-white); /* Chữ trắng trên nền lục */
}
/* ---------------------------------------------- */


/* --- Footer tùy chỉnh với Banner --- */
#sme-quiz-footer { background-color: transparent; padding: 0; margin-top: auto; line-height: 0; }
.sme-quiz-footer-container { padding: 0; max-width: none; text-align: center; }
.sme-quiz-footer-image { display: block; max-width: 100%; height: auto; margin: 0 auto; vertical-align: bottom; }
#sme-quiz-footer p { color: var(--sme-brand-footer-text); text-align: center; font-size: 0.9em; margin: 0; padding: 15px 0; background-color: var(--sme-brand-footer-bg); line-height: normal; }

/* Loading & Error */
#sme-quiz-loading-v2, #sme-quiz-error-v2 { text-align: center; padding: 15px; margin-top: 20px; font-style: italic; }
#sme-quiz-error-v2 p { color: var(--sme-error-color); font-weight: bold; margin:0; }
#sme-quiz-error-v2 { padding: 15px; border: 1px solid var(--sme-error-border); background-color: var(--sme-error-bg); border-radius: 4px; }

/* --- Responsive --- */
@media (max-width: 768px) {
    #sme-quiz-container-v2 { padding: 20px; margin-left: 10px; margin-right: 10px; width: auto; max-width: none; }
    .sme-page-title { font-size: 1.3em; }
    .fallback-title { text-align: center; font-size: 1.2em; }
    .sme-form-grid { grid-template-columns: 1fr; }
    #sme-quiz-container-v2 .sme-button { padding: 10px 20px; font-size: 0.95em; min-width: 100px; width: 100%; }
    .sme-navigation { flex-direction: column-reverse; gap: 10px; }
}
@media (max-width: 480px) {
    #sme-quiz-container-v2 { padding: 15px; }
    .sme-page-title { font-size: 1.2em; }
    .sme-options label { padding: 8px 10px; }
}