﻿/* ============================================
   admin.css（增强版）
   全局基础样式层（Design Tokens + Reset + Base Components）
   ============================================ */

/* --------------------------------------------
   1. Design Tokens：全局变量体系
-------------------------------------------- */
:root {
  /* 品牌色 & 语义色 */
  --color-primary: #1677ff;
  --color-primary-hover: #0f5ed2;
  --color-primary-active: #0a49a8;

  --color-success: #52c41a;
  --color-success-bg: #f6ffed;
  --color-success-border: #b7eb8f;

  --color-warning: #faad14;
  --color-warning-bg: #fff7e6;
  --color-warning-border: #ffd591;

  --color-danger: #ff4d4f;
  --color-danger-bg: #fff1f0;
  --color-danger-border: #ffa39e;

  /* 文本 & 边框 & 背景 */
  --color-text: #333333;
  --color-text-light: #666666;
  --color-text-disabled: #999999;

  --color-border: #e5e5e5;
  --color-border-light: #f0f0f0;

  --color-bg-body: #f5f6f8;
  --color-bg-card: #ffffff;
  --color-bg-disabled: #f5f5f5;

  /* 圆角 & 阴影 */
  --radius-sm: 2px;
  --radius-md: 4px;
  --radius-lg: 8px;

  --shadow-card: 0 2px 6px rgba(0,0,0,0.05);

  /* 字体体系 */
  --font-family-base: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, "Helvetica Neue", sans-serif;
  --font-size-xs: 12px;
  --font-size-sm: 13px;
  --font-size-md: 14px;
  --font-size-lg: 16px;

  /* 行高体系 */
  --line-height-base: 1.6;

  /* 间距体系 */
  --space-xxs: 2px;
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 12px;
  --space-lg: 16px;
  --space-xl: 24px;
}

/* --------------------------------------------
   2. 全局基础 Reset
-------------------------------------------- */
html, body {
  margin: 0;
  padding: 0;
  font-family: var(--font-family-base);
  font-size: var(--font-size-md);
  line-height: var(--line-height-base);
  color: var(--color-text);
  background: var(--color-bg-body);
}

a {
  color: var(--color-primary);
  text-decoration: none;
}
a:hover {
  color: var(--color-primary-hover);
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

h1, h2, h3, h4, h5 {
  margin: 0;
  font-weight: 600;
  color: var(--color-text);
}

/* --------------------------------------------
   3. 文本工具类
-------------------------------------------- */
.text-muted {
  color: var(--color-text-light);
  font-size: var(--font-size-sm);
}

/* --------------------------------------------
   4. 按钮组件（Button）
-------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 14px;
  font-size: var(--font-size-sm);
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  cursor: pointer;
  transition: all 0.15s ease-in-out;
  background: #ffffff;
  color: var(--color-text);
}

/* 尺寸体系 */
.btn-sm {
  padding: 4px 10px;
  font-size: var(--font-size-xs);
}
.btn-lg {
  padding: 8px 18px;
  font-size: var(--font-size-md);
}

/* 禁用状态 */
.btn:disabled,
.btn[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
}

/* 主按钮 */
.btn-primary {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #ffffff;
}
.btn-primary:hover {
  background: var(--color-primary-hover);
}
.btn-primary:active {
  background: var(--color-primary-active);
}

/* 成功按钮 */
.btn-success {
  background: var(--color-success-bg);
  border-color: var(--color-success-border);
  color: var(--color-success);
}
.btn-success:hover {
  background: #d9f7be;
}

/* 警告按钮 */
.btn-warning {
  background: var(--color-warning-bg);
  border-color: var(--color-warning-border);
  color: var(--color-warning);
}
.btn-warning:hover {
  background: #ffe7ba;
}

/* 危险按钮 */
.btn-danger {
  background: var(--color-danger-bg);
  border-color: var(--color-danger-border);
  color: var(--color-danger);
}
.btn-danger:hover {
  background: #ffccc7;
}

/* --------------------------------------------
   5. 输入框组件（Input）
-------------------------------------------- */
.form-input,
.input {
  display: inline-block;
  width: 100%;
  padding: 6px 10px;
  font-size: var(--font-size-sm);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  outline: none;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  background: #ffffff;
}

.form-input:focus,
.input:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 2px rgba(22, 119, 255, 0.15);
}

.form-input[disabled],
.input[disabled] {
  background: var(--color-bg-disabled);
  cursor: not-allowed;
}

/* 尺寸体系 */
.input-sm,
.form-input-sm {
  padding: 4px 8px;
  font-size: var(--font-size-xs);
}
.input-lg,
.form-input-lg {
  padding: 8px 12px;
  font-size: var(--font-size-md);
}

/* Select */
.form-select {
  width: 100%;
  padding: 6px 10px;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: #ffffff;
  font-size: var(--font-size-sm);
}

/* Textarea */
.form-textarea {
  width: 100%;
  padding: 8px 10px;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  font-size: var(--font-size-sm);
  resize: vertical;
}

/* --------------------------------------------
   6. 标签组件（Tag）
-------------------------------------------- */
.tag {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  background: var(--color-border-light);
  color: var(--color-text);
}

/* 语义色 Tag */
.tag-success {
  background: var(--color-success-bg);
  color: var(--color-success);
}
.tag-warning {
  background: var(--color-warning-bg);
  color: var(--color-warning);
}
.tag-danger {
  background: var(--color-danger-bg);
  color: var(--color-danger);
}
.tag-info {
  background: #e6f4ff;
  color: var(--color-primary);
}

/* --------------------------------------------
   7. 卡片组件（Card）
-------------------------------------------- */
.card {
  background: var(--color-bg-card);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
  padding: var(--space-md);
}
