/* ============================================= */
/* CÀI ĐẶT BIẾN (CHO SÁNG/TỐI & CHỦ ĐỀ)
/* ============================================= */
:root {
    --font-main: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    
    /* Chế độ Sáng (Mặc định) */
    --bg-primary: #f0f4f8;        /* Nền chính của trang */
    --bg-secondary: #ffffff;    /* Nền của các thẻ, khối nội dung */
    --text-primary: #1a202c;      /* Tiêu đề, chữ chính */
    --text-secondary: #4a5568;  /* Chữ phụ, mô tả */
    --border-color: #e2e8f0;      /* Đường viền */

    /* Màu chủ đề "Game" */
    --color-primary: #3b82f6;   /* Màu chính (links, icons) */
    --color-primary-light: #dbeafe;
    --color-success: #10b981;     /* Hoàn thành, đáp án đúng */
    --color-success-light: #d1fae5;
    --color-danger: #ef4444;      /* Lỗi sai */
    --color-danger-light: #fee2e2;
    --color-vocab: #f59e0b;       /* Thẻ từ vựng */
    --color-vocab-light: #fef3c7;
    
    /* Các biến chung */
    --border-radius: 12px;
    --shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.07), 0 2px 4px -1px rgba(0, 0, 0, 0.04);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.07), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
    --transition: all 0.3s ease;
}

/* Chế độ Tối */
[data-theme="dark"] {
    --bg-primary: #1a202c;
    --bg-secondary: #2d3748;
    --text-primary: #f7fafc;
    --text-secondary: #a0aec0;
    --border-color: #4a5568;

    --color-primary: #60a5fa;
    --color-primary-light: #2d3748;
    --color-success: #34d399;
    --color-success-light: #1f2937;
    --color-danger: #f87171;
    --color-danger-light: #372a2a;
    --color-vocab: #fbbf24;
    --color-vocab-light: #423b22;
}

/* ============================================= */
/* CÀI ĐẶT CƠ BẢN
/* ============================================= */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}
body {
    font-family: var(--font-main);
    background-color: var(--bg-primary);
    color: var(--text-primary);
    line-height: 1.6;
    transition: var(--transition);
}
h1, h2, h3, h4, h5, h6 {
    color: var(--text-primary);
    line-height: 1.2;
}
p {
    color: var(--text-secondary);
    margin-bottom: 1rem;
}
img {
    max-width: 100%;
    height: auto;
    border-radius: var(--border-radius);
}

/* ============================================= */
/* BỐ CỤC "GAME HÓA" (QUEST LOG)
/* ============================================= */
.page-header {
    background-color: var(--bg-secondary);
    padding: 1rem 2rem;
    box-shadow: var(--shadow);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

/* === CSS CẬP NHẬT CHO LOGO === */
.logo-container {
    display: flex;
    align-items: center;
}
.site-logo {
    height: 40px; /* Chiều cao logo */
    width: auto;
    margin-right: 15px; /* Khoảng cách giữa logo và chữ */
    border-radius: 0; /* Bỏ bo góc cho logo */
    /* Thêm transition cho filter */
    transition: filter 0.3s ease;
}
.page-header h1 {
    font-size: 1.5rem;
    color: var(--color-primary);
    margin: 0; /* Bỏ margin mặc định của h1 */
}

/* Thêm quy tắc để đổi màu logo ở chế độ tối */
[data-theme="dark"] .site-logo {
    filter: invert(1); /* Đảo màu logo (đen -> trắng) */
}
/* === KẾT THÚC CSS LOGO === */


.quest-log {
    max-width: 900px;
    margin: 2rem auto;
    padding: 1rem;
}

.quest-step {
    background-color: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    margin-bottom: 1.5rem;
    box-shadow: var(--shadow);
    transition: var(--transition);
    overflow: hidden; /* Để bo góc cho ảnh */
}
.quest-step:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
}

.step-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 1.5rem;
    border-bottom: 1px solid var(--border-color);
}
.step-header h3 { /* SEO: Đổi từ h2 thành h3 */
    font-size: 1.25rem;
    color: var(--color-primary);
}
.step-header i {
    margin-right: 0.75rem;
}
.step-status {
    background-color: var(--color-success);
    color: white;
    font-size: 0.8rem;
    font-weight: 600;
    padding: 0.25rem 0.75rem;
    border-radius: 99px;
}

.step-content {
    padding: 1.5rem;
}

.data-note {
    font-style: italic;
    font-size: 0.9em;
    color: var(--text-secondary);
    background: var(--bg-primary);
    padding: 10px;
    border-radius: 8px;
    border-left: 4px solid var(--color-primary);
    margin-bottom: 1rem;
}

/* ============================================= */
/* TÓM TẮT BÀI HỌC (MỚI THÊM)
/* ============================================= */
.lesson-summary {
    background-color: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    padding: 1.5rem;
    margin-bottom: 1.5rem;
    box-shadow: var(--shadow);
}
.summary-item {
    font-size: 0.95rem;
    color: var(--text-secondary);
    margin-bottom: 0.75rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
.summary-item:last-child {
    margin-bottom: 0;
}
.summary-item strong {
    color: var(--text-primary);
    margin-right: 0.5rem;
    display: inline-flex;
    align-items: center;
}
.summary-item i {
    margin-right: 0.5rem;
    width: 20px;
    text-align: center;
    color: var(--color-primary);
}
.summary-item .tag {
    font-size: 0.85rem;
    font-weight: 600;
    padding: 0.25rem 0.75rem;
    border-radius: 99px;
    margin-right: 0.5rem;
    margin-top: 0.25rem;
    margin-bottom: 0.25rem;
    display: inline-block;
}
.summary-item .professional-field-tag {
    background-color: var(--color-danger-light);
    color: #c2410c; /* Màu cam đậm */
}
[data-theme="dark"] .summary-item .professional-field-tag {
    color: var(--color-danger);
}
.summary-item strong i.fa-briefcase {
    color: #c2410c;
}
[data-theme="dark"] .summary-item strong i.fa-briefcase {
    color: var(--color-danger);
}

.summary-item .vocab-tag {
    background-color: var(--color-vocab-light);
    color: #b45309; /* Màu vàng đậm */
}
[data-theme="dark"] .summary-item .vocab-tag {
    color: var(--color-vocab);
}
.summary-item strong i.fa-lightbulb {
     color: #b45309;
}
[data-theme="dark"] .summary-item strong i.fa-lightbulb {
    color: var(--color-vocab);
}

.summary-item .grammar-tag {
    background-color: var(--color-primary-light);
    color: var(--color-primary);
}


/* ============================================= */
/* CÁC THÀNH PHẦN CON
/* ============================================= */

/* === SỬA LỖI HIỂN THỊ LOGO DỰ PHÒNG === */

/* 1. Div bọc ảnh */
.image-placeholder-wrapper {
    width: 100%;
    height: 300px; /* Giữ nguyên chiều cao cố định */
    background-color: var(--border-color);
    border-radius: 0; 
    margin-bottom: 1.5rem;
}

/* 2. Thẻ <img> bên trong */
.full-width-placeholder {
    width: 100%;
    height: 100%; /* Đổi thành 100% để vừa khít div bọc */
    object-fit: cover; 
    border-radius: 0; 
    margin-bottom: 0; /* Bỏ margin vì div bọc đã có */
}

/* 3. CSS CHO ẢNH BỊ LỖI (FALLBACK) */
/* Áp dụng cho div bọc khi có class 'image-load-failed' */
.image-placeholder-wrapper.image-load-failed {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--bg-primary); 
}

