/* Hallmark · macrostructure: Marquee Hero · theme: Halo · genre: atmospheric
 * nav: N9 · footer: Ft5 · see tokens.css for the full stamp */
@import url("/static/tokens.css?v=20260611b");

* { box-sizing: border-box; }
html, body { overflow-x: clip; }
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  margin: 0;
  background: var(--color-paper);
  color: var(--color-ink-2);
  font-family: var(--font-body);
  font-weight: 350;
  font-size: var(--text-base);
  line-height: 1.6;
  /* the one bloom — fixed, upper area, ~25% footprint */
  background-image: radial-gradient(56rem 36rem at 72% -8rem,
    var(--color-bloom), transparent 70%);
  background-attachment: fixed;
  background-repeat: no-repeat;
}

h1, h2, h3 { color: var(--color-ink); margin: 0; min-width: 0; overflow-wrap: anywhere; }
p { margin: 0 0 var(--space-md); max-width: var(--measure); }
a { color: var(--color-ink); }
:focus-visible { outline: 2px solid var(--color-focus); outline-offset: 3px; border-radius: 2px; }

.label {
  font-family: var(--font-label);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--color-muted);
}

/* ───── nav · N9 edge-aligned minimal ───── */
.nav-edge {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--space-md) var(--page-gutter);
}
.wordmark {
  font-family: var(--font-display); font-weight: 600;
  font-size: var(--text-md); letter-spacing: -0.01em;
  color: var(--color-ink); text-decoration: none;
}
.wordmark .hangul-mark { font-family: var(--font-hangul); font-weight: 600; color: var(--color-accent); margin-right: 0.4rem; }
.nav-cta {
  font-family: var(--font-body); font-size: var(--text-sm); font-weight: 500;
  color: var(--color-ink); text-decoration: none; white-space: nowrap;
  border: var(--rule-hair) solid var(--color-rule-2);
  border-radius: 999px; padding: var(--space-xs) var(--space-md); min-height: 44px;
  display: inline-flex; align-items: center;
  transition: border-color var(--dur-short) var(--ease-out), background-color var(--dur-short) var(--ease-out);
}
.nav-cta:hover { border-color: var(--color-accent); background: var(--color-paper-2); }
.nav-cta:active { transform: translateY(1px); }

/* ───── hero · H1 marquee, left-bias, rule below ───── */
.hero-marquee {
  min-height: min(78dvh, 44rem);
  display: grid; align-content: end;
  padding: var(--space-xl) var(--page-gutter) var(--space-2xl);
}
@media (orientation: portrait) {
  .hero-marquee { min-height: 0; padding-top: var(--space-md); }
}
.display-xxl {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: var(--text-display);
  line-height: 1.02;
  letter-spacing: var(--tracking-display);
  max-width: 14ch;
}
.display-xxl .hanja {
  font-family: var(--font-hanja); font-weight: 400;
  color: var(--color-accent);
}
.hero-sub {
  margin-top: var(--space-lg);
  color: var(--color-muted);
  max-width: 46ch;
}
.rule-thick { border: 0; border-top: 2px solid var(--color-rule-2); margin: 0 var(--page-gutter); }

/* ───── sections ───── */
section { padding: var(--space-2xl) var(--page-gutter); }
.head-hang { padding-block: 0 var(--space-lg); }
.head-hang h2 {
  font-family: var(--font-display); font-weight: 600;
  font-size: var(--text-display-s); letter-spacing: -0.02em; line-height: 1.1;
}
.head-hang .lede { color: var(--color-muted); margin-top: var(--space-sm); }

/* ───── birth form ───── */
.cast { padding-top: var(--space-xl); }
.cast-form { max-width: 36rem; }
.field-row { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-sm); }
.field { display: grid; gap: var(--space-2xs); margin-bottom: var(--space-md); }
.field label { font-size: var(--text-sm); color: var(--color-neutral); }
.field input, .field select {
  background: var(--color-paper-2);
  border: var(--rule-hair) solid var(--color-rule);
  border-radius: var(--radius-input);
  color: var(--color-ink);
  font: inherit; font-size: var(--text-base);
  padding: var(--space-sm) var(--space-sm); min-height: 48px; width: 100%;
  transition: border-color var(--dur-short) var(--ease-out);
}
.field input:hover, .field select:hover { border-color: var(--color-rule-2); }
.field input:focus-visible, .field select:focus-visible { outline: 2px solid var(--color-focus); outline-offset: 1px; border-color: var(--color-focus); }
.field input:disabled, .field select:disabled { opacity: 0.55; cursor: not-allowed; }
.field input[aria-invalid="true"] { border-color: var(--color-error); }
.time-row { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-sm); }
.check {
  display: flex; align-items: center; gap: var(--space-xs);
  color: var(--color-neutral); font-size: var(--text-sm);
  margin-bottom: var(--space-lg); min-height: 44px;
}
.check input { width: 1.1rem; height: 1.1rem; accent-color: var(--color-accent); }

