/* 按钮 */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-sm);
  padding: 10px 18px; border: 1px solid var(--c-outline-var); border-radius: var(--r-lg);
  background: var(--c-surface-container); color: var(--c-on-surface);
  font-size: var(--fs-sm); font-weight: 600;
  transition: all .15s var(--ease);
}
.btn:hover { border-color: var(--c-primary); color: var(--c-primary); }
.btn:disabled { opacity: .55; cursor: not-allowed; }

.btn--primary {
  background: var(--c-primary-container); color: var(--c-on-primary);
  border-color: transparent; letter-spacing: .08em; text-transform: uppercase;
  box-shadow: var(--shadow-glow);
}
.btn--primary:hover { color: var(--c-on-primary); filter: brightness(1.06); }

.btn--ghost { background: transparent; border-color: var(--c-outline-var); }
.btn--block { width: 100%; padding: 13px 18px; }

/* 主题切换 */
.theme-toggle {
  display: inline-flex; align-items: center; gap: var(--sp-sm);
  padding: 7px 12px; border-radius: var(--r-full);
  border: 1px solid var(--c-outline-var); background: var(--c-surface-container);
  color: var(--c-on-surface); font-size: var(--fs-sm); font-weight: 600;
}
.theme-toggle:hover { border-color: var(--c-primary); }
.theme-toggle__dot { width: 14px; height: 14px; border-radius: var(--r-full); background: var(--c-primary-container); box-shadow: 0 0 0 3px var(--c-surface); }
