/* ===== FastAdmin 自定义样式优化 ===== */

/* ===== CSS 变量定义 ===== */
:root {
  /* 默认主题色彩系统 */
  --blue-50: #f0f9ff;
  --blue-100: #e0f2fe;
  --blue-200: #bae6fd;
  --blue-300: #7dd3fc;
  --blue-400: #38bdf8;
  --blue-500: #0ea5e9;
  --blue-600: #0284c7;
  --blue-700: #0369a1;
  --blue-800: #075985;
  --blue-900: #0c4a6e;
  
  --orange-50: #fffbeb;
  --orange-100: #fef3c7;
  --orange-200: #fde68a;
  --orange-300: #fcd34d;
  --orange-400: #fbbf24;
  --orange-500: #f59e0b;
  --orange-600: #d97706;
  --orange-700: #b45309;
  --orange-800: #92400e;
  --orange-900: #78350f;
  
  --neutral-50: #fafafa;
  --neutral-100: #f4f4f5;
  --neutral-200: #e4e4e7;
  --neutral-300: #d4d4d8;
  --neutral-400: #a1a1aa;
  --neutral-500: #71717a;
  --neutral-600: #52525b;
  --neutral-700: #3f3f46;
  --neutral-800: #27272a;
  --neutral-900: #18181b;
  
  --success: #10b981;
  --warning: var(--orange-500);
  --danger: #ef4444;
  --info: var(--blue-500);
  
  --primary: var(--blue-600);
  --secondary: var(--neutral-600);
  --accent: var(--orange-500);
  
  /* 间距系统 */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  
  /* 阴影系统 */
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  
  /* 圆角系统 */
  --radius: 0.375rem;
  --radius-lg: 0.5rem;
  --radius-xl: 0.75rem;
}

/* ===== 深色主题变量 ===== */
[data-theme="dark"] {
  --neutral-50: #0f172a;
  --neutral-100: #1a1d23;
  --neutral-200: #2a2e35;
  --neutral-300: #3a3e45;
  --neutral-400: #5a5e65;
  --neutral-500: #7a7e85;
  --neutral-600: #9a9ea5;
  --neutral-700: #babec5;
  --neutral-800: #dadede;
  --neutral-900: #f8fafc;
  
  --blue-400: #5d9cff;
  --blue-500: #3b82f6;
  --orange-400: #ff8c42;
  --orange-500: #ff6b35;
  --success: #34d399;
  
  --primary: var(--blue-400);
  --secondary: var(--neutral-500);
  --accent: var(--orange-400);
}
/* ===== FastAdmin 通用CSS参数系统 ===== */
/* 版本: 1.0 | 最后更新: 2024年 */

/* ===== 色彩系统 ===== */
:root {
  /* 主色调 - 青蓝色系 */
    --qns-1: rgba(240, 249, 255, 0.1);
    --qns-2: rgba(240, 249, 255, 0.2);
    --qns-3: rgba(240, 249, 255, 0.3);
    --qns-4: rgba(240, 249, 255, 0.4);
  --qns-5: rgba(240, 249, 255, 0.5);
  --qns-10: rgba(224, 242, 254, 0.5);
  --qns-20: rgba(186, 230, 253, 0.5);
  
  --primary-50: #f0f9ff;
  --primary-100: #e0f2fe;
  --primary-200: #bae6fd;
  --primary-300: #7dd3fc;
  --primary-400: #38bdf8;
  --primary-500: #0ea5e9;
  --primary-600: #0284c7;
  --primary-700: #0369a1;
  --primary-800: #075985;
  --primary-900: #0c4a6e;
  
  /* 辅色调 - 橙色系 */
  --accent-50: #fffbeb;
  --accent-100: #fef3c7;
  --accent-200: #fde68a;
  --accent-300: #fcd34d;
  --accent-400: #fbbf24;
  --accent-500: #f59e0b;
  --accent-600: #d97706;
  --accent-700: #b45309;
  --accent-800: #92400e;
  --accent-900: #78350f;
  
  /* 中性色调 - 黑白灰 */
  --neutral-50: #fafafa;
  --neutral-100: #f4f4f5;
  --neutral-200: #e4e4e7;
  --neutral-300: #d4d4d8;
  --neutral-400: #a1a1aa;
  --neutral-500: #71717a;
  --neutral-600: #52525b;
  --neutral-700: #3f3f46;
  --neutral-800: #27272a;
  --neutral-900: #18181b;
  
  /* 功能色 */
  --success-50: #ecfdf5;
  --success-100: #d1fae5;
  --success-200: #a7f3d0;
  --success-300: #6ee7b7;
  --success-400: #34d399;
  --success-500: #10b981;
  --success-600: #059669;
  --success-700: #047857;
  --success-800: #065f46;
  --success-900: #064e3b;
  
  --warning-50: #fffbeb;
  --warning-100: #fef3c7;
  --warning-200: #fde68a;
  --warning-300: #fcd34d;
  --warning-400: #fbbf24;
  --warning-500: #f59e0b;
  --warning-600: #d97706;
  --warning-700: #b45309;
  --warning-800: #92400e;
  --warning-900: #78350f;
  
  --danger-50: #fef2f2;
  --danger-100: #fee2e2;
  --danger-200: #fecaca;
  --danger-300: #fca5a5;
  --danger-400: #f87171;
  --danger-500: #ef4444;
  --danger-600: #dc2626;
  --danger-700: #b91c1c;
  --danger-800: #991b1b;
  --danger-900: #7f1d1d;
  
  --info-50: #f0f9ff;
  --info-100: #e0f2fe;
  --info-200: #bae6fd;
  --info-300: #7dd3fc;
  --info-400: #38bdf8;
  --info-500: #0ea5e9;
  --info-600: #0284c7;
  --info-700: #0369a1;
  --info-800: #075985;
  --info-900: #0c4a6e;
} 

/* ===== 语义化颜色变量 ===== */
:root {
  /* 主色调 */
  --primary: var(--primary-600);
  --primary-light: var(--primary-500);
  --primary-dark: var(--primary-700);
  
  /* 辅色调 */
  --accent: var(--accent-500);
  --accent-light: var(--accent-400);
  --accent-dark: var(--accent-600);
  
  /* 中性色 */
  --background: var(--neutral-50);
  --surface: white;
  --text-primary: var(--neutral-800);
  --text-secondary: var(--neutral-600);
  --text-muted: var(--neutral-500);
  --border: var(--neutral-200);
  --divider: var(--neutral-300);
  
  /* 功能色 */
  --success: var(--success-500);
  --warning: var(--warning-500);
  --danger: var(--danger-500);
  --info: var(--info-500);
}

/* ===== 间距系统 ===== */
:root {
  /* 基础间距 */
  --space-1: 0.25rem;   /* 4px */
  --space-2: 0.5rem;    /* 8px */
  --space-3: 0.75rem;   /* 12px */
  --space-4: 1rem;      /* 16px */
  --space-5: 1.25rem;   /* 20px */
  --space-6: 1.5rem;    /* 24px */
  --space-8: 2rem;      /* 32px */
  --space-10: 2.5rem;   /* 40px */
  --space-12: 3rem;     /* 48px */
  --space-16: 4rem;     /* 64px */
  --space-20: 5rem;     /* 80px */
  
  /* 语义化间距 */
  --padding-xs: var(--space-2);
  --padding-sm: var(--space-3);
  --padding-md: var(--space-4);
  --padding-lg: var(--space-6);
  --padding-xl: var(--space-8);
  
  --margin-xs: var(--space-2);
  --margin-sm: var(--space-3);
  --margin-md: var(--space-4);
  --margin-lg: var(--space-6);
  --margin-xl: var(--space-8);
  
  --gap-xs: var(--space-2);
  --gap-sm: var(--space-3);
  --gap-md: var(--space-4);
  --gap-lg: var(--space-6);
  --gap-xl: var(--space-8);
}

/* ===== 字体系统 ===== */
:root {
  /* 字体大小 */
  --text-xs: 0.75rem;   /* 12px */
  --text-sm: 0.875rem;  /* 14px */
  --text-base: 1rem;    /* 16px */
  --text-lg: 1.125rem;  /* 18px */
  --text-xl: 1.25rem;   /* 20px */
  --text-2xl: 1.5rem;   /* 24px */
  --text-3xl: 1.875rem; /* 30px */
  --text-4xl: 2.25rem;  /* 36px */
  
  /* 字体粗细 */
  --font-light: 300;
  --font-normal: 400;
  --font-medium: 500;
  --font-semibold: 600;
  --font-bold: 700;
  --font-extrabold: 800;
  
  /* 行高 */
  --leading-tight: 1.25;
  --leading-normal: 1.5;
  --leading-relaxed: 1.75;
  --leading-loose: 2;
}

/* ===== 阴影系统 ===== */
:root {
  --shadow-sm: 0 1px 2px 0 rgba(125, 211, 252, 0.2);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
  
  /* 语义化阴影 */
  --shadow-card: var(--shadow-sm);
  --shadow-panel: var(--shadow-md);
  --shadow-modal: var(--shadow-xl);
  --shadow-floating: var(--shadow-2xl);
}

/* ===== 圆角系统 ===== */
:root {
  --radius-none: 0;
  --radius-sm: 0.125rem;  /* 2px */
  --radius: 0.375rem;     /* 6px */
  --radius-md: 0.5rem;    /* 8px */
  --radius-lg: 0.75rem;   /* 12px */
  --radius-xl: 1rem;      /* 16px */
  --radius-2xl: 1.5rem;   /* 24px */
  --radius-3xl: 3rem;   /* 24px */
  --radius-6xl: 6rem;   /* 24px */
  --radius-full: 9999px;
  
  /* 语义化圆角 */
  --radius-button: var(--radius);
  --radius-card: var(--radius-lg);
  --radius-panel: var(--radius-lg);
  --radius-modal: var(--radius-xl);
}

/* ===== 动画和过渡 ===== */
:root {
  /* 过渡时间 */
  --duration-fast: 150ms;
  --duration-normal: 300ms;
  --duration-slow: 500ms;
  --duration-slower: 700ms;
  
  /* 缓动函数 */
  --ease-linear: linear;
  --ease-in: cubic-bezier(0.4, 0, 1, 1);
  --ease-out: cubic-bezier(0, 0, 0.2, 1);
  --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
  
  /* 语义化过渡 */
  --transition-fast: all var(--duration-fast) var(--ease-in-out);
  --transition-normal: all var(--duration-normal) var(--ease-in-out);
  --transition-slow: all var(--duration-slow) var(--ease-in-out);
}

/* ===== 层级系统 ===== */
:root {
  --z-index-dropdown: 1000;
  --z-index-sticky: 1020;
  --z-index-fixed: 1030;
  --z-index-modal-backdrop: 1040;
  --z-index-modal: 1050;
  --z-index-popover: 1060;
  --z-index-tooltip: 1070;
  --z-index-toast: 1080;
}

/* ===== 断点系统 ===== */
:root {
  --breakpoint-sm: 640px;
  --breakpoint-md: 768px;
  --breakpoint-lg: 1024px;
  --breakpoint-xl: 1280px;
  --breakpoint-2xl: 1536px;
}