/* Áp dụng ::after cho div bọc */
.image-placeholder-wrapper.image-load-failed::after {
    content: '';
    display: block;
    width: 100px; 
    height: 100px; 
    
    background-image: url('logo1.png');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    
    opacity: 0.3; 
    transition: filter 0.3s ease; 
}

/* Đổi màu logo dự phòng ở chế độ tối */
[data-theme="dark"] .image-placeholder-wrapper.image-load-failed::after {
    filter: invert(1);
}
/* === KẾT THÚC SỬA LỖI === */


/* 2. Khối câu hỏi */
.question-block {
    margin-top: 1.5rem;
}
.question-block h4 {
    font-size: 1.1rem;
    margin-bottom: 1rem;
    color: var(--text-primary);
}
.question-options {
    list-style-type: none;
}
.question-options li {
    background: var(--bg-primary);
    padding: 0.75rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    margin-bottom: 0.5rem;
    cursor: pointer;
    transition: var(--transition);
}
.question-options li:hover {
    background-color: var(--color-primary-light);
    border-color: var(--color-primary);
}
.explanation {
    background: var(--color-success-light);
    border: 1px solid var(--color-success);
    color: var(--color-success);
    padding: 1rem;
    border-radius: 8px;
    margin-top: 1rem;
}
.explanation strong {
    color: var(--color-success);
}

/* 3. Thẻ từ vựng */
.vocab-card {
    background: var(--color-vocab-light);
    border: 1px solid var(--color-vocab);
    border-left: 5px solid var(--color-vocab);
    padding: 1.5rem;
    border-radius: 8px;
}
.vocab-card h3 {
    color: var(--color-vocab);
    margin-bottom: 0.5rem;
}
.vocab-card p {
    color: var(--text-secondary);
    margin-bottom: 0.25rem;
}
.vocab-card strong {
    color: var(--text-primary);
}

/* 4. Khối ngữ pháp */
.grammar-rule ul {
    padding-left: 20px;
    margin-bottom: 1rem;
}
.grammar-rule li {
    color: var(--text-secondary);
}
.error-example {
    border: 1px solid var(--border-color);
    padding: 1rem;
    border-radius: 8px;
}
.error-example .wrong {
    color: var(--color-danger);
    text-decoration: line-through;
}
.error-example .right {
    color: var(--color-success);
    font-weight: bold;
}

/* 5. Câu chuyện mở rộng */
blockquote {
    background: var(--bg-primary);
    border-left: 5px solid var(--border-color);
    margin: 1rem 0;
    padding: 1rem 1.5rem;
    white-space: pre-line; /* Giữ nguyên xuống dòng */
    font-style: italic;
    color: var(--text-secondary);
}

/* ============================================= */
/* DARK MODE TOGGLE (NÚT CHUYỂN ĐỔI)
/* ============================================= */
.theme-switch-wrapper {
    display: flex;
    align-items: center;
}
.theme-switch {
    display: inline-block;
    height: 34px;
    position: relative;
    width: 60px;
    margin-left: 10px;
}
.theme-switch input {
    display: none;
}
.slider {
    background-color: #ccc;
    bottom: 0;
    cursor: pointer;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
    transition: .4s;
}
.slider:before {
    background-color: #fff;
    bottom: 4px;
    content: "";
    height: 26px;
    left: 4px;
    position: absolute;
    transition: .4s;
    width: 26px;
}
input:checked + .slider {
    background-color: var(--color-primary);
}
input:checked + .slider:before {
    transform: translateX(26px);
}
.slider.round {
    border-radius: 34px;
}
.slider.round:before {
    border-radius: 50%;
}

/* ============================================= */
/* NÚT HOÀN THÀNH BÀI HỌC
/* ============================================= */
.complete-button-container {
    display: flex;
    justify-content: center;
    padding: 1rem 2rem 3rem 2rem; /* Đã trả lại padding bottom */
    background-color: var(--bg-primary); /* Đảm bảo nền nhất quán */
}

.complete-button {
    background-color: var(--color-success); /* Màu xanh lá */
    color: white;
    font-family: var(--font-main);
    font-size: 1.1rem;
    font-weight: 600;
    border: none;
    border-radius: var(--border-radius);
    padding: 0.75rem 1.5rem;
    cursor: pointer;
    box-shadow: var(--shadow);
    transition: var(--transition);
    display: flex;
    align-items: center;
    text-decoration: none; /* Bỏ gạch chân của link */
}

.complete-button i {
    margin-right: 0.75rem;
}

.complete-button:hover {
    background-color: #0f9b6c; /* Màu xanh lá đậm hơn */
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
}

/* ============================================= */
/* NÚT CHIA SẺ BẠN BÈ (ĐÃ ĐƯA LÊN TRÊN)
/* ============================================= */
.share-button-container {
    display: flex;
    justify-content: center;
    padding: 0 2rem 1rem 2rem; /* Bỏ padding top, giữ padding bottom */
    background-color: var(--bg-primary); /* Đảm bảo nền nhất quán */
}

#share-button {
    background-color: var(--color-primary);
    color: white;
    font-family: var(--font-main);
    font-size: 1.1rem;
    font-weight: 600;
    border: none;
    border-radius: var(--border-radius);
    padding: 0.75rem 1.5rem;
    cursor: pointer;
    box-shadow: var(--shadow);
    transition: var(--transition);
    display: flex;
    align-items: center;
}

