/* ===================================
   主題配色系統
   =================================== */

/* 預設主題（漸層紫色 - 原有的） */
:root {
    --primary-color: #667eea;
    --primary-dark: #764ba2;
    --secondary-color: #f093fb;
    --background: #f5f5f5;
    --surface: #ffffff;
    --surface-hover: #f8f9fa;
    --text-primary: #333333;
    --text-secondary: #666666;
    --text-tertiary: #999999;
    --border-color: #e0e0e0;
    --success: #28a745;
    --danger: #dc3545;
    --warning: #ffc107;
    --info: #17a2b8;
    --chart-bg: #ffffff;
    --chart-grid: #f0f0f0;
    --chart-text: #333333;
    --chart-candle-up: #ef5350;
    --chart-candle-down: #26a69a;
    --chart-area-line: #2962ff;
    --chart-area-top: rgba(41, 98, 255, 0.35);
    --chart-area-bottom: rgba(41, 98, 255, 0.05);
}

/* ===================================
   深色主題 (Dark Mode)
   =================================== */
[data-theme="dark"] {
    --primary-color: #667eea;
    --primary-dark: #764ba2;
    --secondary-color: #f093fb;
    --background: #1a1a1a;
    --surface: #2d2d2d;
    --surface-hover: #3a3a3a;
    --text-primary: #e8e8e8;
    --text-secondary: #b8b8b8;
    --text-tertiary: #888888;
    --border-color: #404040;
    --success: #4caf50;
    --danger: #f44336;
    --warning: #ff9800;
    --info: #2196f3;
    --chart-bg: #1e1e1e;
    --chart-grid: #2a2a2a;
    --chart-text: #e8e8e8;
    --chart-candle-up: #ef5350;
    --chart-candle-down: #26a69a;
    --chart-area-line: #7cb7ff;
    --chart-area-top: rgba(124, 183, 255, 0.32);
    --chart-area-bottom: rgba(124, 183, 255, 0.08);
}

/* ===================================
   淺色主題 (Light Mode)
   =================================== */
[data-theme="light"] {
    --primary-color: #2196f3;
    --primary-dark: #1976d2;
    --secondary-color: #64b5f6;
    --background: #fafafa;
    --surface: #ffffff;
    --surface-hover: #f5f5f5;
    --text-primary: #212121;
    --text-secondary: #757575;
    --text-tertiary: #9e9e9e;
    --border-color: #e0e0e0;
    --success: #4caf50;
    --danger: #f44336;
    --warning: #ff9800;
    --info: #2196f3;
    --chart-bg: #ffffff;
    --chart-grid: #f5f5f5;
    --chart-text: #212121;
    --chart-candle-up: #f44336;
    --chart-candle-down: #4caf50;
    --chart-area-line: #1976d2;
    --chart-area-top: rgba(25, 118, 210, 0.28);
    --chart-area-bottom: rgba(25, 118, 210, 0.06);
}

/* ===================================
   無印良品風 (Muji Style)
   =================================== */
[data-theme="muji"] {
    --primary-color: #8b7355;
    --primary-dark: #6b5544;
    --secondary-color: #c9b8a3;
    --background: #f5f3f0;
    --surface: #ffffff;
    --surface-hover: #faf9f7;
    --text-primary: #3e3e3e;
    --text-secondary: #6e6e6e;
    --text-tertiary: #9e9e9e;
    --border-color: #e8e4df;
    --success: #7c9473;
    --danger: #c85a54;
    --warning: #d4a574;
    --info: #7b99a8;
    --chart-bg: #ffffff;
    --chart-grid: #f5f3f0;
    --chart-text: #3e3e3e;
    --chart-candle-up: #c85a54;
    --chart-candle-down: #7c9473;
    --chart-area-line: #8b7355;
    --chart-area-top: rgba(139, 115, 85, 0.28);
    --chart-area-bottom: rgba(139, 115, 85, 0.06);
}

/* ===================================
   主題切換器樣式
   =================================== */
.theme-switcher {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 1000;
    background: var(--surface);
    border-radius: 12px;
    padding: 12px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    border: 2px solid var(--border-color);
    display: flex;
    gap: 8px;
}