/* ===== 深色主题变量 ===== */
[data-theme="dark"] {
  /* 中性色反转 */
  --neutral-50: #0f172a;
  --neutral-100: #1a1d23;
  --neutral-200: #2a2e35;
  --neutral-300: #3a3e45;
  --neutral-400: #5a5e65;
  --neutral-500: #7a7e85;
  --neutral-600: #9a9ea5;
  --neutral-700: #babec5;
  --neutral-800: #dadede;
  --neutral-900: #f8fafc;
  
  /* 功能色调整 */
  --primary-400: #5d9cff;
  --primary-500: #3b82f6;
  --accent-400: #ff8c42;
  --accent-500: #ff6b35;
  --success: #34d399;
  --warning: #fbbf24;
  --danger: #f87171;
  --info: #5d9cff;
  
  /* 语义化颜色调整 */
  --background: var(--neutral-50);
  --surface: var(--neutral-100);
  --text-primary: var(--neutral-800);
  --text-secondary: var(--neutral-600);
  --text-muted: var(--neutral-500);
  --border: var(--neutral-200);
  --divider: var(--neutral-300);
  
  /* 主色调调整 */
  --primary: var(--primary-400);
  --primary-light: var(--primary-300);
  --primary-dark: var(--primary-500);
  
  /* 辅色调调整 */
  --accent: var(--accent-400);
  --accent-light: var(--accent-300);
  --accent-dark: var(--accent-500);
}

/* ===== FastAdmin 通用组件样式 ===== */

/* ===== 基础重置 ===== */
* {
  box-sizing: border-box;
}

body {
  color: var(--text-primary);
  background-color: var(--background);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  line-height: var(--leading-normal);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ===== 排版工具类 ===== */
.text-xs { font-size: var(--text-xs); }
.text-sm { font-size: var(--text-sm); }
.text-base { font-size: var(--text-base); }
.text-lg { font-size: var(--text-lg); }
.text-xl { font-size: var(--text-xl); }
.text-2xl { font-size: var(--text-2xl); }
.text-3xl { font-size: var(--text-3xl); }
.text-4xl { font-size: var(--text-4xl); }

.font-light { font-weight: var(--font-light); }
.font-normal { font-weight: var(--font-normal); }
.font-medium { font-weight: var(--font-medium); }
.font-semibold { font-weight: var(--font-semibold); }
.font-bold { font-weight: var(--font-bold); }
.font-extrabold { font-weight: var(--font-extrabold); }

.leading-tight { line-height: var(--leading-tight); }
.leading-normal { line-height: var(--leading-normal); }
.leading-relaxed { line-height: var(--leading-relaxed); }
.leading-loose { line-height: var(--leading-loose); }

/* ===== 颜色工具类 ===== */
.text-primary { color: var(--text-primary); }
.text-secondary { color: var(--text-secondary); }
.text-muted { color: var(--text-muted); }

.bg-primary { background-color: var(--primary); }
.bg-accent { background-color: var(--accent); }
.bg-success { background-color: var(--success); }
.bg-warning { background-color: var(--warning); }
.bg-danger { background-color: var(--danger); }
.bg-info { background-color: var(--info); }

.bg-surface { background-color: var(--surface); }
.bg-background { background-color: var(--background); }

/* ===== 间距工具类 ===== */
.p-xs { padding: var(--padding-xs); }
.p-sm { padding: var(--padding-sm); }
.p-md { padding: var(--padding-md); }
.p-lg { padding: var(--padding-lg); }
.p-xl { padding: var(--padding-xl); }

.m-xs { margin: var(--margin-xs); }
.m-sm { margin: var(--margin-sm); }
.m-md { margin: var(--margin-md); }
.m-lg { margin: var(--margin-lg); }
.m-xl { margin: var(--margin-xl); }

.gap-xs { gap: var(--gap-xs); }
.gap-sm { gap: var(--gap-sm); }
.gap-md { gap: var(--gap-md); }
.gap-lg { gap: var(--gap-lg); }
.gap-xl { gap: var(--gap-xl); }

/* ===== 卡片组件 ===== */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  transition: var(--transition-normal);
}

.card:hover {
  box-shadow: var(--shadow-panel);
	
}

.card-header {
  padding: var(--padding-lg);
  border-bottom: 1px solid var(--border);
  background: var(--neutral-50);
}

[data-theme="dark"] .card-header {
  background: var(--neutral-200);
}

.card-body {
  padding: var(--padding-lg);
}

.card-footer {
  padding: var(--padding-lg);
  border-top: 1px solid var(--border);
  background: var(--neutral-50);
}

[data-theme="dark"] .card-footer {
  background: var(--neutral-200);
}

/* ===== 按钮组件 ===== */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--gap-sm);
  padding: var(--padding-sm) var(--padding-md);
  border: 1px solid transparent;
  border-radius: var(--radius-button);
  font-weight: var(--font-medium);
  font-size: var(--text-sm);
  line-height: 1;
  text-decoration: none;
  cursor: pointer;
  transition: var(--transition-normal);
  position: relative;
  overflow: hidden;
}

.btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none !important;
}




.btn-primary {
  background: linear-gradient(135deg, var(--primary), var(--primary-dark));
  border-color: var(--primary);
  color: var(--neutral-800);
  box-shadow: var(--shadow-sm);
}

.btn-primary:hover:not(:disabled) {
  background: linear-gradient(135deg, var(--primary-dark), var(--primary));
  transform: translateY(-1px);
}

.btn-accent {
  background: linear-gradient(135deg, var(--accent), var(--accent-dark));
  border-color: var(--accent);
  color: white;
  box-shadow: var(--shadow-sm);
}

.btn-accent:hover:not(:disabled) {
  background: linear-gradient(135deg, var(--accent-dark), var(--accent));
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.btn-outline {
  background: transparent;
  border-color: var(--border);
  color: var(--text-primary);
}

.btn-outline:hover:not(:disabled) {
  background: var(--neutral-100);
  border-color: var(--neutral-300);
}

[data-theme="dark"] .btn-outline:hover:not(:disabled) {
  background: var(--neutral-200);
}

/* ===== 徽章组件 ===== */
.badge {
  display: inline-flex;
  align-items: center;
  padding: var(--padding-xs) var(--padding-sm);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  line-height: 1;
  white-space: nowrap;
}

.badge-primary {
  background: linear-gradient(135deg, var(--primary), var(--primary-dark));
  color: white;
}

.badge-success {
  background: linear-gradient(135deg, var(--success), var(--success-700));
  color: white;
}

.badge-warning {
  background: linear-gradient(135deg, var(--warning), var(--warning-700));
  color: white;
}

.badge-danger {
  background: linear-gradient(135deg, var(--danger), var(--danger-700));
  color: white;
}

.badge-info {
  background: linear-gradient(135deg, var(--info), var(--info-700));
  color: white;
}

/* ===== 表单组件 ===== */
.form-group {
  margin-bottom: var(--margin-lg);
}

.form-label {
  display: block;
  margin-bottom: var(--margin-xs);
  font-weight: var(--font-medium);
  color: var(--text-primary);
  font-size: var(--text-sm);
}

.form-control {
  width: 100%;
  padding: var(--padding-sm) var(--padding-md);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--text-primary);
  font-size: var(--text-sm);
  transition: var(--transition-normal);
}

.form-control:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.1);
}

.form-control::placeholder {
  color: var(--text-muted);
}

[data-theme="dark"] .form-control {
  background: var(--neutral-200);
}

/* ===== 网格布局 ===== */
.grid {
  display: grid;
  gap: var(--gap-md);
}

.grid-cols-1 { grid-template-columns: repeat(1, 1fr); }
.grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
.grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
.grid-cols-4 { grid-template-columns: repeat(4, 1fr); }

/* ===== 弹性布局 ===== */
.flex { display: flex; }
.flex-col { flex-direction: column; }
.items-center { align-items: center; }
.items-start { align-items: flex-start; }
.items-end { align-items: flex-end; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.justify-start { justify-content: flex-start; }
.justify-end { justify-content: flex-end; }

/* ===== 空状态组件 ===== */
.empty-state {
  text-align: center;
  padding: var(--padding-xl);
  color: var(--text-muted);
}

.empty-icon {
  font-size: 3rem;
  color: var(--neutral-400);
  margin-bottom: var(--margin-lg);
}

.empty-state h3 {
  color: var(--text-primary);
  font-size: var(--text-xl);
  font-weight: var(--font-semibold);
  margin-bottom: var(--margin-sm);
}

.empty-state p {
  color: var(--text-secondary);
  margin-bottom: var(--margin-lg);
}

/* ===== 响应式工具类 ===== */
@media (max-width: 768px) {
  .sm\:grid-cols-1 { grid-template-columns: repeat(1, 1fr); }
  .sm\:grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
  .sm\:flex-col { flex-direction: column; }
  .sm\:text-center { text-align: center; }
  .sm\:p-md { padding: var(--padding-md); }
}

@media (min-width: 769px) and (max-width: 1024px) {
  .md\:grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
  .md\:grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width: 1025px) {
  .lg\:grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
  .lg\:grid-cols-4 { grid-template-columns: repeat(4, 1fr); }
}

/* ===== 基础样式优化 ===== */
body {
  color: var(--neutral-700);
  line-height: 1.6;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6 {
  color: var(--neutral-800);
  font-weight: 600;
  line-height: 1.3;
  margin-bottom: var(--space-4);
}

.page-header ,.panel-default h2.page-header{
  color: var(--neutral-600);
  font-weight: 700;
  font-size: 1.75rem;
  border-bottom: 1px solid var(--neutral-300);
  
	
}

/* ===== 侧边栏样式优化skosko ===== */
.sidenav {
  background: linear-gradient(120deg, var(--qns-5) 0%, var(--neutral-50) 80%);
  border-right: 1px solid var(--primary-100);
  box-shadow: var(--shadow-sm);
  padding: 0px;
  position: sticky;
  top: 0px;
  height: auto;
  transition: all 0.3s ease;
}

.sidebar-toggle {
  position: fixed;
  top: var(--space-4);
  left: var(--space-4);
  z-index: 1040;
  background: var(--primary);
  color: white;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: var(--shadow-md);
  transition: all 0.3s ease;
}

.sidebar-toggle:hover {
  background: var(--blue-700);
  transform: scale(1.05);
  box-shadow: var(--shadow-lg);
}

.list-group {
  border: none;
  margin-bottom: var(--space-4);
  background: transparent;
}

.list-group-heading {
  color: var(--neutral-600);
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: var(--space-3) var(--space-5);
  margin-bottom: var(--space-2);
  border-bottom: 1px solid var(--neutral-200);
  background: transparent;
}

.list-group-item {
  border: none;
  background: transparent;
  padding: 0;
  margin: 0;
  transition: all 0.3s ease;
  position: relative;
}

.list-group-item a {
  display: flex;
  align-items: center;
  padding: var(--space-3) var(--space-5);
  color: var(--neutral-700);
  text-decoration: none;
  transition: all 0.3s ease;
  border-radius: 0;
  font-weight: 500;
  position: relative;
  overflow: hidden;
}

.list-group-item a::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 3px;
  background: var(--blue-500);
  transform: scaleY(0);
  transition: transform 0.3s ease;
}

.list-group-item a:hover::before,
.list-group-item.active a::before {
  transform: scaleY(1);
}

.list-group-item a:hover {
  background: var(--blue-50);
  color: var(--blue-600);
  transform: translateX(5px);
}

.list-group-item.active a {
  background: var(--blue-50);
  color: var(--blue-600);
  font-weight: 600;
}

.list-group-item a i {
  width: 20px;
  margin-right: var(--space-3);
  text-align: center;
  color: var(--neutral-500);
  transition: all 0.3s ease;
}

.list-group-item a:hover i,
.list-group-item.active a i {
  color: var(--blue-500);
}

/* 子菜单样式 */
.submenu {
  background: rgba(255, 255, 255, 0.5) !important;
  border-left: 2px solid var(--blue-200) !important;
  margin: var(--space-1) 0 var(--space-1) var(--space-8) !important;
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0 !important;
  overflow: hidden;
  transition: all 0.3s ease;
}

.submenu .list-group-item {
  border-bottom: 1px solid var(--neutral-100);
}

.submenu .list-group-item:last-child {
  border-bottom: none;
}

.submenu .list-group-item a {
  padding: var(--space-2) var(--space-4);
  font-size: 0.875rem;
  color: var(--neutral-600);
}

.submenu .list-group-item a i {
  font-size: 0.75rem;
  width: 16px;
}

.submenu .list-group-item a:hover {
  background: var(--blue-100);
  color: var(--blue-600);
}

.submenu .list-group-item.active a {
  background: var(--blue-100);
  color: var(--blue-600);
}

/* 菜单父项样式 */
.menu-parent {
  position: relative;
}

.menu-parent .fa-angle-down {
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  color: var(--neutral-400);
}

.menu-parent.active .fa-angle-down {
  transform: rotate(180deg);
  color: var(--blue-500);
}

/* ===== 课程网格布局 ===== */
.course-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 24px;
}