.btn-cast {
  font: inherit; font-weight: 600; font-size: var(--text-md);
  background: var(--color-accent); color: var(--color-accent-ink);
  border: 0; border-radius: 999px;
  padding: var(--space-sm) var(--space-lg); min-height: 48px; cursor: pointer; white-space: nowrap;
  transition: filter var(--dur-short) var(--ease-out);
}
.btn-cast:hover { filter: brightness(1.08); }
.btn-cast:active { transform: translateY(1px); }
.btn-cast:disabled { filter: saturate(0.3) brightness(0.8); cursor: not-allowed; opacity: 0.85; }
.form-error { color: var(--color-error); font-size: var(--text-sm); min-height: 1.4em; margin-top: var(--space-sm); }

/* ───── reading result ───── */
#reading { display: none; }
#reading.is-open { display: block; }
@media (prefers-reduced-motion: no-preference) {
  #reading.is-open { animation: fadein var(--dur-long) var(--ease-out); }
  @keyframes fadein { from { opacity: 0; } to { opacity: 1; } }
}

.pillars {
  display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-sm); max-width: 56rem;
}
.pillar {
  background: var(--color-paper-2);
  border-radius: var(--radius-card);
  padding: var(--space-md) var(--space-sm);
  text-align: center;
}
.pillar .label { display: block; margin-bottom: var(--space-sm); }
.pillar .hangul {
  font-family: var(--font-hangul); font-weight: 600;
  font-size: clamp(1.9rem, 4.5vw, 3rem);
  line-height: 1.2; color: var(--color-ink); display: block;
}
.pillar .hanja {
  font-family: var(--font-hanja);
  font-size: var(--text-md);
  line-height: 1.3; color: var(--color-muted); display: block;
  margin-top: var(--space-2xs);
}
.pillar .romanized { color: var(--color-muted); font-size: var(--text-sm); display: block; margin-top: var(--space-xs); }
.pillar .animal { color: var(--color-neutral); font-size: var(--text-sm); }
.pillar--day { background: var(--color-paper-3); border: var(--rule-hair) solid var(--color-rule-2); }

.daymaster { display: grid; grid-template-columns: auto minmax(0, 1fr); gap: var(--space-lg); align-items: start; max-width: 56rem; }
.daymaster .glyph {
  font-family: var(--font-hanja);
  font-size: clamp(5rem, 12vw, 9rem); line-height: 1;
  color: var(--color-accent); text-align: center;
}
.daymaster .glyph .glyph-han {
  display: block; font-family: var(--font-hangul); font-weight: 600;
  font-size: var(--text-lg); color: var(--color-ink-2); margin-top: var(--space-xs);
}
.daymaster h3 { font-size: var(--text-lg); font-weight: 600; margin-bottom: var(--space-xs); }
.daymaster .sub { color: var(--color-muted); font-size: var(--text-sm); margin-bottom: var(--space-md); }

.elements { max-width: 56rem; }
.el-row { display: grid; grid-template-columns: 5.5rem minmax(0, 1fr) 2ch; gap: var(--space-sm); align-items: center; margin-bottom: var(--space-xs); }
.el-name { font-size: var(--text-sm); color: var(--color-neutral); }
.el-track { background: var(--color-paper-2); border-radius: 999px; height: 0.85rem; }
.el-bar { height: 100%; border-radius: 999px; transform: scaleX(0); transform-origin: left; }
.el-bar.is-grown { transform: scaleX(1); }
@media (prefers-reduced-motion: no-preference) {
  .el-bar { transition: transform var(--dur-long) var(--ease-out); }
}
.el-bar[data-el="Wood"]  { background: var(--color-el-wood); }
.el-bar[data-el="Fire"]  { background: var(--color-el-fire); }
.el-bar[data-el="Earth"] { background: var(--color-el-earth); }
.el-bar[data-el="Metal"] { background: var(--color-el-metal); }
.el-bar[data-el="Water"] { background: var(--color-el-water); }
.el-count { font-family: var(--font-label); font-variant-numeric: tabular-nums; color: var(--color-muted); font-size: var(--text-sm); }
.el-notes { margin-top: var(--space-lg); }

