/* balancer.css — 配平工具专属样式（共享组件样式在 v2.css） */

.balancer-hint { color: var(--color-text-lighter); font-size: var(--text-sm); margin-top: var(--space-sm); }
.balancer-hint code { background: var(--color-bg-compact); padding: 1px 6px; border-radius: var(--radius-sm); font-family: var(--font-family-code); font-size: 90%; color: var(--color-primary-dark); }
.balancer-btn { padding: 14px 32px; font-size: var(--text-lg); white-space: nowrap; }

/* ── 结果卡片 ── */
.result-card { background: var(--color-bg-card); border: 1px solid var(--color-border-lighter); border-radius: var(--radius-lg); padding: var(--space-lg); margin-bottom: var(--space-lg); box-shadow: var(--shadow-md); }
.card-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-md); padding-bottom: var(--space-sm); border-bottom: 1px solid var(--color-border-light); }
.card-header h3 { margin: 0; color: var(--color-secondary); font-size: 1.1rem; }
.card-actions { display: flex; gap: var(--space-sm); }
.svg-display { min-height: 100px; display: flex; justify-content: center; align-items: center; background: #f9fafc; border-radius: var(--radius-md); padding: var(--space-lg); }
.svg-display svg { max-width: 100%; height: auto; }
.svg-placeholder { color: var(--color-text-lighter); padding: var(--space-xl); }

.info-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: var(--space-md); }
.info-item { text-align: center; padding: var(--space-sm); }
.info-label { display: block; font-size: var(--text-sm); color: var(--color-text-lighter); margin-bottom: 4px; }
.info-value { display: block; font-size: var(--text-lg); font-weight: 600; color: var(--color-secondary); }

/* ── 配平步骤 ── */
.steps-list { display: flex; flex-direction: column; gap: var(--space-md); }
.step-item { display: flex; gap: var(--space-md); align-items: flex-start; }
.step-number { width: 32px; height: 32px; border-radius: var(--radius-circle); background: var(--color-primary); color: white; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: var(--text-base); flex-shrink: 0; }
.step-title { font-weight: 600; color: var(--color-secondary); margin-bottom: 4px; }
.step-detail pre { background: var(--color-bg-compact); padding: var(--space-md); border-radius: var(--radius-md); font-size: var(--text-sm); font-family: var(--font-family-code); line-height: 1.6; overflow-x: auto; white-space: pre-wrap; margin: 0; }

/* ── 氧化还原 ── */
.redox-table { margin-top: var(--space-md); }
.redox-row { display: grid; grid-template-columns: 60px 70px 70px 60px 80px; gap: var(--space-sm); padding: 6px 0; font-size: var(--text-sm); align-items: center; }
.redox-header { font-weight: 600; color: var(--color-text-lighter); border-bottom: 1px solid var(--color-border); }
.redox-ox { color: #e74c3c; font-weight: 600; }
.redox-re { color: #3498db; font-weight: 600; }
.redox-summary { margin-top: var(--space-md); font-size: var(--text-sm); color: var(--color-text-light); }

@media (max-width: 600px) {
  .info-grid { grid-template-columns: repeat(2, 1fr); }
}