.course-card {
  background: white;
  border: 1px solid var(--neutral-200);
  border-radius: 8px;
  transition: all 0.3s ease;
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  line-height: 1.4;
  position: relative;
}

.course-card:hover {
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1);
  border-color: var(--orange-300);
  transform: translateY(-3px);
}

.course-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
  transition: left 0.6s ease;
  z-index: 1;
}

.course-card:hover::before {
  left: 100%;
}

/* 课程封面图片 - 4:3 比例 */
.course-cover {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 75%; /* 4:3 比例 */
  overflow: hidden;
  background: var(--neutral-100);
  flex-shrink: 0;
}

.course-cover img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.course-card:hover .course-cover img {
  transform: scale(1.05);
}

/* 课程徽章 */
.course-badge {
  position: absolute;
  top: 6px;
  left: 6px;
  z-index: 2;
}

.course-badge .badge {
  font-size: 10px;
  padding: 2px 6px;
  line-height: 1.2;
}

/* 课程内容区域 */
.course-content {
  padding: 10px;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  gap: 2px;
}

/* 课程标题 */
.course-title {
  font-size: 14px;
  font-weight: 600;
  line-height: 1.3;
  height: 2.0em;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  color: var(--neutral-800);
  margin: 0;
}

.course-title a {
  color: inherit;
  text-decoration: none;
  transition: color 0.3s ease;
}

.course-title a:hover {
  color: var(--orange-500);
}

/* 课程描述 */
.course-desc {
  color: var(--neutral-600);
  font-size: 12px;
  line-height: 1.4;
  height: 2.0em;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  margin: 0;
}

/* 价格和统计信息一行布局 */
.course-meta-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 6px 0;
  padding: 0;
}

.course-price {
  font-size: 16px;
  font-weight: 700;
  color: var(--orange-600);
  line-height: 1;
  display: flex;
  align-items: center;
  gap: 4px;
  transition: all 0.3s ease;
}

.course-card:hover .course-price {
  transform: scale(1.05);
}

.course-price.free {
  color: var(--success);
  background: linear-gradient(135deg, var(--success), #22c55e);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  position: relative;
}

.course-price.free::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--success), transparent);
}

.course-price .original {
  font-size: 11px;
  color: var(--neutral-500);
  text-decoration: line-through;
  font-weight: 400;
}

.course-price .discount {
  font-size: 10px;
  color: var(--orange-500);
  background: var(--orange-50);
  padding: 1px 5px;
  border-radius: 8px;
  font-weight: 600;
}

/* 统计信息紧凑布局 */
.course-stats-compact {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--neutral-500);
  font-size: 10px;
}

.course-stats-compact i {
  margin-right: 2px;
  color: var(--neutral-400);
  font-size: 10px;
}

.course-stats-compact span {
  transition: color 0.3s ease;
}

.course-card:hover .course-stats-compact span {
  color: var(--neutral-700);
}

/* 课程操作按钮 */
.course-actions {
  display: flex;
  gap: 6px;
  margin-top: auto;
  padding-top: 6px;
}

.course-actions .btn {
  flex: 1;
  justify-content: center;
  font-size: 11px;
  padding: 5px 6px;
  border-radius: 4px;
  font-weight: 500;
  line-height: 1.2;
  position: relative;
  overflow: hidden;
  transition: all 0.3s ease;
}

.course-actions .btn::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 50%;
  transition: all 0.3s ease;
  transform: translate(-50%, -50%);
}

.course-actions .btn:hover::after {
  width: 100px;
  height: 100px;
}