.animals-line { color: var(--color-neutral); max-width: var(--measure); }
.animals-line strong { color: var(--color-ink); font-weight: 600; }

.beneficial { margin-top: var(--space-xl); border-top: var(--rule-hair) solid var(--color-rule); padding-top: var(--space-lg); }
.beneficial-el strong { font-family: var(--font-display); font-weight: 600; font-size: var(--text-lg); color: var(--color-accent); }
.beneficial p { color: var(--color-neutral); }

.today { max-width: var(--measure); }
.today-pillar { font-size: var(--text-md); color: var(--color-ink); }
.today-pillar .hanja { font-family: var(--font-hanja); color: var(--color-muted); }
.today-pillar strong { color: var(--color-accent); font-weight: 600; }
#today-hangul { font-family: var(--font-hangul); font-weight: 600; }
.today .fine, .match-result .fine, .exact .fine { color: var(--color-muted); font-size: var(--text-sm); }

.match-result { margin-top: var(--space-lg); background: var(--color-paper-2); border-radius: var(--radius-card); padding: var(--space-lg); max-width: 36rem; }
.match-score { font-family: var(--font-display); font-weight: 600; font-size: var(--text-display-s); color: var(--color-accent); margin: 0 0 var(--space-xs); font-variant-numeric: tabular-nums; }
.match-score-of { font-size: var(--text-md); color: var(--color-muted); }
.match-pair { color: var(--color-ink); font-weight: 500; }
.match-result p { max-width: none; }

/* pillar ten-god labels */
.pillar .god { display: block; color: var(--color-accent); font-size: var(--text-xs); font-family: var(--font-label); letter-spacing: 0.04em; margin-bottom: var(--space-2xs); min-height: 1.2em; }
.pillar .god-b { display: block; color: var(--color-muted); font-size: var(--text-xs); margin-top: var(--space-2xs); }

/* share card */
.share { background: var(--color-paper-2); border-radius: var(--radius-card); padding: var(--space-lg); max-width: 56rem; }
.share-grid { display: grid; grid-template-columns: minmax(0, 260px) minmax(0, 1fr); gap: var(--space-lg); align-items: center; }
.share img, .match-result img { width: 100%; height: auto; border-radius: 6px; display: block; }
.share-actions { display: flex; flex-wrap: wrap; gap: var(--space-sm); }
.btn-ghost {
  font: inherit; font-size: var(--text-sm); font-weight: 500;
  background: none; color: var(--color-ink); cursor: pointer; white-space: nowrap;
  border: var(--rule-hair) solid var(--color-rule-2); border-radius: 999px;
  padding: var(--space-xs) var(--space-md); min-height: 44px; text-decoration: none; display: inline-flex; align-items: center;
  transition: border-color var(--dur-short) var(--ease-out);
}
.btn-ghost:hover { border-color: var(--color-accent); }
.btn-share { border-color: var(--color-accent); }
.btn-ghost:active { transform: translateY(1px); }
.share .hint { color: var(--color-muted); font-size: var(--text-sm); }

/* ───── how it works · F4 steps ───── */
.steps { list-style: none; margin: 0; padding: 0; max-width: var(--measure); }
.steps li { padding: var(--space-lg) 0; border-top: var(--rule-hair) solid var(--color-rule); }
.steps .stage { font-family: var(--font-label); color: var(--color-accent); font-size: var(--text-sm); }
.steps h3 { font-size: var(--text-md); font-weight: 600; margin: var(--space-2xs) 0 var(--space-xs); }
.steps p { color: var(--color-muted); margin: 0; }

.exact { background: var(--color-paper-2); }
.exact p { color: var(--color-neutral); }
.exact .fine { color: var(--color-muted); font-size: var(--text-sm); }

