/* ================================================
   auth2.css
   依赖 base.css，勿重复引入 reset
   ================================================ */

/* ── 登录页 body ──────────────────────────────── */
body.auth-body {
  min-height: 100vh;
  font-family: var(--font-body);
  background: var(--bg);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text);
}

/* ── 卡片 ─────────────────────────────────────── */
.auth-card {
  width: 100%;
  max-width: 420px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: var(--space-5) var(--space-6) var(--space-5);
  box-shadow: var(--shadow);
}

/* ── Header ───────────────────────────────────── */
.auth-header {
  text-align: center;
  margin-bottom: var(--space-5);
}
.auth-header h1 {
  font-size: var(--text-xl);
  font-weight: 600;
  font-family: var(--font-display);
}
.auth-header i {
  margin-right: var(--space-1);
  color: var(--accent);
}
.auth-header p {
  margin-top: var(--space-1);
  font-size: var(--text-sm);
  color: var(--muted);
}

/* ── 表单 ─────────────────────────────────────── */
.auth-form { display: flex; flex-direction: column }

.form-group { margin-bottom: var(--space-4) }

label i {
  margin-right: var(--space-1);
  color: var(--accent);
}

.required-label {
  font-size: var(--text-xs);
  color: var(--subtle);
}

/* ── 输入框（base 已处理 border/color/transition，覆盖尺寸差异） */
input[type="text"],
input[type="email"],
input[type="password"] {
  height: 40px;
  padding: 0 var(--space-3);
  margin-bottom: 0;
}

/* ── 密码字段 ─────────────────────────────────── */
.password-field { position: relative }

.password-toggle {
  position: absolute;
  right: var(--space-2);
  top: 50%;
  transform: translateY(-50%);
  cursor: pointer;
  color: var(--subtle);
  font-size: var(--text-sm);
  transition: color var(--duration) var(--ease);
}
.password-toggle:hover { color: var(--accent) }

/* ── 辅助文本 ─────────────────────────────────── */
.helper-text {
  margin: var(--space-1) 0;
  font-size: var(--text-xs);
  color: var(--muted);
  line-height: var(--leading);
}

/* ── 错误提示 ─────────────────────────────────── */
.auth-error {
  color: var(--color-danger);
  font-size: var(--text-sm);
  margin-bottom: var(--space-2);
}

/* ── 提交按钮 ─────────────────────────────────── */
.auth-btn {
  margin-top: var(--space-3);
  height: 40px;
  border: none;
  border-radius: var(--radius-sm);
  background: var(--accent);
  color: var(--panel);
  font-size: var(--text-sm);
  font-weight: 500;
  font-family: var(--font-body);
  cursor: pointer;
  transition: background var(--duration) var(--ease),
              transform var(--duration-fast) var(--ease);
}
.auth-btn:hover   { background: var(--accent-hover) }
.auth-btn:active  { transform: translateY(1px) }

/* ── 链接 ─────────────────────────────────────── */
.auth-links,
.policy-links { font-size: var(--text-xs) }

.auth-links a,
.policy-links a {
  color: var(--accent);
  text-decoration: none;
  transition: color var(--duration) var(--ease);
}
.auth-links a:hover,
.policy-links a:hover { text-decoration: underline }

.policy-links {
  margin-top: var(--space-4);
  color: var(--subtle);
}

/* ── 响应式 ───────────────────────────────────── */
@media (max-width: 480px) {
  .auth-card {
    margin: var(--space-4);
    padding: var(--space-5) var(--space-4);
  }
}

/* ── 暗色模式 ─────────────────────────────────── */
[data-theme="dark"] body.auth-body {
  background: var(--bg);
}
[data-theme="dark"] .auth-card {
  background: var(--panel);
  border-color: var(--line-strong);
}
[data-theme="dark"] .auth-btn {
  color: var(--bg);
}