/* 按钮样式分类 */
.btn-purchase {
  background: linear-gradient(135deg, #ff6b35, #ff8c42);
  border: none;
  color: white;
  box-shadow: 0 2px 8px rgba(255, 107, 53, 0.3);
}

.btn-purchase:hover {
  background: linear-gradient(135deg, #ff8c42, #ff6b35);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(255, 107, 53, 0.4);
  color: white;
}

.btn-free {
  background: linear-gradient(135deg, var(--success), #22c55e);
  border: none;
  color: white;
  box-shadow: 0 2px 8px rgba(16, 185, 129, 0.3);
}

.btn-free:hover {
  background: linear-gradient(135deg, #22c55e, #16a34a);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(16, 185, 129, 0.4);
  color: white;
}

.btn-owned {
  background: linear-gradient(135deg, var(--neutral-400), var(--neutral-500));
  border: none;
  color: white;
  box-shadow: 0 2px 8px rgba(100, 116, 139, 0.3);
}

.btn-owned:hover {
  background: linear-gradient(135deg, var(--neutral-500), var(--neutral-600));
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(100, 116, 139, 0.4);
  color: white;
}

.btn-detail {
  background: transparent;
  border: 1px solid var(--blue-400);
  color: var(--blue-400);
  transition: all 0.3s ease;
}

.btn-detail:hover {
  background: var(--blue-400);
  color: white;
  transform: translateY(-2px);
  box-shadow: 0 2px 8px rgba(59, 130, 246, 0.3);
}

/* ===== 深色模式优化 ===== */
[data-theme="dark"] .sidenav {
  background: linear-gradient(90deg, var(--neutral-100) 0%, var(--neutral-200) 100%);
  border-right: 1px solid var(--neutral-300);
  box-shadow: 5px 0 10px var(--neutral-300);
}

[data-theme="dark"] a {
  color: var(--neutral-600);
}
[data-theme="dark"] a:hover {
  color: var(--neutral-800);
}
[data-theme="dark"] .sidenav .list-group .list-group-item.active a {
  color: var(--neutral-600);
}
[data-theme="dark"] .sidenav .list-group .list-group-item.active a:hover{
  color: var(--neutral-800);
}

[data-theme="dark"] .list-group-heading {
  color: var(--neutral-400);
  border-bottom: 1px solid var(--neutral-200);
}

[data-theme="dark"] .list-group-item a {
  color: var(--neutral-400);
}

[data-theme="dark"] .list-group-item a:hover {
  background:  var(--neutral-300);
  color: var(--neutral-800);
}


[data-theme="dark"] .list-group-item.active a {
  background: var(--neutral-200);
  color: var(--orange-200);
}

[data-theme="dark"] .list-group-item a i {
  color: var(--neutral-400);
}

[data-theme="dark"] .list-group-item a:hover i,
[data-theme="dark"] .list-group-item.active a i {
  color: var(--orange-500);
}

[data-theme="dark"] .submenu {
  background: rgba(30, 41, 59, 0.8) !important;
  border-left: 2px solid var(--blue-500) !important;
}

[data-theme="dark"] .course-card {
  background: linear-gradient(145deg, #1a1d23, #1e2128);
  border: 1px solid #2a2e35;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
}

[data-theme="dark"] .course-card:hover {
  background: linear-gradient(145deg, #1e2128, #23262e);
  border-color: var(--orange-900);
  box-shadow: 0 2px 10px var(--orange-900);
}

[data-theme="dark"] .course-card::before {
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.05), transparent);
}

[data-theme="dark"] .course-cover {
  background: #2a2e35;
}

[data-theme="dark"] .course-cover::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to bottom, transparent 50%, rgba(0, 0, 0, 0.3));
  pointer-events: none;
}

[data-theme="dark"] .course-title {
  color: var(--neutral-100);
}

[data-theme="dark"] .course-title a {
  color: var(--neutral-100);
}

[data-theme="dark"] .course-title a:hover {
  color: var(--orange-400);
}

[data-theme="dark"] .course-desc {
  color: var(--neutral-400);
}

[data-theme="dark"] .course-meta-row {
  border-bottom: none;
}

[data-theme="dark"] .course-price {
  color: var(--orange-500);
  text-shadow: 0 0 8px rgba(255, 107, 53, 0.2);
}

[data-theme="dark"] .course-price.free {
  color: #34d399;
  text-shadow: 0 0 8px rgba(52, 211, 153, 0.2);
  background: linear-gradient(135deg, #34d399, #10b981);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

[data-theme="dark"] .course-price .original {
  color: var(--neutral-500);
}

[data-theme="dark"] .course-price .discount {
  color: var(--orange-300);
  background: rgba(251, 191, 36, 0.2);
}

[data-theme="dark"] .course-stats-compact {
  color: var(--neutral-400);
}

[data-theme="dark"] .course-stats-compact i {
  color: var(--neutral-500);
}

[data-theme="dark"] .course-card:hover .course-stats-compact span {
  color: var(--neutral-300);
}

/* 深色模式按钮优化 */
[data-theme="dark"] .btn-purchase {
  background: linear-gradient(135deg, #ff6b35, #ff8c42);
	color: var(--neutral-900);
}

[data-theme="dark"] .btn-purchase:hover {
  background: linear-gradient(135deg, #ff8c42, #ff6b35);
	color: var(--blue-100);
}

[data-theme="dark"] .btn-free {
  background: linear-gradient(135deg, #34d399, #10b981);
	color: var(--neutral-900);
}

[data-theme="dark"] .btn-free:hover {
  background: linear-gradient(135deg, #10b981, #059669);
	color: var(--neutral-700);
}

[data-theme="dark"] .btn-owned {
  background: linear-gradient(135deg, #3a3e45, #4a4e55);
  color: #babec5;
}

[data-theme="dark"] .btn-owned:hover {
  background: linear-gradient(135deg, #4a4e55, #5a5e65);
  color: #dadede;
}

[data-theme="dark"] .btn-detail {
  border: 1px solid #5d9cff;
  color: #5d9cff;
}

[data-theme="dark"] .btn-detail:hover {
  background: #5d9cff;
  color: white;
}

/* 深色模式徽章优化 */
[data-theme="dark"] .badge-success {
  background: rgba(52, 211, 153, 0.2);
  color: #34d399;
  border: 1px solid rgba(52, 211, 153, 0.3);
}

[data-theme="dark"] .badge-danger {
  background: var(--orange-600);
  color: #f87171;
  border: 1px solid rgba(248, 113, 113, 0.3);
}

/* ===== 响应式设计 ===== */
@media (max-width: 1024px) {
  .course-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }
  
  .course-content {
    padding: 10px;
    gap: 5px;
  }
  
  .course-title {
    font-size: 13px;
    height: 2.4em;
  }
  
  .course-desc {
    font-size: 11px;
    height: 2.4em;
  }
  
  .course-price {
    font-size: 15px;
  }
  
  .course-stats-compact {
    font-size: 9px;
    gap: 8px;
  }
}

@media (max-width: 768px) {
  .course-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }
  
  .course-content {
    padding: 8px;
    gap: 4px;
  }
  
  .course-title {
    font-size: 12px;
    height: 2.2em;
  }
  
  .course-desc {
    font-size: 10px;
    height: 2.2em;
  }
  
  .course-meta-row {
    margin: 4px 0;
  }
  
  .course-price {
    font-size: 14px;
  }
  
  .course-stats-compact {
    font-size: 8px;
    gap: 6px;
  }
  
  .course-actions {
    gap: 4px;
  }
  
  .course-actions .btn {
    font-size: 10px;
    padding: 4px 5px;
  }
  
  /* 移动端侧边栏 */
  .sidenav {
    position: fixed;
    top: 0;
    left: -280px;
    width: 280px;
    z-index: 1035;
    transition: left 0.3s ease;
    box-shadow: var(--shadow-lg);
  }
  
  .sidenav.active {
    left: 0;
  }
  
  .sidebar-toggle {
    display: flex;
  }
  
  /* 移动端遮罩 */
  .sidenav-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: 1034;
    display: none;
  }
  
  .sidenav.active + .sidenav-overlay {
    display: block;
  }
}

@media (max-width: 480px) {
  .course-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  
  .course-content {
    padding: 10px;
  }
  

}

@media (min-width: 769px) {
  .sidebar-toggle {
    display: none;
  }
}
/* ===== 移动端商品容器布局优化 ===== */
@media (max-width: 768px) {
  /* 课程网格布局调整为单列 */
  .course-grid {
    grid-template-columns: 1fr;
    gap: 16px;
    margin-bottom: 20px;
  }

  /* 课程卡片移动端优化 */
  .course-card {
    border-radius: 12px;
    box-shadow: var(--shadow-md);
    margin-bottom: 0;
    transition: all 0.3s ease;
  }

  .course-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
  }

  /* 课程封面优化 */
  .course-cover {
    padding-bottom: 56.25%; /* 16:9 比例，更适合移动端 */
    border-radius: 8px 8px 0 0;
  }

  /* 课程内容区域优化 */
  .course-content {
    padding: 12px;
    gap: 8px;
    flex-grow: 1;
  }

  

  /* ===== 按钮布局优化 - 每行一个按钮 ===== */
  .course-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--neutral-200);
  }

  [data-theme="dark"] .course-actions {
    border-top: 1px solid var(--neutral-300);
  }

  .course-actions .btn {
    flex: none;
    width: 100%;
    height: 44px;
    font-size: 15px;
    font-weight: 600;
    padding: 12px 16px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
  }

  /* 按钮悬停效果优化 */
  .course-actions .btn::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 50%;
    transition: all 0.6s ease;
    transform: translate(-50%, -50%);
  }

  .course-actions .btn:hover::before {
    width: 300px;
    height: 300px;
  }

  /* 购买按钮移动端优化 */
  .btn-purchase {
    background: linear-gradient(135deg, var(--orange-500), var(--orange-600));
    border: none;
    color: white;
    box-shadow: 0 4px 12px rgba(245, 158, 11, 0.3);
    font-size: 16px;
  }

  .btn-purchase:hover {
    background: linear-gradient(135deg, var(--orange-600), var(--orange-700));
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(245, 158, 11, 0.4);
  }

  /* 免费按钮移动端优化 */
  .btn-free {
    background: linear-gradient(135deg, var(--success), #059669);
    border: none;
    color: white;
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3);
    font-size: 16px;
  }

  .btn-free:hover {
    background: linear-gradient(135deg, #059669, #047857);
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(16, 185, 129, 0.4);
  }

  /* 已拥有按钮移动端优化 */
  .btn-owned {
    background: linear-gradient(135deg, var(--neutral-400), var(--neutral-500));
    border: none;
    color: white;
    box-shadow: 0 4px 12px rgba(100, 116, 139, 0.3);
    font-size: 16px;
  }

  .btn-owned:hover {
    background: linear-gradient(135deg, var(--neutral-500), var(--neutral-600));
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(100, 116, 139, 0.4);
  }

  /* 详情按钮移动端优化 */
  .btn-detail {
    background: transparent;
    border: 2px solid var(--blue-500);
    color: var(--blue-500);
    font-size: 15px;
    transition: all 0.3s ease;
  }

  .btn-detail:hover {
    background: var(--blue-500);
    color: white;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
  }

  /* 深色模式按钮优化 */
  [data-theme="dark"] .btn-detail {
    border: 2px solid var(--blue-400);
    color: var(--blue-400);
  }

  [data-theme="dark"] .btn-detail:hover {
    background: var(--blue-400);
    color: white;
  }

  /* 徽章位置优化 */
  .course-badge {
    top: 10px;
    right: 10px;
    left: auto;
  }

  .course-badge .badge {
    font-size: 12px;
    padding: 6px 10px;
    border-radius: 16px;
    font-weight: 600;
  }

  /* 侧边栏移动端优化 */
  .sidenav {
    width: 300px;
    left: -300px;
  }

  .sidebar-toggle {
    width: 48px;
    height: 48px;
    font-size: 18px;
  }

  /* 主题切换按钮移动端优化 */
  .theme-switcher {
    bottom: 20px;
    left: 20px;
  }

  .theme-btn {
    width: 48px;
    height: 48px;
    font-size: 18px;
  }
}

/* ===== 超小屏幕优化 (最大宽度 480px) ===== */
@media (max-width: 480px) {
  .course-grid {
    gap: 12px;
  }

  .course-content {
    padding: 10px;
  }



  .course-actions .btn {
    height: 42px;
    font-size: 14px;
  }

  /* 按钮图标大小调整 */
  .course-actions .btn i {
    font-size: 14px;
  }

  /* 徽章大小调整 */
  .course-badge .badge {
    font-size: 11px;
    padding: 5px 8px;
  }
}

/* ===== 平板端优化 (768px - 1024px) ===== */
@media (min-width: 769px) and (max-width: 1024px) {
  .course-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }

  /* 平板端保持双列布局，但优化按钮显示 */
  .course-actions {
    flex-direction: row;
    flex-wrap: wrap;
  }

  .course-actions .btn {
    flex: 1;
    min-width: 120px;
    height: 40px;
    font-size: 13px;
  }

  /* 确保详情按钮在平板端也正常显示 */
  .btn-detail {
    flex: 0 0 auto;
  }
}

/* ===== 移动端页面标题优化 ===== */
@media (max-width: 768px) {
  .page-header,
  .panel-default h2.page-header {
    font-size: 1.5rem;
    padding: 16px 0;
    margin-bottom: 16px;
    text-align: center;
    border-bottom: 2px solid var(--neutral-200);
  }

  [data-theme="dark"] .page-header,
  [data-theme="dark"] .panel-default h2.page-header {
    border-bottom: 2px solid var(--neutral-300);
  }
}

/* ===== 移动端容器内边距优化 ===== */
@media (max-width: 768px) {
  .container {
    padding-left: 12px;
    padding-right: 12px;
  }

  .panel-body {
    padding: 16px;
  }

  /* 确保内容区域在移动端有适当的内边距 */
  .content {
    padding: 0;
  }
}


/* ===== 移动端空状态优化 ===== */
@media (max-width: 768px) {
  .course-empty {
    padding: 40px 20px;
    margin: 20px 0;
    border-radius: 12px;
  }

  .course-empty .icon {
    font-size: 2.5rem;
    margin-bottom: 20px;
  }

  .course-empty h4 {
    font-size: 1.25rem;
    margin-bottom: 12px;
  }

  .course-empty .text-muted {
    font-size: 14px;
    margin-bottom: 20px;
  }

  .course-empty .btn {
    padding: 12px 24px;
    font-size: 15px;
  }
}

/* ===== 移动端动画性能优化 ===== */
@media (max-width: 768px) {
  /* 减少移动端的动画效果以提升性能 */
  .course-card::before {
    display: none;
  }

  .course-actions .btn::before {
    display: none;
  }

  /* 保留必要的悬停效果 */
  .course-card:hover {
    transform: translateY(-2px);
  }

  .course-actions .btn:active {
    transform: scale(0.98);
  }
}

/* ===== 主题切换按钮 ===== */
.theme-switcher {
  position: fixed;
  bottom: var(--space-6);
  left: var(--space-6);
  z-index: 1000;
}

.theme-btn {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--blue-500), var(--orange-500));
  color: white;
  border: none;
  box-shadow: var(--shadow-lg);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}

.theme-btn::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
  transition: left 0.5s;
}

.theme-btn:hover::before {
  left: 100%;
}

.theme-btn:hover {
  transform: scale(1.1) rotate(15deg);
  box-shadow: var(--shadow-xl);
}

/* 移动端主题按钮调整 */
@media (max-width: 768px) {
  .theme-switcher {
    bottom: var(--space-4);
    left: var(--space-4);
  }
  
  .sidebar-toggle {
    position: fixed;
    bottom: var(--space-4);
    right: var(--space-4);
    top: auto;
    left: auto;
    z-index: 1040;
  }
  
  .theme-btn,
  .sidebar-toggle {
    width: 44px;
    height: 44px;
    font-size: 1.1rem;
  }
}


/* ===== 页头和页尾优化skosko ===== */

[data-theme="default"] .content{
	    background: linear-gradient(135deg, var(--neutral-50) 0%, var(--neutral-50) 100%)!important;
}
[data-theme="default"] .navbar-white {
    background: linear-gradient(90deg, var(--neutral-50) 0%, var(--qns-5) 100%)!important;
    border-color: #fff;
	border-bottom: 1px solid var(--primary-100);
    box-shadow: 0 6px 12px var(--qns-10);
}
[data-theme="default"] .footer {
    background: linear-gradient(90deg, var(--neutral-50) 0%, var(--qns-5) 100%)!important;
  border-top: 1px solid var(--primary-100);
  box-shadow: 0 -6px 12px var(--qns-10);
  padding: var(--space-8) 0 var(--space-6);
  margin-top: auto;
}



.navbar-white.navbar-fixed-top {
  position: sticky;
  top: 0;
  z-index: 1030;
  margin-bottom: 0 !important;
}


[data-theme="dark"] .navbar-white {
  background: linear-gradient(30deg,  var(--neutral-200) 0%, var(--neutral-100) 100%);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--neutral-300);
  box-shadow: 0 5px 10px -1px var(--neutral-300);
}
[data-theme="dark"] .navbar-white .navbar-nav > .active > a{
	color: var(--neutral-600);
}


[data-theme="dark"] .navbar-nav > li > a:hover {
  color: var(--neutral-800) !important;
  background: var(--neutral-200);
}



[data-theme="dark"] .footer {
  background: linear-gradient(135deg, var(--neutral-100) 0%, var(--neutral-200) 100%);
  border-top: 1px solid var(--neutral-700);
}

