/* ==========================================================================
   Reading tool — result styles. Built on tokens.css.
   ========================================================================== */

/* Element color utilities (foreground / background) */
.el-fg--wood  { color: var(--c-element-wood); }
.el-fg--fire  { color: var(--c-element-fire); }
.el-fg--earth { color: var(--c-element-earth); }
.el-fg--metal { color: var(--c-element-metal); }
.el-fg--water { color: var(--c-element-water); }
.el-bg--wood  { background: var(--c-element-wood); }
.el-bg--fire  { background: var(--c-element-fire); }
.el-bg--earth { background: var(--c-element-earth); }
.el-bg--metal { background: var(--c-element-metal); }
.el-bg--water { background: var(--c-element-water); }

/* --- result header ------------------------------------------------------- */
.result-head { margin-top: var(--space-5); }
.result-head h2 { display: flex; align-items: baseline; gap: var(--space-3); flex-wrap: wrap; }
.dm-glyph { font-family: var(--font-display); font-size: 1.4em; }
.result-sub { color: var(--color-text-muted); font-size: var(--fs-sm); }
.corr-note {
  color: var(--color-gold);
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  margin-top: var(--space-2);
}
.corr-note .corr-breakdown { color: var(--color-text-faint); }

/* Birthplace field helpers (reading form) */
.field-help {
  color: var(--color-text-faint);
  font-family: var(--font-sans);
  font-size: var(--fs-xs);
  line-height: var(--lh-snug);
  margin: 0;
  max-width: none;
}
.other-place {
  display: grid;
  gap: var(--space-3);
  grid-template-columns: 1fr 1fr;
  margin-top: var(--space-2);
}
@media (max-width: 26rem) { .other-place { grid-template-columns: 1fr; } }

/* --- pillars grid -------------------------------------------------------- */
.pillars {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-3);
  margin-block: var(--space-5);
}
.pillar {
  text-align: center;
  background: var(--color-bg-elevated);
  border: var(--border-hairline);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-2);
}
.pillar--day {
  border-color: var(--color-accent);
  box-shadow: inset 0 0 0 1px var(--color-accent-ink);
}
.pillar--empty { opacity: 0.55; }
.pillar__label {
  font-family: var(--font-sans);
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--color-text-faint);
  margin-bottom: var(--space-2);
}
.pillar--day .pillar__label { color: var(--color-gold); }
.pillar__glyphs {
  font-family: var(--font-display);
  font-size: var(--fs-3xl);
  line-height: 1.1;
  display: flex;
  flex-direction: column;
}
.pillar__glyphs .glyph { display: block; }
.pillar__romaji { font-family: var(--font-sans); font-size: var(--fs-sm); color: var(--color-text-muted); margin-top: var(--space-2); }
.pillar__zodiac { font-family: var(--font-sans); font-size: var(--fs-xs); color: var(--color-text-faint); }

@media (max-width: 30rem) {
  .pillar__glyphs { font-size: var(--fs-2xl); }
  .pillars { gap: var(--space-2); }
}

/* --- five-element bars --------------------------------------------------- */
.balance-card { margin-block: var(--space-5); }
.balance-card h3 { font-size: var(--fs-lg); margin-bottom: var(--space-4); }
.bars { display: flex; flex-direction: column; gap: var(--space-3); }
.bar-row { display: grid; grid-template-columns: 6.5rem 1fr 1.5rem; align-items: center; gap: var(--space-3); }
.bar-row__label { font-family: var(--font-sans); font-size: var(--fs-sm); }
.bar-row__cn { color: var(--color-text-faint); }
.bar-row__count { font-family: var(--font-mono); font-size: var(--fs-sm); color: var(--color-text-muted); text-align: right; }
.bar-track { height: 0.55rem; background: var(--color-bg); border-radius: 999px; overflow: hidden; }
.bar-fill { display: block; height: 100%; border-radius: 999px; transition: width var(--dur-base) var(--ease-out); }
.balance-note { margin-top: var(--space-4); font-size: var(--fs-sm); color: var(--color-text-faint); }

/* --- reading body -------------------------------------------------------- */
.reading-body { margin-block: var(--space-6); }
.reading-body p { max-width: none; }
.reading-body strong { color: var(--color-text-strong); }
.reading-disclaimer { color: var(--color-text-faint); font-size: var(--fs-sm); border-top: var(--border-hairline); padding-top: var(--space-4); }

/* --- share / cta / related ----------------------------------------------- */
.share-row { display: flex; gap: var(--space-3); flex-wrap: wrap; margin-block: var(--space-5); }
.cta-card { margin-block: var(--space-5); }
.cta-card h3 { font-size: var(--fs-lg); }
.cta-form { display: flex; gap: var(--space-3); flex-wrap: wrap; margin-top: var(--space-4); }
.cta-form input { flex: 1 1 14rem; }
.cta-msg { margin-top: var(--space-4); color: var(--c-element-wood); font-family: var(--font-sans); font-size: var(--fs-sm); }

.related { margin-top: var(--space-7); }
.related-grid { display: grid; gap: var(--space-4); grid-template-columns: repeat(auto-fill, minmax(15rem, 1fr)); margin-top: var(--space-4); }
.related-card { font-family: var(--font-display); color: var(--color-text-strong); }
.related-card:hover { text-decoration: none; border-color: var(--color-accent); }
.related-card span { display: block; font-family: var(--font-sans); font-size: var(--fs-sm); color: var(--color-text-muted); margin-top: var(--space-2); font-weight: 400; }

.form-error { color: var(--color-link); font-family: var(--font-sans); }