#share-button i {
    margin-right: 0.75rem;
}

#share-button:hover {
    background-color: #2563eb; /* Màu xanh đậm hơn */
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
}

/* ============================================= */
/* MODAL CHIA SẺ (THIẾT KẾ THEO HÌNH ẢNH)
/* ============================================= */
.share-modal-overlay {
    display: none; /* Ẩn mặc định */
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgba(0, 0, 0, 0.6); /* Nền mờ */
    align-items: center;
    justify-content: center;
}

.share-modal-content {
    background-color: var(--bg-secondary);
    color: var(--text-primary);
    margin: auto;
    padding: 2rem;
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    box-shadow: var(--shadow-lg);
    width: 90%;
    max-width: 550px; /* Tăng độ rộng để vừa 3 nút */
    position: relative;
    animation: fadeIn 0.3s ease;
    text-align: left; /* Căn trái cho tiêu đề */
}

@keyframes fadeIn {
    from { opacity: 0; transform: scale(0.95); }
    to { opacity: 1; transform: scale(1); }
}

.share-modal-close {
    color: var(--text-secondary);
    position: absolute;
    top: 20px; /* Điều chỉnh vị trí nút X */
    right: 20px;
    font-size: 24px; /* Giảm kích thước nút X */
    font-weight: bold;
    cursor: pointer;
    line-height: 1;
}
.share-modal-close:hover {
    color: var(--color-danger);
}

.share-modal-content h3 {
    color: var(--text-primary); /* Đổi màu tiêu đề thành đen */
    font-size: 1.5rem; /* Tăng kích thước tiêu đề */
    margin-top: 0;
    margin-bottom: 1rem;
    padding-right: 20px; /* Thêm padding để không đè lên nút X */
}

.share-modal-content p {
    color: var(--text-secondary);
    font-size: 1rem; /* Tăng kích thước mô tả */
    margin-bottom: 1.5rem;
}

/* Bố cục flex cho các nút */
.share-modal-buttons {
    display: flex;
    gap: 1rem; /* Khoảng cách giữa các nút */
    margin-bottom: 1rem;
}

/* Kiểu nút chung */
.share-modal-button {
    font-family: var(--font-main);
    font-size: 1rem;
    font-weight: 600;
    color: white;
    border: none;
    border-radius: 8px;
    padding: 0.75rem;
    cursor: pointer;
    transition: var(--transition);
    text-align: center;
    text-decoration: none; 
    flex: 1; /* Các nút co giãn bằng nhau */
}

.share-modal-button i {
    /* Bỏ icon theo thiết kế mới */
    display: none;
}

.share-modal-button:hover {
    opacity: 0.85;
    transform: translateY(-2px);
}

/* Màu nút cụ thể */
.share-modal-button.facebook {
    background-color: #1877F2; /* Xanh Facebook */
}

.share-modal-button.twitter-x {
    background-color: #00ACEE; /* Xanh Twitter/Cyan */
}

.share-modal-button.copy {
    background-color: #E0E0E0; /* Xám nhạt */
    color: var(--text-primary); /* Chữ đen */
}
/* CSS cho nút copy khi ở chếd độ tối */
[data-theme="dark"] .share-modal-button.copy {
    background-color: var(--border-color); /* Xám tối hơn */
    color: var(--text-primary); /* Chữ trắng */
}


/* Thông báo đã sao chép */
.share-modal-copied-text {
    visibility: hidden; /* Ẩn mặc định */
    color: var(--color-success);
    font-size: 0.9rem;
    font-weight: 600;
    margin-top: 0.5rem; /* Thêm margin top */
    display: block; /* Để nó xuống hàng */
    text-align: center; /* Căn giữa thông báo */
}
/* ============================================= */
/* BỐ CỤC 2 CỘT CHO BÀI HỌC
/* ============================================= */

.lesson-container {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    margin-bottom: 1.5rem;
}

@media (min-width: 992px) {
    .lesson-container {
        flex-direction: row;
    }
    .main-content-col {
        flex: 2;
        order: 1;
        min-width: 0; /* Ngăn flex item bị co lại ngoài ý muốn */
    }
    .sidebar-col {
        flex: 1;
        order: 2;
        position: sticky;
        top: 20px;
        align-self: flex-start; /* Giữ sidebar ở trên cùng */
        min-width: 0; /* Ngăn flex item bị co lại ngoài ý muốn */
    }
}

.full-width-task {
    margin-top: 1.5rem;
}

/* ============================================= */
/* CÁC THẺ (TAGS)
/* ============================================= */
.tag { 
    font-size: 0.8rem; 
    font-weight: 600; 
    padding: 0.2rem 0.6rem; 
    border-radius: 99px; 
    margin-right: 0.4rem; 
    margin-top: 0.2rem; 
    margin-bottom: 0.2rem; 
    display: inline-block; 
}
.professional-field-tag { 
    background-color: var(--color-danger-light); 
    color: #c2410c; 
}
[data-theme="dark"] .professional-field-tag { 
    color: var(--color-danger); 
}
.vocab-tag { 
    background-color: var(--color-vocab-light); 
    color: #b45309; 
}
[data-theme="dark"] .vocab-tag { 
    color: var(--color-vocab); 
}
.grammar-tag { 
    background-color: var(--color-primary-light); 
    color: var(--color-primary); 
}

/* ============================================= */
/* CSS CHO TASK 2 (VOCABULARY)
/* ============================================= */

