/* ============================================================
   AI智享家 · 设计令牌体系 (Design Tokens)
   版本: v1.0 | 皮肤: 青花雅韵 (默认)
   ============================================================
   用法: 所有页面 <link rel="stylesheet" href="/static/css/tokens.css">
        品牌覆盖用 <link rel="stylesheet" href="/static/css/brand-xxx.css">
   ============================================================ */

:root {
  /* ===== 色板 ===== */
  --bg-page:         #F0F4FA;  /* 页面底色：淡蓝白 */
  --bg-card:         #FFFFFF;  /* 卡片底色 */
  --bg-input:        #F5F8FC;  /* 输入框底色 */
  --bg-hover:        rgba(43,87,151,.06); /* 悬浮态 */

  --text-primary:    #1A2A3A;  /* 主文字：深蓝黑 对比度10:1 */
  --text-secondary:  #3A4A5A;  /* 次级文字：中蓝灰 对比度6:1 */
  --text-muted:      #5A6A7A;  /* 辅助文字：浅蓝灰 对比度4.5:1 */
  --text-placeholder:#7A8A9A;  /* 占位符文字 */
  --text-on-primary: #FFFFFF;  /* 主色上的文字 */

  --color-primary:   #2B5797;  /* 青花主色 */
  --color-primary-hover:#1E3F6E;/* 主色悬浮 */
  --color-accent:    #5A8ABA;  /* 强调色：青花辅色 */
  --color-accent-light: rgba(43,87,151,.08); /* 轻强调底色 */

  --border-color:    rgba(74,90,106,.12);  /* 边框色 */
  --border-light:    rgba(74,90,106,.06);  /* 轻边框 */
  --shadow-sm:       0 1px 3px rgba(26,42,58,.06);
  --shadow-md:       0 4px 12px rgba(26,42,58,.08);

  --radius-sm:   6px;
  --radius-md:   10px;
  --radius-lg:   14px;
  --radius-xl:   18px;

  /* ===== 字号系统（全部 >= 14px，不透明度 >= 0.85） ===== */
  --text-xs:   11px;
  --text-sm:   13px;
  --text-base: 15px;    /* 正文基准 */
  --text-lg:   17px;
  --text-xl:   20px;
  --text-2xl:  24px;

  /* ===== 间距 ===== */
  --space-xs:  4px;
  --space-sm:  8px;
  --space-md:  12px;
  --space-lg:  16px;
  --space-xl:  24px;

  /* ===== 字体 ===== */
  --font-body: -apple-system, "PingFang SC", "Microsoft YaHei", sans-serif;
}

/* ===== 全局重置 ===== */
*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: var(--font-body);
  background: var(--bg-page);
  color: var(--text-primary);
  font-size: var(--text-base);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  margin: 0;
}

/* ===== 链接 ===== */
a { color: var(--color-primary); text-decoration: none; }
a:hover { color: var(--color-primary-hover); }

/* ===== 卡片 ===== */
.card {
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--space-lg);
  border: 1px solid var(--border-light);
}
.card-title {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: var(--space-sm);
}

/* ===== 输入框 ===== */
.input {
  width: 100%;
  padding: 10px 14px;
  font-size: var(--text-base);
  color: var(--text-primary);
  background: var(--bg-input);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  outline: none;
  transition: border-color .2s;
}
.input:focus { border-color: var(--color-primary); }
.input::placeholder { color: var(--text-placeholder); }

/* ===== 按钮 ===== */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px 20px;
  font-size: var(--text-base);
  font-weight: 600;
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all .2s;
  text-align: center;
  line-height: 1.4;
}
.btn:active { transform: scale(.97); }

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

.btn-outline {
  background: transparent;
  color: var(--color-primary);
  border: 1.5px solid var(--color-primary);
}
.btn-outline:hover { background: var(--color-accent-light); }

.btn-sm {
  padding: 6px 14px;
  font-size: var(--text-sm);
}

/* ===== 徽章 ===== */
.badge {
  display: inline-block;
  padding: 2px 10px;
  font-size: var(--text-xs);
  font-weight: 600;
  border-radius: 20px;
  line-height: 1.6;
}
.badge-primary { background: var(--color-primary); color: var(--text-on-primary); }
.badge-accent { background: var(--color-accent-light); color: var(--color-primary); }

/* ===== 导航标签 ===== */
.tabs {
  display: flex;
  gap: 2px;
  border-bottom: 1px solid var(--border-color);
  padding-bottom: var(--space-sm);
  margin-bottom: var(--space-lg);
  overflow-x: auto;
}
.tab {
  padding: 8px 14px;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-muted);
  cursor: pointer;
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
  transition: all .2s;
  white-space: nowrap;
}
.tab:hover { color: var(--text-primary); background: var(--bg-hover); }
.tab.active { color: var(--color-primary); font-weight: 700; border-bottom: 2px solid var(--color-primary); }

/* ===== 分割线 ===== */
hr { border: none; border-top: 1px solid var(--border-color); margin: var(--space-md) 0; }

/* ===== 页面头部 ===== */
.page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-lg) var(--space-xl);
  background: var(--bg-card);
  border-bottom: 1px solid var(--border-light);
}
.page-header h1 {
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
}

/* ===== 空状态 ===== */
.empty-state {
  text-align: center;
  padding: 40px 20px;
  color: var(--text-muted);
  font-size: var(--text-sm);
}

/* ===== Toast 提示 ===== */
.toast {
  position: fixed;
  bottom: 80px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--text-primary);
  color: var(--bg-card);
  padding: 10px 24px;
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  font-weight: 500;
  z-index: 9999;
  box-shadow: var(--shadow-md);
  transition: opacity .3s, transform .3s;
  opacity: 0;
  pointer-events: none;
}
.toast.show { opacity: 1; pointer-events: auto; }

/* ===== 底部操作栏 ===== */
.bottom-actions {
  position: sticky;
  bottom: 0;
  width: 100%;
  padding: var(--space-md) var(--space-lg);
  background: var(--bg-card);
  border-top: 1px solid var(--border-color);
  display: flex;
  gap: var(--space-sm);
}
.bottom-actions .btn { flex: 1; }

/* ===== 辅助工具 ===== */
.text-center { text-align: center; }
.text-muted { color: var(--text-muted); }
.mt-sm { margin-top: var(--space-sm); }
.mt-md { margin-top: var(--space-md); }
.mt-lg { margin-top: var(--space-lg); }
.mb-sm { margin-bottom: var(--space-sm); }
.mb-md { margin-bottom: var(--space-md); }