.copyright {
  text-align: center;
  color: var(--neutral-600);
  font-size: 0.875rem;
  margin: 0;
}

[data-theme="dark"] .copyright {
  color: var(--neutral-500);
}

.copyright a {
  color: var(--neutral-700);
  text-decoration: none;
  transition: color 0.3s ease;
  margin-left: var(--space-2);
}

[data-theme="dark"] .copyright a {
  color: var(--neutral-400);
}

.copyright a:hover {
  color: var(--blue-600);
  text-decoration: underline;
}

[data-theme="dark"] .copyright a:hover {
  color: var(--blue-300);
}

/* ===== 空状态样式 ===== */
.course-empty {
  background: var(--neutral-100);
  border: 1px solid var(--neutral-200);
  border-radius: var(--radius-lg);
  text-align: center;
  padding: var(--space-8);
}

[data-theme="dark"] .course-empty {
  background: var(--neutral-800);
  border: 1px solid var(--neutral-700);
}

.course-empty .icon {
  font-size: 3rem;
  color: var(--neutral-400);
  margin-bottom: var(--space-4);
}

.course-empty h4 {
  color: var(--neutral-700);
  margin-bottom: var(--space-3);
}

[data-theme="dark"] .course-empty h4 {
  color: var(--neutral-300);
}

.course-empty .text-muted {
  color: var(--neutral-500) !important;
}

/* ===== 筛选区域样式 ===== */
.course-filters {
  background: white;
  border: 1px solid var(--neutral-200);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  margin-bottom: var(--space-6);
  box-shadow: var(--shadow-sm);
}

[data-theme="dark"] .course-filters {
  background: var(--neutral-50);
  border: 1px solid var(--neutral-200);
  backdrop-filter: blur(10px);
	color: var(--neutral-500);
}


.filter-row {
  display: flex;
  gap: var(--space-4);
  align-items: center;
  flex-wrap: wrap;
}

.filter-group {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.filter-label {
  color: var(--neutral-700);
  font-weight: 500;
  font-size: 0.875rem;
  white-space: nowrap;
}

[data-theme="dark"] .filter-label {
  color: var(--neutral-500);
}
[data-theme="dark"] .form-control {
	background: var(--neutral-200);border-color: var(--neutral-300);color: var(--neutral-500);
}

.sort-select {
  min-width: 150px;
}

/* ===== 动画效果 ===== */
@keyframes slideInLeft {
  from {
    opacity: 0;
    transform: translateX(-20px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

.list-group-item {
  animation: slideInLeft 0.3s ease forwards;
}

.list-group-item:nth-child(1) { animation-delay: 0.05s; }
.list-group-item:nth-child(2) { animation-delay: 0.1s; }
.list-group-item:nth-child(3) { animation-delay: 0.15s; }
.list-group-item:nth-child(4) { animation-delay: 0.2s; }
.list-group-item:nth-child(5) { animation-delay: 0.25s; }

@keyframes iconPulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.1); }
}

.course-card:hover .course-actions .btn i {
  animation: iconPulse 2s infinite;
}
/* ===== 页尾颜色统一修复 ===== */
.footer {
  background: linear-gradient(135deg, var(--neutral-100) 0%, var(--neutral-200) 100%);
  border-top: 1px solid var(--neutral-200);
  padding: var(--space-8) 0 var(--space-6);
  margin-top: auto;
  width: 100%;
}

[data-theme="dark"] .footer {
  background: linear-gradient(135deg, var(--neutral-100) 0%, var(--neutral-200) 100%);
  border-top: 1px solid var(--neutral-300);
}

/* 确保页尾内容区域颜色统一 */
.footer .container {
  background: transparent;
}

.footer .copyright {
  text-align: center;
  color: var(--neutral-600);
  font-size: 0.875rem;
  margin: 0;
}

[data-theme="dark"] .footer .copyright {
  color: var(--neutral-400);
}

.footer .copyright a {
  color: var(--neutral-700);
  text-decoration: none;
  transition: color 0.3s ease;
  margin-left: var(--space-2);
}

[data-theme="dark"] .footer .copyright a {
  color: var(--neutral-300);
}

.footer .copyright a:hover {
  color: var(--blue-600);
  text-decoration: underline;
}

[data-theme="dark"] .footer .copyright a:hover {
  color: var(--blue-300);
}

/* 页尾链接区域 */
.footer-links {
  display: flex;
  justify-content: center;
  gap: var(--space-6);
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}

.footer-links a {
  color: var(--neutral-600);
  text-decoration: none;
  font-size: 0.875rem;
  transition: color 0.3s ease;
}

[data-theme="dark"] .footer-links a {
  color: var(--neutral-400);
}

.footer-links a:hover {
  color: var(--blue-600);
}

[data-theme="dark"] .footer-links a:hover {
  color: var(--blue-300);
}
/* ===== 特价标识优化 ===== */
.course-badge {
  position: absolute;
  top: 8px;
  right: 8px; /* 移到右上角 */
  left: auto; /* 覆盖之前的left */
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.course-badge .badge {
  font-size: 10px;
  padding: 3px 8px;
  line-height: 1.2;
  border-radius: 12px;
  font-weight: 600;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

/* 免费标识保持绿色 */
.course-badge .badge-success {
  background: linear-gradient(135deg, #10b981, #059669);
  color: white;
  border: none;
}

/* 特价标识改为 */
.course-badge .badge-danger {
  background: var(--orange-600);
  color: white;
  border: none;
}

/* 深色模式徽章优化 */
[data-theme="dark"] .course-badge .badge-success {
  background: linear-gradient(135deg, #059669, #047857);
  box-shadow: 0 2px 8px rgba(5, 150, 105, 0.3);
}

[data-theme="dark"] .course-badge .badge-danger {
  background:var(--orange-500);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
}
/* ===== 深色模式背景和文字修复 ===== */
[data-theme="dark"] body {
  background: linear-gradient(90deg, var(--neutral-200) 0%, var(--neutral-100) 100%);
  color: var(--neutral-600);
}

[data-theme="dark"] .course-card {
  background: linear-gradient(145deg, #1e293b, #1a2332);
  border: 1px solid var(--neutral-200);
}

[data-theme="dark"] .course-title {
  color: var(--neutral-600);
}

[data-theme="dark"] .course-title a {
  color: var(--neutral-800);
}

[data-theme="dark"] .course-title a:hover {
  color: var(--blue-400);
}

[data-theme="dark"] .course-desc {
  color: var(--neutral-400);
}


.panel-body {
  display: flex;
    flex-direction: column;
    gap: var(--gap-xl);
	padding:0;
}

/* 深色模式内容区域背景 */
[data-theme="dark"] .panel-body {
  background: transparent;
}

[data-theme="dark"] .panel-default {
  background: transparent;
  border: none;
}

[data-theme="dark"] .dropdown-menu > li > a {
  font-size: 14px;
  padding: 5px 20px;
}
[data-theme="dark"] .dropdown-menu {
  border-radius: 2px;background: var(--neutral-100);
  border: 0px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  padding: 5px 0px;
}
[data-theme="dark"] .dropdown-menu li a {
  padding-top: 10px !important;
  padding-bottom: 10px;
}
[data-theme="dark"] .dropdown-menu > li > a {
  font-weight: 400;
  color: var(--neutral-500);
  padding: 5px 15px;
  padding-bottom: 10px;
}
[data-theme="dark"] .dropdown-menu > li > a:hover,
[data-theme="dark"] .dropdown-menu > li > a:focus {
  text-decoration: none;
  color: var(--neutral-700);
  background: var(--neutral-200);
}
[data-theme="dark"] .dropdown-menu > .divider {
	background-color: var(--neutral-300);
}




/* ===== 授权认证管理页面样式优化 ===== */

/* 主内容容器 */
.auth-container.card {
    background: white;
    border: 1px solid var(--neutral-200);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
    margin-bottom: var(--space-6);
}

[data-theme="dark"] .auth-container.card {
    background: var(--neutral-100);
    border: 1px solid var(--neutral-200);
    box-shadow: var(--shadow-md);
}

/* 页面标题区域 */
.auth-header.card-header {
    background: linear-gradient(135deg, var(--blue-50) 0%, var(--blue-100) 100%);
    border-bottom: 1px solid var(--neutral-200);
    padding: var(--space-6) var(--space-6);
}

[data-theme="dark"] .auth-header.card-header {
    background: linear-gradient(135deg, var(--neutral-200) 0%, var(--neutral-300) 100%);
    border-bottom: 1px solid var(--neutral-300);
}

.page-title {
    color: var(--neutral-800);
    font-size: 1.75rem;
    font-weight: 700;
    margin: 0 0 var(--space-2) 0;
}

[data-theme="dark"] .page-title {
    color: var(--neutral-800);
}

.page-subtitle {
    color: var(--neutral-600);
    font-size: 1rem;
    margin: 0;
    font-weight: 400;
}

[data-theme="dark"] .page-subtitle {
    color: var(--neutral-500);
}

/* 认证操作区域 */
.auth-action-section {
    text-align: center;
    padding: var(--space-8) var(--space-4);
    border-bottom: 1px solid var(--neutral-200);
    background: var(--neutral-50);
}

[data-theme="dark"] .auth-action-section {
    background: var(--neutral-200);
    border-bottom: 1px solid var(--neutral-300);
}

.auth-btn {
    background: linear-gradient(135deg, var(--orange-500), var(--orange-600));
    border: none;
    color: white;
    padding: var(--space-4) var(--space-8);
    font-size: 1.125rem;
    font-weight: 600;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
    transition: all 0.3s ease;
    display: inline-flex;
    align-items: center;
    gap: var(--space-3);
}

.auth-btn:hover {
    background: linear-gradient(135deg, var(--orange-600), var(--orange-700));
    transform: translateY(-2px);
box-shadow: 0 2px 5px var(--blue-300);
	color: white;
}

.auth-hint {
    color: var(--neutral-600);
    font-size: 0.875rem;
    margin-top: var(--space-3) !important;
    margin-bottom: 0;
}

[data-theme="dark"] .auth-hint {
    color: var(--neutral-500);
}

/* 授权列表区域 */
.auth-list-section {
    padding: var(--space-6);
}

.section-title {
    color: var(--neutral-800);
    font-size: 1.375rem;
    font-weight: 600;
    margin-bottom: var(--space-6);
    padding-bottom: var(--space-3);
    border-bottom: 2px solid var(--blue-200);
}

[data-theme="dark"] .section-title {
    color: var(--neutral-700);
    border-bottom: 2px solid var(--neutral-300);
}

/* 订单卡片样式 */
.order-card.card {
    background: white;
    border: 1px solid var(--neutral-200);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    margin-bottom: var(--space-5);
    transition: all 0.3s ease;
    overflow: hidden;
}

.order-card.card:hover {
	 box-shadow: 0 3px 6px var(--orange-500);
    border-color: var(--orange-600);
    transform: translateY(-1px);
}

[data-theme="dark"] .order-card.card {
    background: var(--neutral-100);
    border: 1px solid var(--neutral-300);
}

[data-theme="dark"] .order-card.card:hover {
    border-color: var(--orange-700);
	 box-shadow: 0 3px 6px var(--orange-700);
}

.order-header.card-header {
    background: var(--neutral-50);
    border-bottom: 1px solid var(--neutral-200);
    padding: var(--space-4) var(--space-5);
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--space-4);
}

[data-theme="dark"] .order-header.card-header {
    background: var(--neutral-200);
    border-bottom: 1px solid var(--neutral-300);
}

.order-info {
    flex: 1;
}

.order-number {
    font-size: 1rem;
    font-weight: 600;
    color: var(--neutral-800);
    margin-bottom: var(--space-2);
    display: flex;
    align-items: center;
    gap: var(--space-3);
    flex-wrap: wrap;
}

[data-theme="dark"] .order-number {
    color: var(--neutral-700);
}

.order-number strong {
    color: var(--blue-600);
    font-weight: 700;
}

[data-theme="dark"] .order-number strong {
    color: var(--blue-400);
}

.order-software,
.order-device-count {
    color: var(--neutral-600);
    font-size: 0.875rem;
    margin-bottom: var(--space-1);
}

[data-theme="dark"] .order-software,
[data-theme="dark"] .order-device-count {
    color: var(--neutral-500);
}

.order-status {
    font-size: 0.75rem;
    padding: var(--space-1) var(--space-3);
    border-radius: 12px;
    font-weight: 600;
    white-space: nowrap;
}

/* 设备列表样式 */
.devices-list.card-body {
    padding: var(--space-4) var(--space-5);
    background: white;
}

[data-theme="dark"] .devices-list.card-body {
    background: var(--neutral-100);
}

.device-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-3) 0;
    border-bottom: 1px solid var(--neutral-100);
    gap: var(--space-4);
}

.device-item:last-child {
    border-bottom: none;
}

[data-theme="dark"] .device-item {
    border-bottom: 1px solid var(--neutral-200);
}

.device-info {
    flex: 1;
}

.device-id {
    background: var(--neutral-100);
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius);
    font-family: 'Monaco', 'Menlo', 'Ubuntu Mono', monospace;
    font-size: 0.875rem;
    color: var(--neutral-700);
    border: 1px solid var(--neutral-200);
    word-break: break-all;
}

[data-theme="dark"] .device-id {
    background: var(--neutral-200);
    color: var(--neutral-600);
    border: 1px solid var(--neutral-300);
}

.device-meta {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    margin-top: var(--space-2);
    flex-wrap: wrap;
}

.auth-date {
    color: var(--neutral-500);
    font-size: 0.875rem;
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

[data-theme="dark"] .auth-date {
    color: var(--neutral-400);
}

.device-status {
    font-size: 0.75rem;
    padding: var(--space-1) var(--space-3);
    border-radius: 12px;
    font-weight: 600;
}

.device-actions {
    flex-shrink: 0;
}

/* 按钮样式优化 */
.action-btn.unbind {
    background: transparent;
    border: 1px solid var(--danger);
    color: var(--danger);
    padding: var(--space-1) var(--space-3);
    font-size: 0.875rem;
    border-radius: var(--radius);
    transition: all 0.3s ease;
    font-weight: 500;
}

.action-btn.unbind:hover {
    background: var(--danger);
    color: white;
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(239, 68, 68, 0.3);
}

/* 空状态样式 */
.empty-state,
.empty-device-state {
    text-align: center;
    padding: var(--space-8) var(--space-4);
    color: var(--neutral-500);
}

.empty-state .icon,
.empty-device-state .icon {
    font-size: 3rem;
    color: var(--neutral-400);
    margin-bottom: var(--space-4);
}

[data-theme="dark"] .empty-state .icon,
[data-theme="dark"] .empty-device-state .icon {
    color: var(--neutral-500);
}

.empty-state p,
.empty-device-state p {
    font-size: 1.125rem;
    font-weight: 500;
    color: var(--neutral-700);
    margin-bottom: var(--space-2);
}

[data-theme="dark"] .empty-state p,
[data-theme="dark"] .empty-device-state p {
    color: var(--neutral-600);
}

.auth-tip,
.device-tip {
    font-size: 0.875rem;
    color: var(--neutral-500);
    margin-bottom: 0;
}

[data-theme="dark"] .auth-tip,
[data-theme="dark"] .device-tip {
    color: var(--neutral-400);
}

/* 模态框样式优化 */
#authModal .modal-content {
    border: none;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
    overflow: hidden;
}

[data-theme="dark"] #authModal .modal-content {
    background: var(--neutral-100);
    border: 1px solid var(--neutral-200);
}

.modal-header {
    background: linear-gradient(135deg, var(--blue-50) 0%, var(--blue-100) 100%);
    border-bottom: 1px solid var(--neutral-200);
    padding: var(--space-5) var(--space-6);
}

[data-theme="dark"] .modal-header {
    background: linear-gradient(135deg, var(--neutral-200) 0%, var(--neutral-300) 100%);
    border-bottom: 1px solid var(--neutral-300);
}

.modal-title {
    color: var(--neutral-800);
    font-size: 1.375rem;
    font-weight: 600;
    margin: 0;
}

[data-theme="dark"] .modal-title {
    color: var(--neutral-700);
}

.close {
    color: var(--neutral-600);
    opacity: 0.7;
    transition: all 0.3s ease;
}

.close:hover {
    color: var(--neutral-800);
    opacity: 1;
}

[data-theme="dark"] .close {
    color: var(--neutral-500);
}

[data-theme="dark"] .close:hover {
    color: var(--neutral-700);
}

.modal-body {
    padding: var(--space-6);
}

.form-label {
    color: var(--neutral-700);
    font-weight: 600;
    font-size: 0.875rem;
    margin-bottom: var(--space-2);
}

[data-theme="dark"] .form-label {
    color: var(--neutral-600);
}

.form-control {
    border: 1px solid var(--neutral-300);
    border-radius: var(--radius);
    padding: var(--space-3) var(--space-4);
    font-size: 0.875rem;
    transition: all 0.3s ease;
    background: white;
}

.form-control:focus {
    border-color: var(--blue-400);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
    background: white;
}

[data-theme="dark"] .form-control {
    background: var(--neutral-200);
    border: 1px solid var(--neutral-300);
    color: var(--neutral-600);
}

[data-theme="dark"] .form-control:focus {
    background: var(--neutral-200);
    border-color: var(--blue-400);
    color: var(--neutral-700);
}

.modal-select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");
    background-position: right 0.5rem center;
    background-repeat: no-repeat;
    background-size: 1.5em 1.5em;
    padding-right: 2.5rem;
}