.vocab-card details>summary { 
    list-style: none; 
    cursor: pointer; 
    display: block; 
    position: relative; 
}
.vocab-card details>summary::-webkit-details-marker { display: none; }
.vocab-card details>summary::marker { display: none; }
.vocab-card details>summary h3 { 
    display: inline-block; 
    margin-bottom: 0; 
    vertical-align: middle; 
    font-size: 1.1em; 
    padding-right: 30px; 
}
.vocab-card details .vocab-details { 
    margin-top: 10px; 
    padding-top: 10px; 
    border-top: 1px dashed var(--border-color); 
}
.vocab-card details[open]>summary .toggle-icon::before { 
    content: "\f077"; /* up */
}
.vocab-card details:not([open])>summary .toggle-icon::before { 
    content: "\f078"; /* down */
}
.vocab-card details>summary .toggle-icon { 
    font-family: 'Font Awesome 6 Free'; 
    font-weight: 900; 
    color: var(--color-primary); 
    font-size: 0.9em; 
    display: inline-block; 
    transition: transform 0.2s ease; 
    position: absolute; 
    right: 1rem; 
    top: 50%; 
    transform: translateY(-50%); 
}
.dict-link { 
    margin-left: 8px; 
    text-decoration: none; 
    font-size: 0.8em; 
    color: var(--color-primary); 
    vertical-align: middle; 
}
.dict-link:hover { text-decoration: underline; }
.vocab-card { 
    padding: 0; 
    border: none; 
    background: none; 
}
.vocab-card details { 
    border: 1px solid var(--border-color); 
    border-radius: var(--border-radius); 
    overflow: hidden; 
    margin-bottom: 10px; 
    background-color: var(--bg-secondary); 
    transition: background-color 0.3s ease, border-color 0.3s ease;
}
.vocab-card summary { 
    padding: 0.75rem 1rem; 
    background-color: var(--bg-primary); 
    transition: background-color 0.3s ease; 
}
.vocab-details { padding: 0.75rem 1rem; }
.vocab-details p { 
    margin-bottom: 0.6rem; 
    font-size: 0.95em; 
    line-height: 1.5; 
    color: var(--text-secondary);
}
.vocab-details strong { color: var(--text-primary); }
.vocab-actions { 
    margin-top: 10px; 
    padding-top: 8px; 
    border-top: 1px dashed var(--border-color); 
    display: flex; 
    gap: 8px; 
    flex-wrap: wrap; 
}
.action-btn { 
    background-color: var(--color-primary-light); 
    color: var(--color-primary); 
    border: 1px solid var(--color-primary); 
    padding: 4px 8px; 
    border-radius: 5px; 
    cursor: pointer; 
    font-size: 0.85em; 
    transition: all 0.2s ease; 
    display: inline-flex; 
    align-items: center; 
    gap: 4px; 
    text-decoration: none; 
}
.action-btn:hover { 
    background-color: var(--color-primary); 
    color: white; 
}
[data-theme="dark"] .action-btn { 
    background-color: var(--bg-primary); 
    color: var(--color-primary); 
    border-color: var(--color-primary);
}
[data-theme="dark"] .action-btn:hover { 
    background-color: var(--color-primary); 
    color: var(--bg-primary);
}
.action-btn i { font-size: 0.9em; }
.pronunciation-group { 
    display: inline-block; 
    margin-right: 10px; 
    white-space: nowrap; 
}
/* ============================================= */
/* NÚT PHÁT ÂM (THÊM MỚI)
/* ============================================= */
.speak-btn {
    background: none;
    border: none;
    color: var(--color-primary); /* Màu theo chủ đề */
    cursor: pointer;
    padding: 0 5px; /* Thêm chút đệm */
    font-size: 0.9em; /* Kích thước tương đối */
    vertical-align: middle; /* Căn giữa với dòng chữ */
    transition: color 0.2s ease;
}
.speak-btn:hover {
    color: var(--text-primary); /* Đổi màu khi hover */
}
.speak-btn i {
    font-size: 1.1em; /* Làm icon to hơn một chút */
}
/* ============================================= */
/* MODAL CHUNG (THÊM MỚI)
/* ============================================= */
.modal-overlay {
    display: none; /* Ẩn mặc định */
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgba(0,0,0,0.6); /* Nền mờ */
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.3s ease;
}

/* Kích hoạt modal */
.modal-overlay.active {
    display: flex;
    opacity: 1;
}

.modal-content {
    background-color: var(--bg-secondary);
    color: var(--text-primary);
    margin: auto;
    padding: 2rem;
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    box-shadow: var(--shadow-lg);
    width: 90%;
    max-width: 450px; /* Độ rộng tối đa */
    position: relative;
    text-align: center;
    /* Animation khi mở */
    animation: zoomIn 0.3s ease;
}

@keyframes zoomIn {
    from { transform: scale(0.8); opacity: 0; }
    to { transform: scale(1); opacity: 1; }
}

.modal-close-btn {
    color: var(--text-secondary);
    position: absolute;
    top: 10px;
    right: 15px;
    font-size: 24px;
    font-weight: bold;
    cursor: pointer;
    line-height: 1;
    background: none;
    border: none;
}
.modal-close-btn:hover {
    color: var(--color-danger);
}

.modal-icon {
    font-size: 3rem;
    color: var(--color-primary); /* Màu icon chung */
    margin-bottom: 1rem;
}

.modal-title {
    font-size: 1.5rem;
    margin-bottom: 0.5rem;
    color: var(--text-primary);
}

.modal-subtitle {
    color: var(--text-secondary);
    margin-bottom: 1.5rem;
    font-size: 0.95em;
}

.modal-actions {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 20px;
}

.modal-btn {
    padding: 8px 15px;
    border-radius: 5px;
    cursor: pointer;
    border: none;
    font-weight: 600;
    transition: background-color 0.2s ease;
    font-family: var(--font-main);
    font-size: 0.95rem;
}

/* Nút Hủy */
.btn-secondary {
    background-color: #ccc;
    color: #333;
}
.btn-secondary:hover {
    background-color: #bbb;
}
[data-theme="dark"] .btn-secondary {
     background-color: var(--border-color);
     color: var(--text-primary);
}
[data-theme="dark"] .btn-secondary:hover {
     background-color: var(--text-secondary);
}

/* Nút Đăng ký */
.btn-primary {
    background: var(--color-primary);
    color: white;
    text-decoration: none;
}
.btn-primary:hover {
    opacity: 0.9;
}
/* ============================================= */
/* TƯƠNG TÁC TỪ VỰNG (THÊM MỚI)
/* ============================================= */

/* 1. Làm cho từ in đậm trong đoạn văn có thể click */
.clickable-vocab {
    cursor: pointer;
    color: var(--color-primary);
    font-weight: bold;
    text-decoration: none;
    transition: color 0.2s ease, text-decoration 0.2s ease;
}
.clickable-vocab:hover {
    text-decoration: underline;
    color: #1a5fb4; /* Màu đậm hơn */
}
[data-theme="dark"] .clickable-vocab:hover {
    color: #a3c9f7; /* Màu sáng hơn */
}

/* 2. Hiệu ứng highlight khi click */
details.vocab-highlight {
    /* Thêm viền sáng tạm thời */
    box-shadow: 0 0 10px 3px var(--color-vocab-light);
    border-color: var(--color-vocab);
    /* Animation */
    animation: vocabHighlight 1.5s ease-out;
}

