@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+SC:wght@300;400;500;700&display=swap');

:root {
  --primary: #2c6ecb;
  --primary-light: #e6f0ff;
  --success: #10b981;
  --warning: #f59e0b;
  --danger: #ef4444;
  --dark: #1f2937;
  --gray: #6b7280;
  --light-gray: #e5e7eb;
  --lighter-gray: #f3f4f6;
  --white: #ffffff;
  
  /* SVG图标背景颜色 */
  --bg-purple-light: #f3effb;
  --bg-blue-light: #e6f0ff;
  --bg-success-light: #ecfdf5;
  --bg-warning-light: #fffbeb;
  --bg-danger-light: #fef2f2;
  --bg-info-light: #e0f7fa;
  --bg-secondary-light: #f1f5f9;
  --bg-dark-light: #f8fafc;
  --bg-purple: #8b5cf6;
  --bg-blue: #3b82f6;
}

body {
  font-family: 'Noto Sans SC', sans-serif;
  background-color: #f9fafb;
  color: #374151;
  line-height: 1.5;
}

.logo {
  height: 36px;
}

.sidebar {
  background-color: var(--white);
  border-right: 1px solid var(--light-gray);
  min-height: 100vh;
}

.sidebar .nav-link {
  color: var(--gray);
  border-radius: 0.375rem;
  margin-bottom: 0.25rem;
  transition: all 0.2s;
}

.sidebar .nav-link:hover {
  background-color: var(--lighter-gray);
  color: var(--primary);
}

.sidebar .nav-link.active {
  background-color: var(--primary-light);
  color: var(--primary);
  font-weight: 500;
}

.main-content {
  min-height: calc(100vh - 60px);
}

.card {
  border-radius: 0.5rem;
  border: 1px solid var(--light-gray);
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1);
  background-color: var(--white);
}

.status-badge {
  display: inline-flex;
  padding: 0.25rem 0.75rem;
  border-radius: 9999px;
  font-size: 0.75rem;
  font-weight: 500;
}

.status-badge.pending {
  background-color: #fff7ed;
  color: #c2410c;
}

.status-badge.processing {
  background-color: #eff6ff;
  color: #1d4ed8;
}

.status-badge.completed {
  background-color: #ecfdf5;
  color: #047857;
}

.status-badge.cancelled {
  background-color: #fef2f2;
  color: #b91c1c;
}

.btn-primary {
  background-color: var(--primary);
}

.btn-primary:hover {
  background-color: #1d4ed8;
}

.btn-outline-primary {
  color: var(--primary);
  border-color: var(--primary);
}

.btn-outline-primary:hover {
  background-color: var(--primary-light);
  color: var(--primary);
}

.avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  object-fit: cover;
}

.avatar-lg {
  width: 64px;
  height: 64px;
}

.chart-container {
  height: 300px;
}

.progress-thin {
  height: 6px;
}

.table-hover tbody tr:hover {
  background-color: var(--lighter-gray);
} 

/* SVG 图标 */
.tcm-logo {
  fill: var(--primary);
  height: 36px;
}

/* 背景颜色 */
.bg-purple-light {
  background-color: var(--bg-purple-light);
}

.bg-info-light {
  background-color: var(--bg-info-light);
}

.bg-success-light {
  background-color: var(--bg-success-light);
}

.bg-warning-light {
  background-color: var(--bg-warning-light);
}

.bg-danger-light {
  background-color: var(--bg-danger-light);
}

.bg-secondary-light {
  background-color: var(--bg-secondary-light);
}

.bg-dark-light {
  background-color: var(--bg-dark-light);
}

.text-purple {
  color: var(--bg-purple);
}

/* 会员类型徽章 */
.badge.bg-purple {
  background-color: var(--bg-purple) !important;
}

.badge.bg-blue {
  background-color: var(--bg-blue) !important;
} 