.modal-footer {
    border-top: 1px solid var(--neutral-200);
    padding: var(--space-5) var(--space-6);
    background: var(--neutral-50);
}

[data-theme="dark"] .modal-footer {
    border-top: 1px solid var(--neutral-300);
    background: var(--neutral-200);
}

.skobtn {
    padding: var(--space-3) var(--space-5);
    font-weight: 600;
    border-radius: var(--radius);
    transition: all 0.3s ease;
}

.skobtn.btn-secondary {
    background: var(--neutral-300);
    border: 1px solid var(--neutral-400);
    color: var(--neutral-700);
}

.skobtn.btn-secondary:hover {
    background: var(--neutral-400);
    border-color: var(--neutral-500);
    color: var(--neutral-800);
}

.skobtn.btn-warning {
    background: linear-gradient(135deg, var(--orange-500), var(--orange-600));
    border: none;
    color: white;
}

.skobtn.btn-warning:hover {
    background: linear-gradient(135deg, var(--orange-600), var(--orange-700));
    transform: translateY(-1px);
    box-shadow: 0 2px 5px var(--blue-300);
    color: white;
}

/* 徽章样式统一 */
.badge-primary {
    background: linear-gradient(135deg, var(--blue-500), var(--blue-600));
    color: white;
    border: none;
}

.badge-success {
    background: linear-gradient(135deg, var(--success), #059669);
    color: white;
    border: none;
}

.badge-info {
    background: linear-gradient(135deg, #0ea5e9, #0284c7);
    color: white;
    border: none;
}

.badge-danger {
    background: linear-gradient(135deg, var(--danger), #dc2626);
    color: white;
    border: none;
}

/* 响应式优化 */
@media (max-width: 768px) {
    .auth-container.card {
        margin: 0 -12px;
        border-radius: 0;
        border-left: none;
        border-right: none;
    }
    
    .auth-header.card-header {
        padding: var(--space-5) var(--space-4);
    }
    
    .page-title {
        font-size: 1.5rem;
    }
    
    .auth-action-section {
        padding: var(--space-6) var(--space-3);
    }
    
    .auth-btn {
        width: 100%;
        justify-content: center;
        padding: var(--space-4) var(--space-4);
        font-size: 1rem;
    }
    
    .auth-list-section {
        padding: var(--space-4);
    }
    
    .section-title {
        font-size: 1.25rem;
        margin-bottom: var(--space-4);
    }
    
   
    
    .devices-list.card-body {
        padding: var(--space-3);
    }
    
    .device-item {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--space-3);
        padding: var(--space-4) 0;
    }
    
    .device-meta {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--space-2);
    }
    
    .device-actions {
        align-self: flex-end;
    }
    
    .action-btn.unbind {
        width: 100%;
        text-align: center;
    }
    
    /* 模态框移动端优化 */
    #authModal .modal-dialog {
        margin: 0;
        max-width: 100%;
    }
    
    #authModal .modal-content {
        border-radius: 0;
        min-height: 100vh;
    }
    
    .modal-header,
    .modal-body,
    .modal-footer {
        padding: var(--space-4);
    }
    
    .modal-footer {
        flex-direction: column;
        gap: var(--space-3);
    }
    
    .skobtn {
        width: 100%;
    }
}

/* 平板端优化 */
@media (min-width: 769px) and (max-width: 1024px) {
    .auth-container.card {
        margin: 0;
    }
    
    .order-header.card-header {
        padding: var(--space-4);
    }
    
    .devices-list.card-body {
        padding: var(--space-4);
    }
}

/* 加载状态优化 */
.fa-spinner {
    color: currentColor;
}

/* 确保表单控件在深色模式下的可见性 */
[data-theme="dark"] .form-control::placeholder {
    color: var(--neutral-400);
}

/* 确保代码块在深色模式下的可读性 */
[data-theme="dark"] code {
    background: var(--neutral-200);
    color: var(--neutral-700);
}

/* 链接颜色统一 */
a {
    color: var(--blue-600);
    text-decoration: none;
    transition: color 0.3s ease;
}

a:hover {
    color: var(--blue-700);
    text-decoration: underline;
}

[data-theme="dark"] a {
    color: var(--blue-400);
}

[data-theme="dark"] a:hover {
    color: var(--blue-300);
}


/* ===== SKO图标库样式扩展 ===== */

/* 图标大小类 - 扩展 */
.fas.sko-icon-xs { font-size: 12px; }
.fas.sko-icon-sm { font-size: 14px; }
.fas.sko-icon-md { font-size: 16px; }
.fas.sko-icon-lg { font-size: 20px; }
.fas.sko-icon-xl { font-size: 24px; }
.fas.sko-icon-36 { font-size: 36px; }
.fas.sko-icon-48 { font-size: 48px; }
.fas.sko-icon-72 { font-size: 72px; }
 
/* 图标颜色类 - 扩展 */
.fas.sko-icon-colorful { filter: none !important; }

.fas.sko-icon-primary {
    filter: invert(47%) sepia(90%) saturate(1725%) hue-rotate(176deg) brightness(95%) contrast(91%);
}

.fas.sko-icon-success {
    filter: invert(61%) sepia(64%) saturate(491%) hue-rotate(67deg) brightness(93%) contrast(88%);
}