@keyframes vocabHighlight {
  from {
    box-shadow: 0 0 10px 3px var(--color-vocab-light);
    border-color: var(--color-vocab);
  }
  to {
    box-shadow: none;
    border-color: var(--border-color);
  }
}

/* Đảm bảo "Vật phẩm chính" cũng có hiệu ứng */
div[style*="border-left-color: var(--color-vocab)"] details.vocab-highlight {
    border-color: var(--color-vocab) !important;
     animation: vocabHighlightMain 1.5s ease-out;
}
@keyframes vocabHighlightMain {
  from {
    box-shadow: 0 0 10px 3px var(--color-vocab);
  }
  to {
    box-shadow: none;
  }
}
/* ============================================= */
/* SỬA LỖI LAYOUT GIỚI TỪ (THÊM MỚI)
/* ============================================= */

/* Style cho <ul> và <li> 
   do hàm formatJsonString() tạo ra 
   khi ở trong thẻ từ vựng
*/
.vocab-details ul {
    /* Bỏ lề và đệm mặc định của trình duyệt */
    margin: 0;
    padding-left: 0; /* Bỏ đệm trái */
    list-style-type: none; /* Bỏ dấu bullet (•) */
}

.vocab-details ul li {
    /* Hiển thị như một đoạn văn bình thường */
    display: block;
    color: var(--text-secondary); /* Đảm bảo màu chữ giống <p> */
    font-size: 0.95em;
    line-height: 1.5;
    margin-bottom: 0.6rem; /* Giống margin của <p> */
}
.vocab-details ul li:last-child {
    margin-bottom: 0;
}

/* Style cho <div> bọc (đã thêm ở PHP) 
   để nhóm "Giới từ:" và danh sách "of"
*/
.vocab-list-group {
    margin-bottom: 0.6rem; /* Thêm margin đáy cho cả nhóm */
}
.vocab-list-group p {
    margin-bottom: 0.2rem; /* Giảm margin của <p> <strong> */
}
.vocab-list-group ul {
    margin-top: 0; /* Bỏ margin top của <ul> */
}
/* ============================================= */
/* NHIỆM VỤ 3: CÂU HỎI TƯƠNG TÁC (THÊM MỚI)
/* ============================================= */

/* 1. Trạng thái ban đầu (chưa trả lời) */
.question-options {
    list-style-type: none;
    padding-left: 0 !important; /* Ghi đè CSS mặc định */
}

/* Ghi đè lại style cũ của .question-options li */
.question-options li {
    background: var(--bg-primary);
    padding: 0.75rem 1rem;
    border: 2px solid var(--border-color); /* Dày hơn 1px 1 chút */
    border-radius: 8px;
    margin-bottom: 0.5rem;
    cursor: pointer;
    transition: var(--transition);
    font-weight: normal !important; /* Hủy bỏ in đậm cũ */
}

.question-options:not(.answered) li:hover {
    background-color: var(--color-primary-light);
    border-color: var(--color-primary);
}

/* 2. Ẩn giải thích ban đầu */
.explanation.explanation-hidden {
    display: none;
}

/* 3. Trạng thái đã trả lời (khóa không cho click nữa) */
.question-options.answered {
    cursor: not-allowed;
}
.question-options.answered li {
    cursor: not-allowed;
    opacity: 0.8;
}
.question-options.answered li:hover {
    background-color: var(--bg-primary); /* Hủy hover */
    border-color: var(--border-color);
}

/* 4. Định dạng các lựa chọn SAU KHI CLICK */

/* Lựa chọn SAI của người dùng (màu đỏ) */
.question-options.answered li.user-wrong {
    background-color: var(--color-danger-light);
    border-color: var(--color-danger);
    color: var(--color-danger);
    font-weight: bold !important;
    opacity: 1;
}

/* Lựa chọn ĐÚNG của người dùng (màu xanh) */
.question-options.answered li.user-correct {
    background-color: var(--color-success-light);
    border-color: var(--color-success);
    color: var(--color-success);
    font-weight: bold !important;
    opacity: 1;
}

/* Đáp án ĐÚNG (hiển thị khi người dùng chọn sai) */
.question-options.answered li.actual-correct {
    /* Vẫn giữ nền xám, chỉ viền xanh */
    border-color: var(--color-success);
    opacity: 1;
}

/* CSS cho phần giải thích khi hiện ra */
.explanation {
    /* Ghi đè style cũ */
    background: var(--bg-primary) !important;
    border: 2px solid var(--color-success) !important;
    color: var(--text-secondary) !important;
    padding: 1rem;
    border-radius: 8px;
    margin-top: 1rem;
    animation: fadeIn 0.5s ease;
}
.explanation strong {
    color: var(--color-success) !important;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}
/* ============================================= */
/* NHIỆM VỤ 4: GRAMMAR TABS (THÊM MỚI)
/* ============================================= */

.grammar-section .grammar-rule-card {
    background-color: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    margin-bottom: 2rem;
    box-shadow: var(--shadow);
    overflow: hidden; /* Needed for border-radius */
}

.grammar-section .grammar-header {
    padding: 1rem 1.5rem;
    border-bottom: 1px solid var(--border-color);
    background-color: var(--bg-primary);
}

.grammar-section .grammar-header h3 {
    margin: 0 0 0.5rem 0;
    font-size: 1.3rem;
    color: var(--text-primary);
}

.grammar-section .grammar-title-en {
    font-size: 0.9em;
    font-weight: normal;
    color: var(--text-secondary);
}

.grammar-section .grammar-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1rem; /* row-gap column-gap */
    font-size: 0.85em;
    color: var(--text-secondary);
}

.grammar-section .meta-item {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}
.grammar-section .meta-item i {
    color: var(--color-primary);
}
/* Ensure CEFR tags in meta look right */
.grammar-section .meta-item .tag {
    margin: 0; /* Override default tag margin */
    padding: 0.1rem 0.5rem;
    font-size: 0.9em;
}


.grammar-section .grammar-description {
    padding: 1rem 1.5rem;
}
.grammar-section .grammar-description p {
    margin-bottom: 0; /* Remove bottom margin if it's the only element */
}


.grammar-section .grammar-tabs {
    display: flex;
    border-bottom: 1px solid var(--border-color);
    background-color: var(--bg-primary); /* Slightly different background */
    padding: 0 1.5rem;
}

.grammar-section .tab-link {
    background-color: transparent;
    border: none;
    border-bottom: 3px solid transparent; /* Placeholder for active border */
    padding: 0.8rem 1rem;
    cursor: pointer;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--text-secondary);
    transition: color 0.2s ease, border-color 0.2s ease;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: -1px; /* Overlap border */
}

