/* 主题样式 */

/* 亮色主题 */
.light-theme {
    --bg-color: #ffffff;
    --text-color: #333333;
    --primary-color: #4a90e2;
    --secondary-color: #f5f5f5;
    --border-color: rgba(0, 0, 0, 0.1);
    --hover-color: rgba(0, 0, 0, 0.05);
    --shadow-color: rgba(0, 0, 0, 0.1);
    --correct-color: #4caf50;
    --incorrect-color: #f44336;
    --header-bg: #ffffff;
    --sidebar-bg: #ffffff;
    --content-bg: #ffffff;
    --modal-bg: #ffffff;
    --btn-text: #ffffff;
}

/* 暗色主题 */
.dark-theme {
    --bg-color: #1f1f1f;
    --text-color: #e0e0e0;
    --primary-color: #64b5f6;
    --secondary-color: #333333;
    --border-color: rgba(255, 255, 255, 0.1);
    --hover-color: rgba(255, 255, 255, 0.05);
    --shadow-color: rgba(0, 0, 0, 0.3);
    --correct-color: #81c784;
    --incorrect-color: #e57373;
    --header-bg: #272727;
    --sidebar-bg: #272727;
    --content-bg: #1f1f1f;
    --modal-bg: #272727;
    --btn-text: #ffffff;
}

/* 应用主题变量 */
body {
    background-color: var(--bg-color);
    color: var(--text-color);
}

header {
    background-color: var(--header-bg);
    border-bottom: 1px solid var(--border-color);
}

.nav-btn {
    background-color: var(--secondary-color);
    color: var(--text-color);
}

.nav-btn:hover {
    background-color: var(--hover-color);
}

#sidebar {
    background-color: var(--sidebar-bg);
    border-right: 1px solid var(--border-color);
}

.sidebar-header {
    border-bottom: 1px solid var(--border-color);
}

.subject-item:hover, .chapter-item:hover {
    background-color: var(--hover-color);
}

#content {
    background-color: var(--content-bg);
}

.section-title {
    border-bottom: 1px solid var(--border-color);
}

.choice-option, .connection-item, .true-false-option {
    border: 1px solid var(--border-color);
}

.choice-option:hover, .connection-item:hover, .true-false-option:hover {
    background-color: var(--hover-color);
}

.choice-option.selected, .connection-item.selected, .true-false-option.selected {
    border-color: var(--primary-color);
    background-color: rgba(var(--primary-color-rgb), 0.1);
}

.choice-option.correct, .connection-item.connected, .true-false-option.correct {
    border-color: var(--correct-color);
    background-color: rgba(var(--correct-color-rgb), 0.1);
}

.choice-option.incorrect, .true-false-option.incorrect {
    border-color: var(--incorrect-color);
    background-color: rgba(var(--incorrect-color-rgb), 0.1);
}

.short-answer textarea {
    background-color: var(--bg-color);
    color: var(--text-color);
    border: 1px solid var(--border-color);
}

.short-answer textarea:focus {
    border-color: var(--primary-color);
}

.primary-btn {
    background-color: var(--primary-color);
    color: var(--btn-text);
}

.primary-btn:hover {
    background-color: var(--primary-color-dark);
}

.secondary-btn {
    background-color: var(--secondary-color);
    color: var(--text-color);
}

.secondary-btn:hover {
    background-color: var(--hover-color);
}

footer {
    background-color: var(--header-bg);
    border-top: 1px solid var(--border-color);
}

.modal-content {
    background-color: var(--modal-bg);
    color: var(--text-color);
    box-shadow: 0 4px 15px var(--shadow-color);
}

.voice-status {
    background-color: var(--modal-bg);
    color: var(--text-color);
    box-shadow: 0 3px 10px var(--shadow-color);
}

/* 修复一些颜色变量 */
:root {
    --primary-color-rgb: 74, 144, 226;
    --primary-color-dark: #3a7bc8;
    --correct-color-rgb: 76, 175, 80;
    --incorrect-color-rgb: 244, 67, 54;
}

.dark-theme {
    --primary-color-rgb: 100, 181, 246;
    --primary-color-dark: #4a90e2;
    --correct-color-rgb: 129, 199, 132;
    --incorrect-color-rgb: 229, 115, 115;
}