.fas.sko-icon-warning {
    filter: invert(79%) sepia(67%) saturate(576%) hue-rotate(349deg) brightness(103%) contrast(101%);
}

.fas.sko-icon-danger {
    filter: invert(44%) sepia(55%) saturate(2097%) hue-rotate(331deg) brightness(94%) contrast(91%);
}

.fas.sko-icon-white {
    filter: brightness(0) invert(1);
}

.fas.sko-icon-muted {
    filter: brightness(0) saturate(100%) opacity(0.6);
}

/* 平台特定图标颜色 */
.fas.sko-icon-wechat { filter: invert(48%) sepia(79%) saturate(2476%) hue-rotate(86deg) brightness(104%) contrast(119%); }
.fas.sko-icon-qq { filter: invert(44%) sepia(98%) saturate(2085%) hue-rotate(176deg) brightness(100%) contrast(91%); }
.fas.sko-icon-phone { filter: invert(48%) sepia(79%) saturate(2476%) hue-rotate(86deg) brightness(104%) contrast(119%); }
.fas.sko-icon-email { filter: invert(44%) sepia(98%) saturate(2085%) hue-rotate(176deg) brightness(100%) contrast(91%); }
.fas.sko-icon-bilibili { filter: invert(48%) sepia(99%) saturate(2476%) hue-rotate(306deg) brightness(100%) contrast(119%); }
.fas.sko-icon-douyin { filter: invert(0%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(0%) contrast(100%); }
.fas.sko-icon-xiaohongshu { filter: invert(16%) sepia(99%) saturate(2476%) hue-rotate(330deg) brightness(100%) contrast(119%); }
.fas.sko-icon-kuaishou { filter: invert(44%) sepia(98%) saturate(2085%) hue-rotate(176deg) brightness(100%) contrast(91%); }
.fas.sko-icon-gongzhonghao { filter: invert(48%) sepia(79%) saturate(2476%) hue-rotate(86deg) brightness(104%) contrast(119%); }
.fas.sko-icon-shipinhao { filter: invert(48%) sepia(79%) saturate(2476%) hue-rotate(86deg) brightness(104%) contrast(119%); }

/* 深色模式适配skosko */
[data-theme="dark"] {
    .fas.sko-icon-wechat { filter: invert(65%) sepia(25%) saturate(1000%) hue-rotate(86deg) brightness(95%) contrast(85%); }
    .fas.sko-icon-qq { filter: invert(60%) sepia(90%) saturate(500%) hue-rotate(176deg) brightness(95%) contrast(90%); }
    .fas.sko-icon-bilibili { filter: invert(65%) sepia(40%) saturate(800%) hue-rotate(306deg) brightness(95%) contrast(90%); }
    .fas.sko-icon-xiaohongshu { filter: invert(40%) sepia(80%) saturate(800%) hue-rotate(330deg) brightness(95%) contrast(90%); }
}





[data-theme="dark"] .btn-success{
	color: var(--neutral-200);
	background-color: var(--success-600);
}

[data-theme="dark"] .resource-card, .chapter-item{
    box-shadow: 0 2px 5px var(--neutral-300);background:var(--neutral-100); 
}
[data-theme="dark"] .resource-card:hover, .chapter-item:hover{
    box-shadow: 0 2px 5px var(--orange-500);background:var(--neutral-200) !important; 
}
[data-theme="dark"] .btn-primary {
    color: var(--neutral-800)!important; 
}
[data-theme="dark"] .btn-primary a {
    color: var(--neutral-800)!important; 
}
[data-theme="dark"] .btn-primary:hover {
    color: var(--neutral-900);
}
[data-theme="dark"] .nav-tabs > li.active > a{
	background: var(--neutral-300); color: var(--neutral-800);
	border: 0px;
}
[data-theme="dark"] .nav-tabs > li > a:hover{
	background: var(--neutral-400); color: var(--neutral-900);
	border-bottom: 2px solid var(--blue-500);
}
[data-theme="dark"] .course-tabs .nav-item.active .nav-link{
    border-bottom: 2px solid var(--orange-500);
}

[data-theme="dark"] .btn{
	color: var(--neutral-900);
}
[data-theme="dark"] .btn-default{
	color: var(--neutral-200);
	background-color: var(--neutral-800);
}

[data-theme="dark"] .btn-outline-secondary{
	background: var(--neutral-300);
}
.panel-default {
    padding: 0px;
    border: none;
}

.btn {
	border-radius: var(--radius-xl)!important;
}

.panel {
	background: transparent;
}

.skocard, .skocard-header, .skocard-con{
	     position: relative;
        overflow: hidden;
		    border-radius: var(--radius-xl);
}
 [data-theme="default"] .skocard-header {
	background: var(--qns-3)!important;
		border: 1px solid var(--primary-50)!important;
		box-shadow: 0px 6px 8px var(--qns-10);
}

[data-theme="default"] .skocard::before {
        content: '';
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 2px;
        background:  var(--accent-500);
        transform: scaleX(0);
        transition: var(--transition-normal);
    }

[data-theme="default"]  .skocard-header::before  {
        content: '';
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 2px;
        background:  var(--accent-500);
        transform: scaleX(0);
        transition: var(--transition-normal);
    }

[data-theme="default"] .skocard-con::before {
        content: '';
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 2px;
        background:  var(--primary-500);
        transform: scaleX(0);
        transition: var(--transition-normal);
    }
[data-theme="default"] .skocard-chd {
	background: linear-gradient( 70deg, var(--neutral-50)0%, var(--qns-5)100%);
			box-shadow: 0px 6px 8px var(--qns-10);
    border-bottom: 1px solid var(--qns-5) 
}

[data-theme="default"] .skocard{
	border:1px solid var(--primary-100 );
			box-shadow: 0px 6px 8px var(--qns-10);
    background: transparent;}
[data-theme="default"] .skocard-header:hover{
	box-shadow: 0px 10px 10px -2px rgba(245, 158, 11, 0.1);
}
[data-theme="default"] .skocard:hover{
	border: 1px solid var(--accent-200);
	box-shadow: 0 6px 12px rgba(245, 158, 11, 0.05);
	.skocard-chd {
	border-bottom: 1px solid var(--qns-10);
	box-shadow: 0px 6px 8px var(--qns-20);
		background: linear-gradient(260deg, var(--neutral-50)0%, var(--qns-5)100%);
}
}
[data-theme="default"] .btn-primary {
    background: linear-gradient(135deg, var(--accent), var(--accent-dark));
    border-color: var(--accent);
    color: var(--neutral-100);
    box-shadow: var(--shadow-sm);
}
[data-theme="default"] .btn-primary:hover {
    background: linear-gradient(45deg, var(--accent-400), var(--accent-500));
    border-color: var(--accent);
    color: var(--neutral-50);
    box-shadow: var(--shadow-sm);
}
[data-theme="default"] .skocard-con {
	background:  var(--qns-2);
		border: 1px solid var(--primary-100);
				box-shadow: 0px 6px 8px var(--qns-10);
}
[data-theme="default"] .skocard-con:hover {
		border: 1px solid var(--primary-200);
	box-shadow: 0px 5px 8px -2px rgba(14, 165, 233, 0.3);
}
[data-theme="default"]  .skocard:hover::before, .skocard-header:hover::before ,.skocard-con:hover::before {
        transform: scaleX(1);
    }



 [data-theme="dark"] .skocard-dbfg {
	  position: relative;
        overflow: hidden;
 }
 [data-theme="dark"]  .skocard-dbfg:hover::before {
	 transform: scaleX(1);
 }
[data-theme="dark"]  .skocard-dbfg::before  {
 content: '';
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 3px;
        background:  var(--primary-400);
        transform: scaleX(0);
        transition: var(--transition-normal);
}

 [data-theme="default"] .skocard-dbfg {
	  position: relative;
        overflow: hidden;
 }
 [data-theme="default"]  .skocard-dbfg:hover::before {
	 transform: scaleX(1);
 }
[data-theme="default"]  .skocard-dbfg::before  {
 content: '';
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 3px;
        background:  var(--accent-400);
        transform: scaleX(0);
        transition: var(--transition-normal);
}



[data-theme="dark"] .skocard-chd {
	background: linear-gradient( 90deg, var(--neutral-200), var(--neutral-200));
	
}
[data-theme="dark"] .skocard, .skocard-header, .skocard-con{
	     position: relative;
        overflow: hidden;
}
[data-theme="dark"]  .skocard:hover::before, .skocard-header:hover::before , .skocard-con:hover::before, .skocard-chd:hover::before {
        transform: scaleX(1);
    }
[data-theme="dark"] .skocard-header:hover{
	box-shadow: 0px 10px 10px -2px rgba(14, 165, 233, 0.6);
}
[data-theme="dark"] .skocard, .skocard-header{
	border:1px solid var(--neutral-300 );
		background: var(--neutral-100 );
}

[data-theme="dark"] .skocard:hover{
	border: 1px solid var(--primary-800)!important;
	box-shadow: 0 6px 12px rgba(14, 165, 233, 0.6);
	 .skocard-chd::before {
        transform: scaleX(1);
    }
	.skocard-chd { 
	box-shadow: 0 3px 6px rgba(14, 165, 233, 0.2);}
}
[data-theme="dark"] .skocard-chd{
	     position: relative;overflow: hidden;
}
[data-theme="dark"] .skocard-chd::before {
        content: '';
        position: absolute;
        bottom: 0;
		left:0;
        width: 100%;
        height: 1px;
        background: rgba(14, 165, 233, 0.2);
        transform: scaleX(0);
        transition: var(--transition-normal);
	}
	
[data-theme="dark"] .skocard::before, .skocard-header::before , .skocard-con::before {
        content: '';
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 3px;
        background:  var(--primary-400);
        transform: scaleX(0);
        transition: var(--transition-normal);
    }



[data-theme="dark"] .skocard-con {
	background:  var(--neutral-200);
		border: 1px solid var(--neutral-300);
position: relative;
        overflow: hidden;
}
[data-theme="dark"] .skocard-con:hover {
	box-shadow: 0px 5px 8px -2px rgba(245, 158, 11, 0.6);
}
[data-theme="dark"] .skocard-con::before {
	        background:  var(--accent-500);

}




/* 页面头部 - 独立容器 */
.service-header-section {
    padding: var(--padding-lg);
    background: linear-gradient(135deg, var(--primary-50) 0%, var(--primary-100) 100%);
    box-shadow: var(--shadow-sm);
}

[data-theme="dark"] .service-header-section {
    background: linear-gradient(135deg, var(--neutral-200) 0%, var(--neutral-300) 100%);
}

.service-header {
    color: var(--text-primary);
    font-size: var(--text-3xl);
    font-weight: var(--font-bold);
    margin: 0 0 var(--margin-sm) 0;
}

.service-subtitle {
    color: var(--text-secondary);
    font-size: var(--text-lg);
    margin: 0;
    font-weight: var(--font-normal);
    line-height: var(--leading-relaxed);
}

/* 联系方式网格 */
.contact-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--gap-lg);
}

.contact-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--padding-lg);
    text-align: center;
    border-radius: var(--radius-card);
    transition: var(--transition-normal);
}

.contact-icon {
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--primary-100);
    color: var(--primary);
    border-radius: var(--radius-full);
    margin-bottom: var(--margin-md);
}

.contact-info {
    width: 100%;
}