.grammar-section .tab-link:hover {
    color: var(--text-primary);
}

.grammar-section .tab-link.active {
    color: var(--color-primary);
    border-bottom-color: var(--color-primary);
}

.grammar-section .tab-link i {
    font-size: 1em;
}

.grammar-section .grammar-tab-content {
    padding: 1.5rem;
}

.grammar-section .tab-pane {
    display: none; /* Hide inactive tabs */
    animation: fadeIn 0.4s ease;
}

.grammar-section .tab-pane.active {
    display: block; /* Show active tab */
}

/* Ensure elements inside tabs have consistent styling */
.grammar-section .tab-pane h4,
.grammar-section .tab-pane h5 {
    margin-top: 0; /* Remove top margin if it's the first element */
    margin-bottom: 0.75rem;
    color: var(--text-primary);
}
.grammar-section .tab-pane p,
.grammar-section .tab-pane ul,
.grammar-section .tab-pane div.error-example {
    color: var(--text-secondary);
    margin-bottom: 1rem;
}
.grammar-section .tab-pane ul li {
     color: var(--text-secondary); /* Ensure list item color */
}
.grammar-section .tab-pane code {
    background-color: var(--bg-primary);
    padding: 0.2em 0.4em;
    border-radius: 4px;
    font-size: 0.9em;
    color: var(--color-danger);
}
[data-theme="dark"] .grammar-section .tab-pane code {
     color: var(--color-danger-light);
}

/* Separator style */
.grammar-separator {
    border: none;
    border-top: 1px dashed var(--border-color);
    margin: 2rem 0; /* More space between cards */
}

/* Ensure error examples from formatJsonString look right */
.grammar-section .tab-pane .error-example {
    border: 1px solid var(--border-color);
    padding: 1rem;
    border-radius: var(--border-radius);
    margin-top: 0.5rem;
    font-size: 0.9em;
    background-color: var(--bg-primary);
}
.grammar-section .tab-pane .error-example p { margin-bottom: 0.5rem; }
.grammar-section .tab-pane .error-example p:last-child { margin-bottom: 0; }
.grammar-section .tab-pane .error-example .wrong {
    color: var(--color-danger);
    text-decoration: line-through;
}
.grammar-section .tab-pane .error-example .right {
    color: var(--color-success);
    font-weight: bold;
}
.grammar-section .tab-pane .error-example strong { color: var(--text-primary); }
/* ============================================= */
/* SỬA LỖI HIỂN THỊ DARK MODE CHO TASK 4 (THÊM MỚI)
/* ============================================= */

[data-theme="dark"] .grammar-section .meta-item .tag {
    /* Đổi màu nền và chữ cho thẻ CEFR */
    background-color: var(--border-color); /* Nền tối hơn */
    color: var(--text-primary); /* Chữ sáng */
}

[data-theme="dark"] .grammar-section .tab-pane code {
    /* Đổi màu nền và chữ cho khối code */
    background-color: var(--bg-primary); /* Nền tối nhất */
    color: var(--color-danger); /* Giữ màu chữ đỏ (hoặc màu khác nếu muốn) */
    border: 1px solid var(--border-color); /* Thêm viền nhẹ */
}

/* Đảm bảo màu chữ trong ví dụ và lỗi sai cũng đúng */
[data-theme="dark"] .grammar-section .tab-pane p,
[data-theme="dark"] .grammar-section .tab-pane ul,
[data-theme="dark"] .grammar-section .tab-pane ul li {
    color: var(--text-secondary);
}

[data-theme="dark"] .grammar-section .tab-pane .error-example {
    background-color: var(--bg-primary);
    border-color: var(--border-color);
}

[data-theme="dark"] .grammar-section .tab-pane .error-example .wrong {
    color: var(--color-danger); /* Giữ màu đỏ */
}

[data-theme="dark"] .grammar-section .tab-pane .error-example .right {
    color: var(--color-success); /* Giữ màu xanh */
}

[data-theme="dark"] .grammar-section .tab-pane .error-example strong {
    color: var(--text-primary); /* Chữ giải thích màu sáng */
}

/* Sửa màu chữ ví dụ và giải thích */
[data-theme="dark"] .grammar-section .tab-pane em,
[data-theme="dark"] .grammar-section .tab-pane small {
     color: var(--text-secondary);
}

/* Sửa màu tag dấu hiệu */
[data-theme="dark"] .grammar-section .tab-pane span.tag.grammar-tag[style*="--color-vocab-light"] {
    background-color: var(--color-vocab-light) !important; /* Ghi đè style inline */
    color: var(--color-vocab) !important;
}
/* ============================================= */
/* NHIỆM VỤ 4: GRAMMAR TABS - CẢI TIẾN (THÊM MỚI)
/* ============================================= */

/* --- Cấu trúc Tab --- */
.grammar-patterns-container {
    /* Container for structure groups */
}

.pattern-group {
    margin-bottom: 1.5rem;
    padding: 1rem;
    background-color: var(--bg-primary); /* Slightly different background for group */
    border-radius: var(--border-radius);
    border: 1px solid var(--border-color);
}
.pattern-group:last-child {
    margin-bottom: 0;
}

.pattern-group-title {
    font-size: 1.1rem;
    color: var(--color-primary);
    margin-top: 0;
    margin-bottom: 0.8rem;
    padding-bottom: 0.4rem;
    border-bottom: 1px dashed var(--border-color);
}

.pattern-list {
    list-style: none;
    padding-left: 0;
    margin: 0;
}

.pattern-list li {
    margin-bottom: 0.5rem;
    display: flex; /* Align code and subtype */
    align-items: baseline;
    gap: 0.5rem;
}
.pattern-list li:last-child {
    margin-bottom: 0;
}

.pattern-structure {
    /* Make the code block larger and stand out */
    font-size: 1.1em; /* Larger font */
    padding: 0.4em 0.6em; /* More padding */
    background-color: var(--bg-secondary); /* Use main bg for contrast */
    border: 1px solid var(--border-color);
    color: var(--text-primary); /* Use primary text color */
    border-radius: 4px;
    display: inline-block; /* Ensure padding works */
}

.pattern-subtype {
    font-size: 0.85em;
    color: var(--text-secondary);
    font-style: italic;
}

/* Dark mode adjustment for structure code */
[data-theme="dark"] .pattern-group {
     background-color: var(--bg-secondary);
     border-color: var(--border-color);
}
[data-theme="dark"] .pattern-structure {
     background-color: var(--bg-primary);
     border-color: var(--border-color);
     color: var(--text-primary);
}