/* ───── footer · Ft5 statement ───── */
.foot-stmt { padding: var(--space-xl) var(--page-gutter) var(--space-2xl); display: grid; gap: var(--space-lg); }
.foot-stmt__line {
  font-family: var(--font-display); font-weight: 600;
  font-size: clamp(1.6rem, 4.5vw, 3rem);
  line-height: 1.05; letter-spacing: -0.02em;
  max-width: 24ch; margin: 0; color: var(--color-ink);
}
.foot-stmt__meta {
  display: flex; justify-content: space-between; align-items: baseline; gap: var(--space-md);
  padding-block-start: var(--space-sm); border-top: var(--rule-hair) solid var(--color-rule);
  color: var(--color-muted); font-size: var(--text-sm); flex-wrap: wrap;
}

/* ad slot — activated when AdSense is approved; invisible until then */
.ad-slot:empty { display: none; }

/* ───── mobile ───── */
@media (max-width: 60rem) {
  .daymaster { grid-template-columns: 1fr; }
  .share-grid { grid-template-columns: 1fr; }
}
@media (max-width: 40rem) {
  .hero-marquee { min-height: 0; padding-top: var(--space-md); }
  .pillars { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .field-row { grid-template-columns: 1fr 1fr; }
  .field-row .field:first-child { grid-column: 1 / -1; }
  .btn-cast { width: 100%; }
}

/* ───── blog / guide ───── */
.article { padding: var(--space-xl) var(--page-gutter) var(--space-2xl); max-width: calc(var(--measure) + 2 * var(--page-gutter)); }
.article h1 { font-family: var(--font-display); font-weight: 600; font-size: var(--text-display-s); letter-spacing: -0.02em; line-height: 1.1; margin: 0 0 var(--space-xs); }
.article-date { color: var(--color-muted); font-size: var(--text-sm); margin-bottom: var(--space-xl); }
.article h2 { font-size: var(--text-lg); font-weight: 600; margin: var(--space-xl) 0 var(--space-sm); }
.article h3 { font-size: var(--text-md); font-weight: 600; margin: var(--space-lg) 0 var(--space-xs); }
.article p, .article li { color: var(--color-ink-2); }
.article a { color: var(--color-accent); text-decoration: underline; text-underline-offset: 2px; text-decoration-thickness: 1px; }
.article-list { list-style: none; padding: 0; margin: 0; }
.article-list li { border-top: var(--rule-hair) solid var(--color-rule); padding: var(--space-lg) 0; }
.article-list a { font-family: var(--font-display); font-weight: 600; font-size: var(--text-md); color: var(--color-ink); text-decoration: none; }
.article-list a:hover { color: var(--color-accent); }
.article-list p { color: var(--color-muted); margin: var(--space-xs) 0 0; }

/* ───── weekly + yearly fortune pages ───── */
.nav-links { display: flex; gap: var(--space-md); align-items: center; }
.nav-links a { color: var(--color-muted); text-decoration: none; font-size: var(--text-sm); white-space: nowrap; }
.nav-links a:hover { color: var(--color-ink); }
.nav-links a[aria-current="page"] { color: var(--color-ink); }
.hero-sub-page { min-height: min(46dvh, 26rem); }
@media (orientation: portrait) { .hero-sub-page { min-height: 0; } }

.week-head { max-width: var(--measure); margin-bottom: var(--space-lg); }
.week-grade { font-family: var(--font-display); font-weight: 600; font-size: var(--text-lg); color: var(--color-ink); margin: 0 0 var(--space-xs); }

.day-list { max-width: 56rem; border-top: var(--rule-hair) solid var(--color-rule); margin-bottom: var(--space-md); }
.day-row {
  display: grid; grid-template-columns: 7rem 8.5rem minmax(0, 1fr) 3ch;
  gap: var(--space-sm); align-items: baseline;
  padding: var(--space-sm) var(--space-xs);
  border-bottom: var(--rule-hair) solid var(--color-rule);
}
.day-row--best { background: var(--color-paper-2); border-left: 2px solid var(--color-accent); }
.day-row--worst .day-line { color: var(--color-muted); }
.day-when { color: var(--color-neutral); font-size: var(--text-sm); white-space: nowrap; }
.day-when strong { color: var(--color-ink); font-weight: 600; }
.day-tag {
  font-family: var(--font-label); font-size: var(--text-xs); letter-spacing: var(--tracking-label);
  color: var(--color-accent); margin-left: var(--space-xs);
}
.day-tag--watch { color: var(--color-muted); }
.day-hangul { font-family: var(--font-hangul); font-weight: 600; color: var(--color-ink); }
.day-god { display: block; color: var(--color-muted); font-size: var(--text-xs); }
.day-line { color: var(--color-ink-2); margin: 0; font-size: var(--text-sm); max-width: none; }
.day-score { font-family: var(--font-label); font-variant-numeric: tabular-nums; color: var(--color-muted); font-size: var(--text-sm); text-align: right; }
@media (orientation: portrait) {
  .day-row { grid-template-columns: 6.5rem minmax(0, 1fr) 3ch; }
  .day-line { grid-column: 1 / -1; }
  .day-score { grid-column: 3; grid-row: 1; }
}

.area-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-lg); max-width: 56rem; }
@media (orientation: portrait) { .area-grid { grid-template-columns: 1fr; } }
.area { background: var(--color-paper-2); border-radius: var(--radius-card); padding: var(--space-lg); }
.area h3 { font-size: var(--text-md); font-weight: 600; margin-bottom: var(--space-sm); }
.area p { color: var(--color-ink-2); margin: 0; max-width: none; }
.area-tier {
  font-family: var(--font-label); font-size: var(--text-xs); letter-spacing: var(--tracking-label);
  text-transform: uppercase; margin-left: var(--space-xs);
}
.area-tier--good { color: var(--color-accent); }
.area-tier--mixed { color: var(--color-neutral); }
.area-tier--tough { color: var(--color-error); }

