/* 主题变量 */

:root {
    /* 亮色主题变量 */
    --bg-color-light: #ffffff;
    --text-color-light: #2d3436;
    --heading-color-light: #4834d4;
    --primary-color-light: #4834d4;
    --primary-dark-light: #3c2aa8;
    --card-bg-light: #ffffff;
    --card-hover-bg-light: #f8f9fa;
    --border-color-light: rgba(0, 0, 0, 0.1);
    --shadow-color-light: rgba(0, 0, 0, 0.1);
    --text-secondary-light: #636e72;
    --feature-bg-light: rgba(72, 52, 212, 0.05);
    --nav-bg-light: rgba(255, 255, 255, 0.95);
    --footer-bg-light: #f8f9fa;
    --link-color-light: #4834d4;
    --link-hover-color-light: #3c2aa8;
    --button-text-light: #ffffff;
    --button-bg-light: #4834d4;
    --button-hover-bg-light: #3c2aa8;
    --card-shadow-light: 0 4px 20px rgba(0, 0, 0, 0.08);
    --card-hover-shadow-light: 0 8px 30px rgba(0, 0, 0, 0.12);
    /* 深色主题变量 */
    --bg-color-dark: #1a1a1a;
    --text-color-dark: #ffffff;
    --heading-color-dark: #ffffff;
    --primary-color-dark: #686de0;
    --primary-dark-dark: #4834d4;
    --card-bg-dark: #2d3436;
    --card-hover-bg-dark: #34495e;
    --border-color-dark: rgba(255, 255, 255, 0.1);
    --shadow-color-dark: rgba(0, 0, 0, 0.2);
    --text-secondary-dark: #b2bec3;
    --feature-bg-dark: rgba(104, 109, 224, 0.1);
    --nav-bg-dark: rgba(26, 26, 26, 0.95);
    --footer-bg-dark: #1a1a1a;
    --link-color-dark: #686de0;
    --link-hover-color-dark: #4834d4;
    --button-text-dark: #ffffff;
    --button-bg-dark: #686de0;
    --button-hover-bg-dark: #4834d4;
    --card-shadow-dark: 0 4px 20px rgba(0, 0, 0, 0.2);
    --card-hover-shadow-dark: 0 8px 30px rgba(0, 0, 0, 0.3);
}


/* 主题切换过渡效果 */

body {
    transition: background-color 0.3s ease, color 0.3s ease;
}


/* 亮色主题 */

[data-theme="light"] {
    --bg-color: var(--bg-color-light);
    --text-color: var(--text-color-light);
    --heading-color: var(--heading-color-light);
    --primary-color: var(--primary-color-light);
    --primary-dark: var(--primary-dark-light);
    --card-bg: var(--card-bg-light);
    --card-hover-bg: var(--card-hover-bg-light);
    --border-color: var(--border-color-light);
    --shadow-color: var(--shadow-color-light);
    --text-secondary: var(--text-secondary-light);
    --feature-bg: var(--feature-bg-light);
    --nav-bg: var(--nav-bg-light);
    --footer-bg: var(--footer-bg-light);
    --link-color: var(--link-color-light);
    --link-hover-color: var(--link-hover-color-light);
    --button-text: var(--button-text-light);
    --button-bg: var(--button-bg-light);
    --button-hover-bg: var(--button-hover-bg-light);
    --card-shadow: var(--card-shadow-light);
    --card-hover-shadow: var(--card-hover-shadow-light);
}


/* 深色主题 */

[data-theme="dark"] {
    --bg-color: var(--bg-color-dark);
    --text-color: var(--text-color-dark);
    --heading-color: var(--heading-color-dark);
    --primary-color: var(--primary-color-dark);
    --primary-dark: var(--primary-dark-dark);
    --card-bg: var(--card-bg-dark);
    --card-hover-bg: var(--card-hover-bg-dark);
    --border-color: var(--border-color-dark);
    --shadow-color: var(--shadow-color-dark);
    --text-secondary: var(--text-secondary-dark);
    --feature-bg: var(--feature-bg-dark);
    --nav-bg: var(--nav-bg-dark);
    --footer-bg: var(--footer-bg-dark);
    --link-color: var(--link-color-dark);
    --link-hover-color: var(--link-hover-color-dark);
    --button-text: var(--button-text-dark);
    --button-bg: var(--button-bg-dark);
    --button-hover-bg: var(--button-hover-bg-dark);
    --card-shadow: var(--card-shadow-dark);
    --card-hover-shadow: var(--card-hover-shadow-dark);
}


/* 主题切换按钮样式 */

.theme-switch {
    position: relative;
    display: inline-flex;
    align-items: center;
}

#themeToggle {
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0.5rem;
    border-radius: 50%;
    transition: all 0.3s ease;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
}

[data-theme="light"] #themeToggle {
    color: var(--text-color);
    background: var(--feature-bg);
}

[data-theme="dark"] #themeToggle {
    color: var(--text-color);
    background: var(--feature-bg);
}

#themeToggle:hover {
    transform: scale(1.1);
    background: var(--primary-color);
    color: white;
}

.theme-icon {
    font-size: 1.2rem;
    transition: transform 0.3s ease;
}

#themeToggle:hover .theme-icon {
    transform: rotate(360deg);
}


/* 主题切换动画 */

@keyframes themeTransition {
    from {
        opacity: 0;
        transform: scale(0.95);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

[data-theme] {
    animation: themeTransition 0.3s ease-out forwards;
}


/* 全局过渡效果 */

* {
    transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}