/* --- Cách dùng Tab --- */
.grammar-usage-list {
    list-style: none;
    padding-left: 0;
    margin: 0;
}

.grammar-usage-list li {
    margin-bottom: 1.2rem;
    padding-left: 1rem;
    border-left: 3px solid var(--color-primary); /* Add a visual indicator */
}
.grammar-usage-list li:last-child {
    margin-bottom: 0;
}

.usage-description {
    margin-bottom: 0.3rem; /* Less space before example */
    color: var(--text-primary); /* Make usage description primary color */
    font-weight: 500;
}

.usage-example {
    font-size: 0.95em;
    color: var(--text-secondary);
    margin-bottom: 0; /* Remove default p margin */
}
.usage-example em {
    font-style: normal; /* Make example text normal */
}
[data-theme="dark"] .usage-description {
     color: var(--text-primary);
}

/* --- General Tab Pane Adjustments --- */
.grammar-section .tab-pane {
    line-height: 1.7; /* Increase line height slightly */
}
/* ============================================= */
/* NHIỆM VỤ 4: GRAMMAR EXAMPLES ACTIONS (THÊM MỚI)
/* ============================================= */

.grammar-example-list {
    list-style: none;
    padding-left: 0;
    margin: 0;
}

.grammar-example-list li {
    margin-bottom: 1.5rem; /* More space between examples */
    padding-left: 1rem;
    border-left: 3px solid var(--color-primary-light);
    position: relative; /* Needed for absolute positioning if desired */
}
.grammar-example-list li:last-child {
    margin-bottom: 0;
}

/* Style for text parts */
.example-english-text {
    margin-bottom: 0.3rem;
    font-weight: 500;
    color: var(--text-primary);
}
.example-vietnamese-text {
    margin-bottom: 0.3rem;
    font-size: 0.9em;
    color: var(--text-secondary);
}
.example-explanation-text {
    margin-bottom: 0.5rem; /* Space before buttons */
    font-size: 0.85em;
    color: var(--text-secondary);
}

/* Container for buttons */
.example-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem; /* Space between buttons */
    margin-top: 0.5rem;
}

/* Style adjustments for buttons inside examples */
.example-actions .speak-btn {
    padding: 4px 8px;
    border: 1px solid var(--border-color);
    border-radius: 5px;
    background-color: var(--bg-primary);
    font-size: 0.85em; /* Match action-btn size */
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}
.example-actions .speak-btn:hover {
    background-color: var(--color-primary-light);
    border-color: var(--color-primary);
}

.example-actions .action-btn {
    padding: 4px 8px; /* Consistent padding */
    font-size: 0.85em; /* Consistent font size */
    gap: 0.3rem;
}

/* Dark mode adjustments */
[data-theme="dark"] .example-english-text {
    color: var(--text-primary);
}
[data-theme="dark"] .example-vietnamese-text,
[data-theme="dark"] .example-explanation-text {
    color: var(--text-secondary);
}
[data-theme="dark"] .example-actions .speak-btn {
    background-color: var(--bg-secondary);
    border-color: var(--border-color);
}
[data-theme="dark"] .example-actions .speak-btn:hover {
    background-color: var(--color-primary-light);
    border-color: var(--color-primary);
    color: var(--color-primary); /* Ensure icon/text color changes on hover */
}
/* ============================================= */
/* NHIỆM VỤ 4: GRAMMAR STRUCTURE TABLE (THÊM MỚI)
/* ============================================= */

.grammar-patterns-table-container {
    overflow-x: auto; /* Allow horizontal scrolling on small screens */
    margin-top: 1rem;
}

.grammar-patterns-table {
    width: 100%;
    border-collapse: collapse;
    border: 1px solid var(--border-color);
    font-size: 0.95em; /* Slightly smaller font for table */
}

.grammar-patterns-table thead {
    background-color: var(--bg-primary); /* Header background */
    border-bottom: 2px solid var(--border-color);
}

.grammar-patterns-table th {
    padding: 0.75rem 1rem;
    text-align: left;
    font-weight: 600;
    color: var(--text-primary);
}

.grammar-patterns-table tbody tr {
    border-bottom: 1px solid var(--border-color);
}
.grammar-patterns-table tbody tr:last-child {
    border-bottom: none;
}
/* Alternate row background */
.grammar-patterns-table tbody tr:nth-child(even) {
    background-color: var(--bg-primary);
}

.grammar-patterns-table td {
    padding: 0.75rem 1rem;
    vertical-align: top; /* Align content to the top */
    color: var(--text-secondary);
}

/* Styling for specific cells */
.pattern-type-cell strong {
    color: var(--color-primary); /* Highlight main type */
}

.pattern-condition-cell {
    /* Style for the condition/specific type column if needed */
     font-style: italic; /* Example style */
}

.pattern-structure-cell code {
    /* Larger font, clear background */
    font-size: 1.1em;
    padding: 0.3em 0.5em;
    background-color: var(--bg-secondary);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
    border-radius: 4px;
    display: inline-block;
    line-height: 1.4;
    white-space: pre-wrap; /* Allow long structures to wrap */
    word-break: break-word;
}

/* Dark Mode Adjustments for Table */
[data-theme="dark"] .grammar-patterns-table {
    border-color: var(--border-color);
}
[data-theme="dark"] .grammar-patterns-table thead {
    background-color: var(--bg-secondary); /* Darker header */
    border-bottom-color: var(--border-color);
}
[data-theme="dark"] .grammar-patterns-table th {
    color: var(--text-primary);
}
[data-theme="dark"] .grammar-patterns-table tbody tr {
    border-bottom-color: var(--border-color);
}
[data-theme="dark"] .grammar-patterns-table tbody tr:nth-child(even) {
    background-color: var(--bg-secondary); /* Darker alternate row */
}
[data-theme="dark"] .grammar-patterns-table td {
    color: var(--text-secondary);
}
[data-theme="dark"] .pattern-type-cell strong {
    color: var(--color-primary); /* Keep highlight color */
}
[data-theme="dark"] .pattern-structure-cell code {
     background-color: var(--bg-primary); /* Darkest bg */
     border-color: var(--border-color);
     color: var(--text-primary);
}
/* ============================================= */
/* NHIỆM VỤ 5: RELATED STORY REDESIGN (THÊM MỚI)
/* ============================================= */