.lucky { margin-top: var(--space-xl); border-top: var(--rule-hair) solid var(--color-rule); padding-top: var(--space-lg); max-width: var(--measure); }
.lucky strong { font-family: var(--font-display); font-weight: 600; color: var(--color-accent); }
.lucky p { color: var(--color-neutral); }

.cross-links { display: flex; flex-wrap: wrap; gap: var(--space-md) var(--space-lg); margin-top: var(--space-xl); }
.cross-links a { color: var(--color-ink); font-weight: 500; text-decoration: none; border-bottom: var(--rule-hair) solid var(--color-rule-2); padding-bottom: 2px; }
.cross-links a:hover { color: var(--color-accent); border-color: var(--color-accent); }

.year-text { max-width: var(--measure); }
.year-text p { color: var(--color-ink-2); }
.month-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-sm); max-width: 64rem; margin-bottom: var(--space-md); }
@media (max-width: 60rem) { .month-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (orientation: portrait) { .month-grid { grid-template-columns: 1fr 1fr; } }
@media (orientation: portrait) and (max-width: 26rem) { .month-grid { grid-template-columns: 1fr; } }
.month-card { background: var(--color-paper-2); border: var(--rule-hair) solid transparent; border-radius: var(--radius-card); padding: var(--space-md); }
.month-card--now { background: var(--color-paper-3); border-color: var(--color-accent); }
.month-tag-now {
  font-family: var(--font-label); font-size: var(--text-xs); letter-spacing: var(--tracking-label);
  background: var(--color-accent); color: var(--color-accent-ink);
  border-radius: 4px; padding: 1px 7px; margin-left: var(--space-xs);
  display: inline-block; line-height: 1.5; vertical-align: 1px;
}
.month-term { color: var(--color-muted); font-size: var(--text-xs); margin: 0 0 var(--space-2xs); max-width: none; }
.month-card .label { display: block; margin-bottom: var(--space-xs); }
.month-pillar { color: var(--color-neutral); font-size: var(--text-sm); margin: 0 0 var(--space-2xs); }
.month-card .stars { color: var(--color-accent); letter-spacing: 0.12em; margin: 0 0 var(--space-xs); }
.month-card h3 { font-size: var(--text-base); font-weight: 600; margin-bottom: var(--space-2xs); }
.month-advice { color: var(--color-muted); font-size: var(--text-sm); margin: 0; max-width: none; }

/* homepage guide teaser */
.guide-list { list-style: none; padding: 0; margin: 0; max-width: var(--measure); }
.guide-list li { border-top: var(--rule-hair) solid var(--color-rule); padding: var(--space-md) 0; }
.guide-list a { color: var(--color-ink); text-decoration: none; font-weight: 500; }
.guide-list a:hover { color: var(--color-accent); }