.contact-name {
    font-size: var(--text-lg);
    font-weight: var(--font-semibold);
    color: var(--text-primary);
    margin-bottom: var(--margin-xs);
}

.contact-value {
    font-size: var(--text-base);
    color: var(--text-secondary);
    margin-bottom: var(--margin-md);
    word-break: break-all;
}

/* 平台网格 */
.platform-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: var(--gap-lg);
}

.platform-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--padding-lg);
    text-align: center;
    border-radius: var(--radius-card);
    transition: var(--transition-normal);
}

.platform-icon {
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--accent-100);
    color: var(--accent);
    border-radius: var(--radius-full);
    margin-bottom: var(--margin-md);
}

.platform-name {
    font-size: var(--text-lg);
    font-weight: var(--font-semibold);
    color: var(--text-primary);
    margin-bottom: var(--margin-sm);
}

.platform-desc {
    font-size: var(--text-sm);
    color: var(--text-secondary);
    margin-bottom: var(--margin-lg);
    line-height: var(--leading-relaxed);
}

.platform-value {
    font-size: var(--text-sm);
    color: var(--text-muted);
    padding: var(--padding-sm);
    background: var(--neutral-100);
    border-radius: var(--radius);
    width: 100%;
}


.chapter-title{
	padding-top: 10px;
}
.chapter-type-video{
	background-color: var(--accent-300);
}
.chapter-type-download{
	background-color: var(--success-300);
}
.chapter-type-content{
    background-color: var(--primary-300);
}
.chapter-type-default{
     background-color: var(--neutral-300);
}

[data-theme="dark"] .chapter-type-video{
	background-color: var(--accent-700);
}
[data-theme="dark"] .chapter-type-download{
	background-color: var(--success-700);
}
[data-theme="dark"] .chapter-type-content{
    background-color: var(--primary-700);
}
[data-theme="dark"] .chapter-type-default{
     background-color: var(--neutral-700);
}





/* ===== 移动端全局优化样式 ===== */

/* 移动端基础重置 */
@media (max-width: 768px) {
  /* 容器优化 */
  .container {
    padding-left: 12px;
    padding-right: 12px;
    max-width: 100%;
    overflow-x: hidden;
  }



  /* 面板优化 */
  .panel {
    margin-bottom: 16px;
    border-radius: 12px;
    overflow: hidden;
  }

  .panel-body {
    padding: 16px;
  }

  /* 卡片通用样式 */
  .card {
    margin-bottom: 16px;
    border-radius: 12px;
    overflow: hidden;
  }

  .card-header {
    padding: 16px;
    font-size: 16px;
  }

  .card-body {
    padding: 16px;
  }

  /* 按钮优化 */
  .btn {
    padding: 12px 16px;
    font-size: 15px;
    border-radius: 8px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .btn-block {
    width: 100%;
  }

  .btn-lg {
    padding: 14px 20px;
    font-size: 16px;
  }

  /* 表单优化 */
  .form-group {
    margin-bottom: 20px;
  }

  .form-label {
    font-size: 15px;
    margin-bottom: 8px;
    font-weight: 500;
  }

  .form-control {
    padding: 12px 16px;
    font-size: 16px;
    border-radius: 8px;
    min-height: 44px;
  }

  /* 图片响应式 */
  img {
    max-width: 100%;
    height: auto;
  }

  /* 文字大小优化 */
  h1 { font-size: 24px; }
  h2 { font-size: 20px; }
  h3 { font-size: 18px; }
  h4 { font-size: 16px; }
  h5 { font-size: 15px; }
  h6 { font-size: 14px; }

  .text-lg { font-size: 16px; }
  .text-xl { font-size: 18px; }
  .text-2xl { font-size: 20px; }

  /* 间距优化 */
  .p-lg { padding: 16px; }
  .p-xl { padding: 20px; }
  .m-lg { margin: 16px; }
  .m-xl { margin: 20px; }

  /* 徽章优化 */
  .badge {
    padding: 4px 8px;
    font-size: 12px;
    border-radius: 10px;
  }

  /* 弹性布局优化 */
  .d-flex {
    flex-wrap: wrap;
  }

  /* 网格布局优化 */
  .grid {
    gap: 12px;
  }





/* 超小屏幕优化 */
@media (max-width: 480px) {
  .container {
    padding-left: 8px;
    padding-right: 8px;
  }

  .panel-body {
    padding: 12px;
  }

  .card-body {
    padding: 12px;
  }

  .btn {
    padding: 10px 14px;
    font-size: 14px;
    min-height: 40px;
  }

  .form-control {
    padding: 10px 14px;
    font-size: 15px;
    min-height: 40px;
  }
}

/* 平板端优化 */
@media (min-width: 769px) and (max-width: 1024px) {
  .container {
    padding-left: 16px;
    padding-right: 16px;
  }
  
 
  


/* 移动端交互优化 */
@media (max-width: 768px) {
  /* 提高点击区域 */
  a, button, .btn {
    min-height: 44px;
    min-width: 44px;
  }

  /* 优化触摸滚动 */
  .card-body {
    -webkit-overflow-scrolling: touch;
  }

  /* 优化过渡动画 */
  * {
    transition-duration: 0.2s;
  }
}

/* 移动端深色模式优化 */
@media (max-width: 768px) {
  [data-theme="dark"] .card {
    background: var(--neutral-100);
    border-color: var(--neutral-300);
  }

  [data-theme="dark"] .card-header {
    background: var(--neutral-200);
    border-color: var(--neutral-300);
  }

  [data-theme="dark"] .btn {
    border-color: var(--neutral-400);
  }
}

/* ===== 软件分类列表全局样式 ===== */

/* 软件网格布局 */
.software-grid {
    display: grid;
    gap: var(--gap-lg);
}

.grid-cols-3 {
    grid-template-columns: repeat(3, 1fr);
}

/* 软件卡片通用样式 */
.software-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-card);
    transition: var(--transition-normal);
    overflow: hidden;
    position: relative;
}

.software-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

/* 软件图标样式 */
.software-icon {
    flex-shrink: 0;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--neutral-100);
    display: flex;
    align-items: center;
    justify-content: center;
}

.software-icon img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* 软件信息区域 */
.software-info {
    flex: 1;
    min-width: 0;
}

.software-title {
    color: var(--text-primary);
    font-weight: var(--font-semibold);
    line-height: var(--leading-tight);
    margin-bottom: var(--space-2);
}

.software-desc {
    color: var(--text-secondary);
    font-size: var(--text-sm);
    line-height: var(--leading-relaxed);
    margin-bottom: var(--space-3);
}

/* 软件元信息 */
.software-meta {
    display: flex;
    gap: var(--gap-md);
    color: var(--text-muted);
    font-size: var(--text-sm);
}

.meta-item {
    display: flex;
    align-items: center;
    gap: var(--space-1);
}

/* 热门标签 */
.hot-badge {
    position: absolute;
    top: var(--space-3);
    right: var(--space-3);
    background: linear-gradient(135deg, var(--orange-500), var(--orange-600));
    color: white;
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    font-weight: var(--font-semibold);
    z-index: 2;
    box-shadow: var(--shadow-sm);
}

/* 空状态样式 */
.empty-category {
    text-align: center;
    padding: var(--space-8) var(--space-4);
    color: var(--text-muted);
}

.empty-icon {
    font-size: 3rem;
    color: var(--neutral-400);
    margin-bottom: var(--space-4);
}

.empty-title {
    color: var(--text-primary);
    font-size: var(--text-xl);
    font-weight: var(--font-semibold);
    margin-bottom: var(--space-2);
}

.empty-description {
    color: var(--text-secondary);
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    max-width: 400px;
    margin: 0 auto;
}

/* 分类标题 */
.category-title {
    color: var(--text-primary);
    font-size: var(--text-xl);
    font-weight: var(--font-semibold);
    margin: 0;
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

.category-more {
    color: var(--primary);
    text-decoration: none;
    font-weight: var(--font-medium);
    transition: var(--transition-normal);
}

.category-more:hover {
    color: var(--primary-dark);
    transform: translateX(2px);
}

/* 移动端软件列表优化 */
@media (max-width: 768px) {
    /* 软件网格布局 */
    .software-grid {
        grid-template-columns: 1fr;
        gap: var(--gap-md);
    }
    
    .grid-cols-3 {
        grid-template-columns: 1fr;
    }
    
    /* 软件卡片移动端优化 */
    .software-card {
        margin-bottom: var(--space-4);
        border-radius: var(--radius-lg);
    }
    
    /* 软件图标移动端优化 */
    .software-icon {
        width: 80px;
        height: 80px;
        border-radius: var(--radius-lg);
    }
    
    /* 软件信息移动端优化 */
    .software-info {
        padding: var(--space-3);
    }
    
    .software-title {
        font-size: var(--text-lg);
        margin-bottom: var(--space-2);
    }
    
    .software-desc {
        font-size: var(--text-sm);
        line-height: 1.5;
        margin-bottom: var(--space-3);
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }
    
    /* 软件元信息移动端优化 */
    .software-meta {
        flex-direction: column;
        gap: var(--space-2);
        align-items: flex-start;
    }
    
    .meta-item {
        font-size: var(--text-xs);
    }
    
    /* 热门标签移动端优化 */
    .hot-badge {
        top: var(--space-2);
        right: var(--space-2);
        padding: var(--space-1) var(--space-2);
        font-size: var(--text-xs);
    }
    
    /* 按钮移动端优化 */
    .software-actions .btn {
        width: 100%;
        justify-content: center;
        margin-top: var(--space-3);
    }
    
    /* 空状态移动端优化 */
    .empty-category {
        padding: var(--space-6) var(--space-4);
    }
    
    .empty-icon {
        font-size: 2.5rem;
        margin-bottom: var(--space-3);
    }
    
    .empty-title {
        font-size: var(--text-lg);
    }
    
    .empty-description {
        font-size: var(--text-sm);
    }
    
    /* 分类标题移动端优化 */
    .category-title {
        font-size: var(--text-lg);
        flex-direction: column;
        align-items: flex-start;
        gap: var(--space-2);
    }
    
    .category-more {
        align-self: flex-end;
        margin-top: var(--space-2);
    }
}

/* 超小屏幕优化 */
@media (max-width: 480px) {
    .software-card {
        margin-bottom: var(--space-3);
    }
    
    .software-icon {
        width: 60px;
        height: 60px;
    }
    
    .software-info {
        padding: var(--space-2);
    }
    
    .software-title {
        font-size: var(--text-base);
    }
    
    .software-desc {
        font-size: var(--text-xs);
        -webkit-line-clamp: 3;
    }
    
    .empty-category {
        padding: var(--space-4) var(--space-3);
    }
    
    .hot-badge {
        padding: 2px 6px;
        font-size: 10px;
    }
}

/* 平板端优化 */
@media (min-width: 769px) and (max-width: 1024px) {
    .grid-cols-3 {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .software-icon {
        width: 100px;
        height: 100px;
    }
}

/* 深色模式优化 */
[data-theme="dark"] {
    .software-card {
        background: var(--neutral-100);
        border-color: var(--neutral-300);
    }
    
    .software-icon {
        background: var(--neutral-200);
    }
    
    .hot-badge {
        background: linear-gradient(135deg, var(--orange-600), var(--orange-700));
    }
    
    .empty-icon {
        color: var(--neutral-500);
    }
}



