.related-story-card {
    background-color: var(--bg-primary); /* Slightly different background */
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    padding: 1.5rem;
    margin-top: 1rem; /* Space from intro text */
}

/* Two-column layout for story details on wider screens */
.story-details {
    display: flex;
    flex-direction: column; /* Stack image and info by default */
    gap: 1.5rem;
}

@media (min-width: 768px) { /* Apply columns on medium screens and up */
    .story-details {
        flex-direction: row; /* Side-by-side */
        align-items: flex-start; /* Align items top */
    }
    .story-image {
        flex: 1; /* Image takes up 1 part */
        max-width: 250px; /* Limit image width */
        margin-bottom: 0; /* Remove bottom margin when in columns */
    }
    .story-info {
        flex: 2; /* Text takes up 2 parts */
    }
}

/* Image styling */
.story-image {
    height: auto; /* Allow height to adjust */
    max-height: 200px; /* Limit max height */
    margin-bottom: 1rem; /* Space below image on mobile */
}
.story-image .full-width-placeholder {
     border-radius: var(--border-radius); /* Apply border radius to image */
}
/* Ensure fallback logo looks okay in this context */
.story-image.image-load-failed {
    height: 200px; /* Maintain height for fallback */
    background-color: var(--bg-secondary); /* Use card bg for fallback */
}
.story-image.image-load-failed::after {
    width: 60px; height: 60px; opacity: 0.2;
}

/* Story info styling */
.story-info h4 {
    margin-top: 0;
    margin-bottom: 0.5rem;
    font-size: 1.2rem;
    color: var(--text-primary);
}

.story-meta-tags {
    margin-bottom: 1rem;
}
.story-meta-tags .tag {
    font-size: 0.8em;
}

.story-content-quote {
    background-color: var(--bg-secondary); /* Use card background */
    border-left: 4px solid var(--color-primary); /* Primary color border */
    margin: 0; /* Override default blockquote margin */
    padding: 1rem;
    font-size: 0.95rem;
    line-height: 1.6;
    color: var(--text-secondary);
    white-space: pre-line; /* Keep line breaks */
    border-radius: 0 var(--border-radius) var(--border-radius) 0; /* Rounded corners */
}

/* Extended Vocabulary Section */
.extended-vocab-section {
    margin-top: 2rem; /* Space between story and vocab */
    padding-top: 1.5rem;
    border-top: 1px dashed var(--border-color); /* Separator */
}

.extended-vocab-title {
    font-size: 1.1rem;
    color: var(--text-primary);
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.extended-vocab-title i {
    color: var(--color-vocab);
}

/* Ensure vocab cards inside Task 5 look consistent */
.extended-vocab-section .vocab-card details {
    background-color: var(--bg-secondary); /* Use card background */
}
.extended-vocab-section .vocab-card summary {
    background-color: var(--bg-primary); /* Use section background */
}

/* Dark mode adjustments */
[data-theme="dark"] .related-story-card {
    background-color: var(--bg-secondary); /* Use darker background */
    border-color: var(--border-color);
}
[data-theme="dark"] .story-image.image-load-failed {
    background-color: var(--bg-primary);
}
[data-theme="dark"] .story-content-quote {
    background-color: var(--bg-primary); /* Darker quote background */
    border-left-color: var(--color-primary);
    color: var(--text-secondary);
}
[data-theme="dark"] .extended-vocab-section {
    border-top-color: var(--border-color);
}
[data-theme="dark"] .extended-vocab-title {
    color: var(--text-primary);
}
[data-theme="dark"] .extended-vocab-section .vocab-card details {
    background-color: var(--bg-primary);
}
[data-theme="dark"] .extended-vocab-section .vocab-card summary {
    background-color: var(--bg-secondary);
}
/* ============================================= */
/* NÚT ĐỌC ĐOẠN VĂN (TASK 1) (THÊM MỚI)
/* ============================================= */

.speak-passage-btn {
    background-color: var(--color-primary-light);
    color: var(--color-primary);
    border: 1px solid var(--border-color);
    padding: 5px 10px; /* Nhỏ hơn nút action */
    border-radius: 5px;
    cursor: pointer;
    font-size: 0.85em;
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    margin-left: 1rem; /* Khoảng cách với tiêu đề task */
    order: 1; /* Đẩy sang bên phải tiêu đề */
}

.step-header {
    /* Đảm bảo flex hoạt động đúng */
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.step-header h3 {
    order: 0; /* Giữ tiêu đề bên trái */
    margin-right: auto; /* Đẩy các nút sang phải */
}

.step-header .step-status {
    order: 2; /* Đẩy trạng thái sang phải cùng */
    margin-left: 1rem;
}


.speak-passage-btn:hover {
    background-color: var(--color-primary);
    color: white;
    border-color: var(--color-primary);
}

/* Kiểu khi đang đọc */
.speak-passage-btn.speaking {
    background-color: var(--color-danger);
    border-color: var(--color-danger);
    color: white;
}

[data-theme="dark"] .speak-passage-btn {
    background-color: var(--bg-secondary);
    border-color: var(--border-color);
    color: var(--color-primary);
}
[data-theme="dark"] .speak-passage-btn:hover {
    background-color: var(--color-primary);
    color: var(--bg-primary); /* Chữ tối trên nền sáng */
    border-color: var(--color-primary);
}
[data-theme="dark"] .speak-passage-btn.speaking {
    background-color: var(--color-danger);
    border-color: var(--color-danger);
    color: white;
}
/* ============================================= */
/* FOOTER (THÊM MỚI)
/* ============================================= */

.page-footer {
    background-color: var(--bg-secondary); /* Nền giống header */
    color: var(--text-secondary); /* Chữ màu phụ */
    text-align: center;
    padding: 1.5rem 1rem;
    margin-top: 2rem; /* Khoảng cách với nội dung bên trên */
    font-size: 0.85em; /* Chữ nhỏ hơn */
    border-top: 1px solid var(--border-color); /* Đường kẻ nhẹ phân cách */
}

.page-footer p {
    margin-bottom: 0.3rem; /* Giảm khoảng cách giữa các dòng */
    color: var(--text-secondary); /* Đảm bảo màu chữ */
}

.page-footer p:last-child {
    margin-bottom: 0;
}

/* Dark mode */
[data-theme="dark"] .page-footer {
     background-color: var(--bg-secondary);
     border-top-color: var(--border-color);
     color: var(--text-secondary);
}
[data-theme="dark"] .page-footer p {
     color: var(--text-secondary);
}