.theme-btn {
    width: 40px;
    height: 40px;
    border-radius: 8px;
    border: 2px solid var(--border-color);
    cursor: pointer;
    transition: all 0.3s;
    position: relative;
    overflow: hidden;
}

.theme-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

.theme-btn.active {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.2);
}

.theme-btn[data-theme="default"] {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
}

.theme-btn[data-theme="dark"] {
    background: #1a1a1a;
}

.theme-btn[data-theme="light"] {
    background: linear-gradient(135deg, #e3f2fd 0%, #bbdefb 100%);
}

.theme-btn[data-theme="muji"] {
    background: linear-gradient(135deg, #f5f3f0 0%, #c9b8a3 100%);
}

/* 主題名稱提示 */
.theme-btn::after {
    content: attr(data-label);
    position: absolute;
    bottom: -30px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--surface);
    color: var(--text-primary);
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 12px;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s;
    border: 1px solid var(--border-color);
}

.theme-btn:hover::after {
    opacity: 1;
}

/* ===================================
   應用主題變數到現有元素
   =================================== */
body {
    background: var(--background);
    color: var(--text-primary);
}

.container {
    background: var(--surface);
}

.header {
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-dark) 100%);
}

.search-bar input {
    background: var(--surface);
    border-color: var(--border-color);
    color: var(--text-primary);
}

.search-bar input:focus {
    border-color: var(--primary-color);
}

.project-card {
    background: var(--surface);
    border-color: var(--border-color);
}

.project-card:hover {
    border-color: var(--primary-color);
    background: var(--surface-hover);
}

.project-card::before {
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-dark) 100%);
}

.project-meta {
    color: var(--text-secondary);
}

.stat-label {
    color: var(--text-tertiary);
}

.stat-positive {
    color: var(--success);
}

.stat-negative {
    color: var(--danger);
}

.stat-neutral {
    color: var(--text-primary);
}

.controls {
    background: var(--surface-hover);
    border-color: var(--border-color);
}

.control-group label {
    color: var(--text-secondary);
}

.control-group select {
    background: var(--surface);
    border-color: var(--border-color);
    color: var(--text-primary);
}

.control-group select:focus {
    border-color: var(--primary-color);
}

.chart-section {
    background: var(--surface-hover);
}

.chart-section h2 {
    color: var(--text-primary);
}

.chart {
    background: var(--chart-bg);
    border-color: var(--border-color);
}

.loading, .error {
    color: var(--text-secondary);
}

.error {
    color: var(--danger);
}

/* ===================================
   深色主題特殊調整
   =================================== */
[data-theme="dark"] .btn-refresh,
[data-theme="dark"] .btn-back {
    background: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .btn-refresh:hover,
[data-theme="dark"] .btn-back:hover {
    background: rgba(255, 255, 255, 0.2);
}

[data-theme="dark"] .info-item {
    background: rgba(255, 255, 255, 0.1);
}

/* 深色主題：卡片標題改為白色 */
[data-theme="dark"] .project-title {
    color: #ffffff;
}

/* 深色主題：商品名稱改為淺藍色（更醒目） */
[data-theme="dark"] .project-meta span {
    color: #64b5f6;
}

/* 深色主題：移除搜尋欄下方的白線 */
[data-theme="dark"] .search-bar {
    border-bottom-color: transparent;
}

/* ===================================
   無印良品風特殊調整
   =================================== */
[data-theme="muji"] .header {
    background: linear-gradient(135deg, #8b7355 0%, #6b5544 100%);
}

[data-theme="muji"] .project-card::before {
    background: #8b7355;
}

[data-theme="muji"] .btn-refresh,
[data-theme="muji"] .btn-back {
    background: rgba(139, 115, 85, 0.1);
}

[data-theme="muji"] .btn-refresh:hover,
[data-theme="muji"] .btn-back:hover {
    background: rgba(139, 115, 85, 0.2);
}

/* ===================================
   平滑過渡動畫
   =================================== */
* {
    transition: background-color 0.3s ease,
                color 0.3s ease,
                border-color 0.3s ease;
}

/* 避免過渡動畫影響某些元素 */
.loading::after,
.theme-btn {
    transition: none;
}

.theme-btn {
    transition: transform 0.3s, box-shadow 0.3s;
}
