/* 设计系统规范 - 基于70_646组件 */

/* ===== 颜色系统 ===== */
:root {
  /* 主色调 */
  --primary-color: #00B0C2;        /* 青色 */
  --primary-light: #7BD7E0;        /* 浅青色 */
  --primary-lighter: #F0F8FB;      /* 极浅青色 */
  --primary-hover: #008A9B;        /* 主色悬停 */
  
  /* 中性色 */
  --text-primary: #303030;         /* 黑色 */
  --text-secondary: #C4C4C4;       /* 灰色 */
  --text-color: #303030;           /* 文本颜色 */
  --text-muted: #666666;           /* 次要文本 */
  --text-light: #888888;           /* 浅色文本 */
  --background-light: #D9D9D9;     /* 浅灰色 */
  --background-white: #FFFFFF;     /* 白色 */
  
  /* 中性色系 */
  --neutral-600: #6c757d;          /* 中性灰 */
  --neutral-700: #545b62;          /* 深中性灰 */
  
  /* 强调色 */
  --accent-color: #764ba2;         /* 紫色强调 */
  --accent-orange: #FE8C00;        /* 橙色 */
  
  /* 成功色系 */
  --success-color: #28a745;        /* 成功绿 */
  --success-hover: #1e7e34;        /* 成功绿悬停 */
  --success-bg: #d4edda;           /* 成功背景 */
  --success-text: #155724;         /* 成功文本 */
  --success-border: #c3e6cb;       /* 成功边框 */
  
  /* 警告色系 */
  --warning-bg: #fff3cd;           /* 警告背景 */
  --warning-text: #856404;         /* 警告文本 */
  --warning-border: #ffeaa7;       /* 警告边框 */
  
  /* 错误色系 */
  --error-bg: #f8d7da;             /* 错误背景 */
  --error-text: #721c24;           /* 错误文本 */
  --error-border: #f5c6cb;         /* 错误边框 */
  
  /* 边框色 */
  --border-color: #000000;         /* 黑色边框 */
}

/* ===== 字体系统 ===== */
:root {
  /* 字体族 */
  --font-family: Inter, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", SimHei, Arial, Helvetica, sans-serif;
  
  /* 字体大小 */
  --font-size-h1: 36px;           /* H1 副标题 */
  --font-size-h2: 24px;           /* H2 副标题 */
  --font-size-h3: 20px;           /* H3 选项 */
  --font-size-body: 16px;         /* 正文 */
  --font-size-small: 12px;        /* 小号正文 */
  --font-size-xs: 10px;           /* 小号字体 */
  
  /* 字体粗细 */
  --font-weight-bold: 700;        /* 加粗 */
  --font-weight-medium: 500;      /* 中等 */
  --font-weight-light: 300;       /* 细体 */
  --font-weight-normal: 400;      /* 正常 */
}

/* ===== 基础样式重置 ===== */
* {
  box-sizing: border-box;
}

body {
  font-family: var(--font-family);
  color: var(--text-primary);
  background-color: var(--background-white);
  margin: 0;
  padding: 0;
  line-height: 1.5;
}

/* ===== 标题样式 ===== */
.h1, h1 {
  font-size: var(--font-size-h1);
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
  margin: 0;
  line-height: 1.4;
}

.h2, h2 {
  font-size: var(--font-size-h2);
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
  margin: 0;
  line-height: 1.3;
}

.h3, h3 {
  font-size: var(--font-size-h3);
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
  margin: 0;
  line-height: 1.3;
}

.h3-bold {
  font-size: var(--font-size-h3);
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
}

.h3-muted {
  font-size: var(--font-size-h3);
  font-weight: var(--font-weight-medium);
  color: var(--text-secondary);
}

/* ===== 正文样式 ===== */
.text-body {
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-normal);
  color: var(--text-primary);
}

.text-small {
  font-size: var(--font-size-small);
  font-weight: var(--font-weight-light);
  color: var(--text-primary);
}

.text-small-bold {
  font-size: var(--font-size-small);
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
}

.text-small-muted {
  font-size: var(--font-size-small);
  font-weight: var(--font-weight-light);
  color: var(--text-secondary);
}

.text-xs {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-light);
  color: var(--text-primary);
}

.text-xs-bold {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
}

.text-xs-muted {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-light);
  color: var(--text-secondary);
}

/* ===== 颜色工具类 ===== */
.text-primary {
  color: var(--text-primary);
}

.text-secondary {
  color: var(--text-secondary);
}

.text-accent {
  color: var(--primary-color);
}

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

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

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

.bg-accent {
  background-color: var(--accent-orange);
}

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

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

/* ===== 按钮样式 ===== */
.btn {
  font-family: var(--font-family);
  font-size: var(--font-size-small);
  font-weight: var(--font-weight-medium);
  padding: 8px 16px;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.3s ease;
  text-decoration: none;
  display: inline-block;
  text-align: center;
}

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

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

.btn-secondary {
  background-color: var(--background-light);
  color: var(--text-primary);
  border: 1px solid var(--text-secondary);
}

.btn-secondary:hover {
  background-color: var(--text-secondary);
  color: var(--background-white);
}

.btn-accent {
  background-color: var(--accent-orange);
  color: var(--background-white);
}

.btn-accent:hover {
  opacity: 0.9;
}

/* ===== 卡片样式 ===== */
.card {
  background-color: var(--background-white);
  border: 1px solid var(--text-secondary);
  border-radius: 8px;
  padding: 20px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.card-bordered {
  border: 1px solid var(--border-color);
}

/* ===== 间距系统 ===== */
.spacing-xs { margin: 4px; }
.spacing-sm { margin: 8px; }
.spacing-md { margin: 16px; }
.spacing-lg { margin: 24px; }
.spacing-xl { margin: 32px; }

.padding-xs { padding: 4px; }
.padding-sm { padding: 8px; }
.padding-md { padding: 16px; }
.padding-lg { padding: 24px; }
.padding-xl { padding: 32px; }

/* ===== 布局工具类 ===== */
.flex {
  display: flex;
}

.flex-column {
  flex-direction: column;
}

.flex-center {
  justify-content: center;
  align-items: center;
}

.flex-between {
  justify-content: space-between;
}

.flex-start {
  justify-content: flex-start;
}

.flex-end {
  justify-content: flex-end;
}

.align-center {
  align-items: center;
}

.align-start {
  align-items: flex-start;
}

.align-end {
  align-items: flex-end;
}

/* ===== 响应式断点 ===== */
@media (max-width: 768px) {
  .h1, h1 {
    font-size: 28px;
  }
  
  .h2, h2 {
    font-size: 20px;
  }
  
  .h3, h3 {
    font-size: 18px;
  }
}

@media (max-width: 480px) {
  .h1, h1 {
    font-size: 24px;
  }
  
  .h2, h2 {
    font-size: 18px;
  }
  
  .h3, h3 {
    font-size: 16px;
  }
}